:root{--brand: #6366f1;--brand-2: #8b5cf6;--brand-3: #06b6d4;--brand-grad: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--brand-soft: linear-gradient(135deg, #eef2ff 0%, #faf5ff 100%);--bg-glow: radial-gradient(1200px 600px at 0% 0%, rgba(99,102,241,.08), transparent 60%), radial-gradient(1000px 600px at 100% 0%, rgba(6,182,212,.05), transparent 60%);--bg: #f8f9fc;--surface: #ffffff;--surface-2: #f3f4f9;--surface-3: #e9ebf3;--glass: rgba(255, 255, 255, .72);--border: #e6e8f0;--border-strong:#d1d5e3;--hover-bg: rgba(99, 102, 241, .04);--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--text-on-brand: #ffffff;--primary: var(--brand);--primary-h: #4f46e5;--primary-fg: #ffffff;--primary-soft: #eef2ff;--success: #10b981;--success-soft: #d1fae5;--warning: #f59e0b;--warning-soft: #fef3c7;--danger: #ef4444;--danger-soft: #fee2e2;--info: #06b6d4;--info-soft: #cffafe;--st-disponible: var(--success);--st-reservado: #6366f1;--st-prestado: var(--warning);--st-rentado: var(--brand);--st-mantenimiento: #ea580c;--st-danado: var(--danger);--st-perdido: #6b7280;--st-retirado: #475569;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-7: 48px;--sp-8: 64px;--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--r-2xl: 28px;--sh-xs: 0 1px 2px rgba(15, 23, 42, .04);--sh-1: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .03);--sh-2: 0 4px 12px rgba(15, 23, 42, .06), 0 2px 4px rgba(15, 23, 42, .04);--sh-3: 0 12px 32px rgba(15, 23, 42, .1), 0 4px 8px rgba(15, 23, 42, .04);--sh-glow: 0 0 0 4px rgba(99, 102, 241, .14);--sh-glow-soft: 0 0 0 3px rgba(99, 102, 241, .08);--font: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--sidebar-w: 248px;--topbar-h: 60px;--ease: cubic-bezier(.16, 1, .3, 1);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--t-fast: .12s;--t-base: .2s;--t-slow: .32s}[data-theme=dark]{--bg: #0a0e1a;--surface: #111827;--surface-2: #0f1729;--surface-3: #1a2238;--glass: rgba(17, 24, 39, .72);--border: #1e293b;--border-strong: #334155;--hover-bg: rgba(139, 92, 246, .08);--text: #f1f5f9;--text-2: #94a3b8;--text-3: #64748b;--brand-soft: linear-gradient(135deg, rgba(99,102,241,.1) 0%, rgba(139,92,246,.1) 100%);--bg-glow: radial-gradient(1200px 600px at 0% 0%, rgba(99,102,241,.1), transparent 60%), radial-gradient(1000px 600px at 100% 0%, rgba(6,182,212,.06), transparent 60%);--primary-soft: rgba(99, 102, 241, .14);--success-soft: rgba(16, 185, 129, .14);--warning-soft: rgba(245, 158, 11, .14);--danger-soft: rgba(239, 68, 68, .14);--info-soft: rgba(6, 182, 212, .14);--sh-xs: 0 1px 2px rgba(0, 0, 0, .25);--sh-1: 0 1px 3px rgba(0, 0, 0, .35), 0 1px 2px rgba(0, 0, 0, .2);--sh-2: 0 4px 16px rgba(0, 0, 0, .35), 0 2px 4px rgba(0, 0, 0, .25);--sh-3: 0 16px 48px rgba(0, 0, 0, .55), 0 4px 8px rgba(0, 0, 0, .25);--sh-glow: 0 0 0 4px rgba(139, 92, 246, .22);--sh-glow-soft: 0 0 0 3px rgba(139, 92, 246, .15)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){color-scheme:dark}}@media (prefers-reduced-motion: reduce){:root{--t-fast: 0ms;--t-base: 0ms;--t-slow: 0ms}}*,*:before,*:after{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{background:var(--bg);background-image:var(--bg-glow);background-attachment:fixed;color:var(--text);font:14px/1.5 var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--primary);text-decoration:none;transition:color var(--t-fast) var(--ease)}a:hover{color:var(--primary-h)}button{font:inherit}h1,h2,h3,h4{margin:0 0 var(--sp-3);line-height:1.25;letter-spacing:-.011em}h1{font-size:24px;font-weight:600;letter-spacing:-.02em}h2{font-size:18px;font-weight:600}h3{font-size:15px;font-weight:600}p{margin:0 0 var(--sp-3)}::selection{background:#6366f138;color:var(--text)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:6px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.boot-loader{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);height:100vh;color:var(--text-2)}.spinner{width:16px;height:16px;border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.page-fade{animation:pageFadeIn var(--t-slow) var(--ease) both}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.stagger>*{animation:staggerItem var(--t-slow) var(--ease) both}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:30ms}.stagger>*:nth-child(3){animation-delay:60ms}.stagger>*:nth-child(4){animation-delay:90ms}.stagger>*:nth-child(5){animation-delay:.12s}.stagger>*:nth-child(6){animation-delay:.15s}.stagger>*:nth-child(7){animation-delay:.18s}.stagger>*:nth-child(8){animation-delay:.21s}@keyframes staggerItem{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.muted{color:var(--text-2)}.subtle{color:var(--text-3)}.text-xs{font-size:12px}.text-sm{font-size:13px}.text-lg{font-size:16px}.text-mono{font-family:var(--mono);font-size:12.5px}.text-bold{font-weight:600}.right{text-align:right}.center{text-align:center}.nowrap{white-space:nowrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-1{flex:1}.wrap{flex-wrap:wrap}.mt-1{margin-top:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-5{margin-top:var(--sp-5)}.mt-6{margin-top:var(--sp-6)}.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.mb-5{margin-bottom:var(--sp-5)}.sk{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;border-radius:var(--r-sm);animation:skShimmer 1.6s ease-in-out infinite;display:inline-block}.sk.line{height:12px;width:100%}.sk.line.sm{height:9px;width:60%}.sk.line.lg{height:16px;width:80%}.sk.box{height:60px;width:100%}.sk.tall{height:120px;width:100%}.sk.circle{height:32px;width:32px;border-radius:50%}@keyframes skShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:9px 16px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:var(--r-md);cursor:pointer;font-weight:500;font-size:13.5px;transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),color var(--t-fast) var(--ease),transform var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:hover{background:var(--surface-2);border-color:var(--text-3);transform:translateY(-1px);box-shadow:var(--sh-1)}.btn:active{transform:translateY(0);transition-duration:60ms}.btn:focus-visible{outline:none;box-shadow:var(--sh-glow)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn.primary{background:var(--brand-grad);color:var(--primary-fg);border-color:transparent;box-shadow:0 1px 2px #6366f14d,0 4px 12px #6366f12e}.btn.primary:hover{filter:brightness(1.05);box-shadow:0 2px 4px #6366f159,0 6px 18px #6366f147}.btn.danger{background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 2px 6px #ef444440}.btn.danger:hover{background:#dc2626;box-shadow:0 3px 10px #ef444459}.btn.ghost{background:transparent;border-color:transparent;color:var(--text-2)}.btn.ghost:hover{background:var(--hover-bg);color:var(--text);transform:none;box-shadow:none}.btn.sm{padding:5px 10px;font-size:12.5px;border-radius:var(--r-sm);gap:6px}.btn.icon{padding:7px}.btn.icon.sm{padding:4px}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:var(--sp-3)}.field label{font-size:12px;color:var(--text-2);font-weight:500;letter-spacing:.01em}.field .hint{font-size:12px;color:var(--text-3)}.field .err{font-size:12px;color:var(--danger)}.input,.select,.textarea{width:100%;padding:9px 12px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-md);font:inherit;font-size:13.5px;outline:none;transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:var(--sh-glow-soft)}.textarea{min-height:84px;resize:vertical;line-height:1.55}.checkbox{display:inline-flex;align-items:center;gap:var(--sp-2);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13.5px}.checkbox input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-5);box-shadow:var(--sh-1);transition:box-shadow var(--t-base) var(--ease),transform var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}.card.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--sh-2);border-color:var(--border-strong)}.card .card-head{display:flex;justify-content:space-between;align-items:center;margin:calc(var(--sp-5) * -1) calc(var(--sp-5) * -1) var(--sp-4);padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--border)}.card.glass{background:var(--glass);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-1)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}.table th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);background:var(--surface-2);font-weight:600;white-space:nowrap}.table tbody tr{transition:background var(--t-fast) var(--ease)}.table tbody tr:hover{background:var(--hover-bg)}.table tbody tr:last-child td{border-bottom:0}.table .row-actions{display:flex;gap:4px;justify-content:flex-end}.empty{padding:var(--sp-7) var(--sp-5);text-align:center;color:var(--text-2);display:flex;flex-direction:column;align-items:center;gap:var(--sp-2)}.empty .empty-icon{width:56px;height:56px;border-radius:50%;background:var(--brand-soft);color:var(--primary);display:grid;place-items:center;font-size:24px;margin-bottom:var(--sp-2);box-shadow:var(--sh-1)}.empty h3{color:var(--text);margin:0 0 4px}.empty p{color:var(--text-2);margin:0;max-width:380px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;background:var(--surface-2);border:1px solid transparent;font-size:11.5px;font-weight:500;white-space:nowrap;line-height:1.5}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--text-3);flex-shrink:0}.badge.success{background:var(--success-soft);color:var(--success)}.badge.success:before{background:var(--success)}.badge.warn{background:var(--warning-soft);color:var(--warning)}.badge.warn:before{background:var(--warning)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.danger:before{background:var(--danger)}.badge.info{background:var(--info-soft);color:var(--info)}.badge.info:before{background:var(--info)}.badge.primary{background:var(--primary-soft);color:var(--primary)}.badge.primary:before{background:var(--primary)}.badge.muted{background:var(--surface-2);color:var(--text-2)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:var(--sp-4);animation:fade var(--t-base) var(--ease-out)}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-3);width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp var(--t-slow) var(--ease) both}.modal.lg{max-width:880px}.modal-head{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-head h3{margin:0}.modal-body{padding:var(--sp-5);overflow-y:auto;flex:1}.modal-foot{padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--border);display:flex;gap:var(--sp-2);justify-content:flex-end;background:var(--surface-2)}@keyframes fade{0%{opacity:0}}@keyframes slideUp{0%{transform:translateY(16px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}#toast-root{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;z-index:100;pointer-events:none}#toast-root>*{pointer-events:auto}.toast{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:11px 16px;box-shadow:var(--sh-3);min-width:240px;max-width:380px;font-size:13.5px;display:flex;align-items:center;gap:var(--sp-2);animation:slideIn var(--t-slow) var(--ease) both}.toast:before{content:"";width:4px;align-self:stretch;border-radius:2px;background:var(--text-3)}.toast.success:before{background:var(--success)}.toast.error:before{background:var(--danger)}.toast.info:before{background:var(--info)}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3) var(--sp-4)}.form-grid .full{grid-column:1 / -1}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}}.pagination{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);justify-content:flex-end;border-top:1px solid var(--border)}.pagination .btn{padding:5px 12px;font-size:12.5px}.toolbar{display:flex;gap:var(--sp-2);flex-wrap:wrap;align-items:center;margin-bottom:var(--sp-4)}.toolbar .input,.toolbar .select{width:auto;min-width:200px}.toolbar .grow{flex:1}.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-4);margin-bottom:var(--sp-5)}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-5);box-shadow:var(--sh-1);position:relative;overflow:hidden;transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}.stat:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--brand-grad);opacity:0;transition:opacity var(--t-base) var(--ease)}.stat:hover{transform:translateY(-2px);box-shadow:var(--sh-2);border-color:var(--border-strong)}.stat:hover:before{opacity:1}.stat .label{font-size:11.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;font-weight:600}.stat .value{font-size:28px;font-weight:700;margin-top:6px;letter-spacing:-.02em;line-height:1.1}.stat .delta{font-size:12px;color:var(--text-3);margin-top:4px}.stat .icon{position:absolute;top:var(--sp-4);right:var(--sp-4);width:36px;height:36px;display:grid;place-items:center;border-radius:var(--r-md);background:var(--surface-2);color:var(--text-2);font-size:18px;transition:background var(--t-base) var(--ease)}.stat:hover .icon{background:var(--primary-soft);color:var(--primary)}.cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:var(--surface-2);border-bottom:1px solid var(--border)}.cal-head>div{padding:10px 14px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:600;text-align:left}.cal-body{display:grid;grid-template-columns:repeat(7,1fr)}.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:8px;min-height:108px;position:relative;display:flex;flex-direction:column;gap:3px;overflow:hidden;transition:background var(--t-fast) var(--ease)}.cal-cell:hover{background:var(--hover-bg)}.cal-cell.out{background:var(--surface-2);opacity:.55}.cal-cell.today{background:color-mix(in oklab,var(--primary) 6%,var(--surface))}.cal-cell:nth-child(7n){border-right:0}.cal-num{font-size:12px;color:var(--text-2);font-weight:600}.cal-cell.today .cal-num{background:var(--brand-grad);color:var(--primary-fg);width:22px;height:22px;text-align:center;border-radius:50%;line-height:22px;box-shadow:0 2px 6px #6366f14d}.cal-evt{display:flex;align-items:center;gap:4px;padding:3px 7px;border-radius:var(--r-sm);font-size:11.5px;text-decoration:none;color:inherit;background:var(--surface-2);border-left:3px solid var(--text-3);transition:filter var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}.cal-evt:hover{text-decoration:none;filter:brightness(.97);transform:translate(2px)}.cal-evt-dot{width:6px;height:6px;border-radius:50%;background:var(--text-3);flex-shrink:0}.cal-evt.reservation{background:var(--info-soft);border-left-color:var(--info)}.cal-evt.reservation .cal-evt-dot{background:var(--info)}.cal-evt.reservation.confirmada{background:color-mix(in oklab,var(--info) 25%,var(--surface))}.cal-evt.reservation.pendiente{background:var(--warning-soft);border-left-color:var(--warning)}.cal-evt.reservation.pendiente .cal-evt-dot{background:var(--warning)}.cal-evt.loan{background:var(--warning-soft);border-left-color:var(--warning)}.cal-evt.loan .cal-evt-dot{background:var(--warning)}.cal-evt.rental{background:var(--primary-soft);border-left-color:var(--primary)}.cal-evt.rental .cal-evt-dot{background:var(--primary)}.cal-evt.overdue{background:var(--danger-soft);border-left-color:var(--danger)}.cal-evt.overdue .cal-evt-dot{background:var(--danger)}.cal-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--text-3)}.cal-dot.reservation,.cal-dot.reservation.confirmada{background:var(--info)}.cal-dot.reservation.pendiente,.cal-dot.loan{background:var(--warning)}.cal-dot.rental{background:var(--primary)}.cal-dot.overdue{background:var(--danger)}.cal-more{font-size:11px;color:var(--text-3);padding:0 6px}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:var(--sp-4);overflow-x:auto}.tabs .tab{padding:10px 14px;font-size:13px;color:var(--text-2);cursor:pointer;background:transparent;border:none;border-bottom:2px solid transparent;transition:color var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease);font-weight:500;white-space:nowrap}.tabs .tab:hover{color:var(--text)}.tabs .tab.active{color:var(--primary);border-bottom-color:var(--primary)}.spark{display:flex;align-items:flex-end;gap:3px;height:48px}.spark>div{flex:1;min-width:4px;background:var(--brand-grad);border-radius:3px 3px 0 0;opacity:.85;transition:opacity var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}.spark>div:hover{opacity:1;transform:scaleY(1.05);transform-origin:bottom}.donut{position:relative;width:140px;height:140px}.donut svg{transform:rotate(-90deg)}.donut-label{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center}.donut-label .v{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.02em}.donut-label .l{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.feed{display:flex;flex-direction:column;gap:var(--sp-3)}.feed-item{display:flex;gap:var(--sp-3);padding:var(--sp-3);border-radius:var(--r-md);transition:background var(--t-fast) var(--ease)}.feed-item:hover{background:var(--hover-bg)}.feed-icon{width:32px;height:32px;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;font-size:14px;flex-shrink:0}.feed-item .feed-body{flex:1;min-width:0}.feed-item .feed-meta{font-size:11.5px;color:var(--text-3)}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:var(--sp-4);position:relative;overflow:hidden}.auth-shell:before,.auth-shell:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;pointer-events:none}.auth-shell:before{top:-10%;left:-10%;width:400px;height:400px;background:var(--brand)}.auth-shell:after{bottom:-10%;right:-10%;width:500px;height:500px;background:var(--brand-3)}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--sp-7);box-shadow:var(--sh-3);position:relative;z-index:1;animation:slideUp var(--t-slow) var(--ease) both}.auth-card .brand-logo{width:48px;height:48px;border-radius:var(--r-md);background:var(--brand-grad);display:grid;place-items:center;color:#fff;font-size:22px;font-weight:700;margin-bottom:var(--sp-4);box-shadow:0 4px 14px #6366f14d}.auth-card .brand{font-size:22px;font-weight:700;margin-bottom:var(--sp-1);letter-spacing:-.02em}.auth-card .sub{color:var(--text-2);margin-bottom:var(--sp-6);font-size:13.5px}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"side topbar" "side main";height:100vh}.sidebar{grid-area:side;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.topbar{grid-area:topbar;background:var(--glass);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--sp-5);gap:var(--sp-3);position:relative;z-index:5}.main{grid-area:main;overflow:auto;padding:var(--sp-5)}.brand-block{padding:var(--sp-5);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--sp-2)}.brand-block .logo-mark{width:32px;height:32px;border-radius:var(--r-sm);background:var(--brand-grad);display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;box-shadow:0 2px 8px #6366f14d;flex-shrink:0}.brand-block .name{font-weight:700;line-height:1.1;letter-spacing:-.01em}.brand-block .small{color:var(--text-3);font-weight:400;font-size:11.5px;margin-top:2px}.nav{padding:var(--sp-3) var(--sp-2);display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1}.nav .section{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding:var(--sp-3) var(--sp-3) var(--sp-1);font-weight:600}.nav a{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-md);color:var(--text-2);text-decoration:none;font-weight:500;font-size:13px;transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}.nav a:hover{background:var(--hover-bg);color:var(--text);text-decoration:none}.nav a .nav-ico{width:18px;display:inline-flex;justify-content:center;opacity:.7;flex-shrink:0}.nav a.active{background:var(--brand-soft);color:var(--primary);box-shadow:var(--sh-xs)}[data-theme=dark] .nav a.active{background:#6366f129}.nav a.active .nav-ico{opacity:1}.user-block{padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--border);display:flex;align-items:center;gap:var(--sp-2);background:var(--surface-2)}.avatar{width:34px;height:34px;background:var(--brand-grad);color:#fff;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:13px;box-shadow:0 2px 6px #6366f140;flex-shrink:0}.topbar h1{margin:0;font-size:16px;font-weight:600;letter-spacing:-.01em}@media (max-width: 768px){.app-shell{grid-template-columns:1fr;grid-template-areas:"topbar" "main"}.sidebar{position:fixed;inset:0 auto 0 0;width:280px;transform:translate(-100%);transition:transform var(--t-base) var(--ease);z-index:40;box-shadow:var(--sh-3)}.sidebar.open{transform:translate(0)}}.menu-toggle{display:none}@media (max-width: 768px){.menu-toggle{display:inline-flex}}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-5);gap:var(--sp-3);flex-wrap:wrap}.page-head h1{margin:0}.page-head .subtitle{color:var(--text-3);font-size:13px;margin-top:2px}
