:root{--bg:#F4F6FB;--surface:#FFFFFF;--surface-muted:#F1F5F9;--surface-raised:#FFFFFF;--sidebar-bg:#0F172A;--sidebar-border:rgba(255,255,255,0.06);--sidebar-text:rgba(255,255,255,0.55);--sidebar-text-active:#FFFFFF;--sidebar-hover:rgba(255,255,255,0.07);--sidebar-active-bg:rgba(30,136,197,0.20);--sidebar-active-border:#1E88C5;--text:#0F172A;--text-muted:#64748B;--text-subtle:#94A3B8;--border:#E2E8F0;--border-strong:#CBD5E1;--primary:#1E88C5;--primary-strong:#0D47A1;--primary-soft:#E3F2FD;--primary-hover:#1976D2;--gradient-brand:linear-gradient(135deg,#5BAFE0,#1976D2);--success:#059669;--success-soft:#D1FAE5;--success-text:#065F46;--warning:#D97706;--warning-soft:#FEF3C7;--warning-text:#92400E;--danger:#DC2626;--danger-soft:#FEE2E2;--danger-text:#991B1B;--info:#0284C7;--info-soft:#E0F2FE;--info-text:#075985;--neutral-soft:#F1F5F9;--neutral-text:#475569;--focus:#1E88C5;--shadow-xs:0 1px 2px rgba(15,23,42,0.06);--shadow-sm:0 1px 3px rgba(15,23,42,0.08),0 1px 2px rgba(15,23,42,0.04);--shadow-md:0 4px 16px rgba(15,23,42,0.08),0 2px 4px rgba(15,23,42,0.04);--shadow-lg:0 12px 40px rgba(15,23,42,0.12),0 4px 8px rgba(15,23,42,0.06);--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--sidebar-width:260px;--topbar-height:64px;--transition-fast:120ms ease;--transition-base:180ms ease;--font-sans:"Plus Jakarta Sans",Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-mono:"JetBrains Mono","SFMono-Regular",Consolas,"Liberation Mono",monospace}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{min-height:100%}body{min-height:100dvh;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:var(--radius-sm)}.skip-link{position:fixed;left:16px;top:12px;z-index:9999;transform:translateY(-160%);border-radius:var(--radius);background:var(--sidebar-bg);color:white;padding:10px 16px;font-weight:600;font-size:14px;box-shadow:var(--shadow-lg);transition:transform var(--transition-fast)}.skip-link:focus{transform:translateY(0)}.app-shell{min-height:100dvh;display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr)}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100dvh;overflow-y:auto;overflow-x:hidden;background:var(--sidebar-bg);display:flex;flex-direction:column;padding:0;scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.sidebar-header{padding:20px 18px 16px;border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:inherit}.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:var(--radius);background:rgba(255,255,255,.04);flex-shrink:0;box-shadow:0 4px 12px rgba(30,136,197,.35);padding:4px}.brand-mark-img{width:100%;height:100%;object-fit:contain;display:block}.brand-mark svg{width:20px;height:20px;color:white}.brand-title-accent{background:linear-gradient(135deg,#5BAFE0,#1976D2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:800}.brand-text{min-width:0}.brand-title{font-size:15px;font-weight:700;color:#FFFFFF;letter-spacing:-.01em;line-height:1.2}.brand-subtitle{font-size:11px;font-weight:500;color:var(--sidebar-text);margin-top:1px;text-transform:uppercase;letter-spacing:.06em}.sidebar-nav{flex:1 1;padding:12px;overflow-y:auto;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section-label{padding:18px 8px 6px;color:var(--sidebar-text);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.nav-list{display:flex;flex-direction:column;gap:1px}.nav-link{display:flex;align-items:center;gap:10px;min-height:40px;border-radius:var(--radius);padding:9px 10px;color:var(--sidebar-text);font-size:13.5px;font-weight:500;transition:background var(--transition-fast),color var(--transition-fast);position:relative}.nav-link:hover{background:var(--sidebar-hover);color:rgba(255,255,255,.85)}.nav-link[data-active=true]{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);font-weight:600}.nav-link[data-active=true]:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--sidebar-active-border)}.nav-link-icon{display:grid;place-items:center;width:20px;height:20px;flex-shrink:0;opacity:.8}.nav-link[data-active=true] .nav-link-icon{opacity:1}.nav-group,.nav-group-btn{margin-bottom:2px}.nav-group-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 8px;background:none;border:none;cursor:pointer;color:var(--sidebar-text);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:var(--radius);transition:background var(--transition-fast),color var(--transition-fast)}.nav-group-btn:hover{background:var(--sidebar-hover);color:rgba(255,255,255,.75)}.nav-chevron{opacity:.6;flex-shrink:0;transition:transform .2s ease}.nav-chevron[data-open=true]{transform:rotate(0deg)}.nav-chevron[data-open=false]{transform:rotate(-90deg)}.logout-btn{display:grid;place-items:center;width:28px;height:28px;border-radius:var(--radius);background:none;border:none;cursor:pointer;color:var(--sidebar-text);flex-shrink:0;margin-left:auto;transition:background var(--transition-fast),color var(--transition-fast)}.logout-btn:hover{background:rgba(239,68,68,.15);color:#FCA5A5}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:14px;flex-shrink:0}.user-card{display:flex;align-items:center;gap:10px;border-radius:var(--radius);padding:8px;cursor:pointer;transition:background var(--transition-fast)}.user-card:hover{background:var(--sidebar-hover)}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--gradient-brand);display:grid;place-items:center;font-size:12px;font-weight:700;color:white;flex-shrink:0}.user-info{min-width:0;flex:1 1}.user-name{font-size:13px;font-weight:600;color:rgba(255,255,255,.9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.user-role{font-size:11px;color:var(--sidebar-text);margin-top:1px;line-height:1.2}.main{min-width:0;display:flex;flex-direction:column}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:var(--topbar-height);border-bottom:1px solid var(--border);background:rgba(244,246,251,.92);padding:0 28px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.topbar-left{min-width:0}.topbar-title{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1.2}.topbar-subtitle,.topbar-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-subtitle{font-size:12.5px;color:var(--text-muted);margin-top:2px}.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.content{flex:1 1;width:min(100%,1440px);margin:0 auto;padding:24px 28px 40px}.toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px}.button{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;border:1.5px solid transparent;border-radius:var(--radius);padding:0 14px;cursor:pointer;font-size:13.5px;font-weight:600;letter-spacing:-.01em;transition:background var(--transition-base),border-color var(--transition-base),color var(--transition-base),box-shadow var(--transition-base),transform 80ms ease;white-space:nowrap}.button:active{transform:scale(.98)}.button-primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px rgba(30,136,197,.3),inset 0 0 0 1px rgba(30,136,197,.1)}.button-primary:hover{background:var(--primary-hover);box-shadow:0 4px 12px rgba(30,136,197,.35),inset 0 0 0 1px rgba(30,136,197,.1)}.button-secondary{background:var(--surface);border-color:var(--border);color:var(--text);box-shadow:var(--shadow-xs)}.button-secondary:hover{background:var(--surface-muted);border-color:var(--border-strong)}.button-ghost{background:transparent;border-color:transparent;color:var(--text-muted)}.button-ghost:hover{background:var(--surface-muted);color:var(--text)}.button-danger{background:var(--danger);color:#fff;box-shadow:0 1px 2px rgba(220,38,38,.25)}.button-danger:hover{background:#B91C1C}.button:disabled{opacity:.5;cursor:not-allowed;transform:none}.icon-button{display:inline-grid;place-items:center;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.icon-button:hover{background:var(--surface-muted);border-color:var(--border-strong);color:var(--text)}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:14px;gap:14px;margin-bottom:20px}.kpi-card{position:relative;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:20px;overflow:hidden;transition:box-shadow var(--transition-base),transform var(--transition-base)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-brand);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.kpi-icon{display:grid;place-items:center;width:36px;height:36px;border-radius:var(--radius);background:var(--primary-soft);color:var(--primary);margin-bottom:14px}.kpi-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.kpi-value{margin-top:8px;font-size:28px;font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.kpi-trend{margin-top:8px;font-size:12px;font-weight:600;color:var(--text-subtle)}.card{padding:20px}.card,.table-panel{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm)}.table-panel{overflow:hidden}.grid-two{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(300px,.7fr);grid-gap:14px;gap:14px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:56px;border-bottom:1px solid var(--border);padding:12px 18px}.panel-title{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:640px}thead tr{background:var(--surface-muted)}th{padding:10px 18px;text-align:left;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}td,th{border-bottom:1px solid var(--border)}td{padding:13px 18px;font-size:13.5px;color:var(--text);vertical-align:middle}tbody tr{transition:background var(--transition-fast)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#F8FAFF}.td-primary{font-weight:600;color:var(--text)}.td-mono{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:12.5px;color:var(--text-muted);font-family:var(--font-mono)}.status-pill{display:inline-flex;align-items:center;gap:5px;height:24px;border-radius:var(--radius-full);padding:0 10px;font-size:11.5px;font-weight:700;letter-spacing:.01em;background:var(--neutral-soft);color:var(--neutral-text);white-space:nowrap}.status-pill:before{content:"";display:block;width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.7}.status-pill[data-tone=success]{background:var(--success-soft);color:var(--success-text)}.status-pill[data-tone=warning]{background:var(--warning-soft);color:var(--warning-text)}.status-pill[data-tone=danger]{background:var(--danger-soft);color:var(--danger-text)}.status-pill[data-tone=info]{background:var(--info-soft);color:var(--info-text)}.status-pill[data-tone=primary]{background:var(--primary-soft);color:var(--primary-strong)}.status-pill[data-nodot=true]:before{display:none}.state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 24px;text-align:center}.state-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:grid;place-items:center;margin-bottom:4px}.state-label{font-size:14px;font-weight:600;color:var(--text-muted)}.state-hint{font-size:13px;color:var(--text-subtle);max-width:320px}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg,var(--surface-muted) 25%,#E8EDF5 50%,var(--surface-muted) 75%);background-size:600px 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-row{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}.skeleton-row:last-child{border-bottom:none}.field{display:grid;grid-gap:6px;gap:6px}.field label{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-.01em}.input{height:38px;width:100%;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:0 12px;font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:var(--text-subtle)}.input:hover{border-color:var(--border-strong)}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,136,197,.14)}.modal-backdrop{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;overflow-y:auto;background:rgba(15,23,42,.56);padding:24px}.modal-sheet{width:min(100%,760px);max-height:calc(100dvh - 48px);display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-lg);overflow:hidden}.modal-sheet-wide{width:min(100%,980px)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);padding:18px 20px}.modal-title{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.modal-subtitle{margin-top:4px;color:var(--text-muted);font-size:13px}.modal-body{overflow-y:auto;padding:18px 20px 20px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px}.form-error{background:var(--danger-soft);color:var(--danger-text);padding:10px 12px;font-size:13px;font-weight:600}.archive-panel,.form-error{margin-top:16px;border:1px solid #fecaca;border-radius:var(--radius)}.archive-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;grid-gap:12px;gap:12px;background:#FFF7F7;padding:14px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;border-top:1px solid var(--border);padding-top:16px}.permission-panel{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}.permission-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);background:var(--surface-muted);padding:12px 14px}.permission-panel-header h3{font-size:13px;font-weight:800;color:var(--text)}.permission-panel-header span{color:var(--text-muted);font-size:12px;font-weight:700}.permission-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));grid-gap:8px;gap:8px;padding:14px}.permission-chip{display:flex;align-items:center;gap:8px;min-height:38px;border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;color:var(--text-muted);cursor:pointer;font-size:12.5px;font-weight:650;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.permission-chip:hover{border-color:var(--border-strong);color:var(--text)}.permission-chip[data-checked=true]{border-color:#C7D2FE;background:var(--primary-soft);color:var(--primary-strong)}.permission-chip input{width:16px;height:16px;accent-color:var(--primary)}.membership-form{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted);padding:14px}.leave-rule,.leave-rule-list{display:grid;grid-gap:12px;gap:12px;padding:14px}.leave-rule{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.login-page{min-height:100dvh;display:grid;grid-template-columns:1fr 1fr}.login-panel-left{background:var(--gradient-brand);display:flex;flex-direction:column;justify-content:center;padding:60px;position:relative;overflow:hidden}.login-panel-left:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(255,255,255,.08) 0,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.06) 0,transparent 50%)}.login-panel-left:after{content:"";position:absolute;bottom:-120px;right:-80px;width:400px;height:400px;border-radius:50%;border:60px solid rgba(255,255,255,.06)}.login-brand{display:flex;align-items:center;gap:12px;position:relative;z-index:1;margin-bottom:60px}.login-brand-icon{width:48px;height:48px;object-fit:contain;display:block;background:rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:6px;border:1px solid rgba(255,255,255,.22)}.login-brand-name{font-size:26px;font-weight:800;color:white;letter-spacing:-.03em}.login-hero{position:relative;z-index:1}.login-hero-label{font-size:12px;font-weight:700;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}.login-hero-title{font-size:36px;font-weight:800;color:white;letter-spacing:-.04em;line-height:1.1;margin-bottom:16px}.login-hero-subtitle{font-size:15px;color:rgba(255,255,255,.7);line-height:1.6;max-width:360px}.login-features{position:relative;z-index:1;margin-top:40px;display:flex;flex-direction:column;gap:12px}.login-feature-item{display:flex;align-items:center;gap:10px;font-size:13.5px;color:rgba(255,255,255,.8);font-weight:500}.login-feature-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);flex-shrink:0}.login-panel-right{background:var(--bg);display:flex;align-items:center;justify-content:center;padding:40px}.login-form-wrap{width:100%;max-width:400px}.login-form-header{margin-bottom:32px}.login-form-title{font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:6px}.login-form-subtitle{font-size:14px;color:var(--text-muted)}.login-form-body{display:flex;flex-direction:column;gap:16px}.login-divider{height:1px;background:var(--border);margin:4px 0}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--danger-soft);border:1px solid #fecaca;font-size:13px;font-weight:500;color:var(--danger-text)}.login-error,.login-submit{border-radius:var(--radius)}.login-submit{width:100%;height:42px;font-size:14px}.planned-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:14px;gap:14px}.planned-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:13.5px;color:var(--text-muted);transition:border-color var(--transition-fast),background var(--transition-fast)}.planned-item:hover{border-color:var(--border-strong);background:var(--surface-muted)}.planned-item-num{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--primary-soft);color:var(--primary);font-size:11px;font-weight:800;flex-shrink:0;margin-top:1px}@media (max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;overflow:visible;padding:12px 16px}.sidebar-header{width:100%;border-bottom:none;padding:0 0 12px}.sidebar-nav{padding:0}.sidebar-footer{display:none}.nav-list{flex-direction:row;flex-wrap:wrap;gap:4px}.nav-link[data-active=true]:before{display:none}.grid-two,.kpi-grid,.login-page{grid-template-columns:1fr}.login-panel-left{display:none}}@media (max-width:640px){.content,.topbar{padding-left:16px;padding-right:16px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.modal-backdrop{align-items:stretch;padding:12px}.modal-sheet{max-height:calc(100dvh - 24px)}.archive-panel,.form-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column-reverse}.modal-footer .button{width:100%}}.inline-form-section{padding:16px 20px 20px;border-bottom:1px solid var(--border);background:var(--surface-muted)}.inline-form-section-title{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:14px}.inline-form-actions{margin-top:14px;display:flex;justify-content:flex-end}.settings-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));border-top:1px solid var(--border)}.setting-item{padding:16px 20px;border-right:1px solid var(--border)}.setting-item:last-child{border-right:none}.setting-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px}.setting-value{font-size:14px;font-weight:700;color:var(--text);line-height:1.3}.setting-sub{font-size:12px;color:var(--text-muted);margin-top:3px}@media (max-width:768px){.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.setting-item{border-bottom:1px solid var(--border)}.setting-item:nth-child(odd){border-right:1px solid var(--border)}.setting-item:nth-child(2n){border-right:none}}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border);background:var(--surface);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.pagination-info{font-size:13px;color:var(--text-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{display:inline-grid;place-items:center;min-width:32px;height:32px;padding:0 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--surface-muted);border-color:var(--border-strong);color:var(--text)}.pagination-btn[data-active=true]{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-ellipsis{display:inline-grid;place-items:center;min-width:32px;height:32px;font-size:13px;color:var(--text-subtle);-webkit-user-select:none;-moz-user-select:none;user-select:none}.drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:140px;border:2px dashed var(--border);border-radius:var(--radius-lg);background:var(--surface-muted);padding:24px;cursor:pointer;transition:border-color var(--transition-base),background var(--transition-base);text-align:center}.drop-zone:hover,.drop-zone[data-active=true]{border-color:var(--primary);background:var(--primary-soft)}.drop-zone-icon{color:var(--text-subtle);transition:color var(--transition-base)}.drop-zone:hover .drop-zone-icon,.drop-zone[data-active=true] .drop-zone-icon{color:var(--primary)}.drop-zone-label{font-size:14px;font-weight:600;color:var(--text-muted)}.drop-zone-hint{font-size:12px;color:var(--text-subtle)}.drop-zone-file{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1.5px solid var(--primary);border-radius:var(--radius);background:var(--primary-soft);width:100%;max-width:360px}.drop-zone-file-name{flex:1 1;font-size:13px;font-weight:600;color:var(--primary-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drop-zone-file-size{font-size:12px;color:var(--text-muted);white-space:nowrap}.page-tabs{display:flex;align-items:stretch;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto;scrollbar-width:none}.page-tabs::-webkit-scrollbar{display:none}.page-tab{display:inline-flex;align-items:center;gap:7px;padding:0 16px;height:44px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--text-muted);font-size:13.5px;font-weight:600;cursor:pointer;white-space:nowrap;transition:color var(--transition-fast),border-color var(--transition-fast);margin-bottom:-1px}.page-tab:hover{color:var(--text)}.page-tab[data-active=true]{color:var(--primary);border-bottom-color:var(--primary)}.page-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:var(--radius-full);background:var(--surface-muted);color:var(--text-muted);font-size:11px;font-weight:700;line-height:1;transition:background var(--transition-fast),color var(--transition-fast)}.page-tab[data-active=true] .page-tab-count{background:var(--primary-soft);color:var(--primary-strong)}.guide-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;overflow:hidden}.guide-panel-header{display:flex;align-items:center;gap:10px;padding:14px 18px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;border:none;background:transparent;width:100%;text-align:left}.guide-panel-header:hover{background:var(--bg)}.guide-panel-title{font-size:13.5px;font-weight:700;color:var(--text);flex:1 1}.guide-panel-toggle{font-size:12px;color:var(--text-muted);font-weight:600;white-space:nowrap}.guide-panel-body{padding:0 18px 20px;border-top:1px solid var(--border)}.guide-steps{list-style:none;padding:0;display:flex;flex-direction:column;gap:14px;margin:18px 0 0}.guide-step{display:flex;gap:14px;align-items:flex-start}.guide-step-num{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-full);background:var(--primary-soft);color:var(--primary-strong);font-size:12px;font-weight:800;flex-shrink:0;margin-top:1px}.guide-step-content{flex:1 1}.guide-step-label{font-size:13px;font-weight:700;color:var(--text);margin:0 0 3px}.guide-step-desc{font-size:12.5px;color:var(--text-muted);line-height:1.6;margin:0}.guide-step-desc code{font-family:var(--font-mono);font-size:11.5px;background:var(--surface-muted);padding:1px 5px;border-radius:4px;color:var(--primary-strong)}.guide-note{margin-top:16px;padding:10px 14px;background:var(--primary-soft);border-left:3px solid var(--primary);border-radius:0 var(--radius) var(--radius) 0;font-size:12.5px;color:var(--text);line-height:1.6}.guide-cols{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px;margin-top:18px}.guide-concept{padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.guide-concept-title{font-size:12.5px;font-weight:700;color:var(--text);margin:0 0 4px}.guide-concept-desc{font-size:12px;color:var(--text-muted);line-height:1.55;margin:0}@media (max-width:640px){.guide-cols{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*,:after,:before{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}