:root,[data-theme=light]{--bg:#f7f7f5;--surface:#fff;--surface-2:#fafaf9;--surface-3:#f4f4f2;--surface-hover:#f0f0ee;--border:#e8e8e4;--border-strong:#d8d8d3;--text-1:#0a0a0a;--text-2:#404040;--text-3:#737373;--text-4:#a3a3a3;--accent:#f97316;--accent-hover:#ea580c;--accent-fg:#fff;--accent-soft:rgba(249,115,22,.1);--accent-soft-2:rgba(249,115,22,.16);--success:#16a34a;--success-soft:rgba(22,163,74,.12);--warning:#d97706;--warning-soft:rgba(217,119,6,.14);--danger:#dc2626;--danger-soft:rgba(220,38,38,.12);--info:#2563eb;--info-soft:rgba(37,99,235,.12);--shadow-card:0 1px 2px hsla(0,0%,4%,.04),0 1px 3px hsla(0,0%,4%,.03);--shadow-pop:0 12px 32px hsla(0,0%,4%,.1),0 4px 8px hsla(0,0%,4%,.04);--shadow-modal:0 24px 60px hsla(0,0%,4%,.18);--ring:0 0 0 3px rgba(249,115,22,.2)}[data-theme=dark]{--bg:#0a0a0a;--surface:#131313;--surface-2:#181818;--surface-3:#1f1f1f;--surface-hover:#232323;--border:#232323;--border-strong:#2e2e2e;--text-1:#fafafa;--text-2:#d4d4d4;--text-3:#a3a3a3;--text-4:#737373;--accent:#f97316;--accent-hover:#fb923c;--accent-fg:#0a0a0a;--accent-soft:rgba(249,115,22,.14);--accent-soft-2:rgba(249,115,22,.22);--success:#22c55e;--success-soft:rgba(34,197,94,.14);--warning:#eab308;--warning-soft:rgba(234,179,8,.14);--danger:#ef4444;--danger-soft:rgba(239,68,68,.14);--info:#3b82f6;--info-soft:rgba(59,130,246,.14);--shadow-card:0 1px 2px rgba(0,0,0,.4),0 0 0 1px hsla(0,0%,100%,.02);--shadow-pop:0 12px 32px rgba(0,0,0,.5);--shadow-modal:0 24px 60px rgba(0,0,0,.7);--ring:0 0 0 3px rgba(249,115,22,.3)}:root{--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-full:999px;--sans:"Inter",system-ui,-apple-system,sans-serif;--mono:"JetBrains Mono",ui-monospace,monospace;--sb-w:232px;--tb-h:56px;--content-pad:24px;--row-h:38px}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text-1);font-family:var(--sans);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;font-feature-settings:"cv11","ss01";transition:background-color .2s ease,color .2s ease}button{font-family:inherit;cursor:pointer}.mono{font-family:var(--mono);font-feature-settings:"tnum","zero"}.tnum{font-variant-numeric:tabular-nums}.app{display:grid;grid-template-columns:var(--sb-w) 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar::-webkit-scrollbar{width:10px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px;border:2px solid var(--surface)}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-4)}.brand{gap:10px;height:var(--tb-h);padding:0 16px;border-bottom:1px solid var(--border);flex-shrink:0;box-sizing:border-box}.brand,.brand-mark{display:flex;align-items:center}.brand-mark{width:30px;height:30px;border-radius:8px;background:var(--accent);color:var(--accent-fg);justify-content:center;font-weight:700;font-size:13px;letter-spacing:-.02em}.brand-name{font-weight:600;font-size:14px;letter-spacing:-.01em}.brand-sub{font-size:11px;color:var(--text-3);margin-top:1px;font-family:var(--mono);letter-spacing:.04em}.nav-group{padding:14px 10px 6px}.nav-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-4);padding:0 8px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:6px;color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;width:100%;border:none;background:transparent;text-align:left;text-decoration:none}.nav-item:hover{background:var(--surface-hover);color:var(--text-1)}.nav-item.active{background:var(--surface-3);color:var(--text-1)}.nav-item.active .nav-ico{color:var(--accent)}.nav-ico{flex:0 0 16px;color:var(--text-3);display:flex;align-items:center;justify-content:center}.nav-ico,.nav-ico svg{width:16px;height:16px}.nav-ico svg{stroke-width:1.6}.nav-count{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--text-3);background:var(--surface-3);padding:1px 6px;border-radius:var(--r-sm);font-feature-settings:"tnum"}.nav-item.active .nav-count{background:var(--accent-soft);color:var(--accent)}.sidebar-foot{margin-top:auto;padding:12px 10px;border-top:1px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer}.user-card:hover{background:var(--surface-hover)}.avatar{width:28px;height:28px;border-radius:var(--r-full);background:var(--surface-3);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.avatar.accent{background:var(--accent);color:var(--accent-fg)}.user-info{min-width:0;flex:1}.user-name{font-size:12px;font-weight:600;line-height:1.2}.user-role{font-size:11px;color:var(--text-3);line-height:1.2}.main{min-width:0;display:flex;flex-direction:column}.topbar{height:var(--tb-h);background:var(--surface);border-bottom:1px solid var(--border);gap:12px;padding:0 var(--content-pad);position:sticky;top:0;z-index:10}.crumbs,.topbar{display:flex;align-items:center}.crumbs{gap:6px;color:var(--text-3);font-size:13px}.crumbs .sep{color:var(--text-4)}.crumbs .here{color:var(--text-1);font-weight:500}.search{margin-left:16px;flex:1;max-width:420px;position:relative}.search input{width:100%;height:34px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:0 36px 0 32px;font-family:var(--sans);font-size:13px;color:var(--text-1);transition:border-color .15s,box-shadow .15s}.search input::placeholder{color:var(--text-4)}.search input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.search-ico{left:10px;width:14px;height:14px}.search-ico,.search-kbd{position:absolute;top:50%;transform:translateY(-50%);color:var(--text-4)}.search-kbd{right:8px;font-family:var(--mono);font-size:10px;background:var(--surface-3);border:1px solid var(--border);padding:2px 6px;border-radius:4px}.tb-actions{margin-left:auto;gap:6px}.icon-btn,.tb-actions{display:flex;align-items:center}.icon-btn{width:34px;height:34px;border-radius:var(--r-md);background:transparent;border:1px solid transparent;color:var(--text-2);justify-content:center;position:relative}.icon-btn:hover{background:var(--surface-hover);color:var(--text-1)}.icon-btn svg{width:16px;height:16px;stroke-width:1.6}.icon-btn .dot{position:absolute;top:7px;right:8px;width:6px;height:6px;border-radius:50%;background:var(--accent);border:1.5px solid var(--surface)}.btn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 12px;border-radius:var(--r-md);font-size:13px;font-weight:500;border:1px solid transparent;background:transparent;color:var(--text-1);white-space:nowrap;transition:background-color .15s,border-color .15s,color .15s}.btn svg{width:14px;height:14px;stroke-width:1.8}.btn-primary{background:var(--accent);color:var(--accent-fg)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface);border-color:var(--border-strong);color:var(--text-1)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--border-strong)}.btn-ghost{color:var(--text-2)}.btn-ghost:hover{background:var(--surface-hover);color:var(--text-1)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{height:28px;padding:0 9px;font-size:12px;gap:5px}.btn-sm svg{width:12px;height:12px}.btn-lg{height:40px;padding:0 16px;font-size:14px}.page{padding:var(--content-pad);flex-direction:column}.page,.page-head{display:flex;gap:16px}.page-head{align-items:flex-end;justify-content:space-between;flex-wrap:wrap}.page-title{font-size:22px;font-weight:600;letter-spacing:-.02em;line-height:1.1;margin:0}.page-sub{font-size:13px;color:var(--text-3);margin-top:4px}.page-actions{display:flex;gap:6px;align-items:center}.seg{display:inline-flex;padding:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);gap:2px}.seg button{border:none;background:transparent;padding:5px 11px;font-size:12px;font-weight:500;color:var(--text-3);border-radius:6px}.seg button:hover{color:var(--text-1)}.seg button.on{color:var(--text-1)}.card,.seg button.on{background:var(--surface);box-shadow:var(--shadow-card)}.card{border:1px solid var(--border);border-radius:var(--r-lg)}.card-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-size:14px;font-weight:600;letter-spacing:-.01em}.card-sub{font-size:12px;color:var(--text-3);margin-top:2px}.card-body{padding:16px}.card-foot{padding:10px 16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-3)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.kpi-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.kpi-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-3)}.kpi-icon{width:24px;height:24px;border-radius:6px;background:var(--surface-3);color:var(--text-2);display:flex;align-items:center;justify-content:center}.kpi-icon svg{width:13px;height:13px}.kpi-value{font-family:var(--sans);font-size:26px;font-weight:600;line-height:1.1;letter-spacing:-.02em;color:var(--text-1);font-variant-numeric:tabular-nums}.kpi-value .unit{font-size:14px;color:var(--text-3);font-weight:500;margin-left:2px}.kpi-trend{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:11px;color:var(--success);font-feature-settings:"tnum"}.kpi-trend.dn{color:var(--danger)}.kpi-trend.flat{color:var(--text-3)}.kpi-spark{position:absolute;right:0;bottom:0;width:90px;height:30px;opacity:.7}.tbl{width:100%;font-size:13px;border-collapse:separate;border-spacing:0}.tbl thead th{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-weight:500;text-align:left;padding:9px 14px;border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap}.tbl thead th.r{text-align:right}.tbl tbody td{padding:0 14px;height:var(--row-h);border-bottom:1px solid var(--border);color:var(--text-1);vertical-align:middle;white-space:nowrap}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr:hover td{background:var(--surface-2)}.tbl td.r{text-align:right;font-feature-settings:"tnum"}.tbl td.muted{color:var(--text-3)}.tbl td.mono{font-family:var(--mono);font-feature-settings:"tnum"}.tbl td.id{font-family:var(--mono);font-size:12px;color:var(--text-3)}.cell-guest{display:flex;align-items:center;gap:8px}.cell-guest .name{font-weight:500}.cell-actions{display:flex;gap:4px;justify-content:flex-end}.pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;padding:2px 8px;border-radius:var(--r-full);border:1px solid transparent;font-family:var(--sans);white-space:nowrap;line-height:1.4}.pill:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.pill-success{color:var(--success);background:var(--success-soft)}.pill-warning{color:var(--warning);background:var(--warning-soft)}.pill-danger{color:var(--danger);background:var(--danger-soft)}.pill-info{color:var(--info);background:var(--info-soft)}.pill-accent{color:var(--accent);background:var(--accent-soft)}.pill-neutral{color:var(--text-2);background:var(--surface-3);border-color:var(--border)}.pill.no-dot:before{display:none}.chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 7px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);font-family:var(--mono)}.two-col{display:grid;grid-template-columns:1fr 320px;gap:16px;align-items:flex-start}@media(max-width:1100px){.two-col{grid-template-columns:1fr}}.filter-bar{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.filter-bar .sep{width:1px;height:20px;background:var(--border);margin:0 4px}.cal-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface)}.cal{display:grid;grid-template-columns:130px repeat(14,minmax(72px,1fr));font-size:12px;min-width:1100px}.cal .ch{padding:9px 8px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);background:var(--surface-2);border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:center}.cal .ch.first{text-align:left;padding-left:14px}.cal .ch.weekend{background:var(--surface-3);color:var(--text-2)}.cal .ch.today{color:var(--accent);background:var(--accent-soft);box-shadow:inset 2px 0 0 var(--accent)}.cal .ch.past{opacity:.65}.cal .cr{height:54px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);position:relative}.cal .cr.first{font-weight:500;color:var(--text-1);display:flex;align-items:center;padding:0 14px;font-size:13px}.cal .cr.first,.cal .cr.weekend{background:var(--surface-2)}.cal .cr:last-child{border-right:0}.cal .cr.past{background-image:repeating-linear-gradient(-45deg,transparent,transparent 4px,color-mix(in srgb,var(--text-1) 5%,transparent) 4px,color-mix(in srgb,var(--text-1) 5%,transparent) 5px)}.cal .cr.today{box-shadow:inset 2px 0 0 var(--accent)}.cal .booking{position:absolute;top:6px;bottom:6px;left:4px;right:4px;border-radius:10px;padding:0 10px;display:flex;align-items:center;gap:7px;font-size:12px;font-weight:500;overflow:hidden;white-space:nowrap;cursor:pointer}.booking-direct{background:#0ea5e9}.booking-booking{background:#16a34a}.booking-airbnb{background:#e11d48}.booking-agoda{background:#7c3aed}.booking-vip{background:var(--accent)}[data-theme=dark] .booking{color:#0a0a0a;font-weight:600}[data-theme=dark] .booking-direct{background:#7dd3fc}[data-theme=dark] .booking-booking{background:#86efac}[data-theme=dark] .booking-airbnb{background:#fda4af}[data-theme=dark] .booking-agoda{background:#c4b5fd}[data-theme=dark] .booking-vip{background:#fdba74}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.room{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:border-color .15s,transform .1s}.room:hover{border-color:var(--border-strong)}.room-num{font-size:18px;font-weight:600;letter-spacing:-.02em;line-height:1}.room-num,.room-type{font-family:var(--mono)}.room-type{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.room-foot{display:flex;align-items:center;justify-content:space-between}.room.dirty{background:var(--warning-soft);border-color:transparent}.room.dirty .room-num{color:var(--warning)}.room.occupied{background:var(--info-soft);border-color:transparent}.room.occupied .room-num{color:var(--info)}.room.oos{background:var(--danger-soft);border-color:transparent}.room.oos .room-num{color:var(--danger)}.stat-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}.stat-row:last-child{border-bottom:0}.stat-row .lbl{color:var(--text-3)}.stat-row .val{font-family:var(--mono);font-feature-settings:"tnum";font-weight:500}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3)}.input,.select,.textarea{width:100%;height:34px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:0 10px;font-family:var(--sans);font-size:13px;color:var(--text-1)}.input::placeholder{color:var(--text-4)}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.stepper{display:flex;align-items:center;gap:0;margin-bottom:18px}.step{gap:8px;font-size:13px}.step,.step .dot{display:flex;align-items:center;color:var(--text-3)}.step .dot{width:24px;height:24px;border-radius:50%;background:var(--surface-3);justify-content:center;font-size:12px;font-weight:600;font-family:var(--mono);border:1px solid var(--border)}.step.done .dot{background:var(--success);color:#fff;border-color:var(--success)}.step.active{color:var(--text-1);font-weight:500}.step.active .dot{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.step-line{flex:1;height:1px;background:var(--border);margin:0 12px;min-width:24px}.step.done+.step-line{background:var(--success)}.timeline{display:flex;flex-direction:column;gap:14px;padding-left:6px}.tl-item{display:flex;gap:12px;position:relative}.tl-item:not(:last-child):after{content:"";position:absolute;left:5px;top:16px;bottom:-14px;width:1px;background:var(--border)}.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--surface);border:2px solid var(--text-4);flex-shrink:0;margin-top:3px;z-index:1}.tl-item.done .tl-dot{border-color:var(--success);background:var(--success)}.tl-item.now .tl-dot{border-color:var(--accent);background:var(--accent)}.tl-body{flex:1;padding-bottom:2px}.tl-title{font-size:13px;font-weight:500}.tl-meta{font-size:12px;color:var(--text-3);margin-top:1px}.theme-toggle{display:flex;padding:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);gap:0}.theme-toggle button{border:none;background:transparent;width:28px;height:26px;display:flex;align-items:center;justify-content:center;color:var(--text-3);border-radius:5px}.theme-toggle button.on{background:var(--surface);color:var(--text-1);box-shadow:var(--shadow-card)}.theme-toggle button svg{width:13px;height:13px}.folio-line{display:grid;grid-template-columns:1fr 100px 70px 90px 30px;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}.folio-line:last-child{border-bottom:0}.folio-line .desc{font-weight:500}.folio-line .meta{font-size:12px;color:var(--text-3);margin-top:1px}.folio-line .amt{font-family:var(--mono);text-align:right;font-feature-settings:"tnum"}.settings-grid{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:flex-start}.settings-nav{position:sticky;top:calc(var(--tb-h) + 24px);display:flex;flex-direction:column;gap:2px}.settings-nav button{border:none;background:transparent;text-align:left;padding:7px 10px;font-size:13px;color:var(--text-2);border-radius:6px;cursor:pointer}.settings-nav button:hover{background:var(--surface-hover);color:var(--text-1)}.settings-nav button.on{background:var(--accent-soft);color:var(--accent);font-weight:500}.toggle{position:relative;width:32px;height:18px;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-full);cursor:pointer}.toggle:after{content:"";position:absolute;top:1px;left:1px;width:14px;height:14px;border-radius:50%;background:var(--surface);border:1px solid var(--border-strong);transition:left .15s}.toggle.on{background:var(--accent);border-color:var(--accent)}.toggle.on:after{left:15px;background:#fff;border-color:transparent}.hint{font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:6px}.hint .kbd{font-family:var(--mono);font-size:10px;background:var(--surface-3);border:1px solid var(--border);padding:1px 5px;border-radius:4px}.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sec-title{font-size:15px;font-weight:600;letter-spacing:-.01em}.sec-sub{font-size:12px;color:var(--text-3);margin-top:2px}.tw-wrap{position:fixed;bottom:18px;right:18px;z-index:50;font-family:var(--sans)}.tw-fab{width:42px;height:42px;border-radius:var(--r-full);background:var(--text-1);color:var(--bg);border:none;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-pop);cursor:pointer}.tw-fab svg{width:18px;height:18px}.tw-panel{position:absolute;bottom:50px;right:0;width:280px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);padding:14px;display:flex;flex-direction:column;gap:14px}.tw-panel h4{margin:0;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:space-between}.tw-row{display:flex;flex-direction:column;gap:6px}.tw-row .lbl{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3)}.tw-swatches{display:flex;gap:6px}.tw-swatch{width:26px;height:26px;border-radius:var(--r-md);border:1.5px solid var(--border);cursor:pointer;position:relative}.tw-swatch.on{border-color:var(--text-1)}.tw-swatch.on:after{content:"";position:absolute;inset:-4px;border-radius:calc(var(--r-md) + 4px);border:1.5px solid var(--text-1)}.screen{display:none}.screen.active{display:flex;flex-direction:column}[data-density=comfortable]{--row-h:46px;--content-pad:28px}[data-density=dense]{--row-h:32px;--content-pad:20px}[data-density=dense] .card-body,[data-density=dense] .kpi{padding:12px}[data-sidebar-minimal=true]{--sb-w:60px}[data-sidebar-minimal=true] .brand-name,[data-sidebar-minimal=true] .brand-sub,[data-sidebar-minimal=true] .nav-count,[data-sidebar-minimal=true] .nav-label,[data-sidebar-minimal=true] .nav-text,[data-sidebar-minimal=true] .sidebar-foot{display:none}[data-sidebar-minimal=true] .nav-item{justify-content:center;padding:8px}[data-sidebar-minimal=true] .nav-group{padding:8px 4px 4px}[data-sidebar-minimal=true] .brand{justify-content:center;padding:14px 0}.divider-h{height:1px;background:var(--border);margin:4px 0}.flex{align-items:center}.flex,.flex-col{display:flex;gap:8px}.flex-col{flex-direction:column}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.grow{flex:1}.muted{color:var(--text-3)}.right{text-align:right}.nowrap{white-space:nowrap}.pad-16{padding:16px}.pad-20{padding:20px}.pad-24{padding:24px}.grid-2{grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:12px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:900px){.grid-2,.grid-3,.grid-4,.kpi-grid{grid-template-columns:1fr 1fr}}@media(max-width:680px){.app,.grid-2,.grid-3,.grid-4,.kpi-grid{grid-template-columns:1fr}.sidebar{display:none}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--text-4)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px;animation:overlay-in .15s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-modal);width:100%;max-width:560px;max-height:calc(100dvh - 32px);display:flex;flex-direction:column;overflow:hidden;animation:modal-in .18s cubic-bezier(.16,1,.3,1)}.modal-lg{max-width:760px}.modal-sm{max-width:400px}@keyframes modal-in{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}.modal-title{font-size:15px;font-weight:600;letter-spacing:-.01em}.modal-sub{font-size:12px;color:var(--text-3);margin-top:2px}.modal-close{width:28px;height:28px;border-radius:var(--r-md);background:transparent;border:none;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close:hover{background:var(--surface-hover);color:var(--text-1)}.modal-close svg{width:14px;height:14px}.modal-body{padding:20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.modal-foot{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0}.modal-foot.spread{justify-content:space-between}.confirm-message{font-size:13px;color:var(--text-2);line-height:1.5}.confirm-field{display:block;margin-top:14px}.confirm-field>span{display:block;font-size:12px;color:var(--text-3);margin-bottom:6px}.confirm-field .input,.confirm-field textarea.input{width:100%}.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:9998;animation:overlay-in .15s ease}.drawer{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:480px;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;z-index:9999;overflow:hidden;animation:drawer-in .22s cubic-bezier(.16,1,.3,1)}.drawer-lg{max-width:640px}@keyframes drawer-in{0%{transform:translateX(100%)}to{transform:translateX(0)}}.drawer-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-shrink:0}.drawer-title{font-size:15px;font-weight:600;letter-spacing:-.01em}.drawer-sub{font-size:12px;color:var(--text-3);margin-top:2px}.drawer-body{padding:20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.drawer-foot{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0}.drawer-foot.spread{justify-content:space-between}.toast-stack{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:8px;align-items:flex-end;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);min-width:280px;max-width:380px;pointer-events:all;animation:toast-in .22s cubic-bezier(.16,1,.3,1);font-size:13px}@keyframes toast-in{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.toast-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center}.toast-icon svg{width:16px;height:16px}.toast-content{flex:1;min-width:0}.toast-msg{font-weight:500;line-height:1.35}.toast-desc{font-size:12px;color:var(--text-3);margin-top:2px;line-height:1.35}.toast-dismiss{width:20px;height:20px;flex-shrink:0;background:transparent;border:none;color:var(--text-4);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;padding:0}.toast-dismiss:hover{color:var(--text-2);background:var(--surface-hover)}.toast-dismiss svg{width:12px;height:12px}.toast.success .toast-icon{color:var(--success)}.toast.error .toast-icon{color:var(--danger)}.toast.warning .toast-icon{color:var(--warning)}.toast.info .toast-icon{color:var(--info)}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.warning{border-left:3px solid var(--warning)}.toast.info{border-left:3px solid var(--info)}.skeleton{background:linear-gradient(90deg,var(--surface-3) 25%,var(--surface-hover) 50%,var(--surface-3) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:12px;border-radius:4px}.skeleton-title{height:18px;border-radius:4px}.skeleton-row{display:flex;align-items:center;gap:12px;padding:0 14px;height:var(--row-h);border-bottom:1px solid var(--border)}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block;flex-shrink:0}.spinner-sm{width:14px;height:14px;border-width:1.5px}.spinner-lg{width:24px;height:24px;border-width:2.5px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:12px;color:var(--text-3)}.empty-state svg{width:40px;height:40px;opacity:.4}.empty-title{font-size:14px;font-weight:600;color:var(--text-2)}.empty-desc{font-size:13px;max-width:320px;line-height:1.5}.field-error{font-size:11px;color:var(--danger);display:flex;align-items:center;gap:4px}.input.error,.select.error,.textarea.error{border-color:var(--danger)}.input.error:focus,.select.error:focus,.textarea.error:focus{box-shadow:0 0 0 3px rgba(220,38,38,.2)}.input-group{display:flex;gap:0}.input-group .input{border-radius:0}.input-group .input:first-child{border-radius:var(--r-md) 0 0 var(--r-md)}.input-group .btn,.input-group .input:last-child{border-radius:0 var(--r-md) var(--r-md) 0}.input-group .btn{flex-shrink:0;height:34px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.checkbox-wrap{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-1);user-select:none}.checkbox-wrap input[type=checkbox]{width:16px;height:16px;border:1.5px solid var(--border-strong);border-radius:4px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.checkbox-label{line-height:1.4}.checkbox-sub{font-size:11px;color:var(--text-3);margin-top:1px}.pagination{display:flex;align-items:center;gap:6px;justify-content:center;padding:12px 0 4px}.pagination .pg-info{font-size:12px;color:var(--text-3);font-family:var(--mono);font-feature-settings:"tnum";margin:0 8px}.pagination .pg-btn{height:28px;min-width:28px;padding:0 4px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text-2);font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer}.pagination .pg-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text-1)}.pagination .pg-btn.on{background:var(--accent);border-color:var(--accent);color:var(--accent-fg);font-weight:600}.pagination .pg-btn:disabled{opacity:.4;cursor:not-allowed}.search-field{position:relative;display:inline-flex;align-items:center}.search-field .input{padding-left:32px;padding-right:8px;width:220px}.search-field .search-ico{position:absolute;left:9px;color:var(--text-4);pointer-events:none;width:14px;height:14px}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23737373' stroke-width='1.5'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:14px;padding-right:28px;cursor:pointer}.textarea{height:auto;padding:9px 10px;resize:vertical;min-height:64px;line-height:1.5}