:root{--bg:#f5f7fb;--panel:#ffffff;--text:#111827;--muted:#6b7280;--line:#e5e7eb;--primary:#2563eb;--sidebar:#111827;--button-radius:10px;--panel-radius:16px;--green:#dcfce7;--yellow:#fef9c3;--red:#fee2e2;--gray:#f3f4f6}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif}html[data-theme=dark]{--bg:#0f172a;--panel:#111827;--text:#f9fafb;--muted:#9ca3af;--line:#374151;--gray:#1f2937}html[data-compact=true] .main{padding:18px}html[data-compact=true] td,html[data-compact=true] th{padding:7px 9px}html[data-compact=true] input,html[data-compact=true] select,html[data-compact=true] textarea{padding:8px 10px}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--sidebar);color:white;padding:22px 18px}.logo{font-size:19px;font-weight:700;margin-bottom:24px;line-height:1.3;display:flex;gap:10px;align-items:center}.logo-img{max-width:42px;max-height:42px;border-radius:8px;object-fit:contain;background:white}.nav{display:grid;grid-gap:8px;gap:8px}.nav a,.nav button{display:block;width:100%;text-align:left;color:#d1d5db;background:transparent;border:0;padding:10px 12px;border-radius:10px;cursor:pointer}.nav a.active,.nav a:hover,.nav button:hover{background:#1f2937;color:#fff}.main{padding:28px;overflow-x:auto}.page-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.page-title h1{margin:0;font-size:28px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--panel-radius);padding:18px;box-shadow:0 8px 30px rgba(15,23,42,.04)}.grid{display:grid;grid-gap:16px;gap:16px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card-title{color:var(--muted);font-size:13px;margin-bottom:8px}.card-value{font-size:24px;font-weight:700}.muted{color:var(--muted)}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--panel-radius);background:var(--panel)}table{width:100%;border-collapse:collapse}td,th{border-bottom:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}th{background:#f9fafb;color:#374151;font-size:13px;font-weight:700}td.num,th,th.num{white-space:nowrap}td.num,th.num{text-align:right}.form{grid-gap:12px}.form,.form-row{display:grid;gap:12px}.form-row{grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px}label{display:grid;grid-gap:6px;gap:6px;color:#374151;font-size:13px}input,select,textarea{border:1px solid #d1d5db;border-radius:var(--button-radius);padding:10px 12px;background:var(--panel);color:var(--text)}textarea{min-height:82px;resize:vertical}.btn{border:0;border-radius:var(--button-radius);background:var(--primary);color:white;padding:10px 14px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn.secondary{background:#e5e7eb;color:#111827}.btn.danger{background:#dc2626}.error{background:#fee2e2;color:#991b1b}.error,.success{padding:10px 12px;border-radius:10px}.success{background:#dcfce7;color:#166534}.cell{cursor:pointer;border-radius:8px;padding:8px;min-width:118px}.cell.green{background:var(--green)}.cell.yellow{background:var(--yellow)}.cell.red{background:var(--red)}.cell.gray{background:var(--gray)}.badge{display:inline-flex;border-radius:999px;padding:4px 8px;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:700}.drawer{position:fixed;top:0;right:0;width:min(560px,96vw);height:100vh;background:white;box-shadow:-16px 0 40px rgba(15,23,42,.18);padding:22px;overflow:auto;z-index:20}.drawer-backdrop{position:fixed;inset:0;background:rgba(17,24,39,.25);z-index:10}.login-page{position:fixed;inset:0;z-index:100;min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.login-card{width:min(420px,100%)}.actions{display:flex;gap:8px;flex-wrap:wrap}@media (max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.form-row,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.main{padding:16px}}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tab{border:1px solid var(--line);background:var(--panel);color:var(--text);padding:10px 12px;border-radius:var(--button-radius);cursor:pointer;font-weight:700}.tab.active{background:var(--primary);color:white;border-color:var(--primary)}.code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;background:var(--gray);border-radius:8px;padding:2px 6px}.auth-loading{min-height:100vh;display:grid;place-items:center;color:var(--muted);background:var(--bg)}.security-reminder{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:var(--panel-radius);margin-bottom:16px}html[data-theme=dark] .security-reminder{background:#451a03;border-color:#92400e;color:#fde68a}.secret-box{word-break:break-all;border:1px dashed var(--line);border-radius:var(--button-radius);padding:10px 12px;background:var(--gray);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px}.btn,.clickable-row,.nav a,.nav button,.tab,button.panel{transition:background-color .16s ease,color .16s ease,border-color .16s ease,filter .16s ease,opacity .16s ease,transform .12s ease,box-shadow .16s ease}.btn:hover{filter:brightness(.92);transform:translateY(-1px);box-shadow:0 8px 18px rgba(15,23,42,.12)}.btn:active{transform:translateY(0);filter:brightness(.86);box-shadow:none}.btn.secondary:hover{background:#d1d5db}.btn.danger:hover{background:#b91c1c}.tab:hover{border-color:var(--primary);color:var(--primary)}.tab.active:hover{color:white;filter:brightness(.95)}.clickable-row{cursor:pointer}.clickable-row:hover td{background:rgba(37,99,235,.06)}.selected-row td{background:rgba(37,99,235,.12)}button.panel:hover{border-color:var(--primary);box-shadow:0 12px 28px rgba(15,23,42,.1)}.reference-tabs{position:-webkit-sticky;position:sticky;top:0;z-index:5;background:var(--bg);padding:4px 0 12px}.service-reference-layout{grid-template-columns:minmax(320px,.85fr) minmax(0,1.15fr);align-items:start}.table-wrap input,.table-wrap select,.table-wrap textarea{min-width:130px}.table-wrap textarea{min-height:64px}@media (max-width:1100px){.service-reference-layout{grid-template-columns:1fr}}@media (max-width:700px){body,html{font-size:15px}.app-shell{display:block}.sidebar{padding:14px 12px;position:-webkit-sticky;position:sticky;top:0;z-index:30}.logo{margin-bottom:12px;font-size:16px}.nav{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.nav a,.nav button{white-space:nowrap;width:auto;flex:0 0 auto;padding:9px 10px}.main{padding:12px;overflow-x:hidden}.page-title{align-items:flex-start;flex-direction:column;gap:10px}.page-title h1{font-size:23px}.panel{padding:14px;border-radius:14px}.card-value{font-size:20px}.actions{width:100%}.actions .btn,.actions a.btn{flex:1 1 auto}.btn{width:100%;min-height:42px}.tabs{display:flex;flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px}.tab{white-space:nowrap;flex:0 0 auto}input,select,textarea{width:100%}.table-wrap{border-radius:12px;margin-left:-2px;margin-right:-2px}table{min-width:720px}.form-row,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.drawer{width:100vw}.security-reminder{flex-direction:column;align-items:stretch}}@media (max-width:420px){.main{padding:10px}.panel{padding:12px}td,th{padding:8px}.logo-img{max-width:34px;max-height:34px}}.chart-scroll{overflow-x:auto;padding:8px 0}.line-chart{min-width:760px;width:100%;height:auto;color:var(--primary);background:linear-gradient(#fff,#fff);border:1px solid var(--line);border-radius:var(--panel-radius)}.line-chart text{font-size:12px;fill:#475569}.line-chart circle{fill:currentColor}.badge.green,.finance-row.green td{background:#dcfce7;color:#166534}.badge.yellow,.finance-row.yellow td{background:#fef9c3;color:#854d0e}.badge.red,.finance-row.red td{background:#fee2e2;color:#991b1b}.summary-row{margin-top:16px;display:flex;justify-content:flex-end;gap:16px;flex-wrap:wrap}.mini-row{display:flex;gap:6px;align-items:center;justify-content:space-between;padding:4px 0;border-bottom:1px dashed var(--line)}.link-btn{border:0;background:transparent;color:#dc2626;cursor:pointer;font-weight:700}html[data-theme=dark] .line-chart{background:#111827}.chart-grid{stroke:rgba(107,114,128,.32);stroke-width:1;stroke-dasharray:3 5}.chart-legend{font-size:10px!important;font-weight:700}.payment-status{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:800;white-space:nowrap}.payment-status.paid{background:#dcfce7;color:#166534}.payment-status.partially-paid{background:#fef9c3;color:#854d0e}.payment-status.unpaid{background:#111827;color:#ffffff}.payment-status.overdue{background:#fee2e2;color:#991b1b}.link-button{border:0;background:transparent;color:var(--primary);font-weight:800;cursor:pointer;padding:0}.link-button:hover{text-decoration:underline;filter:brightness(.85)}.wide-drawer{width:min(90vw,1480px)}.drawer .panel{box-shadow:none}.sales-summary-row td{font-weight:700;border-top:1px solid var(--border)}.sales-total-row td{background:#ecfdf5}.sales-plan-row td{background:#eff6ff}.sales-paid-row td{background:#d1fae5}.sales-margin-row td{background:#fef9c3}.sales-efficiency-row td:first-child,.sales-execution-row td:first-child{background:#ffffff}.sales-dynamic-cell.efficiency-low,.sales-dynamic-cell.plan-execution-low{background:#fee2e2}.sales-dynamic-cell.efficiency-mid,.sales-dynamic-cell.plan-execution-mid{background:#fef9c3}.sales-dynamic-cell.efficiency-good,.sales-dynamic-cell.plan-execution-high{background:#dcfce7}.sales-dynamic-cell.efficiency-neutral{background:#ffffff}.line-chart polyline{stroke-width:2}.line-chart .chart-grid{stroke-width:.75}.line-chart polyline{stroke-width:1.25!important}.chart-data-label{font-size:9px!important;opacity:.55;font-weight:600}td.month-past,th.month-past{opacity:.58;background-image:linear-gradient(rgba(148,163,184,.08),rgba(148,163,184,.08))}td.month-current,th.month-current{background-image:linear-gradient(rgba(59,130,246,.12),rgba(59,130,246,.12));box-shadow:inset 2px 0 rgba(37,99,235,.45),inset -2px 0 rgba(37,99,235,.45)}td.month-future,th.month-future{background-image:linear-gradient(rgba(255,255,255,.02),rgba(255,255,255,.02))}.summary-separator td{height:10px;background:transparent!important;border:0}.drawer.wide,.wide-drawer{width:min(90vw,1480px);max-width:98vw}td[data-label]:before{content:attr(data-label);display:block;font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:700}@media (max-width:900px){.drawer.wide,.wide-drawer{width:100vw}}.service-drawer-90{width:min(90vw,1600px);max-width:98vw}.component-backdrop{z-index:30;background:rgba(17,24,39,.18)}.component-drawer{z-index:40;width:min(90vw,1500px);max-width:98vw;top:18px;height:calc(100vh - 36px);border-radius:18px 0 0 18px}.badge.green,.finance-row.green .badge{background:#dcfce7;color:#166534}.badge.yellow,.finance-row.yellow .badge{background:#fef9c3;color:#854d0e}.badge.red,.finance-row.red .badge{background:#fee2e2;color:#991b1b}.badge.gray,.finance-row.gray .badge{background:#f3f4f6;color:#374151}@media (max-width:900px){.component-drawer,.service-drawer-90{width:100vw;height:100vh;top:0;border-radius:0}}