:root{--bg: #f4f6fb;--surface: #ffffff;--surface2: #f8fafd;--surface3: #eff3fa;--hover: #eef3fc;--blue: #3b82f6;--blue-dark: #2563eb;--blue-light: #60a5fa;--blue-soft: #eff6ff;--blue-border:#bfdbfe;--text: #0f172a;--text2: #3f4f66;--muted: #64748b;--green: #059669;--green-soft: #ecfdf5;--green-border:#a7f3d0;--amber: #b45309;--amber-soft: #fffbeb;--amber-border:#fde68a;--red: #dc2626;--red-soft: #fef2f2;--red-border: #fecaca;--slate: #64748b;--slate-soft: #f8fafc;--slate-border:#e2e8f0;--line: #e6ebf4;--line2: #cfd9e8;--sh-xs: 0 1px 2px rgba(16,24,40,.04);--sh-sm: 0 1px 2px rgba(16,24,40,.05), 0 2px 6px rgba(16,24,40,.04);--sh-md: 0 2px 4px rgba(16,24,40,.05), 0 8px 24px rgba(16,24,40,.08);--sh-lg: 0 4px 8px rgba(16,24,40,.06), 0 20px 48px rgba(16,24,40,.14);--sh-blue: 0 0 0 3px rgba(59,130,246,.25);--side: #0c1322;--side2: #141d31;--side-text: #eef2f8;--side-muted: #93a3ba;--side-line: rgba(255,255,255,.06);--side-hover: rgba(148,180,255,.09);--side-active:rgba(59,130,246,.18);--side-w: 226px;--side-sm: 60px;--r-xs: 6px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 20px;--r-pill: 999px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-7: 32px;--sp-8: 48px;--z-dropdown: 50;--z-drawer: 101;--z-backdrop: 10000;--z-modal: 10001;--z-toast: 10010;--ease: cubic-bezier(.4,0,.2,1);--fast: .15s;--mid: .22s;--slow: .32s;--background: var(--bg);--surface-elevated: var(--surface);--border: var(--line);--border-strong: var(--line2);--text-primary: var(--text);--text-secondary: var(--text2);--text-muted: var(--muted);--accent: var(--blue);--accent-hover: var(--blue-dark);--success: var(--green);--warning: var(--amber);--danger: var(--red);--radius-sm: var(--r-sm);--radius-md: var(--r-md);--radius-lg: var(--r-lg);--teal: var(--blue);--teal-50: var(--blue-soft);--teal-100: #dbeafe;--teal-200: #bfdbfe;--teal-300: var(--blue-light);--teal-400: var(--blue);--teal-500: var(--blue);--teal-600: var(--blue-dark);--teal-700: var(--blue-dark);--teal-soft: var(--blue-soft);--teal-dark: var(--blue-dark);--n-0: #fff;--n-25: var(--surface2);--n-50: var(--surface3);--n-100: var(--hover);--n-200: var(--line);--n-300: var(--line2);--n-400: var(--muted);--n-500: var(--muted);--n-600: var(--text2);--n-700: var(--text2);--n-800: var(--text);--n-900: var(--text);--green-500: var(--green);--green-600: var(--green);--amber-500: var(--amber);--amber-600: var(--amber);--red-500: var(--red);--red-600: var(--red);--slate-500: var(--slate);--line-strong: var(--line2);--shadow-xs: var(--sh-xs);--shadow-sm: var(--sh-sm);--shadow-md: var(--sh-md);--shadow-lg: var(--sh-lg);--ring: var(--sh-blue);--ring-red: 0 0 0 3px #fecaca;--surface-2: var(--surface2);--surface-3: var(--surface3);--text-2: var(--text2);--primary: var(--blue);--font-sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font-family:var(--font-sans);color-scheme:light;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background:var(--bg);color:var(--text)}*,*:before,*:after{box-sizing:border-box;min-width:0}html{scroll-behavior:smooth;overflow-x:hidden;max-width:100%}body{margin:0;min-width:0;min-height:100vh;overflow-x:hidden;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6}h1,h2,h3,h4,h5{margin:0;letter-spacing:-.02em;line-height:1.25;font-family:var(--font-sans);text-wrap:balance}p{margin:0}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}::selection{background:#3b82f62e}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}*{scrollbar-width:thin;scrollbar-color:var(--line2) transparent}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:var(--line2);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn,.week-switcher button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px;padding:0 16px;border:1px solid transparent;border-radius:10px;font-size:13.5px;font-weight:600;white-space:nowrap;letter-spacing:.005em;transition:background var(--fast) var(--ease),border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease),color var(--fast) var(--ease),transform var(--fast) var(--ease)}.btn:active:not(:disabled){transform:scale(.98)}.btn:focus-visible{outline:none;box-shadow:var(--sh-blue)}.btn[aria-busy=true]{pointer-events:none}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue-dark);box-shadow:inset 0 1px #ffffff24,0 1px 2px #1018281a,0 2px 8px #3b82f633}.btn-primary:hover:not(:disabled){background:var(--blue-dark);border-color:var(--blue-dark);box-shadow:inset 0 1px #ffffff1f,0 2px 10px #3b82f652}.btn-primary:focus-visible{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #3b82f673}.btn-secondary{background:var(--blue-soft);color:var(--blue-dark);border-color:var(--blue-border)}.btn-secondary:hover:not(:disabled){background:#dbeafe;box-shadow:var(--sh-xs)}.btn-ghost,.week-switcher button{background:var(--surface);color:var(--text2);border-color:var(--line2);box-shadow:var(--sh-xs)}.btn-ghost:hover:not(:disabled),.week-switcher button:hover:not(:disabled){background:var(--hover);border-color:var(--blue-border);color:var(--text)}.btn-danger{background:var(--red);color:#fff;border-color:#b91c1c;box-shadow:inset 0 1px #ffffff1f,0 1px 2px #1018281a}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:focus-visible{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #dc262666}.link-btn{background:none;border:none;padding:0;color:var(--blue);font-size:13px;font-weight:600;text-decoration:underline;text-underline-offset:2px}.link-btn:hover{color:var(--blue-dark)}.app-shell{min-height:100vh;display:grid;grid-template-columns:var(--side-w) minmax(0,1fr);transition:grid-template-columns var(--slow) var(--ease)}.app-shell.sidebar-collapsed{grid-template-columns:var(--side-sm) minmax(0,1fr)}.sidebar{background:var(--side);color:var(--side-text);padding:20px 12px 16px;display:flex;flex-direction:column;gap:24px;border-right:1px solid rgba(255,255,255,.04);position:sticky;top:0;min-height:100dvh;overflow-y:auto;overflow-x:hidden;transition:padding var(--slow) var(--ease)}.sidebar-collapsed .sidebar{padding:20px 8px 16px}.brand{display:flex;align-items:center;gap:11px;padding:0 4px;overflow:hidden;flex:none}.brand-mark{width:36px;height:36px;border-radius:10px;flex:none;background:linear-gradient(135deg,var(--blue) 0%,#818cf8 100%);color:#fff;display:grid;place-items:center;box-shadow:0 2px 8px #3b82f666;overflow:hidden}.brand-logo{width:100%;height:100%;object-fit:contain;background:#fff}.brand-logo-text{display:grid;gap:1px;min-width:0}.brand-wordmark{display:block;font-size:14.5px;font-weight:800;letter-spacing:-.02em;color:var(--text);white-space:nowrap}.brand-logo-component--on-dark .brand-wordmark{color:#f1f5f9}.brand-logo-component--on-dark .brand-logo-text span{color:var(--side-muted)}.brand-logo-component--sm .brand-mark{width:32px;height:32px}.brand-logo-component--sm .brand-wordmark{font-size:13px}.brand-logo-component--lg .brand-mark{width:40px;height:40px}.brand-logo-component--lg .brand-wordmark{font-size:17px}.public-brand.brand-logo-component{color:inherit;text-decoration:none}.public-footer-brand-logo{margin-bottom:4px}.public-footer-brand-logo .brand-logo-text span{color:var(--muted);font-size:11px}.brand-mark.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.brand strong{display:block;font-size:14.5px;font-weight:800;letter-spacing:-.02em;color:#f1f5f9;white-space:nowrap}.brand span{display:block;margin-top:1px;color:var(--side-muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:148px}.sidebar-collapsed .brand{justify-content:center;gap:0}.sidebar-collapsed .brand strong,.sidebar-collapsed .brand span{display:none}.sidebar-section{display:grid;gap:4px}.sidebar-section-label{padding:0 10px 4px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--side-muted);white-space:nowrap}.sidebar-collapsed .sidebar-section-label{display:none}.filters{display:grid;gap:2px}.filters button{position:relative;min-height:40px;padding:0 10px 0 12px;border:1px solid transparent;border-radius:var(--r-sm);background:transparent;color:var(--side-muted);display:flex;align-items:center;gap:10px;text-align:left;font-size:13px;font-weight:500;overflow:hidden;white-space:nowrap;transition:background var(--fast) var(--ease),color var(--fast) var(--ease)}.filters button svg{flex:none;opacity:.85}.filters button span{overflow:hidden;text-overflow:ellipsis}.filters button:hover{background:var(--side-hover);color:var(--side-text)}.filters button:focus-visible{outline:2px solid var(--blue-light);outline-offset:-2px}.filters button.active{background:var(--side-active);color:#fff;font-weight:600;border-color:#60a5fa47}.filters button.active svg{color:#93c5fd;opacity:1}.filters button.active:before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--blue-light)}.sidebar-collapsed .filters button{justify-content:center;padding:0 8px}.sidebar-collapsed .filters button span{display:none}.status-filters button{min-height:34px;font-size:12px;padding-left:14px}.sidebar-collapse-btn{width:100%;min-height:34px;margin-top:auto;display:flex;align-items:center;justify-content:flex-end;gap:7px;padding:0 6px;border:none;background:none;color:var(--side-muted);border-radius:var(--r-sm);font-size:12px;font-weight:500;transition:color var(--fast) var(--ease),background var(--fast) var(--ease)}.sidebar-collapse-btn:hover{color:var(--side-text);background:var(--side-hover)}.sidebar-collapse-btn span{font-size:12px}.sidebar-collapsed .sidebar-collapse-btn{justify-content:center}.side-note{display:flex;gap:9px;align-items:flex-start;padding:12px;border-radius:var(--r-md);background:#3b82f612;border:1px solid rgba(59,130,246,.12);font-size:12px;line-height:1.5;color:var(--side-muted)}.side-note svg{flex:none;margin-top:1px;color:#93c5fd;opacity:.7}.side-note p{margin:0}.sidebar-collapsed .side-note{display:none}.week-list-toggle,.week-panel-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0;border:none;background:none;outline:none;color:var(--text);font-size:14px;font-weight:700;letter-spacing:-.01em;margin-bottom:14px;cursor:pointer;-webkit-appearance:none;appearance:none}.week-list-toggle em{font-style:normal;font-size:13px;font-weight:600;color:var(--blue);background:var(--blue-soft);border:1px solid var(--blue-border);border-radius:var(--r-pill);padding:1px 9px;margin-left:6px}.week-list-toggle svg,.week-panel-toggle svg{color:var(--muted);transition:transform var(--fast) var(--ease)}.week-list-toggle.open svg{transform:rotate(90deg)}.week-list-toggle:hover{color:var(--blue-dark)}.workspace{min-width:0;width:100%;max-width:1400px;margin-inline:auto;padding:28px 32px 56px}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:28px}.topbar-title h1{font-size:23px;font-weight:800;letter-spacing:-.025em;color:var(--text)}.topbar-title p{margin-top:4px;color:var(--muted);font-size:13.5px}.top-actions,.editor-actions,.week-switcher{display:flex;align-items:center;gap:8px}.top-actions{flex-wrap:wrap;justify-content:flex-end}.mobile-menu-btn{display:none;min-height:40px;min-width:40px;padding:0 11px;border:1px solid var(--line2);border-radius:10px;background:var(--surface);color:var(--text2);align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:600;box-shadow:var(--sh-xs);transition:all var(--fast) var(--ease)}.mobile-menu-btn:hover{border-color:var(--blue-border);color:var(--text)}.sync-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 18px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--r-md);margin-bottom:20px}.offline-banner{background:#eff6ff;border-color:#bfdbfe}.queue-banner{background:#ecfeff;border-color:#a5f3fc}.install-banner{background:#eef2ff;border-color:#c7d2fe}.update-banner{background:#f0fdf4;border-color:#bbf7d0}.sync-banner-text{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--text2)}.sync-banner-text svg{flex:none;margin-top:2px;color:var(--amber)}.sync-banner-text strong{display:block;margin-bottom:2px;color:var(--text);font-size:13.5px}.sync-banner-actions{display:flex;gap:8px;align-items:center;flex:none}.overview-grid{display:grid;gap:20px}.overview-hero{padding:24px 28px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.overview-hero-meta{display:flex;gap:32px;flex-wrap:wrap}.overview-hero-meta>div{display:grid;gap:2px}.overview-hero-meta span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.overview-hero-meta strong{font-size:15px;font-weight:700;color:var(--text)}.overview-progress{margin-top:16px}.overview-progress-bar{height:6px;background:var(--line);border-radius:99px;overflow:hidden}.overview-progress-bar span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),#818cf8);transition:width var(--slow) var(--ease)}.module-quickcards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.module-quickcard{position:relative;padding:18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);display:flex;flex-direction:column;gap:12px;cursor:pointer;text-align:left;box-shadow:var(--sh-xs);transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease),transform var(--fast) var(--ease)}.module-quickcard:hover{border-color:var(--blue-border);box-shadow:var(--sh-md);transform:translateY(-2px)}.module-quickcard-icon{width:40px;height:40px;border-radius:var(--r-md);display:grid;place-items:center;color:#fff;flex:none;box-shadow:0 2px 8px #00000026}.module-quickcard strong{display:block;font-size:22px;font-weight:800;letter-spacing:-.03em;color:var(--text)}.module-quickcard span{display:block;font-size:12px;color:var(--muted);margin-top:2px}.module-quickcard-arrow{position:absolute;top:14px;right:14px;color:var(--muted);transition:color var(--fast) var(--ease),transform var(--fast) var(--ease)}.module-quickcard:hover .module-quickcard-arrow{color:var(--blue);transform:translate(2px,-2px)}.overview-hint{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--blue-soft);border:1px solid var(--blue-border);border-radius:var(--r-md);color:var(--blue-dark);font-size:13px;font-weight:600}.overview-hint svg{flex:none}.overview-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.next-action{padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.next-action-kicker{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:10px}.next-action-head{margin-bottom:18px}.next-action-head h2{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}.next-action-head p{font-size:13px;color:var(--text2)}.next-action-buttons{display:flex;gap:10px;flex-wrap:wrap}.overview-actions{display:flex;flex-wrap:wrap;gap:10px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-xs)}.recent-panel{padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.recent-panel>.panel-title{margin-bottom:16px}.recent-list{display:grid;gap:8px}.recent-list button{width:100%;display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:8px 10px;text-align:left;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);padding:10px 13px;transition:border-color var(--fast) var(--ease),background var(--fast) var(--ease)}.recent-list button:hover{border-color:var(--blue-border);background:var(--blue-soft)}.recent-main{display:grid;gap:1px;min-width:0;flex:1 1 140px}.recent-main strong{overflow-wrap:anywhere}.recent-main span{font-size:13.5px;font-weight:600;color:var(--text)}.recent-main small{font-size:12px;color:var(--muted)}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.stat{padding:18px 20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);display:flex;align-items:center;gap:14px;box-shadow:var(--sh-xs);transition:box-shadow var(--fast) var(--ease),transform var(--fast) var(--ease)}.stat:hover{box-shadow:var(--sh-md);transform:translateY(-1px)}button.stat{width:100%;text-align:left;font:inherit;cursor:pointer;min-height:44px}button.stat:focus-visible{outline:none;box-shadow:var(--sh-blue)}button.stat .stat-chevron{margin-left:auto;color:var(--muted);flex-shrink:0;transition:transform var(--fast) var(--ease),color var(--fast) var(--ease)}button.stat:hover .stat-chevron{color:var(--blue);transform:translate(2px)}.stat>svg{width:40px;height:40px;padding:10px;border-radius:var(--r-md);flex:none}.stat strong{display:block;font-size:24px;font-weight:800;letter-spacing:-.03em;color:var(--text);line-height:1;font-variant-numeric:tabular-nums}.stat span{display:block;margin-top:5px;color:var(--muted);font-size:12px}.stat-brand>svg{background:var(--blue-soft);color:var(--blue)}.stat-success>svg{background:var(--green-soft);color:var(--green)}.stat-warning>svg{background:var(--amber-soft);color:var(--amber)}.stat-danger>svg{background:var(--red-soft);color:var(--red)}.profile-strip{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-bottom:20px}.profile-strip div{padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);box-shadow:var(--sh-xs)}.profile-strip span{display:block;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:5px}.profile-strip strong{display:block;font-size:13.5px;font-weight:600;color:var(--text);line-height:1.35;overflow-wrap:anywhere}.reports-head{margin-bottom:20px}.reports-head-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.reports-head-title h1,.reports-head-title h2{font-size:16px;font-weight:700;letter-spacing:-.015em;color:var(--text)}.reports-head-title p{margin-top:2px;color:var(--muted);font-size:12.5px;font-variant-numeric:tabular-nums}.reports-search{margin-bottom:0}.status-tabs{display:flex;gap:4px;padding:4px;background:var(--surface3);border:1px solid var(--line);border-radius:var(--r-md);overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scroll-padding-inline:4px;max-width:100%}.status-tabs::-webkit-scrollbar{display:none}.status-tab{flex:none;min-height:32px;padding:0 14px;border-radius:var(--r-pill);border:1px solid transparent;background:none;color:var(--muted);font-size:13px;font-weight:600;white-space:nowrap;display:flex;align-items:center;gap:7px;transition:all var(--fast) var(--ease)}.status-tab:hover{background:var(--surface);color:var(--text2)}.status-tab.active{background:var(--surface);color:var(--blue-dark);border-color:var(--blue-border);box-shadow:var(--sh-xs)}.content-grid{display:grid;grid-template-columns:310px minmax(0,1fr) 304px;gap:16px;align-items:start}.week-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:18px}.week-panel-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0;border:none;background:none;color:var(--text);font-size:14px;font-weight:700;letter-spacing:-.01em;margin-bottom:14px}.week-panel-toggle svg{color:var(--muted);transition:transform var(--fast) var(--ease)}.week-panel-toggle[aria-expanded=false] svg{transform:rotate(-90deg)}.week-panel-toggle:hover{color:var(--blue-dark)}.search{height:40px;display:flex;align-items:center;gap:8px;padding:0 12px;border:1px solid var(--line2);border-radius:10px;background:var(--surface2);color:var(--muted);margin-bottom:12px;transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease)}.search:focus-within{border-color:var(--blue);box-shadow:var(--sh-blue)}.search svg{flex:none}.search input{border:0;outline:0;background:transparent;min-width:0;width:100%;color:var(--text);font-size:13.5px}.search-clear{border:none;background:none;color:var(--muted);padding:0;display:flex;align-items:center}.search-clear:hover{color:var(--text2)}.week-list{display:grid;gap:6px;max-height:520px;overflow-y:auto;padding-right:3px;margin-right:-3px}.week-row{position:relative;width:100%;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);padding:10px 13px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;align-items:flex-start;text-align:left;transition:border-color var(--fast) var(--ease),background var(--fast) var(--ease)}.week-row:hover{border-color:var(--blue-border);background:var(--blue-soft)}.week-row.selected{border-color:var(--blue);background:var(--blue-soft);box-shadow:inset 3px 0 0 var(--blue)}.week-row-main{display:grid;gap:2px;min-width:0;flex:1 1 140px}.week-row-main strong{font-size:13px;font-weight:600;color:var(--text);overflow-wrap:anywhere}.week-row-main small{font-size:11.5px;color:var(--muted);font-variant-numeric:tabular-nums}.week-row-side{flex:1 1 auto;min-width:0;max-width:100%;display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:6px}.week-empty{display:grid;gap:8px;justify-items:center;text-align:center;padding:28px 16px;color:var(--muted)}.week-empty p{margin:0;font-size:13px}.week-empty strong{color:var(--text2);font-weight:600}.week-progress{margin-top:12px;padding-top:12px;border-top:1px solid var(--line);font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}.week-progress .progress-track{flex:1;height:4px;background:var(--line);border-radius:99px;overflow:hidden}.week-progress .progress-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),#818cf8)}.editor-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:22px;min-width:0;max-width:100%;overflow-x:clip}.editor-head{padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:6px;display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px}.editor-head h2{font-size:17px;font-weight:700;color:var(--text);margin-bottom:4px}.editor-head p{font-size:13px;color:var(--muted)}.editor-back{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--muted);border:none;background:none;padding:0;margin-bottom:14px;transition:color var(--fast) var(--ease)}.editor-back:hover{color:var(--blue-dark)}.editor-actions{flex-wrap:wrap}.progress-wrap{margin:18px 0;padding:14px 16px;background:var(--surface2);border:1px solid var(--line);border-radius:var(--r-md)}.progress-wrap>div:first-child{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.progress-wrap span{font-size:12.5px;color:var(--muted)}.progress-wrap strong{font-size:12.5px;font-weight:700;color:var(--text2)}.progress-track{height:5px;background:var(--line);border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),#818cf8);transition:width var(--slow) var(--ease)}.progress-bar{height:5px;background:var(--line);border-radius:99px;overflow:hidden}.editor-sections{display:grid;gap:16px;margin-top:18px}.editor-section{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease)}.editor-section:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.editor-section:focus-within .editor-section-title{color:var(--blue-dark)}.editor-section-title{padding:11px 14px;font-size:12.5px;font-weight:700;color:var(--text2);background:var(--surface2);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}.editor-section>textarea,.editor-section>.section-body{display:block;width:100%;padding:14px;background:var(--surface);border:0;outline:0;font:inherit;color:var(--text);font-size:13.5px;line-height:1.65;resize:vertical;min-height:100px}.hours-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}.form-section-optional{margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}.form-section-optional .form-section-title{margin:0 0 6px;font-size:15px;font-weight:700;color:var(--text)}.form-section-optional .form-section-hint{margin:0 0 16px;font-size:13px;line-height:1.5;color:var(--text2)}.editor-confirm{margin-top:18px;padding:16px;background:var(--red-soft);border:1px solid var(--red-border);border-radius:var(--r-md)}.editor-confirm p{font-size:13px;color:var(--text2);margin-bottom:12px}.editor-confirm-actions{display:flex;gap:8px}.right-panel{display:grid;gap:14px;min-width:0}.right-panel>section{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.missed{padding:18px}.missed-list{display:grid;gap:6px}.missed-list button{width:100%;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);padding:10px 13px;display:flex;justify-content:space-between;align-items:center;gap:10px;text-align:left;transition:border-color var(--fast) var(--ease),background var(--fast) var(--ease)}.missed-list button:hover{border-color:var(--blue-border);background:var(--blue-soft)}.missed-main{display:grid;gap:2px;min-width:0}.missed-list span{display:block;font-size:13px;font-weight:600;color:var(--text)}.missed-list small{display:block;margin-top:1px;color:var(--muted);font-size:12px}.missed-empty{display:grid;gap:3px;padding:8px 2px;color:var(--muted);font-size:12.5px}.missed-empty strong{color:var(--text2);font-weight:600}.overdue-tag{font-style:normal;font-size:11px;font-weight:600;color:var(--red);background:var(--red-soft);border:1px solid var(--red-border);border-radius:var(--r-pill);padding:3px 9px;flex:none}.panel-title{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.panel-title.split{justify-content:space-between;align-items:center}.panel-title-left{display:flex;align-items:flex-start;gap:12px}.panel-title>svg,.panel-title-left>svg{width:34px;height:34px;padding:8px;border-radius:var(--r-sm);background:var(--blue-soft);color:var(--blue);flex:none}.panel-title h2{font-size:14.5px;font-weight:700;color:var(--text)}.panel-title p{margin-top:2px;color:var(--muted);font-size:12px}.badge,.status-dot{display:inline-flex;align-items:center;gap:5px;border-radius:var(--r-pill);font-size:11.5px;font-style:normal;font-weight:600;line-height:1;padding:4px 9px 4px 8px;border:1px solid transparent;white-space:nowrap}.badge:before,.status-dot:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;flex:none}.badge-open,.status-dot.open{color:var(--slate);background:var(--slate-soft);border-color:var(--slate-border)}.badge-draft,.status-dot.draft{color:var(--amber);background:var(--amber-soft);border-color:var(--amber-border)}.badge-complete,.status-dot.complete,.badge-approved,.status-dot.approved,.badge-released{color:var(--green);background:var(--green-soft);border-color:var(--green-border)}.badge-submitted,.status-dot.submitted{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.badge-rejected,.status-dot.rejected{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.badge-submitted{color:var(--blue-dark);background:var(--blue-soft);border-color:var(--blue-border)}.badge-returned{color:var(--red);background:var(--red-soft);border-color:var(--red-border)}.badge-exported{color:var(--text2);background:var(--surface3);border-color:var(--line2)}.badge-current,.status-dot.current{color:var(--blue-dark);background:var(--blue-soft);border-color:var(--blue-border)}.badge-planned,.status-dot.planned{color:var(--muted);background:var(--slate-soft);border-color:var(--slate-border)}.status-dot{margin-bottom:10px}.week-row .badge,.recent-list .badge,.editor-head-title .status-dot{white-space:normal;line-height:1.35;text-align:left;max-width:100%;overflow-wrap:anywhere}.field{display:grid;gap:6px}.field label,.field-label{font-size:12.5px;font-weight:600;color:var(--text2);letter-spacing:.01em}.field-label em{font-style:normal;color:var(--red);margin-left:2px}.field .hint,.field-hint{font-size:12px;color:var(--muted);line-height:1.5}.field .error,.field-message{font-size:12px;color:var(--red);font-weight:500;line-height:1.5}.field-error input,.field-error textarea,.field-error select{border-color:var(--red)}.field-error input:focus,.field-error textarea:focus,.field-error select:focus{border-color:var(--red);box-shadow:var(--ring-red)}input[type=text],input[type=email],input[type=password],input[type=date],input[type=number],select,textarea{display:block;width:100%;min-height:42px;padding:9px 13px;border:1.5px solid var(--line2);border-radius:10px;background:var(--surface);color:var(--text);font-size:13.5px;outline:none;transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease);-webkit-appearance:none;appearance:none}input:hover:not(:disabled):not(:focus),select:hover:not(:disabled):not(:focus),textarea:hover:not(:disabled):not(:focus){border-color:#b6c4d9}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:var(--sh-blue)}input:disabled,select:disabled,textarea:disabled{background:var(--surface3);color:var(--muted);cursor:not-allowed}input::placeholder,textarea::placeholder{color:#94a3b8}input:-webkit-autofill{-webkit-box-shadow:0 0 0 100px var(--blue-soft) inset;-webkit-text-fill-color:var(--text)}select option{background:#fff;color:var(--text)}textarea{resize:vertical;min-height:100px;line-height:1.65}input[type=checkbox],input[type=radio]{accent-color:var(--blue)}.form-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row.triple{grid-template-columns:1fr 1fr 1fr}.profile-form{display:grid;gap:16px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px}.form-grid .field.span-full,.form-grid .span-full,.form-grid>*:last-child:nth-child(odd){grid-column:1 / -1}.form-section-block{display:grid;gap:12px;margin-top:8px}.form-section-block+.form-section-block{margin-top:22px;padding-top:22px;border-top:1px solid var(--line)}.duration-options{display:grid;gap:10px}.duration-option{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.45;cursor:pointer}.duration-option input{margin-top:3px;flex-shrink:0}.setup-steps{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.setup-step-pill{font-size:11.5px;line-height:1.3;padding:6px 10px;border-radius:999px;border:1px solid var(--line);color:var(--muted);background:var(--surface-2, #f8fafc)}.setup-step-pill.is-active{color:var(--text);border-color:var(--blue);background:color-mix(in srgb,var(--blue) 8%,white);font-weight:600}.setup-step-pill.is-done{color:var(--text);border-color:color-mix(in srgb,var(--blue) 35%,var(--line))}.setup-step-indicator{margin:0 0 14px;font-size:13px;color:var(--muted)}.setup-form-hint,.setup-form-note{margin:0 0 14px;font-size:13px;line-height:1.5;color:var(--muted)}.setup-step-actions{justify-content:space-between}.setup-step-actions .btn-primary,.setup-step-actions .btn:not(.btn-ghost){margin-left:auto}.char-count{text-align:right;font-size:11.5px;color:var(--muted);margin-top:4px}.preview{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:20px}.preview-paper{margin-top:16px;background:#fff;color:#1a1a1a;border:1px solid #dde3ec;border-radius:var(--r-md);padding:28px 30px;font-size:12.5px;line-height:1.65;box-shadow:0 1px 4px #0f172a0f}.preview-paper header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding-bottom:16px;border-bottom:2px solid #1e3a5f;margin-bottom:18px}.preview-paper-branding{display:inline-flex;align-items:center;gap:10px}.preview-paper-logo{width:28px;height:28px;object-fit:contain}.preview-paper header strong{font-size:16px;font-weight:800;color:#1e3a5f}.preview-paper header span{font-size:12px;color:#64748b}.preview-meta{display:grid;gap:0;margin-bottom:20px;border:1px solid #dde3ec;border-radius:6px;overflow:hidden}.preview-meta>div{display:grid;grid-template-columns:160px 1fr;border-bottom:1px solid #eef2f7}.preview-meta>div:last-child{border-bottom:none}.preview-meta>div span{padding:8px 12px;font-size:11.5px;font-weight:700;color:#64748b;background:#f8fafc;border-right:1px solid #eef2f7;letter-spacing:.01em;display:flex;align-items:center}.preview-meta>div strong{padding:8px 14px;font-size:12.5px;font-weight:500;color:#1a1a1a;display:flex;align-items:center}.preview-paper article{margin-bottom:20px}.preview-paper article h3{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#1e3a5f;padding-bottom:6px;border-bottom:1px solid #dde3ec;margin-bottom:10px}.preview-paper article p{font-size:12.5px;color:#374151;line-height:1.7;white-space:pre-wrap}.preview-sign{display:flex;justify-content:space-between;gap:20px;margin-top:28px;padding-top:16px;border-top:1px solid #dde3ec}.preview-sign>div{flex:1;padding-top:28px;border-top:1px solid #374151;font-size:11px;color:#64748b}.preview-view{width:100%;max-width:100%;display:grid;gap:16px;box-sizing:border-box}.preview-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:14px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.preview-toolbar .field{flex:2;min-width:0}.preview-toolbar select{min-width:0;width:100%}.preview-week-select{display:flex;align-items:center;gap:8px}.preview-section{width:100%;min-width:0}.preview-section-heading{display:grid;gap:4px;margin-bottom:12px}.preview-section-heading h2{font-size:16px;font-weight:700;color:var(--text);margin:0}.preview-section-heading p{font-size:13px;color:var(--text2);margin:0;line-height:1.45}.preview-backup-section,.preview-pdf-section{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:18px;width:100%;box-sizing:border-box}.preview-backup-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.preview-backup-actions .btn{min-height:44px;justify-content:center;width:100%}.preview-pdf-section{display:grid;gap:14px}.preview-pdf-toolbar{display:flex;justify-content:flex-start}.preview-pro-hint{margin:0;padding:14px 16px;font-size:13px;line-height:1.5;color:var(--text2);background:linear-gradient(135deg,var(--blue-soft) 0%,#eef2ff 100%);border:1px solid var(--blue-border);border-radius:var(--r-md)}.preview-pro-hint-link{background:none;border:none;padding:0;color:var(--blue);font:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.preview-pro-hint-link:hover{color:var(--blue-dark, #1d4ed8)}.preview-pro-hint-link:focus-visible{outline:none;box-shadow:var(--sh-blue)}.toolbar-group{display:flex;align-items:center;gap:8px}.toolbar-spacer{flex:1}.pdf-export-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:18px;display:grid;gap:12px}.pdf-week-picker{max-height:180px;overflow:auto;border:1px solid var(--line);border-radius:var(--r-md);padding:8px;background:var(--surface2);display:grid;gap:6px}.pdf-week-option{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text2)}.pdf-branding-card{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);padding:12px;display:grid;gap:10px}.pdf-branding-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.pdf-logo-preview{min-height:100px;border:1px dashed var(--line2);border-radius:var(--r-sm);display:grid;place-items:center;background:#fff;color:var(--muted)}.pdf-logo-preview img{max-width:100%;max-height:96px;object-fit:contain}.pdf-export-summary{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:12.5px;color:var(--text2)}.pdf-export-explainer{font-size:12.5px;color:var(--text2);margin:6px 0 0}.pdf-export-warning{font-size:12.5px;color:var(--text);background:var(--surface2);border:1px solid var(--line);border-radius:var(--r-md);padding:8px 10px;margin:6px 0 0}.pdf-export-regional-hint{font-size:11.5px;color:var(--text2);margin:6px 0 0;opacity:.85}.pdf-export-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:4px 0 2px}.pdf-mode-chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.pdf-mode-chip{display:grid;gap:2px;text-align:left;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);cursor:pointer;transition:border-color .15s ease,background .15s ease}.pdf-mode-chip:hover{border-color:var(--accent)}.pdf-mode-chip.is-active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.pdf-mode-chip strong{font-size:13px;color:var(--text)}.pdf-mode-chip span{font-size:11.5px;color:var(--text2)}.pdf-toggle-row{display:flex;flex-wrap:wrap;gap:16px}.pdf-toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text);cursor:pointer}.pdf-toggle input{width:16px;height:16px;accent-color:var(--accent)}.pdf-toggle.is-locked{color:var(--text2)}.pdf-week-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.pdf-week-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);cursor:pointer}.pdf-week-card.is-selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface))}.pdf-week-card input{margin-top:3px;accent-color:var(--accent)}.pdf-week-card-body{display:grid;gap:3px;min-width:0}.pdf-week-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.pdf-week-card-head strong{font-size:13px;color:var(--text)}.pdf-week-status{font-size:10.5px;color:var(--text2);background:var(--surface2);border:1px solid var(--line);border-radius:999px;padding:1px 8px;white-space:nowrap}.pdf-week-meta{font-size:11.5px;color:var(--text2)}.pdf-empty-hint{font-size:12.5px;color:var(--text2)}.pdf-export-limit{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:12.5px;color:var(--text);background:color-mix(in srgb,var(--accent) 8%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));border-radius:var(--r-md);padding:8px 10px}.pdf-export-limit-cta{border:none;background:none;color:var(--accent);font:inherit;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.pdf-preview-pane{display:grid;gap:10px}.pdf-preview-card{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);padding:12px;display:grid;gap:4px}.pdf-preview-card h3{font-size:13.5px;color:var(--text)}.pdf-preview-card p{font-size:12.5px;color:var(--text2)}.pdf-preview-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.pdf-preview-cover{background:var(--surface);border-style:solid}.pdf-preview-tag{justify-self:start;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);font-weight:700}.pdf-cover-rows{display:grid;gap:3px;margin:4px 0 0}.pdf-cover-rows>div{display:grid;grid-template-columns:minmax(120px,40%) 1fr;gap:8px}.pdf-cover-rows dt{font-size:11.5px;color:var(--text2)}.pdf-cover-rows dd{font-size:11.5px;color:var(--text);margin:0}.pdf-cover-disclaimer{font-size:10.5px;color:var(--text2);margin-top:6px}.pdf-preview-hours{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--text2)}.pdf-preview-hours strong{color:var(--text)}.pdf-preview-excerpt{font-size:12px;color:var(--text2)}.settings-panel{max-width:100%;display:grid;gap:14px}.settings-autosave-note{margin:0 2px;font-size:12.5px;color:var(--muted)}.settings-section{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-xs);background:var(--surface)}.settings-section.open{box-shadow:var(--sh-sm)}.settings-section-heading{margin:0;font:inherit}.settings-section-toggle{width:100%;display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--surface);color:var(--text);border:none;cursor:pointer;text-align:left;transition:background var(--fast) var(--ease)}.settings-section-toggle:hover{background:var(--surface2)}.settings-section-toggle:focus-visible{outline:2px solid var(--blue);outline-offset:-2px}.settings-section-icon{width:34px;height:34px;flex:none;border-radius:var(--r-sm);display:grid;place-items:center;background:var(--blue-soft);color:var(--blue)}.settings-section-titles{display:grid;gap:2px;min-width:0;flex:1}.settings-section-title{font-size:14px;font-weight:700;color:var(--text);overflow-wrap:anywhere}.settings-section-desc{font-size:12.5px;color:var(--muted);overflow-wrap:anywhere}.settings-chevron{flex:none;color:var(--muted);transition:transform var(--mid) var(--ease)}.settings-section-toggle[aria-expanded=true] .settings-chevron{transform:rotate(180deg)}.settings-collapse{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--mid) var(--ease)}.settings-collapse.open{grid-template-rows:1fr}.settings-collapse-inner{overflow:hidden;min-height:0;visibility:hidden;transition:visibility 0s linear var(--mid)}.settings-collapse.open .settings-collapse-inner{visibility:visible;transition-delay:0s}.settings-section-content{padding:18px;border-top:1px solid var(--line);background:var(--surface)}@media(prefers-reduced-motion:reduce){.settings-collapse,.settings-chevron{transition:none}}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row strong{font-size:13.5px;color:var(--text)}.settings-row p{margin:3px 0 0;font-size:12px;color:var(--muted)}.cloud-status{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);font-size:13px;color:var(--text2);margin-bottom:0;min-width:0}.account-email{overflow-wrap:anywhere;min-width:0}.cloud-dot{width:8px;height:8px;border-radius:50%;flex:none}.cloud-dot.ok{background:var(--green);box-shadow:0 0 6px #05966966}.cloud-dot.err{background:var(--red)}.cloud-dot.idle{background:var(--muted)}.cloud-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.danger-zone{margin-top:18px;padding:16px;background:var(--red-soft);border:1px solid var(--red-border);border-radius:var(--r-md)}.danger-zone h4{font-size:13.5px;font-weight:700;color:var(--red);margin:0 0 6px}.danger-zone p{font-size:12.5px;color:var(--text2);margin-bottom:12px}.danger-actions{display:flex;gap:8px;flex-wrap:wrap}.sync-summary{font-size:12.5px;color:var(--muted);padding:12px 14px;background:var(--surface2);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:12px;display:grid;gap:4px}.sync-summary strong{color:var(--text2);font-size:13px}.account-security{display:grid;gap:16px}.account-security .danger-zone{margin-top:0}.module-panel{display:grid;gap:18px;max-width:100%}.module-hero{display:flex;align-items:center;gap:18px;padding:22px 26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);flex-wrap:wrap}.module-hero h2{font-size:19px;font-weight:800;letter-spacing:-.02em;color:var(--text);margin:0}.module-hero p{margin:4px 0 0;font-size:13.5px;color:var(--muted)}.module-hero-icon{width:52px;height:52px;border-radius:var(--r-lg);display:grid;place-items:center;color:#fff;flex:none;box-shadow:0 4px 12px #00000026}.module-hero-stats{display:flex;gap:24px;margin-left:auto}.module-hero-stat{text-align:center;margin-left:auto}.module-hero-stat strong{display:block;font-size:26px;font-weight:800;letter-spacing:-.03em;color:var(--blue);font-variant-numeric:tabular-nums}.module-hero-stat span{display:block;font-size:11.5px;color:var(--muted);margin-top:2px}.module-empty{display:grid;gap:12px;justify-items:center;text-align:center;padding:52px 24px;color:var(--muted);background:var(--surface);border:1.5px dashed var(--line2);border-radius:var(--r-lg)}.module-empty svg{opacity:.25;color:var(--blue)}.module-empty strong{font-size:16px;color:var(--text2)}.module-empty span{font-size:13.5px;max-width:320px;line-height:1.65}.subjects-list{display:grid;gap:12px}.subject-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-xs)}.subject-header{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;background:none;border:none;width:100%;text-align:left;transition:background var(--fast) var(--ease)}.subject-header:hover{background:var(--surface2)}.subject-header-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.subject-header-left svg{flex:none;color:var(--muted)}.subject-header-left span{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subject-header-right{display:flex;align-items:center;gap:10px;flex:none}.subject-avg{font-size:24px;font-weight:800;letter-spacing:-.03em;min-width:30px;text-align:center}.grade-chip{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:24px;border-radius:var(--r-pill);font-size:12.5px;font-weight:700;padding:0 9px;border:1px solid transparent}.grade-entries{border-top:1px solid var(--line);padding:12px 16px;display:grid;gap:8px;background:var(--surface2)}.grade-entry{display:flex;align-items:center;gap:12px;font-size:13.5px}.grade-entry-date{color:var(--muted);font-size:12px;flex:none;font-variant-numeric:tabular-nums}.grade-entry-note{flex:1;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grade-add-form{border-top:1px solid var(--line);padding:14px 16px;background:var(--surface2)}.grade-add-row{display:grid;grid-template-columns:1fr 90px 1fr;gap:10px;margin-bottom:10px}.add-subject-form{padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);display:grid;gap:12px;box-shadow:var(--sh-xs)}.obj-overall-progress{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;display:flex;align-items:center;gap:14px}.obj-overall-bar{flex:1;height:6px;background:var(--line);border-radius:99px;overflow:hidden}.obj-overall-bar span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),#818cf8)}.obj-overall-progress>span{font-size:12.5px;color:var(--muted);white-space:nowrap}.obj-categories{display:grid;gap:12px}.obj-category{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-xs)}.obj-category-header{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-size:13.5px;font-weight:600;color:var(--text);transition:background var(--fast) var(--ease)}.obj-category-header:hover{background:var(--surface2)}.obj-category-header>svg{flex:none;color:var(--muted)}.obj-category-header>span{flex:1}.obj-category-header>em{font-style:normal;font-size:12px;color:var(--muted);white-space:nowrap}.obj-progress-mini{width:64px;height:4px;background:var(--line);border-radius:99px;overflow:hidden;flex:none}.obj-progress-mini span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),#818cf8)}.obj-list{border-top:1px solid var(--line);overflow:hidden}.obj-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line);transition:background var(--fast) var(--ease)}.obj-item:last-child{border-bottom:none}.obj-item:hover{background:var(--surface2)}.obj-achieved{opacity:.55}.obj-check{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line2);background:none;color:var(--muted);display:grid;place-items:center;flex:none;transition:all var(--fast) var(--ease)}.obj-check:hover{border-color:var(--blue);color:var(--blue)}.obj-content{flex:1;min-width:0}.obj-title{font-size:13.5px;color:var(--text)}.obj-note{font-size:12px;color:var(--muted);margin-top:2px}.obj-meta{display:flex;align-items:center;gap:8px;flex:none}.obj-badge{display:inline-flex;align-items:center;gap:5px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600;padding:3px 9px}.obj-add-form{padding:14px 16px;background:var(--surface2);border-top:1px solid var(--line);display:grid;gap:10px}.absence-type-legend{display:flex;gap:12px;flex-wrap:wrap;padding:14px 16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md)}.absence-legend-item{display:flex;align-items:center;gap:7px}.absence-legend-item strong{font-size:12.5px;color:var(--text2)}.absence-badge{display:inline-flex;align-items:center;gap:4px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600;padding:3px 10px;border:1px solid transparent;white-space:nowrap}.absence-add-form,.deployment-add-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;display:grid;gap:14px;box-shadow:var(--sh-xs)}.absence-add-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}.absence-list,.deployment-list{display:grid;gap:8px}.absence-row,.deployment-row{position:relative;display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease);box-shadow:var(--sh-xs)}.absence-row:hover,.deployment-row:hover{border-color:var(--blue-border);box-shadow:var(--sh-sm)}.absence-dates,.deployment-dates{flex:1;min-width:0}.absence-dates strong,.deployment-dates strong{display:block;font-size:13.5px;font-weight:600;color:var(--text)}.absence-dates span,.deployment-dates span{display:block;font-size:12px;color:var(--muted);margin-top:2px}.absence-days,.deployment-days{font-size:13px;font-weight:700;color:var(--text2);white-space:nowrap}.dept-legend{display:flex;gap:8px;flex-wrap:wrap;padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md)}.dept-chip,.dept-chip-sm{display:inline-flex;align-items:center;border-radius:var(--r-pill);font-size:12px;font-weight:600;padding:4px 12px;border:1px solid transparent}.dept-chip-sm{font-size:11.5px;padding:3px 9px}.deployment-stripe{position:absolute;left:0;top:0;bottom:0;width:4px}.deployment-phase{font-size:11px;font-weight:700;border-radius:var(--r-pill);padding:3px 8px;border:1px solid var(--line)}.deployment-phase-past{color:var(--muted);background:var(--surface2)}.deployment-phase-current{color:var(--green);background:var(--green-soft);border-color:var(--green-border)}.deployment-phase-future{color:var(--blue-dark);background:var(--blue-soft);border-color:var(--blue-border)}.deployment-row-current{border-color:var(--green-border);box-shadow:0 0 0 2px #05966914}.module-toolbar-row{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:12px}.module-toolbar-row-dual{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.calendar-panel{display:grid;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-sm)}.calendar-head{display:grid;gap:8px}.calendar-head h2{font-size:19px;font-weight:800}.calendar-head p{font-size:13px;color:var(--muted)}.calendar-controls{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.calendar-controls strong{font-size:14px;color:var(--text2);min-width:140px;text-transform:capitalize}.calendar-legend{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:12px;color:var(--text2)}.calendar-legend span{display:inline-flex;align-items:center;gap:6px}.calendar-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.calendar-dot.report-open{background:var(--slate)}.calendar-dot.report-draft{background:var(--amber)}.calendar-dot.report-complete{background:var(--green)}.calendar-dot.absence{background:#f59e0b}.calendar-dot.deployment{background:var(--blue)}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.calendar-weekday{text-align:center;font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase}.calendar-cell{min-height:78px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface2);padding:6px;display:flex;flex-direction:column;gap:6px}.calendar-cell.is-muted{opacity:.5}.calendar-cell.is-current-week{border-color:var(--blue-border)}.calendar-cell.is-today{box-shadow:inset 0 0 0 2px #3b82f626}.calendar-cell.is-out-of-training{background:#f8fafc;border-style:dashed}.calendar-day{font-size:12px;font-weight:700;color:var(--text2)}.calendar-events{display:flex;gap:5px;flex-wrap:wrap}.calendar-event{width:22px;height:22px;border:1px solid transparent;border-radius:999px;font-size:11px;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;background:var(--surface);color:var(--text2)}.calendar-event.report-open{background:var(--slate-soft);border-color:var(--slate-border);color:var(--slate)}.calendar-event.report-draft{background:var(--amber-soft);border-color:var(--amber-border);color:var(--amber)}.calendar-event.report-complete{background:var(--green-soft);border-color:var(--green-border);color:var(--green)}.calendar-event.absence{background:#fff7ed;border-color:#fdba74;color:#c2410c}.calendar-event.deployment{background:var(--blue-soft);border-color:var(--blue-border);color:var(--blue-dark)}.calendar-event:disabled{opacity:.45;cursor:not-allowed}.icon-btn-sm{width:28px;height:28px;border:1px solid var(--line2);border-radius:var(--r-sm);background:none;color:var(--muted);display:grid;place-items:center;flex:none;transition:all var(--fast) var(--ease)}.icon-btn-sm:hover{background:var(--surface2);color:var(--text2);border-color:var(--line2)}.icon-btn-sm.danger{color:var(--red);border-color:var(--red-border)}.icon-btn-sm.danger:hover{background:var(--red-soft)}.empty-state{display:grid;gap:14px;justify-items:center;text-align:center;padding:48px 24px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-xs)}.empty-state svg{opacity:.3;color:var(--blue)}.empty-state h3{font-size:17px;font-weight:700;color:var(--text2)}.empty-state p{font-size:13.5px;line-height:1.65;max-width:360px}.section-heading{margin-bottom:24px}.section-heading h1{font-size:22px;font-weight:800;color:var(--text)}.section-heading p{margin-top:5px;color:var(--muted);font-size:13.5px}.setup-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.setup-card{width:100%;max-width:860px;display:grid;grid-template-columns:200px 1fr;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);border:1px solid var(--line)}.setup-aside{background:var(--side);padding:28px 20px;border-right:1px solid rgba(255,255,255,.05)}.setup-main{background:var(--surface);padding:36px 32px}.setup-account{display:grid;gap:16px;margin-top:24px}.setup-card.foreign-card{display:block;width:100%;max-width:720px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(24px,4vw,40px);box-shadow:var(--sh-lg)}.foreign-screen{display:flex;flex-direction:column;min-width:0}.foreign-card .brand{overflow:visible}.foreign-card .brand strong{white-space:normal;color:var(--text);font-size:16px}.foreign-card .brand span{max-width:none;white-space:normal;overflow:visible;text-overflow:clip;color:var(--text2)}.foreign-email{overflow-wrap:anywhere}.foreign-note{font-size:12.5px;color:var(--muted);margin-top:16px}.foreign-text{margin-top:18px;font-size:14px;line-height:1.6;color:var(--text2)}.foreign-summary{display:grid;gap:0;margin-top:18px;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.foreign-summary>div{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:11px 14px;min-width:0}.foreign-summary>div+div{border-top:1px solid var(--line)}.foreign-summary dt{font-size:13px;color:var(--text2)}.foreign-summary dd{font-size:13.5px;font-weight:700;color:var(--text)}.foreign-actions{display:grid;gap:10px;margin-top:22px}.foreign-actions .btn{width:100%;white-space:normal;height:auto;min-height:44px;padding:10px 16px;text-align:center;line-height:1.35}.foreign-confirm{margin-top:20px;padding:16px;border-radius:var(--r-md);background:var(--red-soft);border:1px solid var(--red-border)}.foreign-confirm p{font-size:13.5px;line-height:1.6;color:var(--text2)}.foreign-confirm .foreign-actions{margin-top:14px}.setup-card.auth-gate{display:grid;grid-template-columns:minmax(0,.42fr) minmax(0,.58fr);align-items:stretch;width:100%;max-width:1040px;background:var(--surface)}.auth-gate .setup-aside{display:flex;flex-direction:column;gap:28px;background:var(--side);color:var(--side-text);padding:clamp(28px,3vw,44px)}.auth-gate .setup-aside .brand strong{font-size:17px}.auth-gate .setup-aside .brand span{max-width:none;white-space:normal;overflow:visible;text-overflow:clip}.auth-gate .setup-main{display:flex;flex-direction:column;justify-content:center;padding:clamp(28px,3vw,44px);min-width:0}.auth-form-wrap{width:100%;max-width:400px;margin:0 auto;min-width:0}.auth-forgot{display:inline-block;margin-top:-2px;justify-self:start}.auth-benefits{display:grid;gap:18px;margin-top:auto;list-style:none;padding:0}.auth-benefit{display:flex;align-items:flex-start;gap:12px;min-width:0}.auth-benefit-icon{flex:none;width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:#60a5fa29;color:var(--blue-light)}.auth-benefit>span{display:grid;gap:2px;min-width:0}.auth-benefit strong{font-size:13.5px;font-weight:700;color:var(--side-text)}.auth-benefit>span>span{font-size:12.5px;line-height:1.45;color:var(--side-muted)}.auth-callback-banner{display:flex;align-items:flex-start;gap:12px;padding:16px;margin-bottom:22px;border-radius:var(--r-md);background:var(--amber-soft);border:1px solid var(--amber-border)}.auth-callback-banner>svg{flex:none;margin-top:1px;color:var(--amber)}.auth-callback-banner strong{display:block;font-size:14px;color:var(--text)}.auth-callback-banner p{margin-top:4px;font-size:13px;color:var(--text2)}.auth-callback-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.auth-success{display:grid;gap:12px;justify-items:center;text-align:center;padding:8px 0}.auth-success-icon{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.auth-success h1{font-size:21px;font-weight:800;color:var(--text)}.auth-success p{font-size:14px;line-height:1.6;color:var(--text2);max-width:340px}.auth-success .btn{margin-top:6px}.verify-email-step{display:grid;gap:12px;justify-items:center;text-align:center;padding:8px 0}.verify-email-step h1{font-size:21px;font-weight:800;color:var(--text)}.verify-email-step>p{font-size:14px;line-height:1.6;color:var(--text2);max-width:340px;overflow-wrap:anywhere}.verify-email-address{color:var(--text);font-weight:700}.verify-code-form{display:grid;gap:14px;justify-items:center;width:100%;max-width:320px}.verify-code-inputs{display:flex;gap:10px;justify-content:center}.verify-code-inputs input{width:clamp(44px,13vw,56px);height:clamp(52px,15vw,62px);text-align:center;font-size:24px;font-weight:700;color:var(--text);background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r-md);transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease)}.verify-code-inputs input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 18%,transparent)}.verify-code-form .btn{width:100%;justify-content:center}.verify-code-form .inline-info{width:100%;text-align:left}.inline-info--success{background:var(--green-soft);border-color:var(--green-border);color:var(--green)}.verify-code-actions{display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:center}.verify-code-actions .link-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px}.verify-code-actions .link-btn:disabled{opacity:.55;cursor:default;text-decoration:none}.auth-box{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:36px;box-shadow:var(--sh-lg)}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.auth-tabs{display:flex;gap:0;border:1.5px solid var(--line2);border-radius:var(--r-pill);overflow:hidden;margin-bottom:24px}.auth-tab{flex:1;min-height:38px;border:none;border-radius:0;background:none;color:var(--muted);font-size:13.5px;font-weight:600;transition:all var(--fast) var(--ease)}.auth-tab.active{background:var(--blue);color:#fff}.auth-error{padding:12px 14px;border:1px solid var(--red-border);border-radius:var(--r-md);background:var(--red-soft);color:var(--red);font-size:13px;margin-bottom:14px}.auth-toggle{display:flex;position:relative;background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r-pill);padding:3px;gap:2px;margin-bottom:22px}.auth-toggle button{flex:1;position:relative;min-height:36px;border:none;border-radius:calc(var(--r-pill) - 3px);background:none;color:var(--muted);font-size:13.5px;font-weight:600;cursor:pointer;transition:color var(--fast) var(--ease);z-index:1}.auth-toggle button.active{color:var(--text)}.auth-seg-bg{position:absolute;inset:0;border-radius:inherit;background:var(--surface);box-shadow:0 1px 4px #0000001a;z-index:-1}.auth-gate-form{display:grid;gap:14px}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon input{flex:1;padding-right:38px}.input-icon-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;padding:4px;transition:color var(--fast) var(--ease)}.input-icon-btn:hover{color:var(--text)}.inline-info{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-radius:var(--r-md);background:var(--red-soft);border:1px solid var(--red-border);color:var(--red);font-size:13px}.inline-info svg{flex-shrink:0;margin-top:1px}.auth-switch-hint{font-size:13px;color:var(--muted);text-align:center;margin-top:6px}.auth-switch-hint .link-btn{font-size:13px}.setup-points{display:grid;gap:12px;margin-top:24px}.setup-points p{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;color:var(--side-muted);line-height:1.45}.setup-points p svg{flex-shrink:0;margin-top:1px;color:var(--blue-light)}.section-heading>span{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}.drawer-overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100}.drawer{position:fixed;left:0;top:0;bottom:0;width:280px;max-width:86vw;background:var(--side);border-right:1px solid rgba(255,255,255,.06);padding:max(12px,env(safe-area-inset-top)) 14px max(16px,env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:12px;z-index:101;overflow:hidden;box-sizing:border-box}.drawer-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex:none}.drawer-head .brand{padding:0;min-width:0}.drawer-close-btn{flex:none;width:36px;height:36px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--side-text)}.drawer-close-btn:hover{border-color:#ffffff47;color:#fff;background:#ffffff14}.drawer-user{display:flex;align-items:center;gap:10px;flex:none;padding:10px 12px;border-radius:var(--r-md);background:#ffffff0a;min-width:0}.drawer-user>div{display:grid;min-width:0}.drawer-user strong{font-size:13px;color:var(--side-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawer-user span{font-size:12px;color:var(--side-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawer-avatar{width:36px;height:36px;flex:none;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;background:linear-gradient(135deg,var(--blue) 0%,#818cf8 100%);color:#fff}.drawer-nav{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:14px}.back-btn{min-height:36px;padding:0 14px;border:1px solid var(--line2);border-radius:10px;background:var(--surface);color:var(--text2);display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;box-shadow:var(--sh-xs);transition:all var(--fast) var(--ease)}.back-btn:hover{border-color:var(--blue-border);color:var(--text)}@media(max-width:1200px){.content-grid{grid-template-columns:260px minmax(0,1fr)}.content-grid .right-panel{display:none}.profile-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.overview-columns{grid-template-columns:1fr}}@media(max-width:900px){.module-quickcards{grid-template-columns:repeat(2,minmax(0,1fr))}.absence-add-row{grid-template-columns:1fr 1fr}.settings-grid,.module-toolbar-row-dual{grid-template-columns:1fr}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr))}}@media(max-width:740px){.app-shell{grid-template-columns:1fr;width:100%;max-width:100%;overflow-x:hidden}.sidebar{display:none}.mobile-menu-btn{display:flex}.workspace{width:100%;max-width:100%;box-sizing:border-box;padding:14px 12px 64px;overflow-x:hidden}.topbar{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:0;margin-bottom:20px;width:100%}.mobile-menu-btn{order:0;justify-self:start}.topbar-title{order:1;text-align:center;padding:0 4px}.topbar-title h1{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.topbar-title p{display:none}.top-actions{order:2;justify-self:end;gap:4px}.top-actions .btn span{display:none}.top-actions .btn{min-height:36px;width:36px;padding:0;border-radius:50%;justify-content:center}.module-panel,.settings-panel,.preview-view,.editor-panel,.week-panel,.reports-panel,.overview-grid,.reports-view,.reports-head,.topbar,.search,.week-list,.week-row,.subject-card,.obj-category,.absence-add-form,.deployment-add-form,.add-subject-form,.preview-toolbar{width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}input,select,textarea{max-width:100%}.content-grid{grid-template-columns:1fr;gap:12px;width:100%}.content-grid .week-panel,.content-grid .right-panel{display:none}.status-tabs{overflow-x:auto;padding:3px;gap:3px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.status-tabs::-webkit-scrollbar{display:none}.status-tab{padding:0 12px;font-size:12px;white-space:nowrap;flex:none}.reports-head{width:100%}.reports-head-top{flex-direction:column;align-items:stretch;gap:10px}.settings-panel{width:100%}.settings-section{width:100%;box-sizing:border-box}.settings-section-toggle{padding:12px 14px}.settings-section-content{padding:14px}.form-grid,.settings-grid{grid-template-columns:1fr}.module-panel{gap:14px}.module-hero{padding:16px;gap:12px;flex-wrap:wrap;width:100%;box-sizing:border-box}.module-hero h2{font-size:17px}.module-hero-icon{width:44px;height:44px}.module-hero-stats{margin-left:0;gap:16px}.module-hero-stat strong{font-size:22px}.module-empty{padding:36px 16px;width:100%;box-sizing:border-box}.subjects-list,.obj-categories,.absence-list,.deployment-list{width:100%}.subject-card,.obj-category,.absence-row,.deployment-row{width:100%;box-sizing:border-box}.subject-header-left span{white-space:normal}.grade-add-row{grid-template-columns:1fr 80px}.absence-add-row{grid-template-columns:1fr 1fr}.obj-add-form{padding:12px}.dept-legend{gap:6px}.editor-panel{padding:14px;width:100%;box-sizing:border-box}.editor-sections{gap:10px}.hours-row{grid-template-columns:1fr}.editor-head{flex-direction:column;align-items:stretch;gap:12px}.editor-head-title{width:100%}.week-row-side{width:100%;justify-content:flex-start}.recent-list button{align-items:stretch}.editor-head-actions{width:100%;grid-template-columns:minmax(0,1fr) auto}.editor-head-actions .status-toggle-btn{flex:1 1 auto;min-height:44px;justify-content:center;font-size:13px;padding:8px 12px;white-space:normal;text-align:center}.editor-head-actions .week-switcher{flex:none;margin-left:auto}.editor-head-actions .week-switcher button{min-height:44px;min-width:44px}.overview-hero{flex-direction:column;align-items:flex-start;width:100%}.profile-strip,.stats-grid,.module-quickcards{grid-template-columns:1fr 1fr;width:100%}.calendar-controls{align-items:stretch}.calendar-controls .btn{width:100%;justify-content:center}.calendar-controls strong{width:100%;text-align:center}.calendar-cell{min-height:66px}.form-row,.form-row.triple{grid-template-columns:1fr}.preview-toolbar{flex-direction:column;align-items:stretch;gap:10px;width:100%}.preview-toolbar .field,.preview-toolbar select{min-width:0;width:100%}.preview-toolbar select{min-height:44px;text-overflow:ellipsis}.preview-toolbar .week-switcher{width:100%;display:flex;gap:8px}.preview-toolbar .week-switcher button{flex:1;min-height:44px}.preview-backup-actions{grid-template-columns:1fr}.preview-backup-actions .btn{width:100%}.toolbar-spacer{display:none}.toolbar-group{display:flex;flex-wrap:wrap;width:100%}.toolbar-group .btn{flex:1 1 120px;justify-content:center;min-height:44px}.pdf-branding-top{flex-direction:column;align-items:stretch}.preview-paper{padding:16px 12px}.preview-paper header{flex-direction:column;gap:4px;align-items:flex-start}.preview-paper-branding{gap:8px}.preview-paper-logo{width:24px;height:24px}.preview-paper header strong{font-size:15px}.preview-paper header span{font-size:11.5px}.preview-meta>div{grid-template-columns:110px 1fr}.preview-meta>div span{font-size:10.5px;padding:7px 8px}.preview-meta>div strong{font-size:12px;padding:7px 10px}.setup-card{grid-template-columns:1fr}.setup-aside{display:none}.setup-card.auth-gate{grid-template-columns:1fr}.auth-gate .setup-aside{display:flex;flex-direction:row;align-items:center;gap:14px;padding:20px clamp(20px,6vw,28px)}.auth-gate .setup-aside .auth-benefits{display:none}.auth-gate .setup-main{padding:clamp(24px,6vw,32px)}.auth-form-wrap{max-width:460px}}.public-page{min-height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column}.public-header{border-bottom:1px solid var(--line);background:var(--surface);position:sticky;top:0;z-index:40}.public-header-inner,.public-main,.public-footer-inner{width:min(1100px,calc(100% - 32px));margin:0 auto}.public-header-inner{min-height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px}.public-brand{display:inline-flex;align-items:center;gap:10px;color:inherit;text-decoration:none}.public-brand-text{display:grid;gap:1px}.public-brand-text strong{font-size:14px}.public-brand-text small{color:var(--muted);font-size:11px}.public-nav{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.public-nav a{color:var(--text2);text-decoration:none;font-size:13px;padding:6px 10px;border-radius:var(--r-pill)}.public-nav a:hover,.public-nav a[aria-current=page]{background:var(--surface3);color:var(--text)}.public-nav .public-nav-cta{background:var(--blue);color:#fff}.public-nav .public-nav-cta:hover{background:var(--blue-dark)}.public-user{font-size:12.5px;color:var(--muted);max-width:min(48vw,320px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.public-user-email{color:var(--text2);font-weight:600}.public-main{flex:1;padding:28px 0 36px}.landing-hero{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}.landing-kicker{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);font-weight:700}.landing-hero h1{font-size:34px;line-height:1.2;margin:8px 0 10px}.landing-hero p{color:var(--text2)}.landing-actions{margin-top:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-height:44px}.landing-auth-status{margin:0;font-size:13.5px;font-weight:600;color:var(--green, #059669)}.landing-card{border:1px solid var(--line);background:var(--surface);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-sm)}.landing-card h2{font-size:18px;margin-bottom:10px}.landing-card ul{margin:0;padding-left:18px;display:grid;gap:8px}.landing-features{margin-top:20px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.landing-feature{border:1px solid var(--line);background:var(--surface);border-radius:var(--r-md);padding:14px}.landing-feature h2{font-size:15px;margin:8px 0 6px}.landing-feature p{font-size:13px;color:var(--text2)}.legal-page{border:1px solid var(--line);background:var(--surface);border-radius:var(--r-lg);padding:22px;box-shadow:var(--sh-sm)}.legal-page h1{font-size:28px;margin-bottom:10px}.legal-page h2{margin-top:18px;margin-bottom:6px;font-size:18px}.legal-page p{color:var(--text2);margin:0 0 8px;overflow-wrap:anywhere}.legal-page ul{margin:0 0 10px 1.1rem;padding:0;color:var(--text2)}.legal-page li{margin-bottom:6px}.legal-page code{font-size:.92em}.legal-link{color:var(--blue);font-weight:600;text-decoration:underline;overflow-wrap:anywhere}.legal-link:hover{color:var(--blue-dark)}.legal-note{margin-top:14px;padding:10px 12px;font-size:12.5px;background:var(--surface2);border:1px solid var(--line);border-radius:var(--r-md)}.seo-content-page .seo-hero h1{font-size:clamp(26px,5vw,34px);line-height:1.25}.seo-content-page .seo-hero{margin-bottom:4px}.seo-page-nav{margin-bottom:14px;font-size:13px;color:var(--muted)}.seo-table-wrap{overflow-x:auto;margin:10px 0 4px;-webkit-overflow-scrolling:touch}.seo-table{width:100%;min-width:520px;border-collapse:collapse;font-size:14px}.seo-table th,.seo-table td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}.seo-table thead th{background:var(--surface2);font-weight:700}.seo-table tbody th[scope=row]{background:var(--surface2);font-weight:600;width:28%}.seo-faq-item h3{font-size:16px;margin:0 0 4px}.seo-faq-item p{margin:0 0 12px}.seo-cta-block{margin-top:22px;padding:20px;background:var(--blue-soft);border:1px solid var(--blue-border);border-radius:var(--r-lg);text-align:center}.seo-cta-block h2{margin-top:0}.seo-page-footer-note{margin-top:18px;font-size:13px}.seo-steps-list{margin:0 0 10px 1.25rem;padding:0;color:var(--text2)}.seo-steps-list li{margin-bottom:8px}.not-found-page{border:1px solid var(--line);background:var(--surface);border-radius:var(--r-lg);padding:32px;text-align:center}.not-found-page h1{margin:8px 0 10px;font-size:30px}.not-found-page p{color:var(--text2)}.public-footer{border-top:1px solid var(--line);background:var(--surface);margin-top:auto}.public-footer-inner{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0}.public-footer-brand{display:flex;flex-direction:column;gap:4px;min-width:0}.public-footer-name{font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.01em}.public-footer-copy{font-size:12px;color:var(--muted)}.public-footer-home-link{color:inherit;text-decoration:none}.public-footer-home-link:hover{color:var(--text2);text-decoration:underline}.public-footer-links{display:flex;gap:16px;flex-wrap:wrap;justify-content:flex-end}.public-footer-links a{color:var(--text2);text-decoration:none;font-size:13px;font-weight:500;transition:color var(--fast) var(--ease)}.public-footer-links a:hover{color:var(--blue-dark)}.public-footer--premium{border-top-color:#94a3b840;background:linear-gradient(to bottom,#f8fafceb,#f6f8fc)}.public-footer-inner--premium{min-height:80px}@media(max-width:900px){.landing-hero{grid-template-columns:1fr}.landing-features{grid-template-columns:1fr 1fr}}@media(max-width:640px){.public-header-inner,.public-main,.public-footer-inner{width:min(1100px,calc(100% - 18px))}.public-header-inner{min-height:62px}.landing-hero h1{font-size:28px}.landing-features{grid-template-columns:1fr}.legal-page,.not-found-page{padding:16px}.public-footer-inner{align-items:flex-start;flex-direction:column;justify-content:center;padding:16px 0 20px;gap:14px}.public-footer-links{gap:12px 16px}}@media(max-width:400px){.workspace{padding:12px 10px 56px}.stats-grid,.profile-strip{grid-template-columns:1fr 1fr}.module-quickcards,.editor-head-actions{grid-template-columns:1fr}.editor-head-actions .status-toggle-btn{width:100%}.editor-head-actions .week-switcher{justify-content:flex-end;justify-self:end}}.editor-head-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:10px;flex:1 1 280px;min-width:0;max-width:100%}.editor-head-title{display:grid;gap:8px;min-width:0;flex:1 1 180px}.editor-head-title h2{order:1;margin-bottom:0;min-width:0;overflow-wrap:anywhere}.editor-head-title .status-dot{order:2;margin-bottom:0;justify-self:start}.editor-head-title p{order:3;margin-top:0}.status-toggle-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;min-height:36px;padding:5px 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all var(--fast) var(--ease)}.status-toggle-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-dim, #eff6ff)}.status-toggle-btn.is-complete{background:#ecfdf5;border-color:#34d399;color:#059669}.status-toggle-btn.is-complete:hover{background:#d1fae5}.workflow-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;min-width:0;max-width:100%}.editor-head-actions .week-switcher{flex:none;align-self:center}.workflow-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;min-height:36px;padding:5px 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all var(--fast) var(--ease);white-space:nowrap}.workflow-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-dim, #eff6ff)}.workflow-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.workflow-btn.primary:hover{opacity:.9}.workflow-btn.success{background:#ecfdf5;border-color:#34d399;color:#059669}.workflow-btn.danger{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.workflow-btn:disabled{opacity:.45;cursor:not-allowed}.workflow-notice{margin:0 0 12px}.editor-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-backdrop{position:fixed;inset:0;z-index:120;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px}.review-dialog{width:min(100%,480px);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-lg)}.review-dialog h3{margin:0 0 8px;font-size:18px}.review-dialog-hint{margin:0 0 14px;color:var(--text2);font-size:13px;line-height:1.45}.review-dialog-field{display:grid;gap:6px;margin-bottom:12px}.review-dialog-field span{font-size:12px;font-weight:600;color:var(--text2)}.review-dialog-field input,.review-dialog-field textarea{width:100%;border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px;background:var(--surface2);color:var(--text)}.review-dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}@media(max-width:720px){.workflow-actions{justify-content:stretch}.workflow-btn{flex:1 1 calc(50% - 4px);justify-content:center}.editor-meta-grid{grid-template-columns:1fr}}.editor-toolbar{display:flex;align-items:center;gap:8px;margin:10px 0 14px;flex-wrap:wrap}.toolbar-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--text2);min-height:36px;padding:5px 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface2);cursor:pointer;transition:all var(--fast) var(--ease);white-space:nowrap}.toolbar-btn:hover{color:var(--blue);border-color:var(--blue)}.toolbar-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.toolbar-btn.primary:hover{opacity:.9}.toolbar-btn:disabled{opacity:.45;cursor:not-allowed}.template-picker{position:relative}.template-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:50;min-width:220px;max-width:280px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:0 6px 20px #0000001f;padding:8px 0}.template-empty{font-size:12px;color:var(--muted);padding:8px 14px;margin:0}.template-list{list-style:none;margin:0;padding:0}.template-item{display:flex;align-items:center;padding:2px 10px}.template-apply-btn{flex:1;text-align:left;font-size:13px;font-weight:500;color:var(--text);padding:6px 4px;border:none;background:none;cursor:pointer;border-radius:var(--r-sm);transition:background var(--fast) var(--ease);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-apply-btn:hover{background:var(--surface2)}.template-delete-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;cursor:pointer;color:var(--muted);border-radius:var(--r-sm);transition:all var(--fast) var(--ease);flex-shrink:0}.template-delete-btn:hover{color:#ef4444;background:#fee2e2}.template-save-trigger{display:flex;align-items:center;gap:5px;width:100%;text-align:left;font-size:12px;color:var(--muted);padding:8px 14px;border:none;background:none;cursor:pointer;border-top:1px solid var(--line);margin-top:4px;transition:color var(--fast) var(--ease)}.template-save-trigger:hover:not(:disabled){color:var(--blue)}.template-save-trigger:disabled{opacity:.45;cursor:not-allowed}.template-save-form{display:flex;flex-direction:column;gap:6px;padding:10px 12px;border-top:1px solid var(--line);margin-top:4px}.template-save-form input{font-size:13px;padding:6px 8px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface2);color:var(--text);outline:none}.template-save-form input:focus{border-color:var(--blue)}.absence-indicator{border-color:#fbbf24!important}.absence-indicator .editor-section-title{display:flex;align-items:center;gap:6px;color:#b45309}.absence-week-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.absence-week-item{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px}.absence-type-tag{font-size:11px;font-weight:700;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}.absence-type-krank{background:#fee2e2;color:#991b1b}.absence-type-urlaub{background:#dbeafe;color:#1e40af}.absence-type-berufsschule{background:#ede9fe;color:#5b21b6}.absence-type-sonstig{background:#f3f4f6;color:#374151}.absence-week-dates{color:var(--muted);font-size:12px}.absence-week-days{font-size:12px;font-weight:600;color:var(--text)}.absence-week-note{font-size:12px;color:var(--muted);font-style:italic}.backup-manager{display:flex;flex-direction:column;gap:12px}.backup-manager-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.backup-manager-hint{font-size:13px;color:var(--muted);margin:0}.backup-manager-empty{font-size:13px;color:var(--muted);font-style:italic;margin:0}.backup-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.backup-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface2)}.backup-trigger-icon{font-size:14px;width:20px;text-align:center;color:var(--muted);flex-shrink:0}.backup-info{flex:1;min-width:0}.backup-label{display:block;font-size:13px;font-weight:600;color:var(--text)}.backup-date{display:block;font-size:12px;color:var(--muted)}.backup-actions{display:flex;gap:4px;flex-shrink:0}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--muted);cursor:pointer;font-size:12px;transition:all var(--fast) var(--ease)}.icon-btn:hover{border-color:var(--blue);color:var(--blue)}.icon-btn.danger:hover{border-color:#ef4444;color:#ef4444;background:#fee2e2}.dialog-overlay{position:fixed;inset:0;z-index:var(--z-backdrop);background:#0f172a80;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.dialog-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--sh-lg);padding:28px;max-width:480px;width:100%;max-height:calc(100dvh - 40px);overflow-y:auto;display:flex;flex-direction:column;gap:14px}.dialog-header{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;color:var(--text)}.dialog-subtitle{font-size:14px;color:var(--muted);margin:0}.dialog-hint{font-size:12px;color:#059669;background:#ecfdf5;border-radius:var(--r-sm);padding:8px 12px;margin:0}.import-sections{display:flex;flex-direction:column;gap:4px}.import-section-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;transition:background var(--fast) var(--ease)}.import-section-row:hover:not(.disabled){background:var(--surface2)}.import-section-row.disabled{opacity:.4;cursor:not-allowed}.import-section-row input[type=checkbox]{width:16px;height:16px;flex-shrink:0}.import-section-label{flex:1;font-size:14px;font-weight:500;color:var(--text)}.import-section-count{font-size:12px;color:var(--muted)}.dialog-actions{display:flex;gap:10px;justify-content:flex-end}.plan-gate-locked{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:32px 20px;width:100%;background:var(--surface2);border:1.5px dashed var(--line2);border-radius:var(--r-lg);cursor:pointer;text-align:center;transition:border-color var(--fast) var(--ease),background var(--fast) var(--ease)}.plan-gate-locked:hover{border-color:var(--blue);background:var(--blue-soft)}.plan-gate-locked:focus-visible{outline:none;box-shadow:var(--sh-blue)}.plan-gate-lock-icon{color:var(--muted)}.plan-gate-locked:hover .plan-gate-lock-icon{color:var(--blue)}.plan-gate-label{font-size:14px;font-weight:600;color:var(--text2)}.plan-gate-hint{font-size:12px;color:var(--blue);font-weight:500}.filters button.nav-locked{opacity:.72}.filters button.nav-locked .nav-lock-icon{margin-left:auto;color:var(--muted)}.dialog-backdrop,.modal-backdrop{position:fixed;inset:0;z-index:10000;background:#0f172a94;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.upgrade-dialog{position:fixed;inset:0;margin:auto;width:min(480px,calc(100vw - 32px));max-width:480px;max-height:calc(100dvh - 32px);overflow-x:hidden;overflow-y:auto;background:#fff;opacity:1;backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid rgba(148,163,184,.28);border-radius:var(--r-xl);box-shadow:0 32px 80px #0f172a47,0 8px 24px #0f172a24;padding:max(28px,env(safe-area-inset-top,0px)) max(28px,env(safe-area-inset-right,0px)) max(28px,env(safe-area-inset-bottom,0px)) max(28px,env(safe-area-inset-left,0px));z-index:10001;display:flex;flex-direction:column;gap:20px;isolation:isolate}.upgrade-dialog:focus{outline:none}.upgrade-dialog:focus-visible{box-shadow:0 32px 80px #0f172a47,0 8px 24px #0f172a24,var(--sh-blue)}.upgrade-dialog-header{display:flex;gap:14px;align-items:flex-start;background:#fff;opacity:1}.upgrade-dialog-icon{width:44px;height:44px;border-radius:var(--r-md);flex:none;background:#eff6ff;color:var(--blue);opacity:1;display:flex;align-items:center;justify-content:center}.upgrade-dialog-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 4px}.upgrade-dialog-sub{font-size:14px;color:var(--text2);margin:0}.upgrade-dialog-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;background:#fff;opacity:1}.upgrade-dialog-features li{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text)}.upgrade-feature-check{color:var(--green);flex-shrink:0}.upgrade-dialog-pricing,.upgrade-dialog__price{background:#eff6ff;border:1px solid #bfdbfe;opacity:1;border-radius:var(--r-lg);padding:16px 18px;display:flex;flex-direction:column;gap:6px}.upgrade-trial-badge{display:inline-block;background:var(--blue);color:#fff;font-size:11px;font-weight:700;border-radius:var(--r-pill);padding:3px 10px;letter-spacing:.03em;width:fit-content;opacity:1}.upgrade-price{display:flex;align-items:baseline;gap:4px}.upgrade-price-amount{font-size:24px;font-weight:800;color:var(--text)}.upgrade-price-interval{font-size:13px;color:var(--text2)}.upgrade-price-note{font-size:12px;color:var(--text2);margin:0}.upgrade-error{font-size:13px;color:var(--red);background:#fef2f2;border:1px solid var(--red-border);border-radius:var(--r-sm);padding:8px 12px;margin:0;opacity:1}.upgrade-dialog-actions{display:flex;flex-direction:column;gap:8px;background:#fff;opacity:1}.upgrade-cta{width:100%;justify-content:center}.dialog-close{position:absolute;top:max(16px,env(safe-area-inset-top,0px));right:max(16px,env(safe-area-inset-right,0px));width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);cursor:pointer;color:var(--text2);transition:background var(--fast) var(--ease);z-index:1;opacity:1}.dialog-close:hover{background:var(--surface3)}.dialog-close:focus-visible{outline:none;box-shadow:var(--sh-blue)}@media(prefers-reduced-motion:reduce){.upgrade-dialog,.dialog-backdrop,.modal-backdrop{transition:none!important;animation:none!important}}.instructor-access-panel{display:flex;flex-direction:column;gap:16px;min-width:0}.instructor-access-intro{display:grid;gap:8px;font-size:13.5px;line-height:1.55;color:var(--text2)}.instructor-access-note{margin:0;color:var(--muted);font-size:13px}.instructor-access-legal{margin:0;padding:10px 12px;border-radius:var(--r-sm);background:var(--surface2);border:1px solid var(--line);font-size:12px;color:var(--muted);line-height:1.5}.instructor-access-hint{margin:0;font-size:13.5px;color:var(--text2);line-height:1.55}.instructor-access-form{display:grid;gap:12px;max-width:100%}.instructor-access-form .btn{justify-self:start}.instructor-access-feedback,.instructor-access-success{display:flex;align-items:flex-start;gap:8px;font-size:13px;line-height:1.45}.instructor-access-success{color:var(--green);background:var(--green-soft);border:1px solid var(--green-border);border-radius:var(--r-sm);padding:10px 12px}.instructor-access-loading{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text2)}.instructor-access-spinner{animation:billing-spin 1s linear infinite}.instructor-access-empty{margin:0;padding:14px;border-radius:var(--r-md);background:var(--surface2);border:1px dashed var(--line2);font-size:13px;color:var(--muted);text-align:center}.instructor-access-list{list-style:none;margin:0;padding:0;display:grid;gap:10px;min-width:0}.instructor-access-item{display:grid;gap:8px;padding:14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);min-width:0}.instructor-access-item-main{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;min-width:0}.instructor-access-email{font-size:14px;color:var(--text);overflow-wrap:anywhere}.instructor-access-badge{display:inline-flex;align-items:center;font-size:11.5px;font-weight:700;border-radius:var(--r-pill);padding:3px 10px;white-space:nowrap}.instructor-access-badge--pending{background:var(--amber-soft);color:var(--amber);border:1px solid var(--amber-border)}.instructor-access-badge--accepted{background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.instructor-access-badge--rejected{background:var(--red-soft);color:var(--red);border:1px solid var(--red-border)}.instructor-access-badge--revoked{background:var(--surface3);color:var(--muted);border:1px solid var(--line2)}.instructor-access-item-meta{display:flex;flex-wrap:wrap;gap:8px 14px;font-size:12px;color:var(--muted)}.instructor-access-item .btn{justify-self:start}@media(max-width:640px){.instructor-access-item-main{align-items:flex-start}.instructor-access-form .btn,.instructor-access-item .btn{width:100%;justify-content:center}}.instructor-review-view{display:flex;flex-direction:column;gap:18px;min-width:0;max-width:100%}.instructor-review-header{display:grid;gap:8px;min-width:0}.instructor-review-header h1{display:flex;align-items:center;gap:10px;margin:0;font-size:1.35rem;color:var(--text)}.instructor-review-header p{margin:0;font-size:13.5px;line-height:1.55;color:var(--text2)}.instructor-review-notice{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r-md);background:var(--surface2);border:1px solid var(--line);font-size:13px;line-height:1.5;color:var(--text2)}.instructor-review-notice p{margin:0}.instructor-review-hint,.instructor-review-empty,.instructor-review-section-empty{margin:0;padding:14px;border-radius:var(--r-md);background:var(--surface2);border:1px dashed var(--line2);font-size:13px;color:var(--muted);text-align:center}.instructor-review-feedback,.instructor-review-success{display:flex;align-items:flex-start;gap:8px;font-size:13px;line-height:1.45}.instructor-review-success{color:var(--green);background:var(--green-soft);border:1px solid var(--green-border);border-radius:var(--r-sm);padding:10px 12px}.instructor-review-loading{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text2)}.instructor-review-spinner{animation:billing-spin 1s linear infinite}.instructor-review-section{display:grid;gap:12px;min-width:0}.instructor-review-section h2{margin:0;font-size:1rem;color:var(--text)}.instructor-review-phase-hint{margin:0;font-size:12.5px;color:var(--muted);line-height:1.5}.instructor-review-invite-list,.instructor-review-report-list{list-style:none;margin:0;padding:0;display:grid;gap:10px;min-width:0}.instructor-review-invite-card,.instructor-review-report-card{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);min-width:0}.instructor-review-invite-head,.instructor-review-report-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;min-width:0}.instructor-review-invite-head strong,.instructor-review-report-head strong{font-size:14px;color:var(--text);overflow-wrap:anywhere}.instructor-review-meta{display:grid;gap:8px;margin:0;min-width:0}.instructor-review-meta>div{display:flex;flex-wrap:wrap;gap:6px 10px;min-width:0}.instructor-review-meta dt{margin:0;font-size:12px;color:var(--muted);font-weight:600}.instructor-review-meta dd{margin:0;font-size:13px;color:var(--text2);overflow-wrap:anywhere}.instructor-review-invite-actions{display:flex;flex-wrap:wrap;gap:8px}.instructor-review-trainee-groups{display:grid;gap:14px;min-width:0}.instructor-review-trainee-group{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);min-width:0}.instructor-review-trainee-head h3{margin:0;font-size:15px;color:var(--text)}.instructor-review-trainee-head p{margin:4px 0 0;font-size:12.5px;color:var(--muted)}.instructor-review-excerpt{margin:0;font-size:13px;line-height:1.5;color:var(--text2);overflow-wrap:anywhere}.instructor-review-report-badge{display:inline-flex;align-items:center;font-size:11.5px;font-weight:700;border-radius:var(--r-pill);padding:3px 10px;white-space:nowrap}.instructor-review-report-badge--submitted{background:var(--blue-soft);color:var(--blue);border:1px solid var(--blue-border)}.instructor-review-report-badge--approved{background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.instructor-review-report-badge--rejected{background:var(--red-soft);color:var(--red);border:1px solid var(--red-border)}.instructor-review-report-actions{display:flex;flex-wrap:wrap;gap:8px}.instructor-review-comment{margin:0;font-size:13px;line-height:1.5;color:var(--text2);overflow-wrap:anywhere}.instructor-review-comment strong{color:var(--text)}.instructor-review-dialog{display:grid;gap:12px;max-width:100%;width:min(100%,480px)}.instructor-review-dialog h3{margin:0;font-size:1.05rem;color:var(--text)}.instructor-review-dialog-hint,.instructor-review-dialog-week{margin:0;font-size:13.5px;line-height:1.55;color:var(--text2)}.instructor-review-dialog-field{display:grid;gap:6px;min-width:0}.instructor-review-dialog-field span{font-size:12.5px;font-weight:600;color:var(--muted)}.instructor-review-dialog-field textarea{width:100%;min-width:0;resize:vertical;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--text);padding:10px 12px;font:inherit;line-height:1.45}.instructor-review-dialog-error{margin:0;font-size:13px;color:var(--red)}.instructor-review-dialog-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.manual-review-note{margin-top:8px;padding:12px 14px;border:1px dashed var(--line2);border-radius:var(--r-md);background:var(--surface2)}.manual-review-note summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--muted)}.manual-review-hint{margin:10px 0 0;font-size:12.5px;line-height:1.5;color:var(--muted)}.manual-review-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.review-status-note{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);padding:12px 14px}.review-status-details{display:grid;gap:8px;margin:8px 0 0}.review-status-details>div{display:flex;flex-wrap:wrap;gap:6px 10px}.review-status-details dt{margin:0;font-size:12px;color:var(--muted);font-weight:600}.review-status-details dd{margin:0;font-size:13px;color:var(--text2);overflow-wrap:anywhere}@media(max-width:640px){.instructor-review-invite-head,.instructor-review-report-head{align-items:flex-start}.instructor-review-invite-actions{flex-direction:column}.instructor-review-invite-actions .btn{width:100%;justify-content:center}.instructor-review-report-actions{flex-direction:column}.instructor-review-report-actions .btn{width:100%;justify-content:center}.instructor-review-dialog-actions{flex-direction:column}.instructor-review-dialog-actions .btn{width:100%;justify-content:center}.manual-review-actions{flex-direction:column}.manual-review-actions .workflow-btn{width:100%;justify-content:center}}.instructor-review-status-panel,.preview-instructor-review{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2);min-width:0}.instructor-review-status-title{display:flex;align-items:center;gap:8px;margin:0;font-size:14px;color:var(--text)}.instructor-review-status-headline{margin:0;font-size:14px;font-weight:600;color:var(--text);line-height:1.45}.instructor-review-status-note,.instructor-review-status-resubmit{margin:0;font-size:13px;line-height:1.5;color:var(--text2)}.instructor-review-status-resubmit{padding:10px 12px;border-radius:var(--r-sm);background:var(--amber-soft);border:1px solid var(--amber-border);color:var(--text)}.instructor-review-status-details{display:grid;gap:8px;margin:0}.instructor-review-status-details>div{display:flex;flex-wrap:wrap;gap:6px 10px}.instructor-review-status-details dt{margin:0;font-size:12px;color:var(--muted);font-weight:600}.instructor-review-status-details dd{margin:0;font-size:13px;color:var(--text2);overflow-wrap:anywhere}.preview-instructor-review{margin-top:12px}@media(max-width:640px){.instructor-review-status-panel,.preview-instructor-review{padding:12px}}.instructor-review-identity{display:flex;flex-direction:column;gap:2px;margin-top:8px;padding:10px 14px;background:var(--surface2);border-radius:var(--r-md);border:1px solid var(--line);font-size:13px;line-height:1.5;color:var(--text2)}.instructor-review-identity strong{color:var(--text)}.instructor-profile-setup-card{max-width:720px}.instructor-profile-form{display:grid;gap:16px}.instructor-profile-form--settings{gap:14px}.instructor-profile-required-hint{margin:0;font-size:12px;color:var(--muted);line-height:1.5}.instructor-profile-required-hint em{font-style:normal;color:var(--red);margin-right:3px}.form-error{margin:0;font-size:13px;color:var(--red);font-weight:500;line-height:1.5}.account-role-card{max-width:920px;grid-template-columns:minmax(0,220px) minmax(0,1fr)}.account-role-main{min-width:0}.account-role-grid{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.account-role-option{display:grid;gap:12px;min-width:0;padding:16px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface2)}.account-role-option-head{display:flex;align-items:center;gap:10px}.account-role-option-head h2{margin:0;font-size:16px;color:var(--text)}.account-role-option p{margin:0;font-size:13.5px;line-height:1.55;color:var(--text2)}.account-role-option .btn{width:100%;justify-content:center}.account-role-footnote{margin:16px 0 0;font-size:12.5px;line-height:1.55;color:var(--muted)}.account-type-settings{display:grid;gap:12px}.account-type-current{margin:0;font-size:14px;color:var(--text2)}.account-type-hint{margin:0;font-size:13px;line-height:1.55;color:var(--muted)}.account-type-actions{display:flex;flex-wrap:wrap;gap:8px}.account-type-confirm{display:grid;gap:10px;padding:14px;border:1px solid var(--amber-border, #fcd34d);border-radius:var(--r-md);background:var(--amber-soft, #fffbeb)}.account-type-confirm-head{display:flex;align-items:center;gap:8px;color:var(--text)}.account-type-confirm p{margin:0;font-size:13.5px;line-height:1.55;color:var(--text2)}.account-type-confirm-actions{display:flex;flex-wrap:wrap;gap:8px}@media(max-width:760px){.account-role-card{grid-template-columns:1fr}.account-role-aside{border-right:none;border-bottom:1px solid rgba(255,255,255,.05)}.account-role-grid{grid-template-columns:1fr}}@media(max-width:390px){.account-role-main{padding:24px 18px}.account-type-actions,.account-type-confirm-actions{flex-direction:column}.account-type-actions .btn,.account-type-confirm-actions .btn{width:100%;justify-content:center}}.billing-section{display:flex;flex-direction:column;gap:14px;padding:4px 0}.billing-loading{flex-direction:row;align-items:center;gap:10px;color:var(--text2);font-size:14px}.billing-spinner{animation:billing-spin 1s linear infinite}@keyframes billing-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.billing-spinner{animation:none}}.billing-plan-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.billing-plan-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;border-radius:var(--r-pill);padding:3px 10px}.billing-plan-free{background:var(--surface3);color:var(--text2)}.billing-plan-pro{background:var(--blue-soft);color:var(--blue-dark);border:1px solid var(--blue-border)}.billing-plan-canceling{background:var(--amber-soft);color:var(--amber);border:1px solid var(--amber-border)}.billing-plan-past-due{background:var(--red-soft);color:var(--red);border:1px solid var(--red-border)}.billing-plan-price{font-size:16px;font-weight:700;color:var(--text)}.billing-trial-end{font-size:13px;color:var(--text2)}.billing-plan-desc{font-size:14px;color:var(--text2);margin:0}.billing-warning{color:var(--red)}.billing-error{font-size:13px;color:var(--red);background:var(--red-soft);border:1px solid var(--red-border);border-radius:var(--r-sm);padding:8px 12px;margin:0}.billing-feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.billing-feature-list li{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text2)}.billing-feature-check{color:var(--green);flex-shrink:0}.billing-more{font-size:12px;color:var(--muted);padding-left:20px}.billing-upgrade-block{background:var(--blue-soft);border:1px solid var(--blue-border);border-radius:var(--r-lg);padding:14px 16px;display:flex;flex-direction:column;gap:12px}.billing-upgrade-header{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--blue-dark)}.billing-pro-preview li{color:var(--text)}.billing-login-hint{font-size:14px;color:var(--text2);margin:0}.toast-stack{position:fixed;top:max(16px,env(safe-area-inset-top,16px));right:max(16px,env(safe-area-inset-right,16px));z-index:10010;display:flex;flex-direction:column;gap:8px;max-width:min(400px,calc(100vw - 32px));pointer-events:none}.toast{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--surface);border-radius:var(--r-md);border:1px solid var(--line);box-shadow:var(--sh-lg);pointer-events:all;min-width:240px}.toast-success{border-color:var(--green-border);background:var(--green-soft)}.toast-error{border-color:var(--red-border);background:var(--red-soft)}.toast-warning{border-color:var(--amber-border);background:var(--amber-soft)}.toast-info{border-color:var(--blue-border);background:var(--blue-soft)}.toast-icon{flex-shrink:0;margin-top:1px}.toast-success .toast-icon{color:var(--green)}.toast-error .toast-icon{color:var(--red)}.toast-warning .toast-icon{color:var(--amber)}.toast-info .toast-icon{color:var(--blue)}.toast-message{flex:1;font-size:14px;line-height:1.45;color:var(--text)}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--r-sm);background:transparent;border:none;cursor:pointer;color:var(--text2);transition:background var(--fast) var(--ease),color var(--fast) var(--ease);margin:-2px -2px -2px 0}.toast-close:hover{background:#0f172a14;color:var(--text)}.toast-close:focus-visible{outline:none;box-shadow:var(--sh-blue)}@media(max-width:480px){.toast-stack{top:auto;bottom:max(80px,calc(env(safe-area-inset-bottom,16px) + 64px));right:max(12px,env(safe-area-inset-right,12px));left:max(12px,env(safe-area-inset-left,12px));max-width:none}}@media(prefers-reduced-motion:reduce){.toast{transition:none!important}}.loading-screen{display:grid;place-items:center;min-height:240px;padding:40px}.spinner{width:28px;height:28px;border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;animation:spinner-rotate .7s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.spinner{animation:none;border-color:var(--blue-border);border-top-color:var(--blue)}}.recovery-banner{background:#f0fdf4;border-color:#bbf7d0}.recovery-banner .sync-banner-text svg{color:var(--green)}.nav-count{margin-left:auto;flex:none;font-style:normal;font-size:11px;font-weight:700;min-width:22px;text-align:center;padding:2px 7px;border-radius:var(--r-pill);background:#ffffff14;color:var(--side-muted);font-variant-numeric:tabular-nums}.filters button.active .nav-count{background:#60a5fa38;color:#bfdbfe}.status-tab-count{font-style:normal;font-size:11px;font-weight:700;padding:1px 7px;border-radius:var(--r-pill);background:var(--surface3);color:var(--text2);font-variant-numeric:tabular-nums}.status-tab.active .status-tab-count{background:var(--blue-soft);color:var(--blue-dark)}.subject-name{font-size:14px;font-weight:600;color:var(--text);min-width:0;overflow-wrap:anywhere}.subject-count{flex:none;font-size:12px;color:var(--muted);white-space:nowrap}.subject-no-grade{font-size:13px;color:var(--muted);min-width:32px;text-align:center}.subject-avg-label{font-size:12.5px;font-weight:700;white-space:nowrap}.subject-body{overflow:hidden}.subject-body>.btn{margin:12px 16px 14px}.grade-add-actions{display:flex;gap:8px;flex-wrap:wrap}.grade-empty-hint{font-size:13px;color:var(--muted);padding:12px 16px 0}.inline-warning{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-radius:var(--r-md);background:var(--amber-soft);border:1px solid var(--amber-border);color:var(--amber);font-size:13px;line-height:1.5}.inline-warning svg{flex-shrink:0;margin-top:1px}.sync-note{font-size:13px;color:var(--green);padding:10px 12px;border-radius:var(--r-md);background:var(--green-soft);border:1px solid var(--green-border)}.placeholder-page{min-height:100vh;background:var(--bg);display:flex;align-items:flex-start;justify-content:center;padding:clamp(24px,6vw,64px) 16px}.placeholder-page-inner{width:100%;max-width:640px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);padding:clamp(24px,4vw,40px);display:grid;gap:14px;justify-items:start}.placeholder-page h1{font-size:24px}.placeholder-back{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text2);text-decoration:none;min-height:34px}.placeholder-back:hover{color:var(--blue-dark)}.placeholder-notice{font-size:14px;line-height:1.65;color:var(--text2)}@media print{.sidebar,.topbar,.preview-toolbar,.mobile-menu-btn,.editor-actions{display:none!important}.workspace{padding:0}.app-shell{grid-template-columns:1fr}.preview-paper{box-shadow:none;border:none}}.public-page--premium{background:#f6f8fc;overflow-x:clip}.public-header--premium{border-bottom-color:transparent;background:#ffffffb8;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:background var(--mid) var(--ease),box-shadow var(--mid) var(--ease),min-height var(--mid) var(--ease)}.public-header--premium.is-scrolled{background:#ffffffeb;border-bottom-color:var(--line);box-shadow:var(--sh-sm)}.public-header--premium .public-header-inner{min-height:68px;transition:min-height var(--mid) var(--ease)}.public-header--premium.is-scrolled .public-header-inner{min-height:58px}.public-header--premium .public-nav-cta{display:inline-flex;align-items:center;min-height:44px;padding:0 18px;font-size:14px;font-weight:600;box-shadow:0 2px 8px #2563eb38}.public-header--premium .public-user{font-size:13px}.public-page--premium{--lp-gutter: clamp(16px, 5vw, 24px)}.public-header-inner--wide,.public-main--premium .lp-page,.public-footer .public-header-inner--wide{width:min(1140px,calc(100% - 2 * var(--lp-gutter)))}.public-main--premium{width:100%;padding:0;position:relative}.public-main--premium .lp-page{margin:0 auto}.public-header--premium{padding-top:env(safe-area-inset-top);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.lp-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.lp-bg-image{position:absolute;inset:0;background-image:url(/branding/landing/hero-ambient.jpg);background-size:cover;background-position:top center;background-repeat:no-repeat;opacity:.9;-webkit-mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.55) 48%,transparent 78%);mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.55) 48%,transparent 78%)}.lp-bg-base{position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 12% -12%,rgba(59,130,246,.1),transparent 55%),radial-gradient(ellipse 55% 38% at 92% 16%,rgba(99,102,241,.07),transparent 50%),linear-gradient(to bottom,transparent 0%,#f6f8fc 70%)}.lp-bg-grid{position:absolute;inset:0;opacity:.35;background-image:radial-gradient(circle at 1px 1px,rgba(15,23,42,.06) 1px,transparent 0);background-size:28px 28px;-webkit-mask-image:linear-gradient(to bottom,#000 0%,transparent 85%);mask-image:linear-gradient(to bottom,#000 0%,transparent 85%)}.lp-bg-orb{position:absolute;border-radius:50%;filter:blur(60px)}.lp-bg-orb-a{width:420px;height:420px;top:-8%;right:10%;background:#3b82f624}.lp-bg-orb-b{width:320px;height:320px;bottom:20%;left:-5%;background:#818cf81a}.lp-bg-glow{position:absolute;border-radius:50%;filter:blur(80px)}.lp-bg-glow-tl{width:500px;height:300px;top:0;left:20%;background:#eff6ffe6}.lp-bg-glow-br{width:400px;height:280px;bottom:10%;right:0;background:#eef2facc}@media(prefers-reduced-motion:reduce){.lp-bg-orb{animation:none!important}}.lp-page{position:relative;z-index:1}.lp-section{padding:clamp(56px,8vw,96px) 0}.lp-section-head{max-width:640px;margin:0 auto clamp(32px,5vw,48px);text-align:center}.lp-section-head h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-.03em;margin:0 0 10px}.lp-section-head p{margin:0;color:var(--text2);font-size:1.05rem;line-height:1.6}.lp-hero{padding:clamp(48px,10vh,88px) 0 clamp(56px,8vw,80px);min-height:min(92vh,900px);display:flex;align-items:center}.lp-hero-inner{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(32px,5vw,64px);align-items:center;width:100%}.lp-kicker{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin:0 0 12px}.lp-hero-copy h1{font-size:clamp(2rem,4.5vw,3.15rem);font-weight:800;line-height:1.08;letter-spacing:-.035em;margin:0 0 16px;max-width:16ch}.lp-lead{font-size:clamp(1rem,1.8vw,1.125rem);line-height:1.65;color:var(--text2);margin:0;max-width:52ch}.lp-hero-cta{margin-top:28px;display:flex;flex-wrap:wrap;align-items:center;gap:12px;min-height:48px}.lp-btn-primary{min-height:48px;padding:0 22px;font-size:15px;box-shadow:0 4px 14px #2563eb47}.lp-btn-ghost{min-height:48px}.lp-hero-points{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:10px 20px}.lp-hero-points li{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--text2)}.lp-hero-points svg{color:var(--green);flex:none}.lp-auth-hint{margin:0;font-size:15px;font-weight:600;color:var(--text2);padding:14px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-xs)}.lp-auth-email{color:var(--text);overflow-wrap:anywhere}.lp-auth-hint-sub{margin:4px 0 0;font-size:13px;color:var(--muted);width:100%}.lp-phone-wrap{position:relative;display:flex;justify-content:center;perspective:1200px;max-width:100%}.lp-phone-stage{position:absolute;inset:-8% -6% -2%;background-image:url(/branding/landing/app-scene.jpg);background-size:cover;background-position:center;border-radius:32px;filter:blur(7px) saturate(1.05);opacity:.5;-webkit-mask-image:radial-gradient(ellipse 70% 72% at 50% 46%,#000 38%,transparent 76%);mask-image:radial-gradient(ellipse 70% 72% at 50% 46%,#000 38%,transparent 76%);transform:translateZ(0);pointer-events:none}.lp-phone{position:relative;transform-style:preserve-3d;max-width:min(100%,280px)}.lp-phone-frame{position:relative;padding:10px;border-radius:44px;background:linear-gradient(145deg,#1a1a1a,#0a0a0a,#151515);box-shadow:0 0 0 1px #ffffff14,0 24px 48px #0f172a59,inset 0 1px #ffffff1f}.lp-phone-island{position:absolute;top:18px;left:50%;transform:translate(-50%);width:72px;height:22px;background:#000;border-radius:20px;z-index:3}.lp-phone-screen{border-radius:34px;overflow:hidden;background:var(--bg);aspect-ratio:9 / 19.2;min-height:420px}.lp-phone-ui{padding:44px 12px 14px;display:grid;gap:10px;height:100%;font-size:10px}.lp-phone-greeting{display:block;font-size:13px;font-weight:800;color:var(--text)}.lp-phone-sub{display:block;font-size:10px;color:var(--muted);margin-top:2px}.lp-phone-progress-bar{height:4px;background:var(--line);border-radius:99px;overflow:hidden;margin-bottom:4px}.lp-phone-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),#818cf8);border-radius:99px}.lp-phone-progress small{color:var(--muted);font-size:9px}.lp-phone-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px}.lp-phone-stat{padding:8px;border-radius:10px;border:1px solid var(--line);background:var(--surface);display:grid;gap:2px}.lp-phone-stat strong{font-size:14px;font-weight:800;color:var(--text)}.lp-phone-stat span{font-size:8px;color:var(--muted)}.lp-phone-stat svg{color:var(--blue)}.lp-phone-stat--success svg{color:var(--green)}.lp-phone-stat--warning svg{color:var(--amber)}.lp-phone-card{padding:10px;border-radius:12px;border:1px solid var(--blue-border);background:var(--blue-soft)}.lp-phone-card-label{display:block;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--blue)}.lp-phone-card strong{display:block;font-size:11px;margin-top:4px}.lp-phone-card small{color:var(--muted);font-size:9px}.lp-phone-modules{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}.lp-phone-module{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:10px;border:1px solid var(--line);background:var(--surface);font-size:8px;font-weight:600;color:var(--text2)}.lp-phone-module-icon{width:18px;height:18px;border-radius:6px;display:grid;place-items:center;color:#fff;flex-shrink:0}.lp-phone-nav{margin-top:auto;display:flex;gap:8px;padding-top:8px;border-top:1px solid var(--line)}.lp-phone-nav span{display:inline-flex;align-items:center;gap:4px;font-size:8px;color:var(--muted);padding:4px 8px;border-radius:8px}.lp-phone-nav span.active{background:var(--blue-soft);color:var(--blue-dark);font-weight:700}.lp-phone-reflection{position:absolute;inset:0;border-radius:44px;background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 42%);pointer-events:none}.lp-bento{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-rows:1fr;gap:16px}.lp-feature-card{display:flex;flex-direction:column;grid-column:span 2;padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-xs);transition:transform var(--fast) var(--ease),box-shadow var(--fast) var(--ease),border-color var(--fast) var(--ease)}.lp-feature-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--blue-border)}.lp-feature--hero{grid-column:span 4;grid-row:span 2;background:radial-gradient(120% 90% at 100% 0%,rgba(59,130,246,.07),transparent 60%),var(--surface)}.lp-feature--hero h3{font-size:18px}.lp-feature--hero p{max-width:46ch}.lp-feature-icon{width:40px;height:40px;border-radius:var(--r-md);display:grid;place-items:center;background:var(--blue-soft);color:var(--blue);margin-bottom:14px}.lp-feature-card h3{font-size:15px;font-weight:700;margin:0 0 8px}.lp-feature-card p{margin:0;font-size:13.5px;line-height:1.55;color:var(--text2)}.lp-feature-mini{margin-top:auto;padding-top:18px;display:grid;gap:10px}.lp-feature-mini-row{display:flex;align-items:center;gap:10px}.lp-feature-mini-dot{width:9px;height:9px;border-radius:50%;background:var(--green);flex:none;box-shadow:0 0 0 3px #05966924}.lp-feature-mini-dot--soft{background:var(--blue);box-shadow:0 0 0 3px #3b82f624}.lp-feature-mini-bar{flex:1;height:7px;border-radius:99px;background:var(--surface2);overflow:hidden}.lp-feature-mini-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),#818cf8)}.lp-feature-mini-tag{font-size:11px;font-weight:700;color:var(--green);white-space:nowrap}.lp-feature-mini-tag--soft{color:var(--muted);font-weight:600}.lp-feature-chips{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}.lp-feature-chips span{font-size:11px;font-weight:600;color:var(--text2);padding:4px 10px;border-radius:var(--r-pill);background:var(--surface2);border:1px solid var(--line)}.lp-demo-grid{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:clamp(28px,5vw,56px);align-items:center}.lp-demo-copy h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-.03em;margin:0 0 12px}.lp-demo-copy>p{color:var(--text2);line-height:1.65;margin:0 0 20px}.lp-demo-list{margin:0;padding-left:18px;display:grid;gap:8px;color:var(--text2);font-size:14px}.lp-browser{border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-lg);background:var(--surface)}.lp-browser-chrome{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--surface2);border-bottom:1px solid var(--line)}.lp-browser-dot{width:10px;height:10px;border-radius:50%;background:var(--line2)}.lp-browser-dot:first-child{background:#fca5a5}.lp-browser-dot:nth-child(2){background:#fde68a}.lp-browser-dot:nth-child(3){background:#86efac}.lp-browser-url{margin-left:8px;font-size:11px;color:var(--muted);padding:4px 12px;background:var(--surface);border-radius:var(--r-pill);border:1px solid var(--line);flex:1;max-width:200px}.lp-browser-body{display:grid;grid-template-columns:130px 1fr;min-height:280px}.lp-browser-side{background:var(--side);padding:12px 8px;display:grid;gap:2px;align-content:start}.lp-browser-side span{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--side-muted);padding:6px 8px;border-radius:var(--r-sm)}.lp-browser-side span.active{background:var(--side-active);color:#fff}.lp-browser-main{padding:14px;display:grid;gap:12px;background:var(--bg)}.lp-browser-hero{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md)}.lp-browser-hero strong{display:block;font-size:13px}.lp-browser-hero span{font-size:10px;color:var(--muted)}.lp-browser-progress{display:flex;align-items:center;gap:8px}.lp-browser-progress-bar{width:88px;height:6px;border-radius:99px;background:var(--surface2);overflow:hidden}.lp-browser-progress-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),#818cf8)}.lp-browser-progress small{font-size:10px;font-weight:700;color:var(--text2);white-space:nowrap}.lp-browser-chart{padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md)}.lp-browser-chart-head{display:flex;align-items:baseline;justify-content:space-between}.lp-browser-chart-head strong{font-size:12px}.lp-browser-chart-head span{font-size:10px;color:var(--muted)}.lp-browser-chart-bars{margin-top:10px;display:grid;grid-template-columns:repeat(6,1fr);align-items:end;gap:8px;height:56px}.lp-browser-chart-bars span{display:block;border-radius:4px 4px 2px 2px;background:var(--blue-border);min-height:6px}.lp-browser-chart-bars span.is-strong{background:linear-gradient(180deg,var(--blue),var(--blue-dark))}.lp-browser-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.lp-browser-stats div{padding:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);text-align:center}.lp-browser-stats small{display:block;font-size:9px;color:var(--muted)}.lp-browser-stats strong{font-size:16px;color:var(--blue)}.lp-browser-highlights{display:grid;grid-template-columns:1fr 1fr;gap:8px}.lp-browser-highlight{padding:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm)}.lp-browser-highlight strong{display:block;font-size:11px}.lp-browser-highlight span{font-size:9px;color:var(--muted)}.lp-steps-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;counter-reset:lp-step}.lp-steps-list li{position:relative;padding:24px 20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-xs)}.lp-step-num{position:absolute;top:16px;right:16px;width:28px;height:28px;border-radius:50%;background:var(--blue-soft);color:var(--blue);font-size:12px;font-weight:800;display:grid;place-items:center}.lp-step-icon{width:40px;height:40px;border-radius:var(--r-md);background:var(--surface2);color:var(--blue);display:grid;place-items:center;margin-bottom:14px}.lp-steps-list h3{font-size:15px;font-weight:700;margin:0 0 8px}.lp-steps-list p{margin:0;font-size:13px;color:var(--text2);line-height:1.55}@media(min-width:901px){.lp-steps-list li:not(:last-child):after{content:"";position:absolute;top:50%;right:-14px;width:28px;height:2px;transform:translateY(-50%);background:linear-gradient(90deg,var(--blue-border),var(--blue));border-radius:1px;pointer-events:none}}.lp-trust-inner{max-width:720px;margin:0 auto;text-align:center;padding:clamp(32px,5vw,48px);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-sm)}.lp-trust-inner h2{font-size:clamp(1.35rem,2.5vw,1.75rem);font-weight:800;margin:0 0 10px}.lp-trust-lead{color:var(--text2);margin:0 0 24px;line-height:1.6}.lp-trust-list{list-style:none;margin:0;padding:0;display:grid;gap:12px;text-align:left}.lp-trust-list li{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--surface2);border-radius:var(--r-md);font-size:14px;color:var(--text2)}.lp-trust-list svg{flex:none;color:var(--blue);margin-top:1px}.lp-cta{padding-bottom:clamp(64px,10vw,96px)}.lp-cta-inner{text-align:center;padding:clamp(40px,6vw,64px) clamp(24px,5vw,48px);border-radius:var(--r-xl);background:radial-gradient(ellipse 80% 120% at 50% 0%,rgba(255,255,255,.15),transparent 60%),linear-gradient(135deg,#2563eb,#1d4ed8 55%,#1e40af);color:#fff;box-shadow:0 20px 50px #2563eb59}.lp-cta-inner h2{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:800;margin:0 0 24px;letter-spacing:-.02em}.lp-cta-sub{margin:0;font-size:15px;opacity:.92}.lp-cta-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.lp-btn-on-blue{min-height:48px;background:#fff;color:var(--blue-dark);box-shadow:0 4px 16px #0000001f}.lp-btn-on-blue:hover{background:#f8fafc}.lp-btn-outline-light{min-height:48px;border:1px solid rgba(255,255,255,.45);background:transparent;color:#fff}.lp-btn-outline-light:hover{background:#ffffff1a}.lp-btn-on-blue:focus-visible,.lp-btn-outline-light:focus-visible{outline:2px solid #fff;outline-offset:2px}@media(max-width:900px){.lp-hero-inner{grid-template-columns:1fr;text-align:center}.lp-hero-copy h1,.lp-lead{max-width:none;margin-left:auto;margin-right:auto}.lp-hero-cta{justify-content:center}.lp-phone-wrap{order:-1;max-width:min(260px,72vw);margin:0 auto}.lp-hero{min-height:auto;padding-top:32px}.lp-bento{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:auto}.lp-feature-card{grid-column:span 1}.lp-feature--hero{grid-column:span 2;grid-row:auto}.lp-demo-grid,.lp-steps-list{grid-template-columns:1fr}}@media(max-width:640px){.public-header-inner--with-user{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;column-gap:12px;row-gap:2px;padding:8px 0 10px}.public-header-inner--with-user .public-nav{display:contents}.public-header-inner--with-user .public-user{grid-row:1;grid-column:1;min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.public-header-inner--with-user .public-nav-cta{grid-row:1;grid-column:2;justify-self:end}.public-header-inner--with-user .public-brand{grid-row:2;grid-column:1 / -1;justify-self:start}.lp-bento{grid-template-columns:1fr}.lp-feature-card,.lp-feature--hero{grid-column:span 1}.lp-browser-body{grid-template-columns:1fr}.lp-browser-side{display:none}.lp-browser-stats{grid-template-columns:1fr 1fr}.lp-browser-highlights{grid-template-columns:1fr}.lp-cta-actions{flex-direction:column;align-items:stretch}.lp-cta-actions .btn{width:100%;justify-content:center}.lp-hero-cta .btn{flex:1 1 140px;justify-content:center}}@media(prefers-reduced-motion:reduce){.lp-feature-card:hover{transform:none}}.lp-pricing{padding:72px 0}.lp-pricing-header{text-align:center;margin-bottom:48px}.lp-pricing-header h2{font-size:clamp(22px,3.5vw,32px);font-weight:800;color:var(--lp-text, #0f172a);margin:0 0 12px}.lp-pricing-sub{font-size:16px;color:var(--lp-text2, #475569);max-width:520px;margin:0 auto}.lp-pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;max-width:780px;margin:0 auto}.lp-pricing-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:28px 24px;display:flex;flex-direction:column;gap:20px;box-shadow:0 2px 12px #0f172a0f;transition:box-shadow .15s ease,transform .15s ease}.lp-pricing-card:hover{box-shadow:0 8px 32px #0f172a1a;transform:translateY(-2px)}.lp-pricing-card--pro{border-color:#3b82f6;background:linear-gradient(160deg,#eff6ff,#fff 60%)}.lp-pricing-card-header{display:flex;flex-direction:column;gap:6px}.lp-pricing-pro-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.lp-plan-name{font-size:18px;font-weight:800;color:#0f172a}.lp-trial-badge{background:#3b82f6;color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:3px 10px;white-space:nowrap}.lp-plan-price{display:flex;align-items:baseline;gap:4px;margin-top:4px}.lp-price-amount{font-size:36px;font-weight:900;color:#0f172a;line-height:1}.lp-price-interval{font-size:14px;color:#64748b}.lp-plan-note{font-size:12px;color:#94a3b8}.lp-pricing-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;flex:1}.lp-pricing-features li{display:flex;align-items:flex-start;gap:8px;font-size:13.5px;color:#334155;line-height:1.4}.lp-pricing-features li svg{color:#059669;margin-top:2px;flex-shrink:0}.lp-pricing-renewal{font-size:12px;color:#94a3b8;margin:0}.lp-pricing-error{font-size:13px;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:8px 12px;margin:0}.lp-pricing-cta{margin-top:auto}.lp-pricing-btn{width:100%;justify-content:center;min-height:44px}@media(max-width:640px){.lp-pricing-cards{grid-template-columns:1fr}.lp-pricing{padding:48px 0}}
