@charset "UTF-8";:root{--bg: oklch(.985 .008 80);--bg-elev: oklch(.995 .006 80);--bg-sunk: oklch(.965 .012 80);--surface: #ffffff;--line: oklch(.92 .012 80);--line-strong: oklch(.86 .014 78);--line-soft: oklch(.945 .01 80);--ink: oklch(.22 .012 60);--ink-2: oklch(.36 .014 65);--ink-3: oklch(.52 .014 70);--ink-4: oklch(.68 .012 75);--ink-mute: oklch(.78 .01 78);--brand: oklch(.72 .1 75);--brand-ink: oklch(.3 .06 60);--brand-soft: oklch(.95 .04 78);--brand-line: oklch(.86 .07 76);--ml: oklch(.86 .16 95);--ml-ink: oklch(.32 .1 80);--shopee: oklch(.7 .18 32);--shopee-ink: #fff;--amazon: oklch(.3 .04 80);--magalu: oklch(.62 .18 25);--shein: oklch(.3 .02 0);--ok: oklch(.62 .13 155);--ok-soft: oklch(.94 .05 155);--warn: oklch(.74 .14 70);--warn-soft: oklch(.96 .05 80);--bad: oklch(.58 .18 25);--bad-soft: oklch(.95 .05 25);--info: oklch(.6 .1 240);--info-soft: oklch(.95 .03 240);--shadow-sm: 0 1px 2px rgba(60, 50, 30, .04);--shadow: 0 1px 3px rgba(60, 50, 30, .05), 0 1px 2px rgba(60, 50, 30, .04);--shadow-lg: 0 8px 24px rgba(60, 50, 30, .08), 0 2px 6px rgba(60, 50, 30, .04);--r-xs: 4px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--font-display: "Fraunces", "Times New Roman", serif;--font-ui: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace}[data-theme=dark]{--bg: oklch(.16 .01 60);--bg-elev: oklch(.2 .012 60);--bg-sunk: oklch(.13 .008 60);--surface: oklch(.21 .012 60);--line: oklch(.28 .012 60);--line-strong: oklch(.36 .014 62);--line-soft: oklch(.24 .01 60);--ink: oklch(.96 .008 80);--ink-2: oklch(.84 .01 78);--ink-3: oklch(.68 .012 75);--ink-4: oklch(.52 .012 72);--ink-mute: oklch(.42 .01 70);--brand: oklch(.78 .11 78);--brand-ink: oklch(.2 .012 60);--brand-soft: oklch(.3 .05 75);--brand-line: oklch(.44 .07 75);--ok-soft: oklch(.28 .06 155);--warn-soft: oklch(.3 .06 80);--bad-soft: oklch(.3 .07 25);--info-soft: oklch(.28 .05 240);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow: 0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.5), 0 2px 6px rgba(0,0,0,.3)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:var(--font-ui);font-size:13px;line-height:1.45;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-variant-numeric:tabular-nums}button{font-family:inherit;font-size:inherit;color:inherit;cursor:default}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button,input,select,textarea{max-width:100%}.serif{font-family:var(--font-display);font-feature-settings:"ss01" on}.mono{font-family:var(--font-mono)}.num{font-variant-numeric:tabular-nums}h1,h2,h3,h4{margin:0;font-weight:500;letter-spacing:-.01em}h1{font-family:var(--font-display);font-weight:400;font-size:28px;line-height:1.15;letter-spacing:-.02em}h2{font-family:var(--font-display);font-weight:400;font-size:22px;line-height:1.2;letter-spacing:-.015em}h3{font-size:14px;font-weight:600;letter-spacing:-.005em}.main{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.content{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--ink-mute) transparent}.content::-webkit-scrollbar{width:10px}.content::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:6px;border:2px solid var(--bg);background-clip:content-box}.sidebar{display:flex;flex-direction:column;background:var(--bg-elev);border-right:1px solid var(--line);overflow:hidden}.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;border-bottom:1px solid var(--line-soft);height:60px}.brand-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--brand) 0%,oklch(from var(--brand) calc(l + .1) c h) 100%);display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:600;font-size:15px;flex-shrink:0;box-shadow:inset 0 1px #ffffff4d,0 1px 2px #0000000f}.brand-name{font-family:var(--font-display);font-weight:500;font-size:18px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden}.brand-name em{font-style:italic;font-weight:400;color:var(--brand)}.nav{flex:1;padding:10px 8px;overflow-y:auto;scrollbar-width:thin}.nav-section{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);padding:14px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-sm);font-size:13px;color:var(--ink-2);cursor:default;position:relative}.nav-item:hover{background:var(--bg-sunk);color:var(--ink)}.nav-item.active{background:var(--brand-soft);color:var(--brand-ink);font-weight:500}[data-theme=dark] .nav-item.active{color:var(--ink)}.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.85}.nav-label{flex:1;white-space:nowrap;overflow:hidden}.nav-badge{font-size:10px;font-weight:600;padding:1px 6px;border-radius:999px;background:var(--bad);color:#fff;font-variant-numeric:tabular-nums}.nav-badge.muted{background:var(--ink-mute);color:var(--surface)}.sidebar-foot{border-top:1px solid var(--line-soft);padding:10px;display:flex;align-items:center;gap:9px}.avatar{width:28px;height:28px;border-radius:999px;background:linear-gradient(135deg,#d3af9b,#9f7655);display:grid;place-items:center;color:#fff;font-weight:600;font-size:11px;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-weight:500;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--ink-3)}.topnav{display:none;align-items:center;gap:4px;padding:0 18px;height:56px;background:var(--bg-elev);border-bottom:1px solid var(--line);overflow-x:auto}.topnav .brand{border:none;padding:0 24px 0 0;height:auto}.topnav .nav-item{padding:7px 12px}html,body,app-root{height:100%}a{color:inherit;text-decoration:none}button,a,input,select,textarea{outline-color:var(--brand)}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh;background:var(--bg)}.app-shell .sidebar{position:sticky;top:0;height:100vh}.brand-copy{display:grid;line-height:1.15}.app-logo{width:32px;height:32px;object-fit:contain;border-radius:var(--r-sm);flex-shrink:0}.brand-copy strong{font-family:var(--font-display);font-size:18px;font-weight:500}.brand-copy small,.user-copy small,.page-head p,.section-title p,.metric-card small,td small{color:var(--ink-3)}.nav-icon{display:grid;place-items:center;width:24px;height:24px;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--brand-ink);background:var(--surface);font-size:11px;font-weight:700}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:60px;padding:0 24px;border-bottom:1px solid var(--line);background:color-mix(in oklch,var(--bg-elev) 92%,transparent)}.topbar p{margin:0;color:var(--ink-4);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.topbar-actions{display:flex;align-items:center;gap:10px;min-width:0}.user-pill{display:grid;place-items:center;width:32px;height:32px;border-radius:999px;background:var(--brand-soft);color:var(--brand-ink);font-weight:700}.user-copy{display:grid;min-width:0;line-height:1.2}.content{padding:24px}.page{display:grid;gap:18px;max-width:1240px;margin:0 auto}.page-head,.panel-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.page-head p,.section-title p{margin:6px 0 0}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-sm);padding:18px;min-width:0}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.metric-card{display:grid;gap:6px;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-sm);min-width:0}.metric-card span{color:var(--ink-3);font-size:12px}.metric-card strong{font-size:24px;font-weight:650;letter-spacing:0;overflow-wrap:anywhere}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(360px,.8fr);gap:18px}.chart-panel{min-height:340px}.chart-panel canvas{width:100%;height:270px;margin-top:14px}.table-wrap{overflow-x:auto;max-width:100%;min-width:0}table{width:100%;border-collapse:collapse;margin-top:14px}th,td{padding:11px 10px;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:middle}th{color:var(--ink-4);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}td strong,td small{display:block}.row-actions{display:flex;justify-content:flex-end;gap:8px;min-width:0}.button{min-height:34px;padding:0 12px;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--ink-2);font-weight:600}.button.primary{border-color:var(--brand-line);background:var(--brand);color:#fff}.button.ghost{background:transparent}.button.danger{border-color:var(--bad-soft);background:var(--bad-soft);color:var(--bad)}.button.full{width:100%}.button:disabled{cursor:not-allowed;opacity:.55}.badge{display:inline-flex;align-items:center;min-height:22px;padding:2px 8px;border:1px solid var(--line);border-radius:999px;background:var(--ok-soft);color:var(--ok);font-size:12px;font-weight:650;max-width:100%;overflow-wrap:anywhere}.badge.warn{background:var(--warn-soft);color:var(--warn)}.badge.bad{background:var(--bad-soft);color:var(--bad)}.alert{padding:11px 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--info-soft);color:var(--ink-2)}.alert.error{border-color:var(--bad-soft);background:var(--bad-soft);color:var(--bad)}.alert.info{display:grid;gap:4px;border-color:var(--info-soft);background:var(--info-soft)}.alert.info a{color:var(--info);word-break:break-all}.state-block{display:grid;place-items:center;gap:6px;min-height:128px;padding:24px;color:var(--ink-3);text-align:center}.state-block strong{color:var(--ink);font-size:15px}.state-block p{margin:0}.form-card,.form-grid{display:grid;gap:14px}.form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.form-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.span-all{grid-column:1/-1}.span-2{grid-column:span 2}.field{display:grid;gap:6px;min-width:0}.field span{color:var(--ink-3);font-size:12px;font-weight:650}input,select,textarea{width:100%;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:var(--surface);padding:8px 10px;min-width:0}select{appearance:auto;text-align:left;text-align-last:left;line-height:1.35}textarea{resize:vertical}input[readonly]{background:var(--bg-sunk)}.form-actions{display:flex;justify-content:flex-end}.check-row,.check-grid{display:flex;flex-wrap:wrap;gap:10px 16px}.check-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.check-row label,.check-grid label{display:flex;align-items:center;gap:8px;min-width:0}.check-row input,.check-grid input{width:auto}.search-field{width:min(340px,100%)}.login-page{display:grid;place-items:center;min-height:100vh;padding:24px;background:linear-gradient(120deg,color-mix(in oklch,var(--brand-soft) 70%,transparent),transparent 45%),var(--bg)}.login-panel{display:grid;gap:20px;width:min(430px,100%)}.login-brand{display:flex;align-items:center;justify-content:center;gap:12px;text-align:left}.login-brand p{margin:4px 0 0;color:var(--ink-3)}.login-panel .form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:22px}.topbar{display:flex;align-items:center;gap:14px;padding:0 24px;height:56px;background:var(--bg-elev);border-bottom:1px solid var(--line);flex-shrink:0}.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-3)}.crumbs strong{color:var(--ink);font-weight:500}.crumbs .sep{color:var(--ink-mute)}.search{flex:1;max-width:480px;position:relative}.search input{width:100%;height:32px;padding:0 12px 0 32px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg-sunk);color:var(--ink);outline:none}.search input::placeholder{color:var(--ink-4)}.search input:focus{border-color:var(--brand-line);background:var(--surface)}.search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--ink-4)}.search kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:10px;padding:2px 5px;border-radius:4px;background:var(--bg-elev);border:1px solid var(--line);color:var(--ink-4)}.topbar-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border:1px solid var(--line-strong);border-radius:var(--r-md);background:var(--surface);color:var(--ink);font-size:12.5px;font-weight:500;white-space:nowrap;transition:background .12s,border-color .12s}.btn:hover{background:var(--bg-sunk);border-color:var(--ink-mute)}.btn-primary{background:var(--brand);border-color:oklch(from var(--brand) calc(l - .05) c h);color:#fff;box-shadow:inset 0 1px #fff3}.btn-primary:hover{background:oklch(from var(--brand) calc(l - .04) c h)}.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--bg-sunk);color:var(--ink)}.btn-icon{width:32px;padding:0;justify-content:center}.btn-sm{height:26px;padding:0 9px;font-size:12px}.btn-lg{height:38px;padding:0 16px;font-size:13.5px}.page{padding:24px 28px 64px;max-width:1600px;margin:0 auto}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:22px}.page-title{display:flex;flex-direction:column;gap:4px}.page-title .eyebrow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4)}.page-title h1{font-size:30px}.page-title .sub{color:var(--ink-3);font-size:13px;margin-top:2px}.page-actions{display:flex;gap:8px;align-items:center}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}.card-pad{padding:18px 20px}.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line-soft)}.card-head h3{display:flex;align-items:center;gap:8px}.card-head .sub{font-size:12px;color:var(--ink-3)}.card-foot{padding:10px 18px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink-3)}.kpi{display:flex;flex-direction:column;gap:6px;padding:18px 20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);position:relative;overflow:hidden}.kpi-label{font-size:11.5px;color:var(--ink-3);font-weight:500;display:flex;align-items:center;gap:6px}.kpi-value{font-family:var(--font-display);font-weight:400;font-size:30px;line-height:1.1;letter-spacing:-.02em;color:var(--ink);font-variant-numeric:tabular-nums}.kpi-value small{font-family:var(--font-ui);font-size:14px;font-weight:500;color:var(--ink-3);margin-right:4px}.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:500;font-variant-numeric:tabular-nums}.kpi-delta.up{color:var(--ok)}.kpi-delta.down{color:var(--bad)}.kpi-spark{margin-top:4px;height:32px}.pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px;background:var(--bg-sunk);color:var(--ink-2);border:1px solid var(--line);white-space:nowrap;line-height:1.5}.pill-dot{width:6px;height:6px;border-radius:999px;background:currentColor}.pill.ok{background:var(--ok-soft);color:var(--ok);border-color:transparent}.pill.warn{background:var(--warn-soft);color:oklch(from var(--warn) calc(l - .18) c h);border-color:transparent}.pill.bad{background:var(--bad-soft);color:var(--bad);border-color:transparent}.pill.info{background:var(--info-soft);color:var(--info);border-color:transparent}.pill.brand{background:var(--brand-soft);color:var(--brand-ink);border-color:transparent}[data-theme=dark] .pill.warn{color:oklch(from var(--warn) calc(l + .05) c h)}.ch{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 7px;border-radius:4px;white-space:nowrap;line-height:1.5;letter-spacing:.01em}.ch-ml{background:var(--ml);color:var(--ml-ink)}.ch-shopee{background:var(--shopee);color:var(--shopee-ink)}.ch-amazon{background:var(--amazon);color:#fff}.ch-magalu{background:var(--magalu);color:#fff}.ch-shein{background:var(--shein);color:#fff}.ch-dot{width:7px;height:7px;border-radius:999px;display:inline-block;flex-shrink:0}.ch-dot.ml{background:var(--ml)}.ch-dot.shopee{background:var(--shopee)}.ch-dot.amazon{background:var(--amazon)}.ch-dot.magalu{background:var(--magalu)}.ch-dot.shein{background:var(--shein)}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:12.5px}.tbl thead th{text-align:left;font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);padding:10px 14px;background:var(--bg-sunk);border-bottom:1px solid var(--line);white-space:nowrap;position:sticky;top:0}.tbl thead th.num,.tbl tbody td.num{text-align:right;font-variant-numeric:tabular-nums}.tbl tbody td{padding:11px 14px;border-bottom:1px solid var(--line-soft);vertical-align:middle;color:var(--ink)}.tbl tbody tr:hover td{background:var(--bg-sunk)}.tbl tbody tr.selected td{background:var(--brand-soft)}.tbl tbody td .muted{color:var(--ink-3);font-size:11.5px}.tbl-compact tbody td{padding:7px 14px}.cell-prod{display:flex;align-items:center;gap:10px;min-width:0}.thumb{width:36px;height:36px;border-radius:var(--r-sm);background:var(--bg-sunk);border:1px solid var(--line);flex-shrink:0;background-size:cover;background-position:center;position:relative;overflow:hidden}.thumb-lg{width:56px;height:56px;border-radius:var(--r-md)}.cell-prod .name{font-weight:500;color:var(--ink)}.cell-prod .sku{font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.toolbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}.tabs{display:flex;gap:2px;padding:3px;background:var(--bg-sunk);border-radius:8px;border:1px solid var(--line)}.tabs button{appearance:none;border:0;background:transparent;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;color:var(--ink-3)}.tabs button:hover{color:var(--ink)}.tabs button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.tabs button .count{font-size:11px;color:var(--ink-4);margin-left:5px;font-variant-numeric:tabular-nums}.tabs button.active .count{color:var(--brand-ink)}.filter-chip{display:inline-flex;align-items:center;gap:5px;height:28px;padding:0 10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);font-size:12px;color:var(--ink-2)}.filter-chip:hover{border-color:var(--ink-mute)}.filter-chip.has-value{background:var(--brand-soft);border-color:var(--brand-line);color:var(--brand-ink)}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11.5px;font-weight:500;color:var(--ink-3)}.input,.select,textarea.input{height:32px;padding:0 10px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-md);color:var(--ink);outline:none;width:100%}textarea.input{height:auto;padding:8px 10px;line-height:1.45;resize:vertical}.input:focus,.select:focus,textarea.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px oklch(from var(--brand) l c h/.15)}.divider{height:1px;background:var(--line-soft);margin:0}.vdiv{width:1px;align-self:stretch;background:var(--line-soft);margin:0 4px}.row{display:flex}.col{display:flex;flex-direction:column}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.between{justify-content:space-between}.center{align-items:center}.grow{flex:1}.muted{color:var(--ink-3)}.faint{color:var(--ink-4)}.tnum{font-variant-numeric:tabular-nums}.grid-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.grid-2-asym{display:grid;grid-template-columns:1.6fr 1fr;gap:14px}.grid-3-asym{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:14px}.thumb-ph{background:repeating-linear-gradient(135deg,#f0e6da 0% 4px,#f6f1eb 4px 8px)}svg.spark{display:block;width:100%;height:32px}.gloss{background:radial-gradient(circle at 30% 25%,#f9f1e3,#dacfc3 35%,#a18e80);position:relative}.gloss:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 70% 80%,oklch(40% .02 50deg / .35) 0%,transparent 40%)}.meter{width:100%;height:4px;background:var(--bg-sunk);border-radius:999px;overflow:hidden}.meter>i{display:block;height:100%;background:var(--brand);border-radius:inherit}.meter>i.ok{background:var(--ok)}.meter>i.warn{background:var(--warn)}.meter>i.bad{background:var(--bad)}.bar-stack{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--bg-sunk)}.bar-stack>i{display:block;height:100%}.alert{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line-soft)}.alert:last-child{border-bottom:0}.alert .icon{width:28px;height:28px;border-radius:var(--r-sm);display:grid;place-items:center;flex-shrink:0}.alert.warn .icon{background:var(--warn-soft);color:oklch(from var(--warn) calc(l - .18) c h)}.alert.bad .icon{background:var(--bad-soft);color:var(--bad)}.alert.info .icon{background:var(--info-soft);color:var(--info)}.alert.ok .icon{background:var(--ok-soft);color:var(--ok)}.alert .body{flex:1;min-width:0}.alert .title{font-weight:500;font-size:13px}.alert .desc{font-size:12px;color:var(--ink-3);margin-top:2px}.alert time{font-size:11px;color:var(--ink-4);white-space:nowrap}.split-stat{display:grid;gap:8px}.split-stat .row1{display:flex;justify-content:space-between;align-items:baseline}.split-stat .lbl{font-size:12px;color:var(--ink-3);display:flex;align-items:center;gap:6px}.split-stat .val{font-weight:500;font-variant-numeric:tabular-nums}.tab-strip{display:flex;gap:0;border-bottom:1px solid var(--line);padding:0 18px}.tab-strip button{appearance:none;border:0;background:transparent;padding:11px 14px;font-size:12.5px;font-weight:500;color:var(--ink-3);border-bottom:2px solid transparent;margin-bottom:-1px}.tab-strip button:hover{color:var(--ink)}.tab-strip button.active{color:var(--ink);border-bottom-color:var(--brand)}.chk{width:15px;height:15px;border:1.5px solid var(--ink-mute);border-radius:3px;background:var(--surface);display:inline-grid;place-items:center;flex-shrink:0}.chk.on{background:var(--brand);border-color:var(--brand)}.chk.on:after{content:"";width:7px;height:4px;border-left:1.5px solid #fff;border-bottom:1.5px solid #fff;transform:rotate(-45deg) translate(1px,-1px)}.backdrop{position:fixed;inset:0;background:#1d140d66;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100}.drawer{position:fixed;right:0;top:0;bottom:0;width:560px;max-width:92vw;background:var(--bg-elev);border-left:1px solid var(--line);box-shadow:var(--shadow-lg);z-index:101;display:flex;flex-direction:column;animation:slide-in .22s ease-out}@keyframes slide-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.drawer-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.drawer-body{flex:1;overflow-y:auto;padding:18px 22px}.drawer-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px;background:var(--bg-sunk)}.dot{width:8px;height:8px;border-radius:999px;display:inline-block}kbd.k{font-family:var(--font-mono);font-size:10px;padding:1px 5px;background:var(--bg-elev);border:1px solid var(--line);border-bottom-width:2px;border-radius:4px;color:var(--ink-3)}.kicker{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4)}dl.kv{margin:0;display:grid;grid-template-columns:max-content 1fr;gap:8px 16px}dl.kv dt{color:var(--ink-3);font-size:12px}dl.kv dd{margin:0;color:var(--ink);font-size:12.5px;font-variant-numeric:tabular-nums}.jewel-frame{aspect-ratio:1;border-radius:var(--r-lg);background:linear-gradient(180deg,#f5f1ea,#ece3d6);border:1px solid var(--line);position:relative;overflow:hidden}.jewel-frame .gloss{position:absolute;inset:16%;border-radius:50%}.lnk{appearance:none;border:0;background:transparent;color:var(--brand-ink);font-weight:500;font-size:12.5px;padding:0;text-decoration:underline;text-decoration-color:oklch(from var(--brand-ink) l c h/.3);text-underline-offset:2px}.lnk:hover{text-decoration-color:currentColor}.list-compact>*+*{border-top:1px solid var(--line-soft)}.list-compact>*{padding:12px 18px;display:flex;gap:12px;align-items:center}.empty{padding:40px 20px;text-align:center;color:var(--ink-3);font-size:13px}html{overflow-x:hidden}body,app-root{min-width:0;overflow-x:hidden}img,canvas,svg{max-width:100%}.app-shell{display:grid;grid-template-columns:minmax(0,1fr);min-height:100dvh;width:100%;overflow-x:clip}.app-shell .main{min-width:0;height:100dvh}.app-shell .content{min-width:0;padding:.875rem;overflow-x:hidden}.app-shell .sidebar{position:fixed;inset:0 auto 0 0;z-index:120;width:min(18rem,84vw);height:100dvh;transform:translate(-100%);transition:transform .16s ease;box-shadow:var(--shadow-lg)}.app-shell .sidebar.open{transform:translate(0)}.sidebar-backdrop{position:fixed;inset:0;z-index:110;border:0;background:#1e191261}.menu-button{display:inline-grid;place-items:center;gap:.18rem;width:2.5rem;min-width:2.5rem;height:2.5rem;padding:0;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:var(--surface)}.menu-button span{display:block;width:.875rem;height:.125rem;border-radius:999px;background:var(--ink-2)}.topbar{min-width:0;height:auto;min-height:3.5rem;padding:.5rem .75rem;gap:.5rem}.topbar-title{min-width:0;flex:1}.topbar-title strong,.user-copy strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-actions{min-width:0;gap:.375rem;margin-left:0;flex:0 0 auto}.topbar-actions .button{min-width:2.5rem;padding-inline:.625rem}.user-copy{display:none}.page{width:100%;max-width:76rem;padding:0;margin:0 auto;gap:1rem}.page-head,.panel-head,.card-head,.drawer-head,.drawer-foot,.form-actions{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.75rem;min-width:0}.page-head{margin-bottom:0}.page-head>*,.panel-head>*,.card-head>*,.drawer-head>*,.drawer-foot>*,.form-actions>*{min-width:0}h1,.page-title h1{font-size:clamp(1.55rem,8vw,1.875rem);line-height:1.12}h2{font-size:clamp(1.2rem,5vw,1.45rem)}.panel,.metric-card,.card,.kpi{min-width:0;border-radius:var(--r-md)}.panel,.card-pad,.login-panel .form-card{padding:.875rem}.metric-grid,.dashboard-grid,.form-grid,.form-grid.compact,.check-grid,.grid-kpis,.grid-2,.grid-3,.grid-2-asym,.grid-3-asym,.requirement-grid{display:grid;grid-template-columns:minmax(0,1fr)}.span-2,.span-all{grid-column:1/-1}.field{min-width:0}.field>span,.field label,.field small{min-width:0;overflow-wrap:anywhere}input,select,textarea,.input,.select,textarea.input{min-height:2.625rem;font-size:1rem;max-width:100%;text-align:left;text-align-last:left}textarea{max-width:100%}.button,.btn,.tabs button,.filter-chip{min-height:2.625rem;touch-action:manipulation}.button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;max-width:100%;white-space:normal;text-align:center}.form-actions .button{width:100%}.row-actions .button{flex:0 0 auto}.check-row,.check-grid{gap:.625rem;min-width:0}.check-row label,.check-grid label{min-height:2.5rem;align-items:flex-start;padding:.375rem 0;overflow-wrap:anywhere}.check-row input,.check-grid input{width:1.125rem;height:1.125rem;margin-top:.15rem;flex:0 0 auto}.table-wrap{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}table,table.tbl{min-width:40rem}th,td,.tbl thead th,.tbl tbody td{padding:.75rem .625rem}.row-actions{justify-content:flex-start;flex-wrap:wrap}.alert{min-width:0;overflow-wrap:anywhere}.alert>*{min-width:0}.alert time{white-space:normal}.login-page{min-height:100dvh;padding:1rem}.login-panel{width:min(100%,27rem)}.login-brand{justify-content:flex-start}.chart-panel{min-height:16rem}.chart-panel canvas{height:14rem}.modal{width:calc(100vw - 1rem)!important;max-width:35rem;max-height:calc(100dvh - 1rem)}.drawer{width:min(35rem,100vw);max-width:100vw}.drawer-body,.drawer-head,.drawer-foot{padding-inline:1rem}.integration-layout{grid-template-columns:minmax(0,1fr)!important}.marketplace-button{min-height:3rem}@media(max-width:399.98px){.topbar-title p{display:none}.topbar-title strong{font-size:.875rem}.user-pill{width:1.875rem;height:1.875rem;font-size:.75rem}.topbar-actions .button{min-width:0;min-height:2.25rem;padding-inline:.5rem}.metric-card strong{font-size:1.25rem}.badge,.pill,.pub-badge{white-space:normal}}@media(min-width:640px){.app-shell .content{padding:1.25rem}.panel,.card-pad,.login-panel .form-card{padding:1rem}.page{gap:1.125rem}.page-head,.panel-head,.card-head,.form-actions{flex-direction:row;align-items:center;justify-content:space-between}.metric-grid,.grid-kpis,.grid-2,.grid-3,.form-grid,.form-grid.compact,.check-grid,.requirement-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-actions .button{width:auto}.user-copy{display:grid;max-width:12rem}}@media(min-width:768px){.app-shell{grid-template-columns:4.5rem minmax(0,1fr)}.app-shell .sidebar{position:sticky;top:0;z-index:1;width:auto;height:100dvh;transform:none;box-shadow:none}.app-shell .sidebar.open{position:fixed;z-index:120;width:min(18rem,84vw);transform:translate(0);box-shadow:var(--shadow-lg)}.sidebar-backdrop{display:none}.app-shell .sidebar.open~.main{min-width:0}.app-shell .brand{justify-content:center;padding-inline:.625rem}.app-shell .brand-copy,.app-shell .nav-item>span:not(.nav-icon){display:none}.app-shell .sidebar.open .brand{justify-content:flex-start;padding:1.125rem 1.125rem .875rem}.app-shell .sidebar.open .brand-copy,.app-shell .sidebar.open .nav-item>span:not(.nav-icon){display:inline}.app-shell .sidebar.open .nav-item{justify-content:flex-start;padding:.5rem .625rem}.app-shell .nav-item{justify-content:center;min-height:2.75rem;padding:.5rem}.menu-button{display:inline-grid}.topbar{padding-inline:1rem}.dashboard-grid{grid-template-columns:minmax(0,1fr)}.form-grid,.check-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px)and (max-width:1023.98px){.sidebar-backdrop{display:block}}@media(min-width:1024px){.app-shell{grid-template-columns:14.5rem minmax(0,1fr)}.menu-button{display:none}.app-shell .sidebar.open{position:sticky;width:auto;transform:none;box-shadow:none}.app-shell .brand{justify-content:flex-start;padding:1.125rem 1.125rem .875rem}.app-shell .brand-copy,.app-shell .nav-item>span:not(.nav-icon){display:inline}.app-shell .nav-item{justify-content:flex-start;padding:.5rem .625rem}.app-shell .content{padding:1.5rem}.metric-grid,.grid-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.dashboard-grid{grid-template-columns:minmax(0,1.4fr) minmax(20rem,.8fr)}.form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.form-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.check-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2-asym{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr)}.grid-3-asym{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr)}.integration-layout{grid-template-columns:minmax(13.75rem,17.5rem) minmax(0,1fr)!important}}@media(min-width:1440px){.app-shell .content{padding:2rem}.page{max-width:86rem}}
