@import"https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap";:root{--bg: oklch(.992 .002 90);--bg-elev: oklch(1 0 0);--bg-muted: oklch(.972 .003 90);--bg-sunken: oklch(.955 .004 90);--border: oklch(.91 .004 90);--border-strong: oklch(.86 .005 90);--fg: oklch(.205 .012 270);--fg-muted: oklch(.48 .01 270);--fg-subtle: oklch(.64 .008 270);--primary: oklch(.46 .165 268);--primary-hover: oklch(.41 .17 268);--primary-active: oklch(.36 .17 268);--primary-fg: oklch(.99 0 0);--primary-soft: oklch(.96 .025 268);--primary-soft-fg: oklch(.4 .16 268);--success: oklch(.55 .14 155);--success-soft: oklch(.95 .04 155);--success-soft-fg: oklch(.42 .12 155);--warning: oklch(.7 .14 75);--warning-soft: oklch(.96 .05 80);--warning-soft-fg: oklch(.5 .13 70);--danger: oklch(.58 .18 22);--danger-soft: oklch(.96 .04 22);--danger-soft-fg: oklch(.48 .16 22);--info: oklch(.6 .12 230);--info-soft: oklch(.96 .03 230);--info-soft-fg: oklch(.42 .12 230);--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-full: 9999px;--shadow-xs: 0 1px 1px rgba(20, 22, 30, .04);--shadow-sm: 0 1px 2px rgba(20, 22, 30, .06), 0 1px 1px rgba(20, 22, 30, .03);--shadow-md: 0 4px 12px -4px rgba(20, 22, 30, .08), 0 2px 4px -2px rgba(20, 22, 30, .04);--shadow-lg: 0 12px 32px -8px rgba(20, 22, 30, .12), 0 4px 8px -4px rgba(20, 22, 30, .05);--shadow-pop: 0 16px 48px -12px rgba(20, 22, 30, .2), 0 6px 16px -8px rgba(20, 22, 30, .08);--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--font-sans: "Geist", ui-sans-serif, system-ui, -apple-system, sans-serif;--font-mono: "Geist Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--t-display: 28px;--t-h1: 22px;--t-h2: 18px;--t-h3: 15px;--t-body: 14px;--t-sm: 13px;--t-xs: 12px;--t-2xs: 11px}*{box-sizing:border-box}html,body,#root{height:100%;overflow-x:hidden}body{margin:0;font-family:var(--font-sans);font-size:var(--t-body);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;text-size-adjust:100%;font-feature-settings:"cv11","ss01","ss03";letter-spacing:-.005em}button{font-family:inherit;font-size:inherit;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}::selection{background:var(--primary-soft);color:var(--primary-soft-fg)}.mono{font-family:var(--font-mono);font-feature-settings:"tnum"}.tabular{font-variant-numeric:tabular-nums}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#d9d7d4;border-radius:9999px;border:2px solid var(--bg)}*::-webkit-scrollbar-thumb:hover{background:#bfbeb9}.app{display:grid;grid-template-columns:248px 1fr;grid-template-rows:56px 1fr;grid-template-areas:"sidebar topbar" "sidebar main";height:100vh}.sidebar{grid-area:sidebar;border-right:1px solid var(--border);background:var(--bg-muted);display:flex;flex-direction:column;overflow:hidden}.topbar{grid-area:topbar;border-bottom:1px solid var(--border);background:var(--bg-elev);display:flex;align-items:center;padding:0 24px;gap:16px}.main{grid-area:main;overflow-y:auto;background:var(--bg)}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:16px 18px 14px;border-bottom:1px solid var(--border)}.brand-mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(140deg,var(--primary) 0%,oklch(.55 .18 290) 100%);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;box-shadow:0 2px 6px -2px #314db280}.brand-name{font-weight:600;font-size:14px;letter-spacing:-.01em}.brand-sub{font-size:11px;color:var(--fg-muted);margin-top:-1px}.nav{flex:1;overflow-y:auto;padding:10px 10px 16px;display:flex;flex-direction:column;gap:1px}.nav-section{font-size:11px;text-transform:uppercase;color:var(--fg-subtle);font-weight:600;letter-spacing:.06em;padding:14px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-md);color:var(--fg-muted);font-size:13.5px;font-weight:500;border:1px solid transparent;cursor:pointer;user-select:none;white-space:nowrap}.nav-item:hover{background:#e9e8e4;color:var(--fg)}.nav-item.active{background:var(--bg-elev);color:var(--fg);border-color:var(--border);box-shadow:var(--shadow-xs)}.nav-item .icon{width:16px;height:16px;flex-shrink:0}.nav-item .badge-mini{margin-left:auto;font-size:11px;padding:1px 6px;background:var(--bg-sunken);color:var(--fg-muted);border-radius:var(--r-full);font-variant-numeric:tabular-nums}.nav-item.active .badge-mini{background:var(--primary-soft);color:var(--primary-soft-fg)}.sidebar-footer{padding:10px;border-top:1px solid var(--border)}.user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-md);cursor:pointer}.user-chip:hover{background:#e9e8e4}.avatar{width:28px;height:28px;border-radius:var(--r-full);background:linear-gradient(140deg,#d18c65,#b14f42);color:#fff;display:grid;place-items:center;font-weight:600;font-size:12px;flex-shrink:0}.user-name{font-size:13px;font-weight:500}.user-mail{font-size:11px;color:var(--fg-muted)}.search-shell{display:flex;align-items:center;gap:8px;height:34px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-muted);width:360px;max-width:50%;color:var(--fg-muted);font-size:13px;cursor:pointer}.search-shell:hover{border-color:var(--border-strong)}.kbd{margin-left:auto;font-family:var(--font-mono);font-size:11px;padding:1px 6px;border:1px solid var(--border);border-bottom-width:2px;border-radius:4px;background:var(--bg-elev);color:var(--fg-muted)}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.page{padding:28px 32px 56px;max-width:1440px;margin:0 auto}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:24px}.page-title{font-size:var(--t-display);font-weight:600;letter-spacing:-.02em;margin:0}.page-sub{color:var(--fg-muted);margin:4px 0 0;font-size:14px}.page-actions{display:flex;gap:8px}.breadcrumbs{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--fg-muted);margin-bottom:6px}.breadcrumbs .sep{opacity:.5}.breadcrumbs a:hover{color:var(--fg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:34px;padding:0 14px;font-size:13px;font-weight:500;border-radius:var(--r-md);border:1px solid transparent;background:transparent;color:var(--fg);white-space:nowrap;transition:background 80ms ease,border-color 80ms ease,color 80ms ease,box-shadow 80ms ease;user-select:none}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn .icon{width:14px;height:14px}.btn-primary{background:var(--primary);color:var(--primary-fg);border-color:var(--primary);box-shadow:var(--shadow-xs),inset 0 1px #ffffff26}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-primary:active{background:var(--primary-active)}.btn-secondary{background:var(--fg);color:var(--bg-elev);border-color:var(--fg)}.btn-secondary:hover{background:#2b2e34;border-color:#2b2e34}.btn-outline{background:var(--bg-elev);color:var(--fg);border-color:var(--border);box-shadow:var(--shadow-xs)}.btn-outline:hover{background:var(--bg-muted);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--fg)}.btn-ghost:hover{background:var(--bg-muted)}.btn-destructive{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-destructive:hover{background:#b32130}.btn-sm{height:28px;padding:0 10px;font-size:12.5px}.btn-lg{height:40px;padding:0 18px;font-size:14px}.btn-icon{width:34px;padding:0}.btn-icon.btn-sm{width:28px}.btn-group{display:inline-flex}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-radius:var(--r-md) 0 0 var(--r-md)}.btn-group .btn:last-child{border-radius:0 var(--r-md) var(--r-md) 0}.btn-group .btn+.btn{border-left-width:0}.btn-group .btn-outline+.btn-outline{border-left:1px solid var(--border)}.btn .badge{margin-left:4px}.field{display:flex;flex-direction:column;gap:6px}.label{font-size:12.5px;font-weight:500;color:var(--fg)}.label .req{color:var(--danger);margin-left:2px}.help{font-size:12px;color:var(--fg-muted)}.help.error{color:var(--danger)}.input,.textarea,.select-trigger{height:34px;padding:0 12px;border:1px solid var(--border);background:var(--bg-elev);border-radius:var(--r-md);font-size:13.5px;color:var(--fg);width:100%;transition:border-color 80ms,box-shadow 80ms;outline:none}.textarea{padding:8px 12px;height:auto;min-height:80px;resize:vertical;line-height:1.5}.input::placeholder,.textarea::placeholder{color:var(--fg-subtle)}.input:hover,.textarea:hover,.select-trigger:hover{border-color:var(--border-strong)}.input:focus,.textarea:focus,.select-trigger:focus{border-color:var(--primary);box-shadow:0 0 0 3px #314db226}.input:disabled,.textarea:disabled{background:var(--bg-muted);color:var(--fg-muted);cursor:not-allowed}.input.error,.textarea.error,.select-trigger.error{border-color:var(--danger)}.input.error:focus{box-shadow:0 0 0 3px #cf404726}.input-group{position:relative;display:flex;align-items:center}.input-group .input{padding-left:34px}.input-group .input.with-suffix{padding-right:56px;padding-left:12px}.input-group .input.with-prefix-text{padding-left:36px}.input-group .lead-icon,.input-group .trail-icon{position:absolute;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--fg-subtle);pointer-events:none}.input-group .lead-icon{left:10px}.input-group .trail-icon{right:10px}.input-group .suffix-text{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--fg-muted);font-family:var(--font-mono)}.input-group .prefix-text{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--fg-muted);font-family:var(--font-mono)}.checkbox,.radio{appearance:none;width:16px;height:16px;border:1.5px solid var(--border-strong);background:var(--bg-elev);border-radius:4px;display:inline-grid;place-items:center;cursor:pointer;flex-shrink:0;transition:background 80ms,border-color 80ms}.radio{border-radius:var(--r-full)}.checkbox:checked,.radio:checked{background:var(--primary);border-color:var(--primary)}.checkbox:checked:after{content:"";width:8px;height:4px;border-left:1.5px solid white;border-bottom:1.5px solid white;transform:rotate(-45deg) translateY(-1px)}.radio:checked:after{content:"";width:6px;height:6px;background:#fff;border-radius:var(--r-full)}.checkbox:focus-visible,.radio:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.check-row{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13.5px}.check-row .desc{color:var(--fg-muted);font-size:12px}.switch{position:relative;width:51px;height:31px;border-radius:var(--r-full);background:#b8b7b4;border:0;padding:0;transition:background .22s ease;cursor:pointer;flex-shrink:0;outline:none}.switch:focus-visible{box-shadow:0 0 0 3px #314db259}.switch:after{content:"";position:absolute;left:2px;top:2px;width:27px;height:27px;background:#fff;border-radius:50%;transition:transform .22s cubic-bezier(.34,1.26,.64,1),width .12s ease;box-shadow:0 2px 6px #00000038,0 1px 2px #0000001f}.switch:active:after{width:30px}.switch.on{background:var(--primary)}.switch.on:after{transform:translate(20px)}.switch.on:active:after{transform:translate(17px);width:30px}[data-theme=dark] .switch{background:#393a3f}.toggle-pill{display:inline-flex;align-items:center;gap:4px;padding:3px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--r-md)}.toggle-pill button{background:transparent;border:0;padding:5px 10px;font-size:12.5px;font-weight:500;color:var(--fg-muted);border-radius:var(--r-sm)}.toggle-pill button.on{background:var(--bg-elev);color:var(--fg);box-shadow:var(--shadow-xs)}.slider{-webkit-appearance:none;width:100%;height:4px;background:var(--border-strong);border-radius:var(--r-full);outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:var(--r-full);background:#fff;border:2px solid var(--primary);cursor:pointer;box-shadow:var(--shadow-sm)}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--r-lg);padding:24px;background:var(--bg-muted);text-align:center;color:var(--fg-muted);cursor:pointer;transition:border-color 80ms,background 80ms}.dropzone:hover{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-soft-fg)}.dropzone.lg{padding:40px 24px}.dropzone .dz-title{font-weight:500;color:var(--fg);margin-bottom:4px;font-size:14px}.dropzone .dz-hint{font-size:12px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs)}.card-pad{padding:18px}.card-pad-lg{padding:24px}.card-head{padding:14px 18px;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;margin:0}.card-sub{font-size:12.5px;color:var(--fg-muted);margin:2px 0 0}.card-body{padding:18px}.card-foot{padding:12px 18px;border-top:1px solid var(--border);background:var(--bg-muted);border-radius:0 0 var(--r-lg) var(--r-lg);display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12.5px}.detail-split-grid{align-items:start}.data-list{display:flex;flex-direction:column}.data-list-row{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr) auto;align-items:center;gap:14px;padding:10px 0}.data-list-row+.data-list-row{border-top:1px solid var(--border)}.data-list-main{font-size:13px;font-weight:500;line-height:1.35}.data-list-meta{font-size:12px;color:var(--fg-muted);line-height:1.35}.data-list-value{min-width:90px;text-align:right;font-weight:500;white-space:nowrap}.meter-list{display:flex;flex-direction:column;gap:12px}.meter-row-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}.meter-row-title{font-size:13px;font-weight:500}.meter-row-meta{margin-top:4px;font-size:11.5px;color:var(--fg-muted);line-height:1.4}.kpi{padding:18px;display:flex;flex-direction:column;gap:6px}.kpi .kpi-label{font-size:12.5px;color:var(--fg-muted);font-weight:500}.kpi .kpi-value{font-size:26px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi .kpi-foot{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--fg-muted)}.kpi .delta-up{color:var(--success-soft-fg);font-weight:500}.kpi .delta-down{color:var(--danger-soft-fg);font-weight:500}.badge{display:inline-flex;align-items:center;gap:4px;height:20px;padding:0 7px;border-radius:var(--r-full);font-size:11.5px;font-weight:500;background:var(--bg-sunken);color:var(--fg-muted);border:1px solid var(--border);white-space:nowrap}.badge .dot{width:5px;height:5px;border-radius:var(--r-full);background:currentColor}.badge.success{background:var(--success-soft);color:var(--success-soft-fg);border-color:#b0dabd}.badge.warning{background:var(--warning-soft);color:var(--warning-soft-fg);border-color:#e9cca6}.badge.danger{background:var(--danger-soft);color:var(--danger-soft-fg);border-color:#f6c2bf}.badge.info{background:var(--info-soft);color:var(--info-soft-fg);border-color:#b0d8ec}.badge.primary{background:var(--primary-soft);color:var(--primary-soft-fg);border-color:#c0d0f9}.badge.solid-dark{background:var(--fg);color:var(--bg-elev);border-color:var(--fg)}.badge.lg{height:24px;padding:0 10px;font-size:12px}.table-wrap{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.table-toolbar{padding:12px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);background:var(--bg-muted)}.table{width:100%;border-collapse:separate;border-spacing:0}.table th,.table td{text-align:left;padding:11px 16px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}.table th{font-weight:500;color:var(--fg-muted);font-size:12px;background:var(--bg-muted);border-bottom-color:var(--border);text-transform:none;letter-spacing:0;white-space:nowrap}.table th .sort{display:inline-flex;align-items:center;gap:4px;cursor:pointer}.table tbody tr:hover{background:var(--bg-muted)}.table tbody tr:last-child td{border-bottom:0}.table tr.selected{background:var(--primary-soft)}.table .num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-mono);font-size:12.5px}.table .actions-cell{text-align:right;white-space:nowrap}.empty{padding:56px 20px;text-align:center;color:var(--fg-muted)}.empty .empty-icon{width:44px;height:44px;border-radius:12px;background:var(--bg-muted);border:1px solid var(--border);display:inline-grid;place-items:center;margin-bottom:14px;color:var(--fg-subtle)}.empty .empty-title{font-weight:600;color:var(--fg);margin-bottom:4px}.pagination{display:flex;align-items:center;gap:12px;padding:10px 14px;border-top:1px solid var(--border);background:var(--bg-muted);font-size:12.5px;color:var(--fg-muted)}.pagination .pages{margin-left:auto;display:flex;gap:4px}.page-btn{min-width:28px;height:28px;padding:0 8px;border:1px solid var(--border);background:var(--bg-elev);border-radius:var(--r-sm);font-size:12.5px;font-variant-numeric:tabular-nums;display:inline-grid;place-items:center;cursor:pointer}.page-btn:hover{background:var(--bg-muted)}.page-btn.active{background:var(--fg);color:var(--bg-elev);border-color:var(--fg)}.maintenance-mobile-list{display:none}.maintenance-ticket-card{display:flex;flex-direction:column;gap:12px}.maintenance-ticket-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.maintenance-ticket-title{font-weight:600;font-size:15px;line-height:1.25}.maintenance-ticket-sub{color:var(--fg-muted);font-size:12.5px;margin-top:4px}.maintenance-ticket-meta{display:flex;flex-wrap:wrap;gap:8px 12px;color:var(--fg-muted);font-size:12px}.maintenance-ticket-meta span{display:inline-flex;align-items:center;gap:6px}.maintenance-ticket-badges{display:flex;flex-wrap:wrap;gap:8px}.maintenance-ticket-description{color:var(--fg);font-size:13px;line-height:1.45}.tabs{display:flex;align-items:center;gap:4px;border-bottom:1px solid var(--border)}.tabs .tab{position:relative;padding:9px 14px;font-size:13.5px;font-weight:500;color:var(--fg-muted);cursor:pointer;border:0;background:transparent}.tabs .tab:hover,.tabs .tab.active{color:var(--fg)}.tabs .tab.active:after{content:"";position:absolute;left:8px;right:8px;bottom:-1px;height:2px;background:var(--fg);border-radius:2px 2px 0 0}.tabs .tab .badge{margin-left:6px}.alert{display:flex;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-elev);font-size:13px}.alert .alert-icon{flex-shrink:0;width:18px;height:18px;margin-top:1px;color:var(--fg-muted)}.alert .alert-title{font-weight:600;margin-bottom:2px}.alert .alert-body{color:var(--fg-muted)}.alert.success{background:var(--success-soft);border-color:#b3ddc0}.alert.success .alert-icon{color:var(--success-soft-fg)}.alert.warning{background:var(--warning-soft);border-color:#e9cca6}.alert.warning .alert-icon{color:var(--warning-soft-fg)}.alert.danger{background:var(--danger-soft);border-color:#f6c2bf}.alert.danger .alert-icon{color:var(--danger-soft-fg)}.alert.info{background:var(--info-soft);border-color:#b0d8ec}.alert.info .alert-icon{color:var(--info-soft-fg)}.toast{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;background:var(--fg);color:var(--bg-elev);border-radius:var(--r-md);box-shadow:var(--shadow-pop);width:340px}.toast .toast-title{font-weight:600;font-size:13px}.toast .toast-body{font-size:12.5px;opacity:.8;margin-top:2px}.tooltip{background:var(--fg);color:var(--bg-elev);font-size:12px;padding:4px 8px;border-radius:var(--r-sm);box-shadow:var(--shadow-md);display:inline-block}.popover{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:6px;min-width:200px}.menu-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-sm);font-size:13px;cursor:pointer;color:var(--fg)}.menu-item:hover{background:var(--bg-muted)}.menu-item.danger{color:var(--danger-soft-fg)}.menu-item .icon{width:14px;height:14px;color:var(--fg-muted)}.menu-sep{height:1px;background:var(--border);margin:4px 0}.menu-label{font-size:11px;text-transform:uppercase;color:var(--fg-subtle);padding:8px 10px 4px;font-weight:600;letter-spacing:.04em}.scrim{position:fixed;inset:0;background:#0f111773;backdrop-filter:blur(2px);display:grid;place-items:center;z-index:80;animation:fade .12s ease}@keyframes fade{0%{opacity:0}}.modal{background:var(--bg-elev);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);width:480px;max-width:calc(100vw - 32px);border:1px solid var(--border);animation:pop .18s cubic-bezier(.2,.8,.2,1)}@keyframes pop{0%{transform:translateY(8px);opacity:0}}.modal.lg{width:640px}.modal-head{padding:18px 20px 8px}.modal-title{font-size:16px;font-weight:600;margin:0}.modal-sub{font-size:13px;color:var(--fg-muted);margin:4px 0 0}.modal-body{padding:14px 20px 20px}.modal-foot{padding:14px 20px;border-top:1px solid var(--border);background:var(--bg-muted);border-radius:0 0 var(--r-lg) var(--r-lg);display:flex;justify-content:flex-end;gap:8px}.drawer{position:fixed;right:0;top:0;bottom:0;width:460px;max-width:calc(100vw - 60px);background:var(--bg-elev);border-left:1px solid var(--border);box-shadow:var(--shadow-pop);display:flex;flex-direction:column;animation:slidein .18s cubic-bezier(.2,.8,.2,1)}@keyframes slidein{0%{transform:translate(20px);opacity:0}}.drawer-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.notification-panel{position:fixed;top:68px;right:20px;width:min(420px,calc(100vw - 32px));max-height:min(72vh,760px);background:var(--bg-elev);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-pop);z-index:85;overflow:hidden;display:flex;flex-direction:column;animation:pop .18s cubic-bezier(.2,.8,.2,1)}.notification-panel-head{padding:16px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.notification-panel-sub{margin-top:4px;font-size:12px;color:var(--fg-muted)}.notification-panel-body{flex:1;overflow-y:auto}.notification-row{display:flex;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);cursor:pointer}.notification-panel-foot{padding:12px 18px;border-top:1px solid var(--border);background:var(--bg-muted);display:flex;gap:8px;flex-wrap:wrap;align-items:center}.notification-panel-foot .btn{flex:1 1 160px;min-width:0;justify-content:center}.progress{height:6px;background:var(--bg-sunken);border-radius:var(--r-full);overflow:hidden}.progress>.bar{height:100%;background:var(--primary);border-radius:var(--r-full);transition:width .24s ease}.progress.success>.bar{background:var(--success)}.progress.warning>.bar{background:var(--warning)}.skeleton{background:linear-gradient(90deg,var(--bg-sunken) 0%,var(--bg-muted) 50%,var(--bg-sunken) 100%);background-size:200% 100%;animation:shimmer 1.4s linear infinite;border-radius:var(--r-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:var(--r-full);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stepper{display:flex;align-items:center;gap:0}.stepper .step{display:flex;align-items:center;gap:10px;padding:6px 10px;color:var(--fg-muted);font-size:13px;font-weight:500}.stepper .step .num{width:22px;height:22px;border-radius:var(--r-full);background:var(--bg-sunken);color:var(--fg-muted);display:grid;place-items:center;font-size:11px;font-weight:600;border:1px solid var(--border)}.stepper .step.active{color:var(--fg)}.stepper .step.active .num{background:var(--primary);color:#fff;border-color:var(--primary)}.stepper .step.done{color:var(--fg)}.stepper .step.done .num{background:var(--fg);color:var(--bg-elev);border-color:var(--fg)}.stepper .conn{flex:1;height:1px;background:var(--border);min-width:24px}.divider{height:1px;background:var(--border);margin:16px 0}.kv{display:grid;grid-template-columns:140px 1fr;row-gap:10px;column-gap:16px;font-size:13px}.kv dt{color:var(--fg-muted)}.kv dd{margin:0;color:var(--fg)}.grid{display:grid;gap:16px}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 1100px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 720px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.placeholder-img{background:repeating-linear-gradient(135deg,transparent 0 9px,oklch(.92 .005 90) 9px 10px),var(--bg-muted);border:1px solid var(--border);border-radius:var(--r-md);display:grid;place-items:center;color:var(--fg-muted);font-family:var(--font-mono);font-size:11px}.timeline{list-style:none;padding:0;margin:0}.timeline li{position:relative;padding:0 0 18px 26px}.timeline li:before{content:"";position:absolute;left:7px;top:6px;bottom:-4px;width:1px;background:var(--border)}.timeline li:last-child:before{display:none}.timeline .tl-dot{position:absolute;left:2px;top:4px;width:12px;height:12px;border-radius:var(--r-full);background:var(--bg-elev);border:2px solid var(--border-strong)}.timeline .tl-dot.primary{border-color:var(--primary)}.timeline .tl-dot.success{border-color:var(--success)}.timeline .tl-dot.warning{border-color:var(--warning)}.timeline .tl-time{font-size:11.5px;color:var(--fg-muted);margin-top:2px}.lib-section{margin-bottom:56px}.lib-section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:4px;padding-bottom:6px}.lib-section-num{font-family:var(--font-mono);color:var(--fg-subtle);font-size:12px;font-weight:500}.lib-section-title{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0}.lib-section-sub{color:var(--fg-muted);font-size:13.5px;margin:0 0 16px}.demo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.demo-grid.wide{grid-template-columns:repeat(auto-fill,minmax(360px,1fr))}.demo-grid.full{grid-template-columns:1fr}.demo{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-xs)}.demo-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-subtle);font-weight:600;margin:0 0 12px}.demo-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.demo-col{display:flex;flex-direction:column;gap:10px}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:160px}.bar-chart .bar-grp{flex:1;display:flex;gap:3px;align-items:flex-end;height:100%}.bar-chart .bar{flex:1;min-width:6px;background:var(--primary);border-radius:3px 3px 0 0;position:relative}.bar-chart .bar.alt{background:#a7b7df}.line-chart{position:relative;height:200px;border:1px solid var(--border);border-radius:var(--r-md);background:linear-gradient(to top,var(--border) 1px,transparent 1px) 0 0/100% 25% repeat-y,var(--bg-elev)}.line-chart svg{width:100%;height:100%;display:block}.objekt-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;cursor:pointer;transition:border-color 80ms,box-shadow 80ms,transform 80ms}.objekt-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.objekt-card .img-area{height:140px;background:repeating-linear-gradient(135deg,transparent 0 9px,oklch(.92 .005 90) 9px 10px),var(--bg-muted);display:grid;place-items:center;color:var(--fg-muted);font-family:var(--font-mono);font-size:11px;border-bottom:1px solid var(--border);position:relative}.objekt-card .img-area .pin{position:absolute;top:10px;left:10px}.objekt-card .body{padding:14px 16px 16px}.objekt-card .name{font-weight:600;font-size:14px;margin:0 0 2px}.objekt-card .addr{font-size:12.5px;color:var(--fg-muted);margin:0}.objekt-card .stats{display:flex;gap:14px;margin-top:12px;font-size:12px}.objekt-card .stats .stat .v{font-weight:600;font-size:13.5px;color:var(--fg)}.objekt-card .stats .stat .l{color:var(--fg-muted)}.split{display:grid;grid-template-columns:1fr 320px;gap:20px}@media (max-width: 1100px){.split{grid-template-columns:1fr}}.swatch{width:100%;height:56px;border-radius:var(--r-md);border:1px solid var(--border)}[data-theme=dark]{--bg: oklch(.165 .01 270);--bg-elev: oklch(.205 .011 270);--bg-muted: oklch(.19 .011 270);--bg-sunken: oklch(.15 .01 270);--border: oklch(.29 .011 270);--border-strong: oklch(.36 .012 270);--fg: oklch(.965 .005 90);--fg-muted: oklch(.7 .01 270);--fg-subtle: oklch(.56 .01 270);--primary: oklch(.7 .18 268);--primary-hover: oklch(.76 .18 268);--primary-active: oklch(.65 .18 268);--primary-fg: oklch(.12 .02 270);--primary-soft: oklch(.3 .1 268);--primary-soft-fg: oklch(.85 .08 268);--success-soft: oklch(.3 .08 155);--success-soft-fg: oklch(.85 .1 155);--warning-soft: oklch(.32 .1 75);--warning-soft-fg: oklch(.88 .13 80);--danger-soft: oklch(.32 .12 22);--danger-soft-fg: oklch(.86 .12 22);--info-soft: oklch(.3 .08 230);--info-soft-fg: oklch(.85 .1 230);--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow-md: 0 4px 12px -4px rgba(0,0,0,.5), 0 2px 4px -2px rgba(0,0,0,.3);--shadow-lg: 0 12px 32px -8px rgba(0,0,0,.55), 0 4px 8px -4px rgba(0,0,0,.3);--shadow-pop: 0 16px 48px -12px rgba(0,0,0,.6), 0 6px 16px -8px rgba(0,0,0,.35)}[data-theme=dark] *::-webkit-scrollbar-thumb{background:#313339;border-color:var(--bg)}[data-theme=dark] .objekt-card .img-area,[data-theme=dark] .dropzone{background-image:repeating-linear-gradient(135deg,#191a20 0 8px,#14161b 8px 16px)}[data-density=kompakt]{--t-body: 13px;--t-sm: 12px;--s-4: 12px;--s-5: 14px;--s-6: 18px}[data-density=kompakt] .table tbody td,[data-density=kompakt] .table thead th{padding:8px 12px}[data-density=kompakt] .card-head,[data-density=kompakt] .card-body{padding:12px 14px}[data-density=kompakt] .nav-item{padding:6px 10px}[data-density=weit] .table tbody td,[data-density=weit] .table thead th{padding:16px 18px}[data-density=weit] .card-head,[data-density=weit] .card-body{padding:22px 24px}[data-accent=emerald]{--primary: oklch(.55 .14 155);--primary-hover: oklch(.5 .15 155);--primary-active: oklch(.45 .15 155);--primary-soft: oklch(.96 .04 155);--primary-soft-fg: oklch(.42 .13 155)}[data-accent=amber]{--primary: oklch(.65 .16 60);--primary-hover: oklch(.6 .17 60);--primary-active: oklch(.55 .17 60);--primary-soft: oklch(.96 .05 60);--primary-soft-fg: oklch(.45 .15 60)}[data-accent=rose]{--primary: oklch(.58 .18 22);--primary-hover: oklch(.53 .19 22);--primary-active: oklch(.48 .19 22);--primary-soft: oklch(.96 .04 22);--primary-soft-fg: oklch(.46 .16 22)}[data-theme=dark][data-accent=emerald]{--primary: oklch(.78 .16 155);--primary-fg: oklch(.15 .05 155);--primary-soft: oklch(.3 .08 155);--primary-soft-fg: oklch(.85 .1 155)}[data-theme=dark][data-accent=amber]{--primary: oklch(.82 .16 70);--primary-fg: oklch(.18 .06 60);--primary-soft: oklch(.32 .1 70);--primary-soft-fg: oklch(.88 .12 70)}[data-theme=dark][data-accent=rose]{--primary: oklch(.74 .18 22);--primary-fg: oklch(.15 .05 22);--primary-soft: oklch(.32 .12 22);--primary-soft-fg: oklch(.86 .13 22)}.mobile-only,.dashboard-payments-mobile,.wohnungen-mobile-list,.kalender-mobile-agenda,.mobile-section-switch{display:none}.mobile-scrim{position:fixed;inset:0;background:#14161e73;z-index:49;opacity:0;pointer-events:none;transition:opacity .18s ease}.mobile-scrim.open{opacity:1;pointer-events:auto}@media (max-width: 880px){.app{position:relative;width:100%;max-width:100vw;overflow-x:clip;grid-template-columns:1fr;grid-template-rows:56px 1fr;grid-template-areas:"topbar" "main"}.sidebar{grid-area:unset;position:fixed!important;inset:0 auto 0 0;width:min(360px,calc(100vw - 24px));max-width:calc(100vw - 24px);min-width:0;height:100dvh;z-index:50;margin:0!important;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;transform:translate3d(calc(-100% - 16px),0,0);transition:transform .24s cubic-bezier(.2,.8,.2,1);box-shadow:var(--shadow-pop);will-change:transform}.sidebar.open{transform:translateZ(0)}.sidebar-collapse-bar{display:none}[data-sidebar=collapsed] .sidebar{width:min(360px,calc(100vw - 24px));max-width:calc(100vw - 24px)}[data-sidebar=collapsed] .sidebar .brand-name,[data-sidebar=collapsed] .sidebar .brand-sub,[data-sidebar=collapsed] .sidebar .nav-item span:not(.icon):not(.badge-mini),[data-sidebar=collapsed] .sidebar .badge-mini,[data-sidebar=collapsed] .sidebar .user-name,[data-sidebar=collapsed] .sidebar .user-mail,[data-sidebar=collapsed] .sidebar .user-chip>svg{display:initial}[data-sidebar=collapsed] .sidebar .sidebar-brand{justify-content:flex-start;padding:16px 18px 14px}[data-sidebar=collapsed] .sidebar .nav{padding:10px 10px 16px}[data-sidebar=collapsed] .sidebar .nav-item{justify-content:flex-start;padding:10px 12px}[data-sidebar=collapsed] .sidebar .nav-section{height:auto;margin:0;padding:14px 10px 6px;border-top:0;font-size:11px;overflow:visible;letter-spacing:.06em}[data-sidebar=collapsed] .sidebar .nav>.nav-section:first-child{display:block}.sidebar-mobile-close{display:flex!important;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;cursor:pointer;color:var(--fg-muted);border-radius:var(--r-sm);flex-shrink:0}.sidebar-mobile-close:hover{background:var(--bg-sunken);color:var(--fg)}.sidebar-desktop-chevron{display:none!important}.nav-item{padding:10px 12px;min-height:44px;font-size:14px}.topbar{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;padding:8px 10px;gap:6px;min-height:64px;position:sticky;top:0;z-index:24;background:color-mix(in srgb,var(--bg-elev) 96%,white 4%);box-shadow:0 10px 24px -22px #14161e47}.mobile-only{display:inline-flex!important;flex-shrink:0;margin-left:6px}.mobile-only.btn{width:38px;height:38px;border-radius:12px}.topbar-breadcrumb,.topbar-brand-prefix,.topbar-brand-sep{display:none!important}.topbar-breadcrumb>span:last-child{font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.topbar .search-shell{display:flex!important;flex:1;min-width:0;max-width:none;width:auto;height:40px;margin-left:2px!important;padding:0 12px;gap:8px;border-radius:16px;background:var(--bg-elev);border-color:var(--border);box-shadow:var(--shadow-xs)}.input,.textarea,.select-trigger,.cmdk-input{font-size:16px!important}.topbar-search-text{flex:1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:13px}.topbar .kbd,.topbar-help-btn,.topbar-sep,.topbar-new-btn{display:none!important}.topbar-actions{margin-left:0;gap:2px;flex-shrink:0}.topbar-actions .btn{width:34px;height:34px;padding:0;border-radius:10px}.page{padding:16px 14px 72px!important}.page,.page-inner{max-width:100%;overflow-x:clip}.page>*,.page-inner>*,.grid>*,.card,.card-head>div,.card-body>*{min-width:0}.page-head{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}.page-title{font-size:19px!important;letter-spacing:-.015em;line-height:1.1}.page-sub{font-size:12.5px}.page-actions{width:100%;flex-wrap:wrap;gap:8px}.page-actions .btn-outline:not([data-keep]){display:none}.page-actions .btn-primary{display:inline-flex!important}.breadcrumbs{font-size:12px;gap:4px}.grid{grid-template-columns:1fr!important;gap:12px!important}.grid.grid-2,.grid.grid-3{grid-template-columns:1fr!important}.grid.grid-4{grid-template-columns:1fr 1fr!important;gap:10px!important}.grid.mobile-keep-two{grid-template-columns:1fr 1fr!important}.demo-grid,.demo-grid.wide,.dashboard-main-grid,.kalender-main-grid{grid-template-columns:1fr!important}.dashboard-kpi-grid{margin-bottom:16px!important}.kpi{padding:14px}.kpi .kpi-value{font-size:22px!important}.kpi .kpi-label{font-size:11.5px}.kpi .kpi-foot{font-size:11px}.card-body{padding:14px!important}.card-head{padding:12px 14px!important}.card-pad{padding:14px!important}.card-pad-lg{padding:16px!important}.table-wrap{max-width:100%;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y}.table{min-width:520px}.table .btn-group{flex-wrap:nowrap}.table .btn-group .btn{white-space:nowrap}.table th,.table td{padding:10px 12px;font-size:12.5px}.table-toolbar{flex-direction:column;gap:8px;padding:10px 12px}.table-toolbar>div,.table-toolbar .input-group,.table-toolbar>button{width:100%}.mobile-stack-row{display:flex;flex-direction:column;align-items:stretch!important;gap:8px!important;width:100%}.mobile-stack-row>*{width:100%!important;min-width:0;margin-left:0!important;max-width:none!important}.mobile-stack-row .toggle-pill,.mobile-stack-row [style*="marginLeft: 'auto'"],.mobile-stack-row .select-trigger,.mobile-section-switch .select-trigger{width:100%}.mobile-section-switch{display:block;margin-bottom:14px}.mobile-section-switch+.page-head{margin-top:0}.mobile-card-table{border-top:1px solid var(--border);border-radius:0 0 var(--r-lg) var(--r-lg)}.maintenance-desktop-table{display:none}.maintenance-mobile-list{display:flex;flex-direction:column;gap:12px}.maintenance-mobile-list .card-body{padding:14px!important}.card-head{flex-direction:column;align-items:flex-start}.card-head>div:last-child{width:100%}.page-actions .toggle-pill,.card-head .toggle-pill{width:100%}.page-actions .toggle-pill button,.card-head .toggle-pill button{flex:1;min-width:0}.card>.table,.card-body>.table,.modal-body .table,.drawer .table{display:block;width:100%;overflow-x:auto;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch}.pagination{font-size:12px;padding:8px 12px}.page-btn{min-width:28px;height:28px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;flex-shrink:0;padding:10px 14px}.modal{max-width:calc(100vw - 24px)!important}.modal-body{max-height:60vh;overflow-y:auto}.modal-foot{flex-wrap:wrap;gap:8px}.scrim{align-items:flex-end;padding:0}.drawer{width:100%!important;max-width:100%!important;border-radius:20px 20px 0 0!important;max-height:92vh}.split,.page-with-aside{grid-template-columns:1fr!important}.page-with-aside>aside{display:none!important}.page-with-aside .page-inner{padding:16px 14px!important;overflow-y:auto}.dashboard-main-column,.dashboard-side-column{gap:16px!important}.dashboard-chart-card .card-head>:last-child,.dashboard-payments-card .card-head>:last-child,.dashboard-chart-card .toggle-pill{width:100%}.dashboard-chart-card .toggle-pill button{flex:1;min-width:0}.dashboard-chart-body{padding:14px!important}.dashboard-chart-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding-bottom:4px;margin:0 -2px;overscroll-behavior-x:contain}.dashboard-chart-scroll>div{min-width:540px}.dashboard-chart-legend{flex-wrap:wrap;gap:10px!important}.dashboard-chart-labels{font-size:10px!important;gap:8px}.dashboard-chart-labels span{min-width:0;text-align:center}.notification-panel{position:fixed;top:calc(env(safe-area-inset-top,0px) + 78px);right:12px;left:12px;width:auto;max-height:calc(100dvh - env(safe-area-inset-top,0px) - 94px)}.notification-panel-foot{flex-direction:column;align-items:stretch}.notification-panel-foot .btn{width:100%;flex:0 0 auto}.dashboard-payments-desktop,.wohnungen-desktop-table,.kalender-desktop-month{display:none}.dashboard-payments-mobile,.wohnungen-mobile-list,.kalender-mobile-agenda{display:block}.dashboard-payments-mobile,.wohnungen-mobile-list{padding:14px}.kalender-mobile-agenda .card-body{padding:8px 16px!important}.kalender-main-grid>div:last-child{order:-1}.wohnungen-count{width:100%;margin-left:0!important}.mobile-data-card{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-elev);padding:14px}.mobile-data-card+.mobile-data-card{margin-top:12px}.mobile-nav-card{cursor:pointer}.mobile-data-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.mobile-data-card-title{font-size:15px;font-weight:600;line-height:1.2}.mobile-data-card-sub{margin-top:4px;font-size:12px;color:var(--fg-muted);line-height:1.4}.mobile-data-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px}.mobile-data-card-grid span{display:block;margin-bottom:4px;font-size:11px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.04em}.mobile-data-card-grid strong{display:block;font-size:14px;font-weight:600;line-height:1.35}.data-list-row{grid-template-columns:1fr;gap:6px;align-items:flex-start}.data-list-main,.data-list-meta,.data-list-value{min-width:0;text-align:left}.data-list-meta{font-size:11.5px}.data-list-value{font-size:15px}.meter-row-head{align-items:flex-start}.meter-row-title{font-size:14px}.toggle-pill{flex-wrap:wrap}.toggle-pill button{flex:1;min-width:56px;font-size:12.5px}.stepper{gap:0}.stepper .step{font-size:11.5px;padding:4px 8px}.stepper .step .num{width:20px;height:20px;font-size:10px}.stepper .conn{min-width:12px}.bar-chart{height:124px;gap:5px}.bar-chart .bar-grp{gap:2px}.vorlagen-grid{grid-template-columns:1fr!important}.kv{grid-template-columns:110px 1fr;font-size:12.5px}.main{overflow-x:hidden;padding-bottom:0}.tweaks-fab,.tweaks-panel{display:none!important}.objekt-card .img-area{height:120px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}}.nav-mobile-close,.sidebar-mobile-close{display:none}.sidebar-desktop-chevron{display:inline-block}.cmdk-overlay{position:fixed;inset:0;z-index:70;display:grid;place-items:start center;padding-top:12vh;background:#14161e6b;backdrop-filter:blur(2px);animation:fade-in .14s ease}[data-theme=dark] .cmdk-overlay{background:#0000008c}.cmdk{width:min(640px,calc(100vw - 28px));background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-pop);overflow:hidden;animation:pop-in .18s cubic-bezier(.16,1,.3,1)}.cmdk-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.cmdk-input-row svg{color:var(--fg-muted)}.cmdk-input{flex:1;border:0;outline:0;background:transparent;font-size:14.5px;color:var(--fg)}.cmdk-input::placeholder{color:var(--fg-subtle)}.cmdk-list{max-height:60vh;overflow-y:auto;padding:6px}.cmdk-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13.5px}.cmdk-item .ic{width:28px;height:28px;border-radius:6px;background:var(--bg-muted);display:grid;place-items:center;color:var(--fg-muted);flex-shrink:0}.cmdk-item .meta{flex:1;min-width:0}.cmdk-item .t{font-weight:500;color:var(--fg)}.cmdk-item .s{font-size:12px;color:var(--fg-muted)}.cmdk-item.active{background:var(--primary-soft)}.cmdk-item.active .ic{background:var(--primary);color:var(--primary-fg)}.cmdk-empty{padding:32px 16px;text-align:center;color:var(--fg-muted);font-size:13px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pop-in{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:none}}.tweaks-fab{position:fixed;bottom:22px;right:22px;z-index:55;width:44px;height:44px;border-radius:50%;background:var(--fg);color:var(--bg);display:grid;place-items:center;border:0;box-shadow:var(--shadow-lg);transition:transform .15s ease}.tweaks-fab:hover{transform:scale(1.06)}.tweaks-panel{position:fixed;bottom:22px;right:22px;width:300px;background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-pop);z-index:60;overflow:hidden;animation:pop-in .18s cubic-bezier(.16,1,.3,1)}.tweaks-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.tweaks-head h3{margin:0;font-size:14px;font-weight:600}.tweaks-body{padding:14px 16px;display:flex;flex-direction:column;gap:16px}.tweaks-row .tweaks-label{font-size:12px;color:var(--fg-muted);margin-bottom:8px;font-weight:500}.swatch-row{display:flex;gap:8px}.swatch-btn{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .12s ease}.swatch-btn.active{border-color:var(--fg);transform:scale(1.06)}.swatch-btn:hover{transform:scale(1.06)}.seg-row{display:flex;gap:4px;padding:3px;background:var(--bg-muted);border-radius:8px;border:1px solid var(--border)}.seg-btn{flex:1;padding:6px 8px;border:0;background:transparent;color:var(--fg-muted);border-radius:6px;font-size:12px;font-weight:500}.seg-btn.active{background:var(--bg-elev);color:var(--fg);box-shadow:var(--shadow-xs)}.timeline-large li{padding:10px 0 10px 24px;border-left:2px solid var(--border);position:relative;margin-left:8px}.timeline-large li:before{content:"";position:absolute;left:-7px;top:14px;width:12px;height:12px;border-radius:50%;background:var(--bg-elev);border:2px solid var(--primary)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.gallery-tile{aspect-ratio:4 / 3;border-radius:10px;border:1px solid var(--border);background-image:repeating-linear-gradient(45deg,var(--bg-muted) 0 10px,var(--bg-sunken) 10px 20px);display:grid;place-items:center;color:var(--fg-subtle);font-family:var(--font-mono);font-size:11px}.gallery-tile.add{border-style:dashed;cursor:pointer}.sidebar{position:relative;transition:width .22s ease}.sidebar-collapse-bar{display:flex;align-items:center;justify-content:flex-end;padding:8px 12px;border-top:1px solid var(--border)}.sidebar-collapse-btn{width:28px;height:28px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;display:grid;place-items:center;color:var(--fg-muted);box-shadow:var(--shadow-xs);cursor:pointer;transition:background .12s ease,color .12s ease}.sidebar-collapse-btn:hover{color:var(--fg);background:var(--bg-muted)}.sidebar-collapse-btn svg{transition:transform .22s ease}[data-sidebar=collapsed] .sidebar-collapse-btn svg{transform:rotate(180deg)}[data-sidebar=collapsed] .app{grid-template-columns:56px 1fr}[data-sidebar=collapsed] .sidebar .brand-name,[data-sidebar=collapsed] .sidebar .brand-sub,[data-sidebar=collapsed] .sidebar .nav-item span:not(.icon):not(.badge-mini),[data-sidebar=collapsed] .sidebar .badge-mini,[data-sidebar=collapsed] .sidebar .user-name,[data-sidebar=collapsed] .sidebar .user-mail,[data-sidebar=collapsed] .sidebar .user-chip>svg{display:none}[data-sidebar=collapsed] .sidebar .sidebar-brand{justify-content:center;padding:16px 0 14px}[data-sidebar=collapsed] .sidebar .nav{padding:8px 6px}[data-sidebar=collapsed] .sidebar .nav-item{justify-content:center;padding:9px 8px}[data-sidebar=collapsed] .sidebar .sidebar-footer{padding:10px 6px}[data-sidebar=collapsed] .sidebar .nav-section{height:0;margin:5px 10px;padding:0;border:none;border-top:1px solid var(--border);font-size:0;overflow:hidden;letter-spacing:0}[data-sidebar=collapsed] .sidebar .nav>.nav-section:first-child{display:none}[data-sidebar=collapsed] .sidebar .user-chip{justify-content:center;padding:6px}[data-sidebar=collapsed] .sidebar-collapse-bar{justify-content:center;padding:8px 6px}@media (max-width: 880px){[data-sidebar=collapsed] .app{grid-template-columns:1fr}.sidebar-collapse-bar{display:none}}.page-with-aside{padding:0!important;display:grid;grid-template-columns:240px 1fr;height:100%;min-height:0;transition:grid-template-columns .22s ease}.page-with-aside.aside-collapsed{grid-template-columns:44px 1fr}.page-with-aside>aside{border-right:1px solid var(--border);background:var(--bg-muted);display:flex;flex-direction:column;overflow:hidden;position:relative;transition:width .22s ease}.page-with-aside .page-inner{padding:28px 32px;overflow-y:auto;min-width:0}.aside-collapse-bar{display:flex;align-items:center;justify-content:flex-end;padding:8px 10px;border-top:1px solid var(--border);margin-top:auto}.aside-collapse-btn{width:26px;height:26px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;display:grid;place-items:center;color:var(--fg-muted);box-shadow:var(--shadow-xs);cursor:pointer;transition:background .12s ease,color .12s ease}.aside-collapse-btn:hover{color:var(--fg);background:var(--bg-muted)}.aside-collapse-btn svg{transition:transform .22s ease}.page-with-aside.aside-collapsed>aside .nk-years-head span,.page-with-aside.aside-collapsed>aside .nk-years-head .btn,.page-with-aside.aside-collapsed>aside .nk-year-list,.page-with-aside.aside-collapsed>aside .nk-years-foot,.page-with-aside.aside-collapsed>aside .kat-list{display:none}.page-with-aside.aside-collapsed>aside .nk-years-head{justify-content:center;padding:12px 6px;border-bottom:0}.page-with-aside.aside-collapsed .aside-collapse-bar{justify-content:center;padding:8px 6px}.page-with-aside.aside-collapsed .aside-collapse-btn svg{transform:rotate(180deg)}.aside-collapsed-icons{display:none;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;flex:1;overflow-y:auto}.page-with-aside.aside-collapsed .aside-collapsed-icons{display:flex}.aside-icon-btn{width:34px;height:34px;border:0;background:transparent;border-radius:6px;display:grid;place-items:center;color:var(--fg-muted);cursor:pointer;font-family:var(--font-mono);font-size:11px;font-weight:600;transition:background .12s ease,color .12s ease}.aside-icon-btn:hover{background:var(--bg-elev);color:var(--fg)}.aside-icon-btn.active{background:var(--primary-soft);color:var(--primary-soft-fg)}@media (max-width: 1100px){.page-with-aside{grid-template-columns:200px 1fr}.page-with-aside.aside-collapsed{grid-template-columns:44px 1fr}.page-with-aside .page-inner{padding:22px 18px}}@media (max-width: 880px){.page-with-aside{grid-template-columns:1fr!important}.page-with-aside>aside{display:none}}.nk-years-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em}.nk-year-list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.nk-year{background:transparent;border:1px solid transparent;border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:12px;text-align:left;cursor:pointer;transition:background .12s ease,border-color .12s ease}.nk-year:hover{background:var(--bg-elev)}.nk-year.active{background:var(--bg-elev);border-color:var(--primary)}.nk-year-num{font-weight:600;font-size:15px;min-width:42px;font-family:var(--font-mono)}.nk-year-meta{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.nk-year-sum{font-size:11.5px;color:var(--fg-muted)}.nk-year-arr{color:var(--fg-subtle);flex-shrink:0}.nk-year.active .nk-year-arr{color:var(--primary)}.nk-years-foot{border-top:1px solid var(--border);padding:12px 16px}.nk-years-stat{display:flex;justify-content:space-between;font-size:12px;color:var(--fg-muted)}.vorlagen-aside{display:flex;flex-direction:column}.kat-list{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.kat-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:0;border-radius:8px;color:var(--fg);font-size:13.5px;cursor:pointer;transition:background .12s ease}.kat-row:hover{background:var(--bg-elev)}.kat-row.active{background:var(--primary-soft);color:var(--primary-soft-fg);font-weight:500}.kat-ic{width:24px;height:24px;display:grid;place-items:center;color:var(--fg-muted)}.kat-row.active .kat-ic{color:var(--primary-soft-fg)}.kat-count{font-size:11px;color:var(--fg-subtle);font-family:var(--font-mono)}.vorlagen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:24px}.vorlage-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px;transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.vorlage-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.vorlage-card.dragging{opacity:.5;transform:scale(.98)}.vorlage-card-top{display:flex;justify-content:space-between;align-items:center}.vorlage-fmt{font-family:var(--font-mono);font-size:10px;font-weight:700;padding:3px 6px;border-radius:4px;background:var(--danger-soft);color:var(--danger-soft-fg)}.vorlage-fmt.fmt-docx{background:var(--info-soft);color:var(--info-soft-fg)}.vorlage-fmt.fmt-pdf{background:var(--danger-soft);color:var(--danger-soft-fg)}.vorlage-fmt.fmt-odt{background:var(--success-soft);color:var(--success-soft-fg)}.vorlage-handle{color:var(--fg-subtle);cursor:grab}.vorlage-name{font-weight:600;font-size:14px;line-height:1.35}.vorlage-meta{display:flex;gap:6px;flex-wrap:wrap}.kat-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:var(--bg-muted);border:1px solid var(--border);font-size:11.5px;color:var(--fg-muted)}.vorlage-fields{display:flex;gap:4px;flex-wrap:wrap;min-height:22px}.chip{font-family:var(--font-mono);font-size:10.5px;padding:2px 6px;border-radius:4px;background:var(--primary-soft);color:var(--primary-soft-fg)}.chip.muted{background:var(--bg-muted);color:var(--fg-muted)}.vorlage-foot{display:flex;justify-content:space-between;font-size:11px;color:var(--fg-muted);padding-top:8px;border-top:1px solid var(--border)}.vorlage-actions{display:flex;gap:6px;align-items:center}.vorlage-actions>.btn:first-child{flex:1}
