:root{--tpg-color-bg:#0b1220;--tpg-color-surface:#111a2e;--tpg-color-border:#1f2a44;--tpg-color-text:#e6ebff;--tpg-color-muted:#8090b8;--tpg-color-accent:#4f8cff;--tpg-color-error:#ff6b6b;--tpg-radius:6px}.tpg-btn{border:1px solid var(--tpg-color-border);background:var(--tpg-color-accent);color:white;border-radius:var(--tpg-radius);padding:.5rem .875rem;cursor:pointer}.tpg-btn[disabled]{opacity:.6;cursor:not-allowed}.tpg-btn-ghost,.tpg-btn-outline{background:transparent;color:var(--tpg-color-text)}.tpg-btn-destructive{background:var(--tpg-color-error)}.tpg-input{background:var(--tpg-color-surface);color:var(--tpg-color-text);border:1px solid var(--tpg-color-border);border-radius:var(--tpg-radius);padding:.5rem .625rem;width:100%}.tpg-label{display:block;font-size:.85rem;color:var(--tpg-color-muted);margin-bottom:.25rem}.tpg-card{background:var(--tpg-color-surface);border:1px solid var(--tpg-color-border);border-radius:var(--tpg-radius);padding:1rem}.tpg-card-header{margin-bottom:.5rem}.tpg-card-title{margin:0;font-size:1rem}.tpg-card-content{font-size:.95rem}.tpg-form-field{margin-bottom:.75rem}.tpg-form-error{color:var(--tpg-color-error);margin-top:.5rem}.tpg-avatar{display:inline-flex;width:2rem;height:2rem;border-radius:9999px;background:var(--tpg-color-border);color:var(--tpg-color-text);align-items:center;justify-content:center;font-size:.85rem}.tpg-table{width:100%;border-collapse:collapse}.tpg-table td,.tpg-table th{padding:.5rem;border-bottom:1px solid var(--tpg-color-border);text-align:left}.tpg-toast-region{position:fixed;right:1rem;bottom:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:1000}.tpg-toast{background:var(--tpg-color-surface);border:1px solid var(--tpg-color-border);color:var(--tpg-color-text);padding:.5rem .75rem;border-radius:var(--tpg-radius)}.tpg-toast-error{border-color:var(--tpg-color-error)}:root{--admin-bg:#f3f4f8;--admin-surface:#ffffff;--admin-border:#e5e8ef;--admin-text:#1d2433;--admin-text-muted:#6b7388;--admin-text-faint:#9ba2b4;--admin-accent:#2f7bf6;--admin-accent-soft:rgba(47,123,246,0.10);--admin-accent-text:#ffffff;--admin-success:#16a34a;--admin-warning:#d97706;--admin-danger:#dc2626;--admin-danger-soft:rgba(220,38,38,0.12);--admin-sidebar-bg:#1b2542;--admin-sidebar-bg-hover:#243059;--admin-sidebar-bg-active:#2f7bf6;--admin-sidebar-text:#c7cee2;--admin-sidebar-text-active:#ffffff;--admin-sidebar-divider:rgba(255,255,255,0.06);--admin-sidebar-w:240px;--admin-topbar-h:64px;--admin-radius:10px;--admin-radius-sm:6px;--admin-shadow-card:0 1px 2px rgba(15,22,49,0.04),0 1px 3px rgba(15,22,49,0.06)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;-webkit-font-smoothing:antialiased}.tpg-dashboard-shell{display:grid;grid-template-columns:var(--admin-sidebar-w) 1fr;min-height:100vh;background:var(--admin-bg);color:var(--admin-text)}.tpg-dashboard-main{display:flex;flex-direction:column;min-width:0}.tpg-dashboard-outlet{padding:1.5rem 2rem;flex:1 1;min-width:0}@media (max-width:900px){.tpg-dashboard-shell{grid-template-columns:64px 1fr}.tpg-sidebar-label,.tpg-sidebar-logo-text{display:none}}.tpg-sidebar{background:var(--admin-sidebar-bg);color:var(--admin-sidebar-text);padding:0;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto}.tpg-sidebar-header{display:flex;align-items:center;gap:.6rem;padding:1.1rem 1.25rem;border-bottom:1px solid var(--admin-sidebar-divider);color:#ffffff;font-weight:700;font-size:1.05rem}.tpg-sidebar-logo-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#4f8cff,#2f7bf6);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.95rem;flex-shrink:0}.tpg-sidebar ul{list-style:none;margin:.5rem 0;padding:0}.tpg-sidebar li{padding:0 .6rem}.tpg-sidebar a{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--admin-radius-sm);color:var(--admin-sidebar-text);text-decoration:none;font-size:.92rem;margin:.15rem 0;transition:background .12s ease,color .12s ease}.tpg-sidebar a:hover{background:var(--admin-sidebar-bg-hover);color:var(--admin-sidebar-text-active)}.tpg-sidebar a.is-active{background:var(--admin-sidebar-bg-active);color:var(--admin-sidebar-text-active);font-weight:600}.tpg-sidebar-icon{width:18px;height:18px;flex-shrink:0;opacity:.85}.tpg-sidebar a.is-active .tpg-sidebar-icon{opacity:1}.tpg-sidebar-label{flex:1 1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tpg-sidebar-badge{background:var(--admin-danger);color:white;border-radius:999px;font-size:.7rem;font-weight:600;padding:1px 7px;min-width:18px;text-align:center}.tpg-topbar{background:var(--admin-surface);border-bottom:1px solid var(--admin-border);height:var(--admin-topbar-h);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.tpg-topbar-spacer{flex:1 1}.tpg-topbar-search{display:flex;align-items:center;gap:.5rem;background:var(--admin-bg);border:1px solid var(--admin-border);border-radius:var(--admin-radius-sm);padding:.4rem .75rem;flex:0 1 320px;color:var(--admin-text-muted);font-size:.85rem}.tpg-topbar-search input{border:none;outline:none;background:transparent;flex:1 1;font-size:.88rem;color:var(--admin-text);min-width:0}.tpg-topbar-iconbtn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--admin-text-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:background .12s ease,color .12s ease}.tpg-topbar-iconbtn:hover{background:var(--admin-bg);color:var(--admin-text)}.tpg-topbar-iconbtn svg{width:18px;height:18px}.tpg-topbar-notify-dot{position:absolute;top:6px;right:6px;background:var(--admin-danger);color:white;border-radius:999px;font-size:.62rem;font-weight:700;padding:0 4px;min-width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;border:2px solid var(--admin-surface)}.tpg-topbar-user{display:flex;align-items:center;gap:.6rem;padding-left:.5rem;border-left:1px solid var(--admin-border);margin-left:.25rem}.tpg-topbar-user .tpg-avatar{width:36px;height:36px;font-size:.85rem;background:var(--admin-accent-soft);color:var(--admin-accent);font-weight:600}.tpg-topbar-username{font-size:.9rem;font-weight:600;color:var(--admin-text)}.tpg-topbar-logout{background:transparent;border:1px solid var(--admin-border);color:var(--admin-text-muted);border-radius:var(--admin-radius-sm);padding:.35rem .75rem;font-size:.82rem;cursor:pointer;font-weight:500}.tpg-topbar-logout:hover{background:var(--admin-bg);color:var(--admin-text)}.tpg-topbar-logout[disabled]{opacity:.6;cursor:wait}.tpg-dashboard-shell .tpg-card{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:var(--admin-radius);padding:1.1rem 1.25rem;box-shadow:var(--admin-shadow-card);color:var(--admin-text)}.tpg-dashboard-shell .tpg-card-header{margin-bottom:.4rem}.tpg-dashboard-shell .tpg-card-title{margin:0;font-size:.82rem;font-weight:500;color:var(--admin-text-muted);text-transform:none;letter-spacing:0}.tpg-dashboard-shell .tpg-card-content{font-size:1.6rem;font-weight:700;color:var(--admin-text)}.tpg-dashboard-shell .tpg-input{background:var(--admin-surface);color:var(--admin-text);border:1px solid var(--admin-border);border-radius:var(--admin-radius-sm)}.tpg-dashboard-shell .tpg-input:focus{outline:2px solid var(--admin-accent-soft);border-color:var(--admin-accent)}.tpg-dashboard-shell .tpg-label{color:var(--admin-text-muted);font-weight:500}.tpg-dashboard-shell .tpg-btn{background:var(--admin-accent);border:1px solid var(--admin-accent);color:#fff;border-radius:var(--admin-radius-sm);font-weight:600;font-size:.88rem;padding:.5rem 1rem}.tpg-dashboard-shell .tpg-btn:hover{filter:brightness(1.05)}.tpg-dashboard-shell .tpg-btn-ghost,.tpg-dashboard-shell .tpg-btn-outline{background:transparent;color:var(--admin-text);border-color:var(--admin-border)}.tpg-dashboard-shell .tpg-btn-destructive{background:var(--admin-danger);border-color:var(--admin-danger)}.tpg-dashboard-shell .tpg-table{background:var(--admin-surface);border-radius:var(--admin-radius);overflow:hidden;font-size:.9rem}.tpg-dashboard-shell .tpg-table td,.tpg-dashboard-shell .tpg-table th{border-bottom:1px solid var(--admin-border);padding:.7rem .85rem;text-align:left}.tpg-dashboard-shell .tpg-table th{background:#fafbfd;color:var(--admin-text-muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.tpg-dashboard-shell .tpg-table tbody tr:hover{background:#fafbfd}.tpg-dashboard-shell .tpg-table tbody tr:last-child td{border-bottom:none}.tpg-page-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin:0 0 1.25rem}.tpg-page-header h1{margin:0;font-size:1.35rem;font-weight:700;color:var(--admin-text)}.tpg-page-header .tpg-page-subtitle{margin:.25rem 0 0;color:var(--admin-text-muted);font-size:.88rem}.tpg-overview{display:flex;flex-direction:column;gap:1.25rem}.tpg-overview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:1rem;gap:1rem}@media (max-width:1100px){.tpg-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:600px){.tpg-overview-grid{grid-template-columns:1fr}}.tpg-stat-card{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:var(--admin-radius);padding:1.1rem 1.25rem;box-shadow:var(--admin-shadow-card)}.tpg-stat-label{margin:0 0 .4rem;font-size:.82rem;color:var(--admin-text-muted);font-weight:500}.tpg-stat-value{font-size:1.7rem;font-weight:700;color:var(--admin-text);line-height:1.1}.tpg-stat-foot{margin-top:.6rem;font-size:.78rem;color:var(--admin-text-faint)}.tpg-stat-foot .tpg-stat-trend-up{color:var(--admin-success);font-weight:600}.tpg-stat-foot .tpg-stat-trend-down{color:var(--admin-danger);font-weight:600}.tpg-section-card{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:var(--admin-radius);box-shadow:var(--admin-shadow-card);padding:1.25rem 1.5rem}.tpg-section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;border-bottom:1px solid var(--admin-border);padding-bottom:.75rem}.tpg-section-tabs{display:flex;gap:.25rem}.tpg-section-tab{background:transparent;padding:.45rem .85rem;font-size:.9rem;color:var(--admin-text-muted);cursor:pointer;border:none;border-bottom:2px solid transparent;font-weight:500}.tpg-section-tab.is-active{color:var(--admin-accent);border-bottom-color:var(--admin-accent);font-weight:600}.tpg-section-filters{display:flex;gap:.5rem;align-items:center}.tpg-section-filter-chip,.tpg-section-filters{font-size:.85rem;color:var(--admin-text-muted)}.tpg-section-filter-chip{padding:.25rem .55rem;border-radius:999px;background:transparent;border:none;cursor:pointer}.tpg-section-filter-chip.is-active{background:var(--admin-accent-soft);color:var(--admin-accent);font-weight:600}.tpg-table-card{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:var(--admin-radius);box-shadow:var(--admin-shadow-card);overflow-x:auto;overflow-y:hidden}.tpg-dashboard-shell .tpg-table-card .tpg-table,.tpg-dashboard-shell .tpg-table-card table{min-width:100%;width:max-content}.tpg-table-card>.tpg-pagination,.tpg-table-card>.tpg-toolbar{position:-webkit-sticky;position:sticky;left:0;z-index:1}.tpg-toolbar{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--admin-border);background:#fafbfd;flex-wrap:wrap}.tpg-toolbar>.tpg-toolbar-spacer{flex:1 1}.tpg-toolbar input[type=date],.tpg-toolbar input[type=datetime-local],.tpg-toolbar input[type=search],.tpg-toolbar input[type=text],.tpg-toolbar select{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:var(--admin-radius-sm);padding:.4rem .65rem;font-size:.85rem;color:var(--admin-text);min-width:0}.tpg-toolbar input:focus,.tpg-toolbar select:focus{outline:2px solid var(--admin-accent-soft);border-color:var(--admin-accent)}.tpg-toolbar label{font-size:.82rem;color:var(--admin-text-muted);font-weight:500}.tpg-toolbar label,.tpg-toolbar-primary{display:inline-flex;align-items:center;gap:.4rem}.tpg-toolbar-primary{background:var(--admin-accent);color:#fff;border:1px solid var(--admin-accent);border-radius:var(--admin-radius-sm);padding:.45rem .85rem;font-size:.85rem;font-weight:600;cursor:pointer;text-decoration:none}.tpg-toolbar-primary:hover{filter:brightness(1.05)}.tpg-toolbar-secondary{background:transparent;color:var(--admin-text);border:1px solid var(--admin-border);border-radius:var(--admin-radius-sm);padding:.4rem .75rem;font-size:.85rem;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem}.tpg-toolbar-secondary:hover{background:var(--admin-bg)}.tpg-toolbar-secondary[disabled]{opacity:.5;cursor:not-allowed}.tpg-dashboard-shell .tpg-table-card .tpg-table{border:none;border-radius:0;box-shadow:none}.tpg-pagination{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.1rem;border-top:1px solid var(--admin-border);background:#fafbfd;font-size:.85rem;color:var(--admin-text-muted)}.tpg-pagination>.tpg-pagination-spacer{flex:1 1}.tpg-empty-row td{padding:2.5rem 1rem!important;text-align:center!important;color:var(--admin-text-muted);font-size:.9rem;background:var(--admin-surface)}.tpg-code-chip,.tpg-dashboard-shell .tpg-table code{font-family:JetBrains Mono,Menlo,Consolas,monospace;font-size:.78rem;background:var(--admin-bg);border:1px solid var(--admin-border);border-radius:4px;padding:.05rem .4rem;color:var(--admin-text);white-space:nowrap}.tpg-pill{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;border:1px solid transparent;white-space:nowrap;line-height:1.4}.tpg-pill-neutral{background:#eef0f5;color:#4a5468;border-color:#e1e4ec}.tpg-pill-info{background:rgba(47,123,246,.1);color:#1d57c2;border-color:rgba(47,123,246,.2)}.tpg-pill-warning{background:rgba(217,119,6,.12);color:#92520a;border-color:rgba(217,119,6,.2)}.tpg-pill-success{background:rgba(22,163,74,.12);color:#117a3a;border-color:rgba(22,163,74,.22)}.tpg-pill-danger{background:rgba(220,38,38,.12);color:#a01b1b;border-color:rgba(220,38,38,.22)}.tpg-row-action{color:var(--admin-accent);font-size:.85rem;font-weight:500;text-decoration:none}.tpg-row-action:hover{text-decoration:underline}.tpg-audit-filter-label{display:block;margin-bottom:.6rem;font-size:.78rem;color:var(--admin-text-muted);font-weight:500}.tpg-audit-filter-label>span{display:block;margin-bottom:.2rem}.tpg-audit-filter-label input,.tpg-audit-filter-label select{width:100%;padding:.35rem .55rem;font-size:.8rem;background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:var(--admin-radius-sm);color:var(--admin-text);font-family:JetBrains Mono,Menlo,Consolas,monospace}.tpg-audit-filter-label input:focus,.tpg-audit-filter-label select:focus{outline:2px solid var(--admin-accent-soft);border-color:var(--admin-accent)}.tpg-form-section{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:var(--admin-radius);box-shadow:var(--admin-shadow-card);padding:1.25rem 1.5rem;margin-bottom:1rem}.tpg-form-section-header{margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--admin-border)}.tpg-form-section-title{margin:0;font-size:1rem;font-weight:600;color:var(--admin-text)}.tpg-form-section-subtitle{margin:.2rem 0 0;font-size:.82rem;color:var(--admin-text-muted)}.tpg-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1rem;gap:1rem}.tpg-form-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:1rem;gap:1rem}@media (max-width:760px){.tpg-form-grid,.tpg-form-grid-3{grid-template-columns:1fr}}.tpg-form-grid-wide{grid-column:1/-1}.tpg-dashboard-shell .tpg-form-field{margin-bottom:0}.tpg-dashboard-shell select{background:var(--admin-surface);color:var(--admin-text);border:1px solid var(--admin-border);border-radius:var(--admin-radius-sm);padding:.5rem 2rem .5rem .625rem;font-size:.9rem;width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%236b7388' d='M0 0l5 6 5-6z'/></svg>");background-repeat:no-repeat;background-position:right .65rem center;background-size:10px 6px;cursor:pointer}.tpg-dashboard-shell select:focus{outline:2px solid var(--admin-accent-soft);border-color:var(--admin-accent)}.tpg-dashboard-shell select[disabled]{background-color:var(--admin-bg);cursor:not-allowed;opacity:.7}.tpg-dashboard-shell input[type=date],.tpg-dashboard-shell input[type=datetime-local],.tpg-dashboard-shell input[type=number]{font-family:inherit}.tpg-form-fieldset{border:1px dashed var(--admin-border);border-radius:var(--admin-radius-sm);padding:.85rem 1rem;margin:0;background:#fafbfd}.tpg-form-fieldset>legend{font-size:.78rem;font-weight:600;color:var(--admin-text-muted);text-transform:uppercase;letter-spacing:.04em;padding:0 .4rem}.tpg-dashboard-shell [role=alert],.tpg-form-field-error{display:block;margin-top:.3rem;font-size:.78rem;color:var(--admin-danger)}.tpg-form-field-help{display:block;margin-top:.3rem;font-size:.78rem;color:var(--admin-text-muted)}.tpg-form-actions{display:flex;gap:.6rem;align-items:center;padding-top:1rem;margin-top:1rem;border-top:1px solid var(--admin-border)}.tpg-form-actions>.tpg-form-actions-spacer{flex:1 1}.tpg-login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1b2542,#2f7bf6);padding:1rem}.tpg-login-card{background:#ffffff;border-radius:12px;box-shadow:0 20px 60px rgba(15,22,49,.18),0 1px 3px rgba(15,22,49,.08);padding:2rem 2.25rem;width:100%;max-width:380px;color:var(--admin-text)}.tpg-login-brand{display:flex;align-items:center;gap:.6rem;margin-bottom:1.5rem}.tpg-login-brand .tpg-sidebar-logo-mark{width:40px;height:40px;border-radius:10px;font-size:1.1rem}.tpg-login-brand-text{font-weight:700;font-size:1.15rem;color:var(--admin-text)}.tpg-login-card h1{margin:0 0 .3rem;font-size:1.2rem;font-weight:700}.tpg-login-card .tpg-page-subtitle{margin:0 0 1.5rem}.tpg-login-card .tpg-input{background:#ffffff;color:var(--admin-text);border:1px solid var(--admin-border);border-radius:var(--admin-radius-sm);padding:.55rem .7rem;font-size:.92rem}.tpg-login-card .tpg-input:focus{outline:2px solid var(--admin-accent-soft);border-color:var(--admin-accent)}.tpg-login-card .tpg-label{color:var(--admin-text-muted);font-weight:500;font-size:.82rem;margin-bottom:.3rem}.tpg-login-card .tpg-btn{background:var(--admin-accent);border:1px solid var(--admin-accent);color:#fff;border-radius:var(--admin-radius-sm);font-weight:600;padding:.6rem 1rem;width:100%;margin-top:.5rem;cursor:pointer;font-size:.95rem}.tpg-login-card .tpg-btn:hover{filter:brightness(1.05)}.tpg-login-card .tpg-btn[disabled]{opacity:.7;cursor:wait}.tpg-login-card .tpg-form-error{color:var(--admin-danger);margin-top:.75rem;font-size:.85rem;text-align:center}.tpg-login-card .tpg-form-field{margin-bottom:.9rem}