:root{--accent: #ffde5f;--accent-hover: #ffd633;--accent-soft: #fff4c2;--accent-ink: #7a5b00;--ink: #111111;--ink-muted: #5a5a5a;--surface: #ffffff;--surface-alt: #faf7ee;--border: #ebe7d8;--canvas: #f7f4ec;--panel: #ffffff;--panel-soft: #faf7ee;--line: #ebe7d8;--line-soft: #f1eddf;--text: #111111;--text-2: #5a5a5a;--text-3: #8a8576;--text-on-dark: #ffffff;--text-on-dark-2: rgba(255, 255, 255, .62);--side-bg: #141310;--side-bg-2: #1d1b16;--side-line: rgba(255, 255, 255, .08);--side-text: rgba(255, 255, 255, .7);--side-text-active: #111111;--success: #15803d;--success-bg: #dcfce7;--warning: #c2410c;--warning-bg: #ffedd5;--danger: #dc2626;--danger-bg: #fee2e2;--info: #1d4ed8;--info-bg: #dbeafe;--font: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--fs-hero: 32px;--fs-h1: 26px;--fs-h2: 20px;--fs-h3: 17px;--fs-lg: 16px;--fs-md: 14px;--fs-sm: 13px;--fs-xs: 12px;--fs-micro: 11px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--r-xs: 6px;--r-sm: 8px;--r-md: 12px;--r-lg: 14px;--r-xl: 18px;--r-2xl: 24px;--r-pill: 999px;--sh-1: rgba(17, 17, 17, .04) 0 1px 2px 0;--sh-2: rgba(17, 17, 17, .08) 0 4px 6px 0;--sh-3: rgba(17, 17, 17, .08) 0 0 22px 0;--sh-4: rgba(36, 36, 36, .14) 0 12px 28px -8px;--header-h: 64px;--sidebar-w: 248px;--container: 1240px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);font-size:var(--fs-md);line-height:1.5;color:var(--text);background:var(--canvas);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5{margin:0;font-weight:600;letter-spacing:-.01em;line-height:1.2}p{margin:0}a{color:inherit;text-decoration:none}button,input,textarea,select{font-family:inherit}::selection{background:var(--accent);color:var(--ink)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#d9d4c4;border-radius:999px;border:2px solid var(--canvas)}::-webkit-scrollbar-thumb:hover{background:#c9c3af}.muted{color:var(--text-2)}.tiny{font-size:var(--fs-xs);color:var(--text-3)}.row{display:flex;align-items:center;gap:var(--sp-3)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}.col{display:flex;flex-direction:column}.grow{flex:1;min-width:0}.wrap{flex-wrap:wrap}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-6{gap:var(--sp-6)}.mt-2{margin-top:var(--sp-2)}.mt-4{margin-top:var(--sp-4)}.mt-6{margin-top:var(--sp-6)}.text-center{text-align:center}.nowrap{white-space:nowrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:9px 18px;border-radius:var(--r-pill);border:1px solid transparent;font-size:var(--fs-md);font-weight:600;line-height:1.2;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease,transform 80ms ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:active{transform:translateY(1px)}.btn:disabled{cursor:not-allowed;opacity:.55}.btn svg{width:16px;height:16px}.btn-primary{background:var(--ink);color:#fff}.btn-primary:hover{background:#2a2a2a}.btn-accent{background:var(--accent);color:var(--ink)}.btn-accent:hover{background:var(--accent-hover)}.btn-secondary{background:transparent;color:var(--ink);border-color:var(--ink)}.btn-secondary:hover{background:#1111110d}.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--line)}.btn-ghost:hover{background:var(--panel-soft)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:transparent}.btn-danger:hover{background:#fbd5d5}.btn-sm{padding:6px 13px;font-size:var(--fs-sm)}.btn-lg{padding:12px 24px;font-size:var(--fs-lg)}.btn-block{width:100%}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--line);color:var(--ink);cursor:pointer;transition:background .15s ease,border-color .15s ease;flex:none}.icon-btn:hover{background:var(--panel-soft)}.icon-btn svg{width:17px;height:17px}.icon-btn.sm{width:30px;height:30px}.icon-btn.sm svg{width:15px;height:15px}.icon-btn.danger:hover{background:var(--danger-bg);color:var(--danger);border-color:transparent}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);padding:var(--sp-6)}.card-soft{background:var(--panel-soft);border:1px solid var(--line);border-radius:var(--r-xl);padding:var(--sp-6)}.card-pad-sm{padding:var(--sp-4)}.card-flush{padding:0;overflow:hidden}.section-title{font-size:var(--fs-h3);font-weight:600}.section-sub{font-size:var(--fs-sm);color:var(--text-2);margin-top:2px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:600;line-height:1.4;white-space:nowrap}.badge-neutral{background:var(--panel-soft);color:var(--text-2);border:1px solid var(--line)}.badge-accent{background:var(--accent-soft);color:var(--accent-ink)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-dot{width:7px;height:7px;border-radius:999px;background:currentColor}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:var(--fs-sm);font-weight:500;color:var(--text)}.field-hint{font-size:var(--fs-xs);color:var(--text-3)}.field-req{color:var(--danger);margin-left:2px}.field-error{font-size:var(--fs-xs);color:var(--danger)}.input,.textarea,.select{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 12px;font-size:var(--fs-md);color:var(--text);transition:border-color .15s ease,box-shadow .15s ease}.input::placeholder,.textarea::placeholder{color:var(--text-3)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px #ffde5f66}.textarea{resize:vertical;min-height:84px;line-height:1.55}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235a5a5a' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:32px;cursor:pointer}.input.invalid,.textarea.invalid,.select.invalid{border-color:var(--danger)}.input-affix{position:relative;display:flex;align-items:center}.input-affix .prefix{position:absolute;left:12px;color:var(--text-3);font-size:var(--fs-md);pointer-events:none}.input-affix .input{padding-left:26px}.toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle input{position:absolute;opacity:0;pointer-events:none}.toggle-track{width:38px;height:22px;border-radius:999px;background:#d9d4c4;position:relative;transition:background .15s ease;flex:none}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:999px;background:#fff;transition:transform .15s ease;box-shadow:var(--sh-1)}.toggle input:checked+.toggle-track{background:var(--ink)}.toggle input:checked+.toggle-track:after{transform:translate(16px)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-4)}.form-grid .span-2{grid-column:1 / -1}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}.form-grid .span-2{grid-column:auto}}.tabs-nav{display:flex;align-items:stretch;gap:2px;border-bottom:1px solid var(--line)}.tabs{display:flex;gap:var(--sp-1);overflow-x:auto;scroll-behavior:smooth;flex:1;scrollbar-width:none;-ms-overflow-style:none}.tabs::-webkit-scrollbar{display:none}.tabs-arrow{flex:none;width:30px;border:none;background:none;color:var(--text-2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);transition:background .15s,color .15s,opacity .15s}.tabs-arrow:hover{background:var(--panel-soft);color:var(--ink)}.tabs-arrow.is-hidden{opacity:0;pointer-events:none}.tab{padding:10px 16px;font-size:var(--fs-md);font-weight:500;color:var(--text-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color .15s ease,border-color .15s ease}.tab:hover{color:var(--text)}.tab.active{color:var(--ink);border-bottom-color:var(--ink)}.pill-tabs{display:inline-flex;gap:6px;flex-wrap:wrap}.pill-tab{padding:6px 14px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--surface);color:var(--text-2);font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all .15s ease}.pill-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);overflow:hidden}.table{width:100%;border-collapse:collapse;font-size:var(--fs-md)}.table thead th{text-align:left;background:var(--panel-soft);color:var(--text-2);font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:12px 16px;border-bottom:1px solid var(--line);white-space:nowrap}.table tbody td{padding:13px 16px;border-bottom:1px solid var(--line-soft);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background .12s ease}.table tbody tr:hover{background:var(--panel-soft)}.table .col-actions{text-align:right;white-space:nowrap;width:1%}.cell-thumb{width:46px;height:36px;border-radius:var(--r-sm);object-fit:cover;background:var(--panel-soft);flex:none}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1111116b;display:flex;z-index:80;animation:fade .15s ease}@keyframes fade{0%{opacity:0}}.modal{margin:auto;width:min(560px,calc(100vw - 32px));max-height:calc(100vh - 64px);background:var(--panel);border-radius:var(--r-2xl);box-shadow:var(--sh-4);display:flex;flex-direction:column;overflow:hidden;animation:pop .16s ease}@keyframes pop{0%{transform:scale(.97);opacity:0}}.drawer{margin-left:auto;width:min(720px,100vw);height:100%;background:var(--canvas);box-shadow:var(--sh-4);display:flex;flex-direction:column;animation:slide .2s ease}.drawer.wide{width:min(920px,100vw)}@keyframes slide{0%{transform:translate(40px);opacity:.4}}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--line);background:var(--panel);flex:none}.panel-body{padding:var(--sp-6);overflow-y:auto;flex:1}.panel-foot{display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--line);background:var(--panel);flex:none}.toast-wrap{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:200}.toast{display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:12px 16px;border-radius:var(--r-md);box-shadow:var(--sh-4);font-size:var(--fs-sm);font-weight:500;min-width:240px;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}}.toast.success .toast-dot{background:#4ade80}.toast.error{background:var(--danger)}.toast-dot{width:8px;height:8px;border-radius:999px;background:var(--accent);flex:none}.repeater{display:flex;flex-direction:column;gap:var(--sp-3)}.repeater-item{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);padding:var(--sp-4)}.repeater-item-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);margin-bottom:var(--sp-3)}.repeater-handle{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-sm);font-weight:600;color:var(--text-2)}.string-list{display:flex;flex-direction:column;gap:8px}.string-row{display:flex;align-items:center;gap:8px}.string-row .drag-dot{display:inline-flex;align-items:center;color:var(--text-3);cursor:grab;flex:none}.string-row.dragging{opacity:.5}.repeater-item .repeater-handle{cursor:grab}.repeater-item .repeater-handle:active{cursor:grabbing}.repeater-item.dragging{opacity:.45}.repeater-item.drag-over{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.slider{display:flex;align-items:center;gap:var(--sp-3)}.slider input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:6px;border-radius:var(--r-pill);background:var(--line);outline:none;cursor:pointer}.slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--surface);border:2px solid var(--accent-ink);box-shadow:var(--sh-2);cursor:grab}.slider input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--surface);border:2px solid var(--accent-ink);cursor:grab}.slider-val{min-width:54px;text-align:right;font-weight:600;font-size:var(--fs-sm);font-variant-numeric:tabular-nums}.stepper{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface);overflow:hidden;width:fit-content}.stepper-btn{width:34px;height:34px;border:none;background:var(--panel-soft);color:var(--text);font-size:18px;line-height:1;cursor:pointer;transition:background .15s}.stepper-btn:hover:not(:disabled){background:var(--accent-soft)}.stepper-btn:disabled{opacity:.4;cursor:not-allowed}.stepper-val{min-width:46px;text-align:center;font-weight:600;font-size:var(--fs-md);font-variant-numeric:tabular-nums}.chip-select{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.chip{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--surface);color:var(--text-2);font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all .15s}.chip:hover{border-color:var(--accent-ink);color:var(--text)}.chip.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:600}.pdf-picker{display:flex;gap:var(--sp-3);align-items:flex-start}.pdf-chip{display:inline-flex;align-items:center;gap:7px;padding:10px 14px;border-radius:var(--r-md);border:1px dashed var(--line);background:var(--panel-soft);color:var(--text-3);font-size:var(--fs-sm);font-weight:500;flex:none;max-width:200px}.pdf-chip.has{border-style:solid;border-color:var(--success);background:var(--success-bg);color:var(--success)}.pdf-chip svg{flex:none}.tag-input{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-height:42px;padding:6px 10px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface)}.tag-input:focus-within{border-color:var(--accent-ink)}.tag-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 6px 4px 10px;border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent-ink);font-size:var(--fs-sm);font-weight:500}.tag-chip button{display:inline-flex;align-items:center;border:none;background:none;color:var(--accent-ink);cursor:pointer;opacity:.7;padding:0}.tag-chip button:hover{opacity:1}.tag-input-field{flex:1;min-width:80px;border:none;outline:none;background:none;font-family:inherit;font-size:var(--fs-md);color:var(--text);padding:4px 0}.icon-picker{position:relative;flex:none}.icon-picker-btn{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);color:var(--text-3);cursor:pointer;transition:all .15s}.icon-picker-btn:hover{border-color:var(--accent-ink);color:var(--text)}.icon-picker-btn.has{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink)}.icon-pop{position:absolute;top:calc(100% + 6px);left:0;z-index:60;width:268px;padding:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-4)}.icon-pop-search{width:100%;height:34px;padding:0 10px;margin-bottom:8px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:var(--fs-sm);font-family:inherit;outline:none}.icon-pop-search:focus{border-color:var(--accent-ink)}.icon-pop-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;max-height:188px;overflow-y:auto}.icon-opt{aspect-ratio:1;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--r-sm);background:var(--panel-soft);color:var(--text-2);cursor:pointer;transition:all .12s}.icon-opt:hover{background:var(--accent-soft);color:var(--accent-ink)}.icon-opt.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.synced-stat{display:flex;align-items:center;gap:var(--sp-3);height:42px;padding:0 14px;border:1px dashed var(--line);border-radius:var(--r-md);background:var(--panel-soft)}.synced-stat strong{font-size:var(--fs-lg);font-variant-numeric:tabular-nums}.month-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--sp-2)}.month-cell{padding:9px 0;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--text-2);font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all .15s}.month-cell:hover{border-color:var(--accent-ink);color:var(--text)}.month-cell.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:600}.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-3)}.related-card{position:relative;display:flex;align-items:center;gap:var(--sp-3);padding:8px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);cursor:pointer;text-align:left;transition:all .15s}.related-card:hover:not(.disabled){border-color:var(--accent-ink)}.related-card.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.related-card.disabled{opacity:.45;cursor:not-allowed}.related-card img{width:54px;height:54px;border-radius:var(--r-sm);object-fit:cover;flex:none}.related-check{margin-left:auto;color:var(--accent-ink)}@media (max-width:560px){.month-grid{grid-template-columns:repeat(4,1fr)}}.people-picker{position:relative}.people-chips{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-height:42px;padding:6px 10px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);cursor:text}.people-add{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;border-radius:var(--r-pill);border:1px dashed var(--line);background:var(--panel-soft);color:var(--text-2);font-size:var(--fs-sm);font-weight:500;cursor:pointer}.people-add:hover{border-color:var(--accent-ink);color:var(--accent-ink)}.people-pop{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:60;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-4);padding:10px}.people-pop-list{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:2px;margin-top:8px}.pop-label{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-3);padding:6px 8px 2px}.pop-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border:none;background:none;border-radius:var(--r-sm);cursor:pointer;text-align:left;color:var(--text)}.pop-row:hover{background:var(--panel-soft)}.pop-row.on{background:var(--accent-soft);color:var(--accent-ink)}.pop-row .grow{flex:1;font-weight:500}.pop-check{width:16px;flex:none;display:inline-flex;color:var(--accent-ink)}.list-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4);margin-bottom:var(--sp-5)}.list-stat{display:flex;gap:var(--sp-3);align-items:center;padding:var(--sp-4);background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-1)}.list-stat-ico{width:40px;height:40px;flex:none;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--accent-soft);color:var(--accent-ink)}.list-stat-ico.warn{background:var(--warning-bg);color:var(--warning)}.list-stat-num{font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.1}.list-stat-label{font-size:var(--fs-sm);color:var(--text-2);font-weight:500}.list-toolbar{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-3)}.list-toolbar .toolbar-spacer{flex:1 1 auto;min-width:8px}.list-toolbar .pill-tabs{flex:none;flex-wrap:nowrap}.list-toolbar .pill-tab{white-space:nowrap}.list-toolbar .sort-wrap{width:180px;flex:none}.list-toolbar .seg{flex:none}.seg{display:inline-flex;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden}.seg-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:none;background:var(--surface);color:var(--text-3);cursor:pointer}.seg-btn.on{background:var(--accent);color:var(--accent-ink)}.setup{display:flex;align-items:center;gap:8px;min-width:96px}.setup-track{flex:1;height:6px;border-radius:var(--r-pill);background:var(--line);overflow:hidden}.setup-fill{height:100%;border-radius:var(--r-pill);transition:width .2s}.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--sp-4)}.cat-card{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);overflow:hidden;cursor:pointer;transition:box-shadow .15s,transform .15s}.cat-card:hover{box-shadow:var(--sh-3);transform:translateY(-2px)}.cat-card-img{position:relative;height:130px}.cat-card-img img{width:100%;height:100%;object-fit:cover}.cat-card-img .badge{position:absolute;top:8px;left:8px}.cat-card-body{padding:var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-3)}.pager{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:var(--sp-5)}.pager-btn,.pager-num{min-width:34px;height:34px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--text-2);font-size:var(--fs-sm);font-weight:600;cursor:pointer;transition:all .15s}.pager-btn:hover:not(:disabled),.pager-num:hover{border-color:var(--accent-ink);color:var(--text)}.pager-btn:disabled{opacity:.4;cursor:not-allowed}.pager-num.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.table-pager{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-top:var(--sp-4);flex-wrap:wrap}@media (max-width:980px){.list-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:860px){.list-toolbar{flex-wrap:wrap}.list-toolbar .toolbar-spacer{display:none}.list-toolbar .sort-wrap{width:auto;flex:1}}.img-picker{display:flex;gap:var(--sp-3);align-items:flex-start}.img-thumb{width:92px;height:70px;border-radius:var(--r-md);object-fit:cover;border:1px solid var(--line);background:var(--panel-soft);flex:none}.img-thumb.empty{display:flex;align-items:center;justify-content:center;color:var(--text-3)}.img-thumb.upload{padding:0;cursor:pointer;overflow:hidden;transition:border-color .15s}.img-thumb.upload:hover{border-color:var(--accent-ink)}.img-thumb.upload img{width:100%;height:100%;object-fit:cover}.img-thumb .upload-hint{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-3)}.img-thumb.upload:hover .upload-hint{color:var(--accent-ink)}.img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--sp-3)}.img-grid-add{aspect-ratio:4 / 3;border:2px dashed var(--line);border-radius:var(--r-md);background:var(--panel-soft);color:var(--text-3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;font-weight:600;transition:all .15s}.img-grid-add:hover{border-color:var(--accent-ink);color:var(--accent-ink);background:var(--accent-soft)}.img-grid-item{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);aspect-ratio:4 / 3;background:var(--panel-soft)}.img-grid-item img{width:100%;height:100%;object-fit:cover}.img-grid-item .rm{position:absolute;top:6px;right:6px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:var(--sp-4)}.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);padding:var(--sp-5)}.stat-num{font-size:28px;font-weight:700;letter-spacing:-.02em}.stat-label{font-size:var(--fs-sm);color:var(--text-2);margin-top:2px}.stat-ico{width:38px;height:38px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent-ink);margin-bottom:var(--sp-3)}.stat-ico svg{width:19px;height:19px}.empty{text-align:center;padding:var(--sp-12) var(--sp-6);color:var(--text-2)}.empty-ico{width:52px;height:52px;border-radius:var(--r-xl);background:var(--panel-soft);display:inline-flex;align-items:center;justify-content:center;color:var(--text-3);margin-bottom:var(--sp-4)}kbd{font-family:var(--font);font-size:var(--fs-xs);background:var(--panel-soft);border:1px solid var(--line);border-radius:6px;padding:2px 6px}.divider{height:1px;background:var(--line);border:none;margin:var(--sp-5) 0}.spinner{width:18px;height:18px;border:2px solid rgba(0,0,0,.15);border-top-color:var(--ink);border-radius:999px;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex:none;background:var(--side-bg);color:var(--side-text);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;justify-content:center;padding:16px 18px 12px;border-bottom:1px solid var(--side-line)}.sidebar-brand-logo{width:100%;max-width:132px;height:auto;object-fit:contain}.sidebar-logo{width:38px;height:38px;border-radius:11px;background:var(--accent);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;flex:none}.sidebar-brand-name{color:#fff;font-weight:700;font-size:15px;letter-spacing:-.01em}.sidebar-brand-sub{font-size:11px;color:var(--text-on-dark-2)}.sidebar-nav{flex:1;overflow-y:auto;padding:14px 12px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff24;border-color:transparent}.nav-group{margin-bottom:16px}.nav-group-title{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff57;padding:0 12px 6px}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:var(--side-text);font-size:13.5px;font-weight:500;transition:background .13s ease,color .13s ease;margin-bottom:2px}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:var(--accent);color:var(--side-text-active);font-weight:600}.nav-item svg{flex:none}.sidebar-foot{padding:12px;border-top:1px solid var(--side-line)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:12px}.avatar{width:34px;height:34px;border-radius:999px;background:var(--accent);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:none}.sidebar-user-name{color:#fff;font-size:13px;font-weight:600}.sidebar-user-mail{font-size:11px;color:var(--text-on-dark-2)}.sidebar-logout{background:none;border:none;color:var(--text-on-dark-2);cursor:pointer;padding:6px;border-radius:8px;display:inline-flex}.sidebar-logout:hover{background:#ffffff14;color:#fff}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:var(--header-h);background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 var(--sp-6);position:sticky;top:0;z-index:30}.topbar-title{font-size:16px;font-weight:600}.topbar-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-2);padding:7px 12px;border-radius:999px;border:1px solid var(--line)}.topbar-link:hover{background:var(--panel-soft);color:var(--ink)}.topbar-avatar{width:34px;height:34px;border-radius:999px;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--ink);padding:4px}.content{flex:1;padding:var(--sp-8);max-width:var(--container);width:100%;margin:0 auto}.scrim{display:none}@media (max-width: 900px){.sidebar{position:fixed;left:0;top:0;z-index:90;transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#1116;z-index:85}.hamburger{display:inline-flex}.content{padding:var(--sp-5)}}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 70% -10%,var(--accent-soft),transparent),var(--canvas)}.login-card{width:min(420px,100%);background:var(--panel);border:1px solid var(--line);border-radius:var(--r-2xl);padding:32px;box-shadow:var(--sh-4)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}.login-logo{width:44px;height:44px;border-radius:13px;background:var(--ink);color:var(--accent);display:inline-flex;align-items:center;justify-content:center}.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-3);cursor:pointer;padding:4px;display:inline-flex}.pw-toggle:hover{color:var(--ink)}.login-demo{margin-top:20px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2);background:var(--accent-soft);border-radius:10px;padding:10px 12px}
