@import"https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500&display=swap";:root{--font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--fs-12: 12px;--fs-13: 13px;--fs-14: 14px;--fs-15: 15px;--fs-16: 16px;--fs-18: 18px;--fs-20: 20px;--fs-24: 24px;--fs-28: 28px;--fs-32: 32px;--fs-40: 40px;--lh-tight: 1.15;--lh-snug: 1.35;--lh-normal: 1.55;--tracking-tight: -.018em;--tracking-tighter: -.025em;--tracking-wide: .04em;--canvas: oklch(98.2% .004 80);--surface: oklch(99.5% .003 80);--surface-2: oklch(96.8% .004 80);--surface-3: oklch(94.5% .005 80);--surface-hover: oklch(97.4% .004 80);--ink-900: oklch(22% .012 60);--ink-700: oklch(38% .01 60);--ink-500: oklch(56% .008 60);--ink-400: oklch(68% .007 60);--ink-300: oklch(80% .005 60);--ink-200: oklch(89% .004 60);--ink-100: oklch(94% .003 60);--border: oklch(91% .004 60);--border-strong: oklch(85% .005 60);--border-soft: oklch(94% .003 60);--accent: oklch(58% .18 25);--accent-hover: oklch(53% .19 25);--accent-soft: oklch(95% .03 25);--accent-softer: oklch(97.5% .018 25);--accent-ink: oklch(40% .16 25);--warn: oklch(72% .14 70);--warn-soft: oklch(96% .04 70);--ok: oklch(62% .14 155);--ok-soft: oklch(96% .035 155);--info: oklch(60% .13 240);--info-soft: oklch(96% .03 240);--danger: oklch(55% .2 25);--danger-soft: oklch(96% .04 25);--r-2: 2px;--r-4: 4px;--r-6: 6px;--r-8: 8px;--r-10: 10px;--r-12: 12px;--r-14: 14px;--r-16: 16px;--r-20: 20px;--r-pill: 999px;--s-1: 2px;--s-2: 4px;--s-3: 6px;--s-4: 8px;--s-5: 10px;--s-6: 12px;--s-7: 14px;--s-8: 16px;--s-9: 20px;--s-10: 24px;--s-11: 28px;--s-12: 32px;--s-14: 40px;--s-16: 48px;--s-20: 64px;--shadow-xs: 0 1px 0 0 oklch(0% 0 0 / .03);--shadow-sm: 0 1px 2px oklch(0% 0 0 / .04), 0 0 0 1px oklch(0% 0 0 / .03);--shadow-md: 0 2px 6px oklch(0% 0 0 / .05), 0 1px 2px oklch(0% 0 0 / .04), 0 0 0 1px oklch(0% 0 0 / .03);--shadow-lg: 0 12px 32px oklch(0% 0 0 / .08), 0 4px 10px oklch(0% 0 0 / .04), 0 0 0 1px oklch(0% 0 0 / .04);--shadow-pop: 0 24px 48px oklch(0% 0 0 / .12), 0 8px 16px oklch(0% 0 0 / .06), 0 0 0 1px oklch(0% 0 0 / .05);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--dur-fast: .12s;--dur: .18s;--dur-slow: .28s;--c-1: oklch(86% .08 70);--c-1-soft: oklch(94% .034 70);--c-2: oklch(84% .09 18);--c-2-soft: oklch(94% .038 18);--c-3: oklch(84% .06 145);--c-3-soft: oklch(94% .025 145);--c-4: oklch(84% .08 235);--c-4-soft: oklch(94% .034 235);--c-5: oklch(82% .09 290);--c-5-soft: oklch(94% .038 290);--c-6: oklch(86% .08 195);--c-6-soft: oklch(94% .034 195);--c-7: oklch(84% .06 110);--c-7-soft: oklch(94% .025 110);--c-8: oklch(84% .07 330);--c-8-soft: oklch(94% .03 330);--c-amber: var(--c-1);--c-amber-soft: var(--c-1-soft);--c-rose: var(--c-2);--c-rose-soft: var(--c-2-soft);--c-sage: var(--c-3);--c-sage-soft: var(--c-3-soft);--c-sky: var(--c-4);--c-sky-soft: var(--c-4-soft);--c-violet: var(--c-5);--c-violet-soft: var(--c-5-soft);--c-teal: var(--c-6);--c-teal-soft: var(--c-6-soft);--c-olive: var(--c-7);--c-olive-soft: var(--c-7-soft);--c-mauve: var(--c-8);--c-mauve-soft: var(--c-8-soft)}body.theme-muted{--c-1: oklch(74% .1 70);--c-1-soft: oklch(94% .04 70);--c-2: oklch(70% .1 18);--c-2-soft: oklch(94% .04 18);--c-3: oklch(72% .06 145);--c-3-soft: oklch(94% .025 145);--c-4: oklch(72% .08 235);--c-4-soft: oklch(94% .033 235);--c-5: oklch(68% .09 290);--c-5-soft: oklch(94% .038 290);--c-6: oklch(70% .08 195);--c-6-soft: oklch(94% .034 195);--c-7: oklch(72% .08 110);--c-7-soft: oklch(94% .034 110);--c-8: oklch(68% .07 330);--c-8-soft: oklch(94% .03 330)}body.theme-bright{--c-1: oklch(82% .13 70);--c-1-soft: oklch(94% .05 70);--c-2: oklch(78% .13 18);--c-2-soft: oklch(94% .05 18);--c-3: oklch(80% .1 145);--c-3-soft: oklch(94% .04 145);--c-4: oklch(78% .12 235);--c-4-soft: oklch(94% .05 235);--c-5: oklch(76% .13 290);--c-5-soft: oklch(94% .055 290);--c-6: oklch(80% .1 195);--c-6-soft: oklch(94% .04 195);--c-7: oklch(82% .1 110);--c-7-soft: oklch(94% .04 110);--c-8: oklch(76% .1 330);--c-8-soft: oklch(94% .04 330)}body.theme-vibrant{--c-1: oklch(76% .18 70);--c-1-soft: oklch(94% .07 70);--c-2: oklch(68% .2 18);--c-2-soft: oklch(94% .06 18);--c-3: oklch(72% .14 150);--c-3-soft: oklch(94% .058 150);--c-4: oklch(68% .18 240);--c-4-soft: oklch(94% .06 240);--c-5: oklch(64% .2 295);--c-5-soft: oklch(94% .06 295);--c-6: oklch(70% .16 195);--c-6-soft: oklch(94% .06 195);--c-7: oklch(72% .16 110);--c-7-soft: oklch(94% .06 110);--c-8: oklch(70% .14 330);--c-8-soft: oklch(94% .058 330)}body.theme-pastel{--c-1: oklch(86% .08 70);--c-1-soft: oklch(94% .034 70);--c-2: oklch(84% .09 18);--c-2-soft: oklch(94% .038 18);--c-3: oklch(84% .06 145);--c-3-soft: oklch(94% .025 145);--c-4: oklch(84% .08 235);--c-4-soft: oklch(94% .034 235);--c-5: oklch(82% .09 290);--c-5-soft: oklch(94% .038 290);--c-6: oklch(86% .08 195);--c-6-soft: oklch(94% .034 195);--c-7: oklch(84% .06 110);--c-7-soft: oklch(94% .025 110);--c-8: oklch(84% .07 330);--c-8-soft: oklch(94% .03 330)}body.theme-macaron{--c-1: oklch(88% .1 95);--c-1-soft: oklch(95% .042 95);--c-2: oklch(82% .11 320);--c-2-soft: oklch(94% .046 320);--c-3: oklch(86% .1 130);--c-3-soft: oklch(94% .042 130);--c-4: oklch(82% .1 200);--c-4-soft: oklch(94% .042 200);--c-5: oklch(82% .1 280);--c-5-soft: oklch(94% .042 280);--c-6: oklch(86% .09 165);--c-6-soft: oklch(94% .038 165);--c-7: oklch(86% .09 60);--c-7-soft: oklch(94% .038 60);--c-8: oklch(80% .09 350);--c-8-soft: oklch(94% .038 350)}body.theme-powder{--c-1: oklch(78% .1 195);--c-1-soft: oklch(94% .04 195);--c-2: oklch(76% .12 350);--c-2-soft: oklch(94% .05 350);--c-3: oklch(80% .09 220);--c-3-soft: oklch(94% .038 220);--c-4: oklch(82% .08 160);--c-4-soft: oklch(94% .034 160);--c-5: oklch(78% .1 15);--c-5-soft: oklch(94% .04 15);--c-6: oklch(80% .09 280);--c-6-soft: oklch(94% .038 280);--c-7: oklch(82% .08 130);--c-7-soft: oklch(94% .034 130);--c-8: oklch(80% .09 320);--c-8-soft: oklch(94% .038 320)}body.theme-terracotta{--c-1: oklch(70% .13 75);--c-1-soft: oklch(94% .054 75);--c-2: oklch(62% .12 35);--c-2-soft: oklch(93% .05 35);--c-3: oklch(62% .07 115);--c-3-soft: oklch(94% .03 115);--c-4: oklch(76% .06 90);--c-4-soft: oklch(94% .025 90);--c-5: oklch(60% .1 25);--c-5-soft: oklch(93% .042 25);--c-6: oklch(64% .09 60);--c-6-soft: oklch(93% .038 60);--c-7: oklch(72% .08 100);--c-7-soft: oklch(94% .034 100);--c-8: oklch(58% .1 50);--c-8-soft: oklch(93% .04 50)}body.theme-blue{--c-1: oklch(72% .12 235);--c-1-soft: oklch(94% .05 235);--c-2: oklch(64% .14 260);--c-2-soft: oklch(94% .058 260);--c-3: oklch(76% .1 200);--c-3-soft: oklch(94% .042 200);--c-4: oklch(70% .09 215);--c-4-soft: oklch(94% .038 215);--c-5: oklch(70% .06 250);--c-5-soft: oklch(94% .025 250);--c-6: oklch(74% .1 180);--c-6-soft: oklch(94% .042 180);--c-7: oklch(66% .12 245);--c-7-soft: oklch(94% .05 245);--c-8: oklch(78% .08 195);--c-8-soft: oklch(94% .034 195)}body.theme-romantic{--c-1: oklch(76% .13 340);--c-1-soft: oklch(94% .054 340);--c-2: oklch(72% .14 305);--c-2-soft: oklch(94% .058 305);--c-3: oklch(78% .1 360);--c-3-soft: oklch(94% .042 360);--c-4: oklch(80% .11 35);--c-4-soft: oklch(94% .046 35);--c-5: oklch(74% .09 320);--c-5-soft: oklch(94% .038 320);--c-6: oklch(78% .1 15);--c-6-soft: oklch(94% .042 15);--c-7: oklch(76% .1 285);--c-7-soft: oklch(94% .042 285);--c-8: oklch(80% .09 60);--c-8-soft: oklch(94% .038 60)}html,body{font-family:var(--font-sans);background:var(--canvas);color:var(--ink-900);font-size:var(--fs-14);letter-spacing:var(--tracking-tight);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.mono{font-family:var(--font-mono);font-feature-settings:"tnum"}.num{font-variant-numeric:tabular-nums}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-14)}.card-flat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-12)}.btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-8);font-size:var(--fs-13);font-weight:500;letter-spacing:var(--tracking-tight);background:var(--surface);color:var(--ink-900);border:1px solid var(--border);cursor:pointer;transition:background var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}.btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.btn-primary{background:var(--ink-900);color:var(--surface);border-color:var(--ink-900)}.btn-primary:hover{background:#0f0a06}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-700)}.btn-ghost:hover{background:var(--surface-2);color:var(--ink-900)}.btn-sm{height:26px;padding:0 8px;font-size:var(--fs-12);border-radius:var(--r-6)}.btn-lg{height:40px;padding:0 16px;font-size:var(--fs-14);border-radius:var(--r-10)}.btn-icon{width:28px;padding:0;justify-content:center}.btn-icon-sm{width:22px;height:22px;padding:0;justify-content:center;border-radius:var(--r-6)}.chip{display:inline-flex;align-items:center;gap:4px;height:22px;padding:0 8px;border-radius:var(--r-pill);background:var(--surface-2);color:var(--ink-700);font-size:var(--fs-12);font-weight:500;border:1px solid var(--border-soft)}.chip-soft{background:var(--surface-2);border-color:transparent}.chip-accent{background:var(--accent-soft);color:var(--accent-ink);border-color:transparent}.chip-warn{background:var(--warn-soft);color:#653e00;color:oklch(40% .13 70);border-color:transparent}.chip-ok{background:var(--ok-soft);color:#00502b;color:oklch(38% .12 155);border-color:transparent}.input{height:32px;padding:0 10px;border-radius:var(--r-8);border:1px solid var(--border);background:var(--surface);font-size:var(--fs-13);color:var(--ink-900);width:100%;outline:none;transition:border-color var(--dur) var(--ease-out)}.input:focus{border-color:var(--ink-700)}.input::placeholder{color:var(--ink-300)}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;font-family:var(--font-mono);font-size:10.5px;background:var(--surface-2);color:var(--ink-500);border:1px solid var(--border-soft);border-radius:var(--r-4)}.divider{height:1px;background:var(--border-soft);width:100%}.divider-v{width:1px;background:var(--border-soft);align-self:stretch}.dot{width:8px;height:8px;border-radius:50%;flex:none}.dot-sm{width:6px;height:6px;border-radius:50%;flex:none}.label-cap{font-size:11px;font-weight:500;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--ink-400)}.skel{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;border-radius:var(--r-6)}.state-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:40px 24px;border:1px solid var(--border-soft);border-radius:var(--r-12);background:var(--surface);color:var(--ink-700)}.state-empty .state-empty-icon{width:48px;height:48px;border-radius:var(--r-12);background:var(--surface-2);display:grid;place-items:center;color:var(--ink-400)}.state-empty .state-title{font-size:var(--fs-15);font-weight:600;letter-spacing:var(--tracking-tighter);color:var(--ink-900)}.state-empty .state-desc{font-size:var(--fs-13);color:var(--ink-500);max-width:340px;line-height:1.5}.state-empty .state-actions{display:flex;gap:8px;margin-top:4px}.state-empty.state-inline{flex-direction:row;text-align:left;padding:20px 16px;gap:12px;align-items:flex-start;background:var(--surface-2);border-style:dashed}.state-empty.state-inline>svg{color:var(--ink-400);margin-top:2px;flex:none}.state-empty.state-inline p{margin:0;font-size:var(--fs-13);color:var(--ink-500);line-height:1.5}.state-card{display:flex;gap:12px;padding:14px 16px;border-radius:var(--r-12);border:1px solid var(--border-soft);background:var(--surface)}.state-card .state-icon{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;flex:none;color:var(--ink-500);background:var(--surface-2)}.state-card .state-body{display:flex;flex-direction:column;gap:4px;min-width:0}.state-card .state-title{font-size:var(--fs-13);font-weight:600;color:var(--ink-900)}.state-card .state-desc{font-size:12.5px;color:var(--ink-700);line-height:1.5;margin:0}.state-card .state-actions{display:flex;gap:8px;margin-top:6px}.state-card.state-error{background:var(--accent-softer);border-color:#fedbd7}.state-card.state-error .state-icon{background:var(--accent-soft);color:var(--accent)}.state-card.state-error .state-title{color:var(--accent-ink)}.state-card.state-warning{background:var(--warn-soft);border-color:#fbe0c1}.state-card.state-warning .state-icon{background:#ffe7cc;background:oklch(94% .06 70);color:#8a5600;color:oklch(50% .13 70)}.state-card.state-info{background:var(--info-soft);border-color:#cee9fd}.state-card.state-info .state-icon{background:#d9efff;background:oklch(94% .05 240);color:var(--info)}.state-banner{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:var(--r-8);font-size:var(--fs-13);color:var(--ink-700);background:var(--surface-2);border:1px solid var(--border-soft)}.state-banner .state-banner-icon{color:var(--ink-500);flex:none}.state-banner.state-error{background:var(--accent-softer);border-color:#fedbd7;color:var(--accent-ink)}.state-banner.state-warning{background:var(--warn-soft);border-color:#fbe0c1;color:#653e00;color:oklch(40% .13 70)}.state-banner.state-info{background:var(--info-soft);border-color:#cee9fd;color:var(--info)}@keyframes skel-shimmer{0%{background-position:0% 50%}to{background-position:-200% 50%}}.skel,.skel-line,.skel-block{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:skel-shimmer 1.6s linear infinite;border-radius:var(--r-6)}.skel-line{height:12px}.skel-line.skel-sm{height:10px}.skel-line.skel-lg{height:18px}.skel-block{width:100%;height:100%;min-height:60px}.skel-list{display:flex;flex-direction:column;gap:8px}.state-syncing{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);color:var(--ink-500);padding:6px 4px}.state-syncing-radio{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--ink-300);border-top-color:var(--ink-700);animation:analytics-spin .9s linear infinite;flex:none}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);font-size:var(--fs-14);letter-spacing:var(--tracking-tight);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--canvas);color:var(--ink-900)}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:600;letter-spacing:var(--tracking-tighter)}.landing{min-height:100vh;background:#fff;color:#1a202c}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #f0f0f0}.landing-nav-inner{max-width:1100px;margin:0 auto;padding:0 32px;height:60px;display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:#1a202c;letter-spacing:-.02em}.landing-logo-icon{width:28px;height:28px;border-radius:7px;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.landing-logo-icon.small{width:22px;height:22px;border-radius:5px}.landing-nav-links{display:flex;align-items:center;gap:8px}.landing-nav-link{padding:7px 16px;font-size:14px;font-weight:500;color:#4a5568;text-decoration:none;border-radius:8px;transition:background .15s}.landing-nav-link:hover{background:#f7fafc}.landing-nav-btn{padding:7px 18px;font-size:14px;font-weight:600;color:#fff;background:#1a202c;border-radius:8px;text-decoration:none;transition:background .15s}.landing-nav-btn:hover{background:#2d3748}.landing-hero{padding:130px 32px 40px;text-align:center}.landing-hero-inner{max-width:680px;margin:0 auto}.landing-badge{display:inline-block;padding:5px 14px;font-size:12px;font-weight:600;color:#5a67d8;background:#ebf4ff;border-radius:20px;margin-bottom:24px;letter-spacing:.02em}.landing-title{font-size:52px;font-weight:800;line-height:1.1;letter-spacing:-.03em;color:#1a202c;margin-bottom:20px}.landing-title-accent{background:linear-gradient(135deg,#5a67d8,#38b2ac);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-subtitle{font-size:18px;line-height:1.65;color:#718096;margin-bottom:36px;max-width:520px;margin-left:auto;margin-right:auto}.landing-cta{display:flex;align-items:center;justify-content:center;gap:12px}.landing-cta-primary{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;font-size:15px;font-weight:600;color:#fff;background:#1a202c;border-radius:10px;text-decoration:none;transition:background .15s,transform .1s}.landing-cta-primary:hover{background:#2d3748;transform:translateY(-1px)}.landing-cta-secondary{padding:12px 24px;font-size:15px;font-weight:500;color:#4a5568;text-decoration:none;border-radius:10px;border:1px solid #e2e8f0;transition:background .15s}.landing-cta-secondary:hover{background:#f7fafc}.landing-preview-wrapper{position:relative;max-width:1060px;margin:56px auto 0;padding:0 20px}.landing-preview-glow{position:absolute;top:30px;left:50%;transform:translate(-50%);width:90%;height:70%;background:radial-gradient(ellipse,rgba(90,103,216,.12) 0%,transparent 70%);pointer-events:none;z-index:0}.preview-container{position:relative;z-index:1;border-radius:12px;overflow:hidden;box-shadow:0 8px 40px #0000001f,0 0 0 1px #0000000f;background:#1a1a1a;animation:previewFloat 6s ease-in-out infinite,previewFadeIn .8s ease-out}@keyframes previewFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes previewFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.preview-browser{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#2d2d2d}.preview-dots{display:flex;gap:6px}.preview-dots .dot{width:10px;height:10px;border-radius:50%}.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}.preview-url{flex:1;text-align:center}.preview-url span{display:inline-block;padding:4px 24px;background:#3a3a3a;border-radius:6px;font-size:12px;color:#aaa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,monospace}.preview-screen{position:relative;width:100%;aspect-ratio:2560 / 1347;overflow:hidden;background:#f5f5f5}.preview-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:top left;opacity:0;transition:opacity .6s ease-in-out}.preview-img.active{opacity:1}.preview-tabs{display:flex;justify-content:center;gap:4px;padding:10px 16px;background:#2d2d2d}.preview-tab{padding:4px 14px;font-size:11px;font-weight:500;color:#888;background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s;font-family:inherit}.preview-tab.active{color:#fff;background:#3a3a3a}.preview-tab:hover:not(.active){color:#bbb}.landing-features{padding:80px 32px;background:#fafbfc}.landing-features-inner{max-width:1000px;margin:0 auto}.landing-section-title{text-align:center;font-size:28px;font-weight:700;letter-spacing:-.02em;margin-bottom:48px;color:#1a202c}.landing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.landing-feature-card{padding:28px 24px;background:#fff;border-radius:12px;border:1px solid #edf2f7;transition:box-shadow .2s,transform .15s}.landing-feature-card:hover{box-shadow:0 4px 20px #0000000f;transform:translateY(-2px)}.landing-feature-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ebf4ff;color:#5a67d8;border-radius:10px;margin-bottom:16px}.landing-feature-card h3{font-size:16px;font-weight:600;margin-bottom:8px;color:#1a202c}.landing-feature-card p{font-size:14px;line-height:1.6;color:#718096}.landing-steps{padding:80px 32px}.landing-steps-inner{max-width:900px;margin:0 auto}.landing-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;text-align:center}.landing-step-num{width:40px;height:40px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;background:#1a202c;color:#fff;font-size:16px;font-weight:700;border-radius:50%}.landing-step h3{font-size:16px;font-weight:600;margin-bottom:8px;color:#1a202c}.landing-step p{font-size:14px;line-height:1.6;color:#718096}.landing-bottom-cta{padding:80px 32px;background:#fafbfc;text-align:center}.landing-bottom-cta-inner{max-width:600px;margin:0 auto}.landing-bottom-cta h2{font-size:28px;font-weight:700;letter-spacing:-.02em;margin-bottom:28px;color:#1a202c}.landing-footer{padding:28px 32px;border-top:1px solid #edf2f7}.landing-footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.landing-footer-brand{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#a0aec0}.landing-footer-copy{font-size:13px;color:#a0aec0}@media(max-width:768px){.landing-title{font-size:34px}.landing-subtitle{font-size:16px}.landing-features-grid{grid-template-columns:1fr}.landing-steps-grid{grid-template-columns:1fr;gap:32px}.landing-hero{padding:120px 20px 40px}.landing-cta{flex-direction:column}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fafbfc;padding:40px 20px}.auth-container{width:100%;max-width:400px;text-align:center}.auth-logo{display:inline-flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:#1a202c;text-decoration:none;margin-bottom:36px}.auth-logo .landing-logo-icon{width:28px;height:28px;border-radius:7px;background:var(--accent);display:flex;align-items:center;justify-content:center}.auth-title{font-size:26px;font-weight:700;color:#1a202c;letter-spacing:-.02em;margin-bottom:6px}.auth-subtitle{font-size:14px;color:#718096;margin-bottom:28px}.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px;font-size:14px;font-weight:500;color:#2d3748;background:#fff;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:background .15s,box-shadow .15s;font-family:inherit}.auth-google-btn:hover{background:#f7fafc;box-shadow:0 1px 4px #0000000f}.auth-divider{display:flex;align-items:center;margin:20px 0;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.auth-divider span{font-size:12px;color:#a0aec0;text-transform:uppercase;letter-spacing:.05em}.auth-form{display:flex;flex-direction:column;gap:12px;text-align:left}.auth-field{position:relative}.auth-field-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#a0aec0;pointer-events:none}.auth-field input{width:100%;padding:11px 14px 11px 40px;font-size:14px;font-family:inherit;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#1a202c;transition:border-color .15s,box-shadow .15s;outline:none}.auth-field input:focus{border-color:#5a67d8;box-shadow:0 0 0 3px #5a67d81a}.auth-field input::placeholder{color:#a0aec0}.auth-error{font-size:13px;color:#e53e3e;text-align:center;padding:8px;background:#fff5f5;border-radius:8px}.auth-submit{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:11px;font-size:15px;font-weight:600;font-family:inherit;color:#fff;background:#1a202c;border:none;border-radius:10px;cursor:pointer;transition:background .15s;margin-top:4px}.auth-submit:hover{background:#2d3748}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-footer-text{margin-top:24px;font-size:14px;color:#718096}.auth-footer-text a{color:#5a67d8;font-weight:500;text-decoration:none}.auth-footer-text a:hover{text-decoration:underline}.onboarding-page{min-height:100vh;background:#fafbfc;display:flex;flex-direction:column;align-items:center;padding:40px 20px}.onboarding-header{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:#1a202c;margin-bottom:40px}.onboarding-header .landing-logo-icon{width:28px;height:28px;border-radius:7px;background:var(--accent);display:flex;align-items:center;justify-content:center}.onboarding-progress{display:flex;align-items:center;gap:0;margin-bottom:40px;width:100%;max-width:520px}.onboarding-step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0;transition:all .2s;border:2px solid #e2e8f0;background:#fff;color:#a0aec0}.onboarding-step-dot.active{border-color:#1a202c;background:#1a202c;color:#fff}.onboarding-step-dot.completed{border-color:#48bb78;background:#48bb78;color:#fff}.onboarding-step-line{flex:1;height:2px;background:#e2e8f0;transition:background .2s}.onboarding-step-line.completed{background:#48bb78}.onboarding-card{width:100%;max-width:520px;background:#fff;border-radius:16px;border:1px solid #edf2f7;padding:36px 32px;box-shadow:0 1px 8px #0000000a}.onboarding-card h2{font-size:22px;font-weight:700;color:#1a202c;margin-bottom:6px;letter-spacing:-.02em}.onboarding-card .step-desc{font-size:14px;color:#718096;margin-bottom:28px;line-height:1.5}.ob-field{margin-bottom:18px}.ob-field label{display:block;font-size:13px;font-weight:600;color:#4a5568;margin-bottom:6px}.ob-field input,.ob-field select{width:100%;padding:10px 14px;font-size:14px;font-family:inherit;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#1a202c;outline:none;transition:border-color .15s,box-shadow .15s}.ob-field input:focus,.ob-field select:focus{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e1a}.ob-field input::placeholder{color:#a0aec0}.ob-field .ob-hint{font-size:12px;color:#a0aec0;margin-top:4px}.ob-field-row{display:flex;gap:12px}.ob-field-row .ob-field{flex:1}.ob-token-field{position:relative}.ob-token-field input{padding-right:40px}.ob-token-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;display:flex}.ob-token-toggle:hover{color:#718096}.ob-connection-status{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;margin-bottom:18px}.ob-connection-status.testing{background:#ebf8ff;color:#3182ce}.ob-connection-status.success{background:#f0fff4;color:#38a169}.ob-connection-status.error{background:#fff5f5;color:#e53e3e}.ob-connection-status .ob-spinner{animation:obSpin 1s linear infinite}@keyframes obSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ob-test-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:600;font-family:inherit;color:#3182ce;background:#ebf4ff;border:none;border-radius:8px;cursor:pointer;transition:background .15s;margin-bottom:8px}.ob-test-btn:hover{background:#c3dafe}.ob-test-btn.connected{color:#38a169;background:#f0fff4}.ob-test-btn:disabled{opacity:.6;cursor:not-allowed}.ob-course-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;max-height:340px;overflow-y:auto}.ob-course-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid #edf2f7;border-radius:10px;transition:border-color .15s,background .15s;cursor:pointer}.ob-course-item:hover{background:#f7fafc}.ob-course-item.selected{border-color:#e53e3e;background:#fff5f5}.ob-course-check{width:20px;height:20px;border-radius:6px;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ob-course-item.selected .ob-course-check{border-color:#e53e3e;background:#e53e3e;color:#fff}.ob-course-info{flex:1;min-width:0}.ob-course-name{font-size:14px;font-weight:600;color:#1a202c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ob-course-code{font-size:12px;color:#a0aec0}.ob-course-color{width:24px;height:24px;border-radius:6px;border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:transform .1s}.ob-course-color:hover{transform:scale(1.15)}.ob-color-picker{position:relative}.ob-color-popover{position:absolute;right:0;top:100%;margin-top:4px;padding:8px;background:#fff;border-radius:10px;border:1px solid #edf2f7;box-shadow:0 4px 16px #0000001a;display:flex;gap:6px;flex-wrap:wrap;width:160px;z-index:10}.ob-color-swatch{width:24px;height:24px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:transform .1s}.ob-color-swatch:hover{transform:scale(1.15)}.ob-color-swatch.active{border-color:#1a202c}.ob-pref-group{margin-bottom:22px}.ob-pref-group label{display:block;font-size:13px;font-weight:600;color:#4a5568;margin-bottom:8px}.ob-radio-group{display:flex;gap:8px}.ob-radio-option{flex:1;padding:14px 16px;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;text-align:center;transition:all .15s}.ob-radio-option:hover{background:#f7fafc}.ob-radio-option.selected{border-color:#e53e3e;background:#fff5f5}.ob-radio-option .ob-radio-icon{display:flex;align-items:center;justify-content:center;margin-bottom:6px;color:#a0aec0}.ob-radio-option.selected .ob-radio-icon{color:#e53e3e}.ob-radio-option .ob-radio-title{font-size:14px;font-weight:600;color:#1a202c;margin-bottom:2px}.ob-radio-option .ob-radio-desc{font-size:12px;color:#a0aec0;line-height:1.4}.ob-slider-row{display:flex;align-items:center;gap:12px}.ob-slider-row input[type=range]{flex:1;accent-color:#e53e3e}.ob-slider-value{font-size:14px;font-weight:600;color:#1a202c;min-width:44px;text-align:center}.ob-tz-wrapper{position:relative}.ob-tz-dropdown{position:absolute;top:100%;left:0;right:0;max-height:180px;overflow-y:auto;background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-top:4px;box-shadow:0 4px 16px #00000014;z-index:10}.ob-tz-option{padding:8px 14px;font-size:13px;color:#4a5568;cursor:pointer}.ob-tz-option:hover{background:#f7fafc}.ob-tz-option.active{background:#ebf4ff;color:#e53e3e;font-weight:500}.ob-import-zone{border:2px dashed #e2e8f0;border-radius:12px;padding:32px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;margin-bottom:18px}.ob-import-zone:hover{border-color:#cbd5e0;background:#f7fafc}.ob-import-zone-icon{color:#a0aec0;margin-bottom:8px}.ob-import-zone p{font-size:14px;color:#718096;margin-bottom:4px}.ob-import-zone .ob-import-hint{font-size:12px;color:#a0aec0}.ob-import-file{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#f7fafc;border-radius:10px;margin-bottom:18px}.ob-import-file-name{flex:1;font-size:14px;color:#4a5568;font-weight:500}.ob-import-file-remove{background:none;border:none;color:#a0aec0;cursor:pointer;display:flex;padding:2px}.ob-import-file-remove:hover{color:#e53e3e}.ob-skip-text{text-align:center;font-size:13px;color:#a0aec0;margin-top:8px}.onboarding-nav{display:flex;align-items:center;justify-content:space-between;margin-top:28px;padding-top:20px;border-top:1px solid #edf2f7}.ob-back-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:500;font-family:inherit;color:#718096;background:transparent;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:background .15s}.ob-back-btn:hover{background:#f7fafc}.ob-next-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;font-size:14px;font-weight:600;font-family:inherit;color:#fff;background:#1a202c;border:none;border-radius:10px;cursor:pointer;transition:background .15s}.ob-next-btn:hover{background:#2d3748}.ob-next-btn:disabled{opacity:.5;cursor:not-allowed}.ob-next-btn.finish{background:#48bb78}.ob-next-btn.finish:hover{background:#38a169}.ob-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0;gap:12px;color:#a0aec0}.ob-loading .ob-spinner{animation:obSpin 1s linear infinite}.ob-empty{text-align:center;padding:24px 0;color:#a0aec0;font-size:14px}@media(max-width:560px){.onboarding-card{padding:28px 20px}.ob-radio-group{flex-direction:column}}.legal-page{min-height:100vh;background:#f7fafc;padding:0 20px 60px}.legal-header{padding:20px 0;max-width:720px;margin:0 auto}.legal-container{max-width:720px;margin:0 auto;background:#fff;border-radius:12px;padding:40px 48px;box-shadow:0 1px 3px #00000014}.legal-container h1{font-size:28px;font-weight:700;color:#1a202c;margin:0 0 4px}.legal-updated{color:#a0aec0;font-size:13px;margin:0 0 32px}.legal-container h2{font-size:16px;font-weight:600;color:#2d3748;margin:28px 0 8px}.legal-container p{font-size:14px;line-height:1.7;color:#4a5568;margin:0 0 12px}.legal-container ul{margin:0 0 12px;padding-left:20px}.legal-container li{font-size:14px;line-height:1.7;color:#4a5568;margin-bottom:4px}.legal-container a{color:#5a67d8}.sidebar{width:240px;flex:none;background:var(--canvas);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;padding:14px 10px;gap:2px;font-family:var(--font-sans);color:var(--ink-900)}.sidebar-brand{display:flex;align-items:center;gap:8px;padding:4px 8px 14px}.sidebar-brand-mark{width:26px;height:26px;border-radius:7px;background:var(--accent);color:#fff;display:grid;place-items:center}.sidebar-brand-name{font-weight:600;font-size:14px;letter-spacing:var(--tracking-tight)}.sidebar-quickadd{display:inline-flex;align-items:center;gap:8px;height:30px;margin:4px 4px 10px;padding:0 10px;border-radius:var(--r-8);font-size:13px;font-weight:500;color:var(--ink-500);background:var(--surface-2);border:1px dashed var(--border);cursor:pointer;transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.sidebar-quickadd:hover{background:var(--surface-hover);color:var(--ink-900)}.sidebar-quickadd-keys{margin-left:auto;display:flex;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;height:30px;padding:0 8px;border-radius:var(--r-6);color:var(--ink-700);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.nav-item:hover{background:var(--surface-2);color:var(--ink-900)}.nav-item.active{background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow-sm)}.nav-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-count{margin-left:auto;font-size:11px;color:var(--ink-400);font-family:var(--font-mono)}.sidebar-courses-row{padding-right:4px}.sidebar-courses-meta{margin-left:auto;display:inline-flex;align-items:center;gap:4px}.sidebar-courses-meta .nav-count{margin:0}.sidebar-chevron-wrap{display:grid;place-items:center;width:18px;height:18px;border-radius:4px;color:var(--ink-400);transition:transform var(--dur) var(--ease-out)}.sidebar-chevron-wrap.expanded{transform:rotate(0)}.sidebar-chevron-wrap.collapsed{transform:rotate(-90deg)}.sidebar-course-item{display:flex;align-items:center;gap:10px;height:28px;padding-left:26px;padding-right:8px;border-radius:var(--r-6);color:var(--ink-700);font-size:12.5px;font-weight:500;cursor:pointer;transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.sidebar-course-item:hover{background:var(--surface-2);color:var(--ink-900)}.sidebar-course-item.active{background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow-sm)}.sidebar-course-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-spacer{flex:1}.sidebar-footer{margin-top:auto;padding:10px 8px 4px;border-top:1px solid var(--border-soft);display:flex;align-items:center;gap:8px}.sidebar-avatar{width:22px;height:22px;border-radius:50%;background:var(--c-amber);color:#fff;font-size:11px;font-weight:600;display:grid;place-items:center;flex:none}.sidebar-user{flex:1;overflow:hidden}.sidebar-user-name{font-size:12px;font-weight:500;color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-meta{font-size:11px;color:var(--ink-400)}.sidebar-logout{width:24px;height:24px;display:grid;place-items:center;border-radius:6px;color:var(--ink-400);cursor:pointer;transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.sidebar-logout:hover{background:var(--surface-2);color:var(--ink-900)}@media(max-width:768px){.sidebar{width:100%;height:auto;flex-direction:row;flex-wrap:wrap;padding:8px;overflow-x:auto;border-right:none;border-bottom:1px solid var(--border-soft)}.sidebar-brand{padding:0 8px 0 4px}.sidebar-quickadd{display:none}.nav-item{padding:0 8px;height:28px}.nav-item-label,.sidebar-courses-list,.sidebar-spacer,.sidebar-footer{display:none}}.time-block{position:absolute;left:4px;right:4px;border-radius:6px;cursor:grab;display:flex;flex-direction:column;overflow:hidden;-webkit-user-select:none;user-select:none;transition:box-shadow .18s ease,opacity .18s ease,transform .18s ease;z-index:10;box-sizing:border-box}.time-block.dragging{cursor:grabbing;z-index:100;transition:none}.time-block.selected{z-index:50}.time-block.highlighted{z-index:60;transform:scale(1.012)}.time-block.fixed,.time-block.fixed .block-content{cursor:default}.resize-handle{position:absolute;left:0;right:0;height:7px;cursor:ns-resize;display:flex;justify-content:center;align-items:center;z-index:1}.resize-handle.top{top:0}.resize-handle.bottom{bottom:0}.handle-bar{width:20px;height:2.5px;border-radius:2px;opacity:.6}.block-content{flex:1;padding:4px 8px;display:flex;flex-direction:column;gap:1px;min-height:0;cursor:grab}.time-block.dragging .block-content{cursor:grabbing}.block-title-row{display:flex;align-items:flex-start;gap:5px}.block-title{font-size:12px;font-weight:600;line-height:14px;flex:1;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;letter-spacing:-.01em}.block-time{font-size:10px;display:flex;align-items:center;gap:3px;font-variant-numeric:tabular-nums}.block-duration{margin-left:1px}.block-checkbox-mark{width:12px;height:12px;border-radius:3px;border:1.4px solid var(--ink-300, #cbd5e0);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;cursor:pointer;transition:transform .12s ease}.block-checkbox-mark:hover{transform:scale(1.12)}.block-checkbox-mark.planned{background:var(--surface, #fff)}.block-checkbox-mark.done{border-width:1px}.delete-btn{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:3px;background:#00000080;color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:200;line-height:1;transition:background .15s}.delete-btn:hover{background:#000000b3}.block-checkbox{cursor:pointer;width:13px;height:13px;margin:0;flex-shrink:0}.modal-overlay{position:fixed;inset:0;background:#00000040;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:24px;width:380px;box-shadow:0 20px 60px #00000026}.popover-overlay{position:fixed;inset:0;z-index:1000}.popover-content{position:fixed;background:#fff;border-radius:12px;padding:24px;width:380px;box-shadow:0 8px 30px #0000002e,0 2px 8px #00000014;z-index:1001}.popover-arrow{position:absolute;width:10px;height:10px;background:#fff;transform:translateY(-50%) rotate(45deg)}.popover-arrow-left{left:-5px;box-shadow:-2px 2px 4px #0000000f}.popover-arrow-right{right:-5px;box-shadow:2px -2px 4px #0000000f}.modal-title{font-size:16px;font-weight:700;margin-bottom:12px;color:#2d3748}.modal-input{width:100%;padding:10px 0;border-radius:0;border:none;border-bottom:1px solid #E2E8F0;font-size:14px;outline:none;box-sizing:border-box;margin-bottom:16px}.modal-input:focus{border-color:#3182ce}.modal-form{border-top:1px solid #EDF2F7;padding-top:8px;margin-bottom:16px}.modal-form-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #EDF2F7;min-height:20px}.modal-form-row:last-child{border-bottom:none}.modal-form-row-notes{align-items:flex-start}.modal-form-label{font-size:14px;color:#2d3748;flex-shrink:0;min-width:60px}.modal-form-value{display:flex;align-items:center;gap:8px;color:#4a5568;font-size:14px}.modal-form-date{font-size:14px;color:#718096;background:#f7fafc;padding:4px 8px;border-radius:6px;border:1px solid #E2E8F0}.color-dot-trigger{width:20px;height:20px;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #00000026;transition:transform .12s}.color-dot-trigger:hover{transform:scale(1.15)}.color-grid-overlay{position:fixed;inset:0;z-index:1100}.color-grid-popup{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border-radius:12px;padding:16px;box-shadow:0 12px 40px #0003,0 2px 8px #00000014;z-index:1101;width:280px}.color-grid-presets{display:flex;gap:8px;flex-wrap:wrap}.color-grid-dot{width:22px;height:22px;border-radius:50%;cursor:pointer;transition:transform .12s;box-sizing:border-box}.color-grid-dot:hover{transform:scale(1.2)}.color-grid-dot.selected{transform:scale(1.15)}.color-grid-rainbow{background:conic-gradient(#e06c6c,#e0a66c,#e0e06c,#59c059,#53c6c6,#6186d1,#a679d2,#c6a,#e06c6c)!important;border:2px solid rgba(255,255,255,.6)!important;box-shadow:0 1px 3px #0000001f;position:relative}.color-grid-rainbow.active{border-color:#0003!important;box-shadow:0 0 0 2px #00000026}.color-grid-matrix{display:flex;flex-direction:column;gap:2px;margin-top:12px;padding-top:12px;border-top:1px solid #EDF2F7}.color-grid-row{display:flex;gap:2px}.color-grid-cell{width:20px;height:20px;border-radius:3px;cursor:pointer;transition:transform .1s}.color-grid-cell:hover{transform:scale(1.3);z-index:1}.repeat-modal-overlay{position:fixed;inset:0;background:#0003;z-index:1100;display:flex;align-items:center;justify-content:center}.repeat-modal{background:#fff;border-radius:12px;padding:24px;width:320px;box-shadow:0 12px 40px #0000002e;position:relative}.repeat-close-btn{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:#a0aec0;padding:4px;display:flex;align-items:center;justify-content:center}.repeat-close-btn:hover{color:#4a5568}.repeat-title{font-size:16px;font-weight:700;color:#2d3748;margin-bottom:16px}.repeat-mode-select{width:100%;padding:8px 12px;border:1px solid #E2E8F0;border-radius:8px;font-size:14px;color:#2d3748;background:#f7fafc;outline:none;cursor:pointer;margin-bottom:12px}.repeat-mode-select:focus{border-color:#3182ce}.repeat-interval-row{display:flex;align-items:center;gap:8px;font-size:14px;color:#4a5568;margin-bottom:12px}.repeat-interval-input{width:48px;padding:6px 8px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;text-align:center;outline:none;color:#2d3748}.repeat-interval-input:focus{border-color:#3182ce}.repeat-day-chips{display:flex;gap:6px;margin-bottom:12px}.repeat-chip{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#4a5568;background:#f7fafc;border:1px solid #E2E8F0;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.repeat-chip:hover{background:#edf2f7}.repeat-chip.active{background:#e53e3e;color:#fff;border-color:#e53e3e}.repeat-tabs{display:flex;gap:0;margin-bottom:12px;border:1px solid #E2E8F0;border-radius:8px;overflow:hidden}.repeat-tab{flex:1;padding:8px 0;text-align:center;font-size:13px;font-weight:500;color:#4a5568;background:#f7fafc;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.repeat-tab:hover{background:#edf2f7}.repeat-tab.active{background:#e53e3e;color:#fff}.repeat-date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:12px}.repeat-date-cell{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;color:#4a5568;background:#f7fafc;border:1px solid #EDF2F7;border-radius:6px;cursor:pointer;transition:all .12s;-webkit-user-select:none;user-select:none}.repeat-date-cell:hover{background:#edf2f7}.repeat-date-cell.active{background:#e53e3e;color:#fff;border-color:#e53e3e}.repeat-month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:12px}.repeat-month-chip{padding:8px 0;text-align:center;font-size:13px;font-weight:500;color:#4a5568;background:#f7fafc;border:1px solid #EDF2F7;border-radius:8px;cursor:pointer;transition:all .12s;-webkit-user-select:none;user-select:none}.repeat-month-chip:hover{background:#edf2f7}.repeat-month-chip.active{background:#e53e3e;color:#fff;border-color:#e53e3e}.repeat-confirm-btn{width:100%;padding:10px;border:none;border-radius:8px;background:#e53e3e;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.repeat-confirm-btn:hover{background:#c53030}.modal-form-clickable{color:#4a5568;cursor:pointer;font-size:14px}.repeat-value-display{display:flex;align-items:center;gap:4px}.repeat-stepper-arrows{display:inline-flex;flex-direction:column;align-items:center;line-height:1;margin-left:2px;gap:0}.repeat-arrow-up,.repeat-arrow-down{font-size:10px;color:#a0aec0;line-height:7px;display:block}.repeat-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border-radius:10px;box-shadow:0 8px 30px #00000029,0 2px 8px #0000000f;min-width:200px;padding:6px 0;z-index:1050;overflow:hidden}.repeat-dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:9px 16px;font-size:14px;color:#2d3748;cursor:pointer;transition:background .1s;gap:10px}.repeat-dropdown-item:hover{background:#f7fafc}.repeat-dropdown-item.active{font-weight:500}.repeat-dropdown-check{color:#e53e3e;font-size:15px;font-weight:600}.repeat-dropdown-divider{height:1px;background:#edf2f7;margin:4px 0}.repeat-dropdown-custom{color:#e53e3e;gap:8px;justify-content:flex-start}.repeat-dropdown-custom svg{color:#e53e3e}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:#cbd5e0;border-radius:22px;transition:.2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px #00000026}.toggle-switch input:checked+.toggle-slider{background:#48bb78}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.modal-time-input{padding:4px 8px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;outline:none;color:#2d3748;background:#f7fafc}.modal-time-input:focus{border-color:#3182ce}.modal-notes-input{width:100%;padding:8px 10px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;outline:none;resize:vertical;font-family:inherit;color:#2d3748;box-sizing:border-box;min-height:40px}.modal-notes-input:focus{border-color:#3182ce}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modal-btn{padding:8px 18px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.modal-btn.delete{border:1px solid #E2E8F0;background:#f7fafc;color:#4a5568;margin-right:auto}.modal-btn.delete:hover{background:#edf2f7}.modal-btn.cancel{border:1px solid #E2E8F0;background:#f7fafc;color:#4a5568}.modal-btn.cancel:hover{background:#edf2f7}.modal-btn.confirm{padding:8px 22px;border:none;background:#e53e3e;color:#fff;font-weight:600}.modal-btn.confirm:hover:not(:disabled){background:#c53030}.modal-btn.confirm.disabled,.modal-btn.confirm:disabled{background:#e53e3e66;cursor:default}.calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.calendar-header{padding:22px 28px 4px;flex-shrink:0}.calendar-header h1{margin:0;font-size:var(--fs-24, 24px);font-weight:600;color:var(--ink-900, #1A202C);letter-spacing:var(--tracking-tighter, -.025em);line-height:var(--lh-tight, 1.15)}.calendar-header-top{display:flex;align-items:center;justify-content:space-between;gap:16px}.calendar-header p{margin:4px 0 0;font-size:var(--fs-13, 13px);color:var(--ink-500, #718096)}.calendar-header-right{display:flex;align-items:center;gap:10px}.view-toggle{display:inline-flex;background:var(--surface-2, #EDF2F7);border-radius:8px;padding:2px;gap:1px}.view-toggle-btn{height:28px;padding:0 14px;border:none;border-radius:6px;background:transparent;color:var(--ink-500, #718096);font-size:var(--fs-13, 13px);font-weight:500;font-family:var(--font-sans, inherit);cursor:pointer;transition:background .15s ease,color .15s ease;letter-spacing:-.01em}.view-toggle-btn:hover{color:var(--ink-900, #2D3748)}.view-toggle-btn.active{background:var(--surface, #fff);color:var(--ink-900, #1A202C);box-shadow:0 1px 2px #0000000f;font-weight:600}.auto-schedule-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 14px;border-radius:8px;border:1px solid var(--border, #E2E8F0);background:var(--surface, #fff);color:var(--ink-900, #1A202C);font-size:var(--fs-13, 13px);font-weight:500;font-family:var(--font-sans, inherit);cursor:pointer;transition:background .15s ease,border-color .15s ease}.auto-schedule-btn:hover{background:var(--surface-2, #F7FAFC);border-color:var(--border-strong, #CBD5E0)}.auto-schedule-btn:disabled{opacity:.55;cursor:not-allowed}.calendar-nav{display:flex;align-items:center;padding:8px 28px 10px;gap:10px;flex-shrink:0}.nav-btn-group{display:inline-flex;border:1px solid var(--border, #E2E8F0);border-radius:8px;overflow:hidden;background:var(--surface, #fff)}.nav-btn-group .nav-btn{width:28px;height:28px;border-radius:0;border:none;border-right:1px solid var(--border-soft, #EDF2F7)}.nav-btn-group .nav-btn:last-child{border-right:none}.delete-all-btn{padding:5px 12px;border-radius:6px;border:1px solid #FEB2B2;background:#fff5f5;color:#c53030;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.delete-all-btn:hover{background:#fed7d7}.today-btn{padding:4px 10px;border-radius:var(--r-pill, 999px);border:1px solid var(--border, #E2E8F0);background:var(--surface, #fff);font-size:var(--fs-12, 12px);font-weight:500;color:var(--ink-700, #4A5568);cursor:pointer;height:22px}.today-btn:hover{background:var(--surface-2, #F7FAFC)}.nav-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border, #E2E8F0);background:var(--surface, #fff);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-500, #718096);transition:background .15s ease,color .15s ease}.nav-btn:hover{background:var(--surface-2, #F7FAFC);color:var(--ink-900, #2D3748)}.nav-date{font-weight:600;font-size:var(--fs-14, 14px);color:var(--ink-900, #2D3748);letter-spacing:-.018em}.nav-label{display:inline-flex;align-items:center;height:22px;padding:0 9px;border-radius:var(--r-pill, 999px);background:var(--accent-soft, #FED7D7);color:var(--accent, #C53030);font-size:var(--fs-12, 12px);font-weight:500;letter-spacing:-.005em;margin-left:0}.block-legend{margin-left:auto;display:inline-flex;align-items:center;gap:14px;padding:5px 12px;background:var(--surface, #fff);border:1px solid var(--border-soft, #EDF2F7);border-radius:8px}.legend-item{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--ink-600, #4A5568);font-weight:500;letter-spacing:-.005em}.legend-swatch{width:18px;height:11px;border-radius:2px;flex-shrink:0}.legend-swatch.swatch-class{background:var(--c-1, #93B6E0)}.legend-swatch.swatch-planned{background:transparent;border:1.2px dashed var(--c-1, #93B6E0)}.legend-swatch.swatch-progress{border:1.2px dashed var(--c-1, #93B6E0);background:linear-gradient(to bottom,var(--c-1-soft, #DCE7F5) 0%,var(--c-1-soft, #DCE7F5) 55%,transparent 55%,transparent 100%)}.legend-swatch.swatch-done{background:var(--c-1-soft, #DCE7F5);border-left:2px solid var(--c-1, #93B6E0)}.today-link{cursor:pointer;transition:color .15s}.today-link:not(.current):hover{color:#4a5568}.today-link.current{cursor:default}.nav-week-label{font-size:13px;font-weight:600;color:#2d3748;background:#edf2f7;padding:2px 10px;border-radius:10px;margin-left:4px}.header-section{flex-shrink:0;background:#ffffffd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid #D1D9E3;overflow-y:auto;scrollbar-gutter:stable}.day-headers{display:grid;grid-template-columns:60px repeat(7,1fr);padding:0}.day-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;border-left:1px solid #E2E8F0}.day-name{font-size:12px;font-weight:600;color:#a0aec0;letter-spacing:.8px}.day-date{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:18px;font-weight:600;font-size:16px;color:#2d3748}.day-date.today{background:#e53e3e;color:#fff}.calendar-grid{flex:1;overflow-y:scroll;overflow-x:hidden;position:relative;display:grid;grid-template-columns:60px repeat(7,1fr);scrollbar-gutter:stable}.time-labels{position:relative}.time-label{display:flex;align-items:flex-start;justify-content:flex-end;padding-right:10px;font-size:12px;color:#a0aec0;transform:translateY(-8px);-webkit-user-select:none;user-select:none;font-weight:500}.day-column{position:relative;border-left:1px solid #D1D9E3;background:#fff}.day-column.today-col{background:#fff}.hour-cell{border-bottom:1px solid #D8E0EA;box-sizing:border-box;position:relative}.drag-preview-block{position:absolute;left:4px;right:4px;border-radius:6px;background:#3182ce33;border:2px dashed rgba(49,130,206,.5);pointer-events:none;z-index:5;transition:top .08s ease,height .08s ease}.drag-preview-block.invalid{background:#e53e3e26;border-color:#e53e3e66}.current-time-line{position:absolute;left:0;right:0;height:2px;z-index:150;pointer-events:none;transform:translateY(-1px)}.current-time-line.today{background:#e53e3e}.current-time-line.non-today{background:#e53e3e26}.current-time-label{position:absolute;right:5px;transform:translateY(-50%);background:#e53e3e;color:#fff;font-size:12px;font-weight:500;padding:2px 6px;border-radius:10px;white-space:nowrap;z-index:160;pointer-events:none;line-height:1.3}.current-time-label:after{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);width:6px;height:2px;background:#e53e3e}.all-day-row{display:grid;grid-template-columns:60px repeat(7,1fr);min-height:32px}.all-day-label{display:flex;align-items:center;justify-content:flex-end;padding-right:10px;font-size:11px;color:#a0aec0;font-weight:500}.all-day-cell{border-left:1px solid #D1D9E3;padding:4px 3px;display:flex;flex-direction:column;gap:2px;max-height:116px;overflow-y:auto;scrollbar-width:thin;min-width:0;overflow:hidden}.all-day-cell.today-col{background:transparent}.all-day-pill{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:600;color:#3d3d3d;white-space:nowrap;overflow:hidden;position:relative;cursor:default;min-width:0;flex-shrink:0}.all-day-pill-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.all-day-pill-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.all-day-pill-delete{background:none;border:none;color:#0006;font-size:12px;cursor:pointer;padding:0 2px;margin-left:auto;line-height:1;display:none}.all-day-pill:hover .all-day-pill-delete{display:inline}@media(max-width:768px){.calendar-header{padding:16px 16px 0}.calendar-header h1{font-size:22px}.calendar-header-top{flex-direction:column;gap:12px}.calendar-nav{padding:0 16px 8px;gap:6px;flex-wrap:wrap}.view-toggle-btn{padding:5px 10px;font-size:12px}.day-headers,.calendar-grid,.all-day-row{grid-template-columns:40px repeat(7,1fr)}.time-label{font-size:10px;padding-right:4px}.day-name{font-size:10px}.day-date{width:28px;height:28px;font-size:13px}}.month-calendar-layout{flex:1;display:flex;overflow:hidden;background:var(--canvas);font-family:var(--font-sans)}.month-calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border)}.month-calendar-header{padding:24px 32px;background:var(--surface);border-bottom:1px solid var(--border-soft)}.month-nav{display:flex;align-items:center;gap:12px}.month-nav-btn{width:36px;height:36px;border-radius:6px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#595959;transition:all .15s ease}.month-nav-btn:hover{background:var(--surface-2)}.month-today-btn{padding:6px 16px;border-radius:6px;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-sans);color:#2d3748;transition:all .15s ease;margin-right:4px}.month-today-btn:hover{background:var(--surface-2)}.month-title{font-size:28px;font-weight:700;color:#1a202c;margin:0;min-width:220px;letter-spacing:-.02em}.month-grid-wrapper{overflow-y:auto;flex:1}.month-grid{display:grid;grid-template-columns:repeat(7,1fr)}.month-grid-spacer{grid-column:1 / -1;height:300px}.month-weekday-header{padding:6px 0;text-align:center;font-size:13px;font-weight:600;color:#a0aec0;text-transform:uppercase;letter-spacing:.05em;background:var(--surface);border-bottom:1px solid #D8E0EA;position:sticky;top:0;z-index:1}.month-day-cell{min-height:200px;min-width:0;overflow:hidden;border-right:1px solid #D1D9E3;border-bottom:1px solid #D8E0EA;padding:6px 8px;display:flex;flex-direction:column;background:var(--surface)}.month-day-cell:nth-child(7n+7){border-right:none}.month-day-cell.other-month{background:#f8f9fa}.month-day-cell.other-month .month-day-number{color:#b8b8b8}.month-day-cell.today{background:#e53e3e1f!important}.month-day-number{font-size:15px;font-weight:500;color:#2d3748;padding:2px 6px;margin-bottom:4px;align-self:flex-end}.month-day-number.today-number{background:#e53e3e;color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0;font-weight:700;font-size:14px}.month-day-events{display:flex;flex-direction:column;gap:3px;flex:1}.month-event-item{display:flex;align-items:center;gap:6px;padding:3px 8px;border-radius:4px;border:1px solid;background:var(--surface);font-size:14px;font-family:var(--font-sans);cursor:pointer;transition:all .12s ease;min-height:26px;line-height:1.3;box-shadow:0 1px 2px #0000000a;overflow:hidden;min-width:0}.month-event-item:hover{background:var(--surface-2)}.month-event-item.completed{opacity:.45}.month-event-item.completed .month-event-title{text-decoration:line-through}.month-event-icon{flex-shrink:0;display:flex;align-items:center}.month-event-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;font-size:14px;font-family:var(--font-sans);line-height:1.4}.month-holiday-item{display:flex;align-items:center;padding:3px 8px;border-radius:4px;font-size:13px;font-family:var(--font-sans);font-weight:600;min-height:24px;line-height:1.3;overflow:hidden;min-width:0}.month-holiday-holiday{background:#fee2e2;color:#b91c1c}.month-holiday-no_class{background:#fef3c7;color:#92400e}.month-holiday-event{background:#dbeafe;color:#1e40af}.month-holiday-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.month-calendar-sidebar{width:240px;flex-shrink:0;background:var(--surface);padding:30px 20px 24px;overflow-y:auto}.calendar-sidebar-section{margin-bottom:24px}.calendar-sidebar-title{font-size:14px;font-weight:700;color:#2d3748;text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px;padding:0 4px}.calendar-sidebar-list{display:flex;flex-direction:column;gap:2px}.calendar-sidebar-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:6px;cursor:pointer;transition:background .15s ease}.calendar-sidebar-item:hover{background:var(--surface-2)}.calendar-sidebar-item.hidden-course{opacity:.45}.calendar-color-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0;border:2px solid}.calendar-course-name{font-size:16px;font-weight:400;color:#2d3748;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}@media(max-width:768px){.month-calendar-layout{flex-direction:column}.month-calendar-main{border-right:none;border-bottom:1px solid var(--border)}.month-header{padding:16px}.month-header-title{font-size:22px}.month-day-cell{min-height:60px}}.todo-panel{border-left:1px solid var(--border-soft, #EDF2F7);background:var(--surface, #fff);padding:18px 16px 24px;overflow:auto;flex-shrink:0}.todo-panel-header{display:flex;flex-direction:column;gap:4px;padding-bottom:14px;margin-bottom:10px;border-bottom:1px solid var(--border-soft, #EDF2F7)}.todo-panel-title-row{display:flex;align-items:center;gap:10px}.todo-panel-title{font-size:var(--fs-15, 15px);font-weight:600;color:var(--ink-900, #1A202C);letter-spacing:var(--tracking-tighter, -.025em);font-style:normal}.todo-panel-count{font-size:var(--fs-12, 12px);color:var(--ink-400, #A0AEC0);margin-left:auto;letter-spacing:-.005em}.todo-panel-icon-btn{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-400, #A0AEC0);border-radius:4px;cursor:pointer;padding:0;transition:background .15s ease,color .15s ease}.todo-panel-icon-btn:hover:not(:disabled){background:var(--surface-2, #F7FAFC);color:var(--ink-700, #4A5568)}.todo-panel-icon-btn:disabled{cursor:not-allowed;opacity:.6}.todo-panel-subtitle{font-size:var(--fs-12, 12px);color:var(--ink-500, #718096);letter-spacing:-.005em}.todo-section{margin-bottom:8px}.todo-section-header{display:flex;align-items:center;gap:6px;padding:6px 0;border-bottom:1px solid #EDF2F7;margin-bottom:4px}.section-collapse-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:0;flex-shrink:0}.section-collapse-btn:hover{color:#4a5568}.todo-section-title{font-size:14px;font-weight:700;color:#2d3748;cursor:pointer;-webkit-user-select:none;user-select:none;flex:1}.section-count{font-size:12px;color:#a0aec0;background:#edf2f7;border-radius:10px;padding:1px 7px;min-width:18px;text-align:center}.section-header-actions{display:flex;align-items:center;gap:1px}.section-action-btn{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;border-radius:4px;transition:color .12s ease}.todo-section-header:hover .section-action-btn{display:flex}.section-action-btn:hover{color:#3182ce}.section-action-btn.delete:hover{color:#e53e3e}.section-edit-input{flex:1;padding:1px 4px;border:none;border-bottom:2px solid #3182CE;border-radius:0;background:transparent;font-size:14px;font-weight:700;outline:none;color:#2d3748;background:#fff}.section-plan-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:3px;border-radius:4px;flex-shrink:0;transition:all .15s ease}.section-plan-btn:hover:not(:disabled){color:#805ad5;background:#f0e6ff}.section-plan-btn:disabled{opacity:.5;cursor:not-allowed}.todo-section-header[draggable]{cursor:grab}.todo-section-header[draggable]:active{cursor:grabbing}.todo-section.section-dragging{opacity:.4}.todo-section.section-drag-over{border-top:2px solid #3182CE}.hidden-sections-restore{display:flex;gap:6px;padding:8px 0;flex-wrap:wrap}.restore-section-btn{background:#edf2f7;border:1px dashed #CBD5E0;border-radius:6px;padding:4px 10px;font-size:13px;color:#718096;cursor:pointer;transition:all .15s}.restore-section-btn:hover{background:#e2e8f0;color:#4a5568;border-color:#a0aec0}.new-section-area{padding:4px 0 8px}.new-section-btn{display:flex;align-items:center;gap:6px;background:none;border:1px dashed #CBD5E0;border-radius:6px;padding:6px 12px;font-size:14px;color:#718096;cursor:pointer;transition:all .15s;width:100%;justify-content:center}.new-section-btn:hover{background:#edf2f7;color:#4a5568;border-color:#a0aec0}.todo-section-content{padding-left:2px}.spin{animation:spin 1s linear infinite}.todo-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;cursor:pointer;font-size:15px;position:relative}.todo-drag-zone{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}.todo-item.assignment-item{align-items:flex-start}.todo-indicator{width:3px;min-height:18px;align-self:stretch;border-radius:1.5px;flex-shrink:0;margin-top:2px}.todo-item input[type=checkbox]{accent-color:#3182CE;width:16px;height:16px;flex-shrink:0;margin-top:1px}.todo-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.todo-text{cursor:grab;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;line-height:1.4}.todo-text.done{text-decoration:line-through;color:#cbd5e0}.todo-deadline{font-size:12px;color:#a0aec0;line-height:1.2}.todo-deadline.deadline-red{color:#e53e3e;font-weight:600}.todo-deadline.deadline-orange{color:#f97316;font-weight:600}.todo-deadline.deadline-yellow{color:#e8a630;font-weight:600}.todo-deadline.done{color:#a0aec0;font-weight:400}.todo-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;margin-top:0;visibility:hidden;opacity:0;pointer-events:none}.todo-item.hovered .todo-actions,.todo-item.editing .todo-actions{visibility:visible;opacity:1;pointer-events:auto}.todo-action-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;border-radius:4px;transition:color .12s ease}.todo-action-btn:hover{color:#3182ce}.todo-action-btn.delete:hover{color:#e53e3e}.todo-edit-input{flex:1;padding:2px 4px;border:1px solid #3182CE;border-radius:4px;font-size:14px;outline:none;color:#2d3748;background:#fff}.todo-add-row{display:flex;align-items:center;gap:8px;margin-top:4px;padding:6px 0;position:relative}.todo-add-checkbox{width:16px;height:16px;flex-shrink:0;cursor:not-allowed;accent-color:#3182CE;pointer-events:none}.todo-add-input{flex:1;padding:0;border:none;font-size:14px;outline:none;color:#a0aec0;background:transparent}.todo-empty{padding:8px 0;font-size:13px;color:#cbd5e0;font-style:italic}.todo-assignment-group{margin-bottom:2px}.todo-group-label{font-size:12px;font-weight:600;color:#a0aec0;text-transform:uppercase;letter-spacing:.3px;padding:6px 0 2px 5px}@media(max-width:768px){.todo-panel{padding:16px 12px;width:100%!important;border-left:none;border-top:1px solid #E2E8F0}}.settings-container{flex:1;padding:48px 64px;overflow-y:auto;background:var(--canvas);font-family:var(--font-sans)}.settings-header{margin-bottom:40px}.settings-header h1{font-size:32px;font-weight:700;color:var(--ink-900);margin:0 0 8px;font-family:var(--font-sans);letter-spacing:-.03em}.settings-header p{font-size:15px;color:var(--ink-500);margin:0;font-weight:400}.settings-content{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:32px}.settings-section{background:var(--surface);border-radius:12px;padding:24px;border:1px solid var(--border);box-shadow:0 2px 8px -2px #0000000d,0 4px 16px -4px #00000014;transition:box-shadow .2s}.section-header{display:flex;gap:12px;margin-bottom:24px;align-items:center}.section-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.section-icon.blue-icon{background:#0a74ae1a;color:var(--accent)}.section-icon.red-icon{background:#e33c261a;color:var(--accent)}.section-header h2{font-size:18px;font-weight:500;color:var(--ink-900);margin:0 0 4px;font-family:var(--font-sans);letter-spacing:-.01em}.section-subtitle{font-size:14px;color:var(--ink-500);margin:0;font-weight:400}.section-title-row{display:flex;justify-content:space-between;align-items:center;flex:1}.study-cap-input-wrapper{display:flex;align-items:center;gap:4px}.study-cap-value{font-size:20px;font-weight:500;color:var(--ink-900);padding:6px 14px;background:var(--surface-2);border-radius:6px;border:1px solid var(--border);font-family:var(--font-sans);width:60px;text-align:center;outline:none;transition:all .2s ease}.study-cap-value:hover{border-color:var(--border-strong)}.study-cap-value:focus{border-color:var(--accent);background:var(--surface)}.study-cap-value::-webkit-inner-spin-button,.study-cap-value::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.study-cap-value[type=number]{-moz-appearance:textfield}.study-cap-unit{font-size:20px;font-weight:500;color:var(--ink-900);font-family:var(--font-sans)}.planning-options{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.planning-option{padding:16px;border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;gap:16px;background:var(--surface);align-items:flex-start}.planning-option:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.planning-option.selected{border-color:var(--accent);background:#0a74ae0d}.planning-option.selected.finish-early-option{border-color:var(--accent);background:#e33c260d}.option-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.option-icon.balanced{background:var(--accent);color:var(--surface)}.planning-option:not(.selected) .option-icon.balanced{background:var(--surface-2);color:var(--ink-500)}.option-icon.finish-early{background:var(--accent);color:var(--surface)}.planning-option:not(.selected) .option-icon.finish-early{background:var(--surface-2);color:var(--ink-500)}.option-content h3{font-size:17px;font-weight:500;color:var(--ink-900);margin:0 0 8px;font-family:var(--font-sans)}.option-content p{font-size:14px;color:var(--ink-500);margin:0;line-height:1.5;font-weight:400}.slider-container{margin-top:20px}.study-cap-slider{width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,var(--accent) 0%,var(--accent) var(--slider-progress, 0%),var(--surface-2) var(--slider-progress, 0%),var(--surface-2) 100%);outline:none;-webkit-appearance:none;appearance:none;cursor:pointer;transition:background .15s ease}.study-cap-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 2px 6px #0d6efd4d;transition:all .2s ease}.study-cap-slider::-webkit-slider-thumb:hover{background:#09679a;transform:scale(1.15);box-shadow:0 3px 10px #0d6efd66}.study-cap-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;box-shadow:0 2px 6px #0d6efd4d;transition:all .2s ease}.study-cap-slider::-moz-range-thumb:hover{background:#09679a;transform:scale(1.15);box-shadow:0 3px 10px #0d6efd66}.study-cap-slider::-moz-range-track{background:transparent}.slider-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--ink-400);font-weight:400;position:relative}.slider-labels span{position:absolute;transform:translate(-50%)}.slider-labels span:nth-child(1){left:0%}.slider-labels span:nth-child(2){left:27.27%}.slider-labels span:nth-child(3){left:63.64%}.slider-labels span:nth-child(4){left:100%}.busy-blocks-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.busy-block-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f0f2f480;border-radius:10px;transition:all .2s ease;border:1px solid transparent}.busy-block-item:hover{background:var(--surface-2);border-color:var(--border);box-shadow:0 2px 6px #0000000d}.busy-block-info{flex:1}.busy-block-title{font-size:14px;font-weight:500;color:var(--ink-900);margin-bottom:4px;font-family:var(--font-sans)}.busy-block-details{font-size:13px;color:var(--ink-500);font-weight:400}.busy-block-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s}.busy-block-item:hover .busy-block-actions{opacity:1}.edit-block-btn,.delete-block-btn{padding:6px;background:transparent;border:none;color:var(--ink-400);cursor:pointer;border-radius:6px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.edit-block-btn:hover{background:var(--border-soft);color:#595959}.delete-block-btn:hover{background:#d331311a;color:var(--danger)}.add-block-btn{padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px;margin-left:auto;font-family:var(--font-sans)}.add-block-btn:hover{border-color:var(--accent);color:var(--accent);background:#0a74ae08;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.section-header-content{display:flex;justify-content:space-between;align-items:flex-start;flex:1}.import-btn{padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-sans)}.import-btn:hover{border-color:var(--accent);color:var(--accent);background:#0a74ae08;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.canvas-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:500;color:var(--ink-900);font-family:var(--font-sans)}.form-input{padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--font-sans);outline:none;transition:all .2s ease;background:var(--surface);color:var(--ink-900)}.form-input:hover{border-color:var(--border-strong)}.form-input:focus{border-color:var(--accent);background:var(--surface)}.form-input::placeholder{color:var(--ink-400)}.token-input-wrapper{position:relative;display:flex;align-items:center}.token-input-wrapper .form-input{flex:1;padding-right:44px}.toggle-token-btn{position:absolute;right:8px;padding:6px;background:transparent;border:none;color:var(--ink-400);cursor:pointer;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toggle-token-btn:hover{background:var(--surface-2);color:var(--ink-900)}.form-hint{font-size:13px;color:var(--ink-400);margin:0;font-weight:400}.save-connection-btn{padding:10px 24px;background:var(--accent);border:none;border-radius:8px;font-size:14px;font-weight:500;color:var(--surface);cursor:pointer;transition:all .2s ease;font-family:var(--font-sans);align-self:flex-start}.save-connection-btn:hover:not(:disabled){background:#09679a;transform:translateY(-1px);box-shadow:0 2px 8px #0d6efd33}.save-connection-btn:disabled{opacity:.6;cursor:not-allowed}.connection-status{padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;font-family:var(--font-sans)}.connection-status.testing{background:var(--surface-2);color:var(--ink-500)}.connection-status.success{background:#1eae531a;color:#1a9948}.connection-status.error{background:#d331311a;color:#bd2828}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.import-modal{background:var(--surface);border-radius:12px;padding:24px;width:400px;box-shadow:0 20px 60px #00000026;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.import-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;color:var(--ink-900)}.import-modal-header h3{font-size:18px;font-weight:600;margin:0;font-family:var(--font-sans)}.import-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:2px dashed var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease;background:#f9fafb;margin-bottom:16px}.import-upload-area:hover{border-color:var(--accent);background:#0a74ae08}.import-file-input{display:none}.import-upload-area svg{color:var(--accent);margin-bottom:12px}.import-text{font-size:15px;font-weight:500;color:var(--ink-900);margin:0 0 4px;font-family:var(--font-sans)}.import-hint{font-size:13px;color:var(--ink-400);margin:0;font-weight:400}.import-cancel-btn{width:100%;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:500;color:var(--ink-900);cursor:pointer;transition:all .2s ease;font-family:var(--font-sans)}.import-cancel-btn:hover{background:var(--surface-2)}.add-block-form{display:flex;flex-direction:column;gap:20px}.time-row{display:flex;align-items:flex-end;gap:12px}.time-row .form-group{flex:1}.time-input{width:100%}.time-separator{font-size:18px;font-weight:500;color:var(--ink-500);padding-bottom:12px}.days-selector{display:flex;gap:8px;flex-wrap:wrap}.day-chip{padding:8px 14px;border:1px solid var(--border);border-radius:20px;background:var(--surface);font-size:13px;font-weight:500;color:var(--ink-500);cursor:pointer;transition:all .2s ease;font-family:var(--font-sans)}.day-chip:hover{border-color:var(--accent);color:var(--accent)}.day-chip.selected{background:var(--accent);border-color:var(--accent);color:var(--surface)}.modal-actions{display:flex;gap:12px;margin-top:4px}.modal-actions .import-cancel-btn{width:auto;flex:1}.modal-actions .save-connection-btn{flex:1;align-self:auto;text-align:center}.semester-date-row{display:flex;gap:16px}.semester-date-row .form-group{flex:1}.school-events-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.no-events-text{font-size:14px;color:#a0aec0;padding:12px 0}.school-event-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;transition:background .1s}.school-event-item:hover{background:var(--surface-2)}.school-event-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.school-event-type-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;white-space:nowrap;flex-shrink:0}.school-event-type-badge.holiday{color:#c53030;background:var(--danger-soft)}.school-event-type-badge.no_class{color:#b7791f;background:#fdecce}.school-event-type-badge.event{color:#2b6cb0;background:#deebf7}.school-event-title{font-size:14px;color:#2d3748;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.school-event-date{font-size:13px;color:#718096;white-space:nowrap;margin-left:auto;padding-left:12px}.school-event-actions{display:flex;gap:4px;margin-left:8px;opacity:0;transition:opacity .12s}.school-event-item:hover .school-event-actions{opacity:1}.school-event-edit-btn,.school-event-delete-btn{padding:4px;background:transparent;border:none;color:#a0aec0;cursor:pointer;border-radius:4px;display:flex;align-items:center}.school-event-edit-btn:hover{color:#4a5568;background:var(--border-soft)}.school-event-delete-btn:hover{color:var(--danger);background:#d331311a}.schedule-import-modal{max-width:640px;width:90vw}.schedule-import-desc{font-size:14px;color:#718096;margin:0 0 16px}.schedule-import-files{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.schedule-file-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--border-soft);border-radius:6px;font-size:12px;color:#4a5568}.schedule-file-chip button{background:transparent;border:none;color:#a0aec0;cursor:pointer;padding:2px;display:flex;align-items:center}.schedule-file-chip button:hover{color:#e53e3e}.parsed-events-list{max-height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.parsed-event-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;background:var(--surface-2)}.parsed-event-title{font-size:14px;color:#2d3748;flex:1}.parsed-event-date{font-size:13px;color:#718096;white-space:nowrap}.parsed-event-delete{background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;border-radius:4px;display:flex;align-items:center;flex-shrink:0;transition:all .15s}.parsed-event-delete:hover{color:#e53e3e;background:#fed7d7}.tz-dropdown{position:absolute;top:68px;left:0;right:0;background:var(--surface);border:1px solid var(--accent);border-radius:8px;box-shadow:0 8px 24px #0000001f;max-height:220px;overflow-y:auto;z-index:200;list-style:none;margin:0;padding:4px 0}.tz-option{padding:8px 14px;font-size:13px;font-family:var(--font-sans);color:var(--ink-900);cursor:pointer;transition:background .1s}.tz-option:hover{background:#0a74ae14}.tz-option.selected{background:#0a74ae1f;color:#086191;font-weight:600}.language-options{display:flex;gap:8px}.language-option{padding:8px 20px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#4a5568;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:var(--font-sans)}.language-option:hover{border-color:#3182ce;color:#2d3748}.language-option.active{background:#ebf8ff;border-color:#3182ce;color:#3182ce;font-weight:600}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;cursor:pointer}.toggle-label{font-size:14px;color:#4a5568}.toggle-checkbox{width:18px;height:18px;accent-color:#3182CE;cursor:pointer}@media(max-width:768px){.settings-container{padding:24px 16px}.settings-header h1{font-size:24px}.settings-content{gap:20px}.settings-section{padding:16px}.planning-options{grid-template-columns:1fr}.semester-date-row{flex-direction:column;gap:12px}.time-row{flex-direction:column;align-items:stretch;gap:8px}.time-separator{display:none}.days-selector{gap:6px}.day-chip{padding:6px 10px;font-size:12px}.section-header{flex-wrap:wrap}.section-header-content{flex-direction:column;gap:8px}.import-btn,.add-block-btn{align-self:flex-start}}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.theme-card{position:relative;display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:var(--r-12);border:1px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;font:inherit;color:inherit;transition:border-color var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out)}.theme-card:hover{border-color:var(--border-strong)}.theme-card.active{border-color:var(--ink-900);box-shadow:0 0 0 1px var(--ink-900) inset}.theme-swatches{display:flex;gap:4px;height:24px}.theme-swatch{flex:1;border-radius:var(--r-6)}.theme-card-meta{display:flex;flex-direction:column;gap:2px}.theme-card-name{font-size:13px;font-weight:600;color:var(--ink-900)}.theme-card-hint{font-size:11.5px;color:var(--ink-500);line-height:1.45}.theme-card-check{position:absolute;top:10px;right:10px;color:var(--ink-900)}.settings-container{font-family:var(--font-sans);background:var(--canvas);padding:24px 32px 40px}.settings-header{margin-bottom:24px}.settings-header h1{font-size:var(--fs-20);font-weight:600;letter-spacing:var(--tracking-tighter);color:var(--ink-900)}.settings-header p{font-size:var(--fs-13);color:var(--ink-500);font-weight:400}.settings-layout{display:grid;grid-template-columns:180px 1fr;gap:32px;align-items:flex-start;max-width:1100px}.settings-nav{display:flex;flex-direction:column;gap:1px;position:sticky;top:24px}.settings-nav-item{display:flex;align-items:center;gap:8px;height:30px;padding:0 10px;border-radius:var(--r-6);background:transparent;border:0;font-family:var(--font-sans);font-size:var(--fs-13);font-weight:500;color:var(--ink-700);text-align:left;cursor:pointer;transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.settings-nav-item:hover{background:var(--surface-2);color:var(--ink-900)}.settings-nav-item.active{background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow-sm)}.settings-nav-logout{margin-top:16px;display:flex;align-items:center;gap:8px;height:30px;padding:0 10px;border-radius:var(--r-6);background:transparent;border:0;font-family:var(--font-sans);font-size:var(--fs-13);font-weight:500;color:var(--ink-500);text-align:left;cursor:pointer;transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.settings-nav-logout:hover{background:var(--surface-2);color:var(--accent-ink)}.settings-content{display:flex;flex-direction:column;gap:24px;max-width:720px;margin:0}@media(max-width:800px){.settings-layout{grid-template-columns:1fr}.settings-nav{position:static;flex-direction:row;overflow-x:auto}}.settings-content .settings-section{background:transparent;border:0;border-radius:0;box-shadow:none;padding:0;margin:0}.settings-content>.settings-section+.settings-section{border-top:1px solid var(--border-soft);padding-top:24px;margin-top:24px}.settings-content .section-icon{display:none}.settings-content .section-header{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:4px}.settings-content .section-header>div{display:contents}.settings-content .section-header h2{font-size:var(--fs-18);font-weight:600;letter-spacing:var(--tracking-tighter);color:var(--ink-900);margin:0}.settings-content .section-subtitle{flex-basis:100%;margin:0;font-size:var(--fs-13);color:var(--ink-500);font-weight:400}.settings-content .canvas-form,.settings-content .form-section,.settings-content .schedule-form{display:flex;flex-direction:column;margin-top:14px}.settings-content .form-group{display:grid;grid-template-columns:180px 1fr;gap:24px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--border-soft)}.settings-content .form-group:first-child{border-top:0}.settings-content .form-label{font-size:var(--fs-13);font-weight:500;color:var(--ink-900);margin:0}.settings-content .form-hint,.settings-content .form-help,.settings-content .form-description,.settings-content .field-hint{display:block;font-size:11.5px;color:var(--ink-500);margin-top:3px;line-height:1.5}.settings-content .form-input,.settings-content .form-input[type=text],.settings-content .form-input[type=url],.settings-content .form-input[type=number],.settings-content .form-input[type=email],.settings-content .form-input[type=time],.settings-content .form-input[type=date],.settings-content select.form-input,.settings-content textarea.form-input{height:32px;padding:0 10px;border-radius:var(--r-8);border:1px solid var(--border);background:var(--surface);color:var(--ink-900);font-family:var(--font-sans);font-size:var(--fs-13);width:100%;outline:none;transition:border-color var(--dur) var(--ease-out)}.settings-content textarea.form-input{height:auto;min-height:60px;padding:8px 10px;font-family:var(--font-sans);resize:vertical}.settings-content .form-input:focus{border-color:var(--ink-700)}.settings-content button:not(.theme-card):not(.day-chip):not(.tz-option){font-family:var(--font-sans)}.theme-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.settings-content .busy-block-item,.settings-content .school-event-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-soft);border-radius:var(--r-8);background:var(--surface);margin-bottom:6px}.settings-content .status-chip{display:inline-flex;align-items:center;gap:4px;height:20px;padding:0 8px;border-radius:var(--r-pill);font-size:var(--fs-12);font-weight:500}.course-page{flex:1;overflow-y:auto;background:#e9e9ec;font-family:var(--font-sans)}.course-page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;font-size:14px;color:#a0aec0}.course-page-loading .loading-spinner{animation:course-spin 1s linear infinite}@keyframes course-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.course-page-header{padding:32px 40px 24px;background:#fff;border-bottom:1px solid var(--border-soft);display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.course-header-left{flex:1;min-width:0}.course-page-title{font-size:28px;font-weight:700;color:#1a202c;margin:0}.course-page-subtitle{font-size:15px;color:#718096;margin:6px 0 0}.course-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.course-sync-time{font-size:13px;color:#a0aec0;white-space:nowrap}.course-sync-btn,.course-import-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s ease;white-space:nowrap}.course-sync-btn{background:#fff;border:1px solid var(--border);color:#2d3748}.course-sync-btn:hover:not(:disabled){background:var(--surface-2)}.course-sync-btn:disabled{opacity:.6;cursor:not-allowed}.course-import-btn{background:#3182ce;border:1px solid #3182CE;color:#fff}.course-import-btn:hover{background:#2b6cb0}.course-info-empty{font-size:14px;color:#a0aec0;font-style:italic}.course-info-edit-btn{padding:4px 6px;background:transparent;border:none;color:var(--ink-400);cursor:pointer;border-radius:4px;display:flex;align-items:center;transition:color .12s}.course-info-edit-btn:hover{color:var(--info)}.course-info-edit-actions{display:flex;gap:6px}.course-info-save-btn,.course-info-cancel-btn{display:flex;align-items:center;gap:3px;padding:3px 10px;border-radius:6px;border:none;font-size:12px;font-weight:500;cursor:pointer;transition:background .12s}.course-info-save-btn{background:var(--info);color:#fff}.course-info-save-btn:hover{background:var(--info)}.course-info-cancel-btn{background:#ededed;color:#4a5568}.course-info-cancel-btn:hover{background:#e0e0e0}.course-info-form{display:flex;flex-direction:column;gap:8px}.course-info-form-row{display:flex;align-items:center;gap:10px}.course-info-input{flex:1;padding:6px 10px;border:1px solid var(--border-strong);border-radius:6px;font-size:13px;color:#2d3748;outline:none;font-family:inherit}.course-info-input:focus{border-color:var(--info);box-shadow:0 0 0 2px #478cd126}.course-info-input::placeholder{color:#a0aec0}.course-ta-form-item{padding:10px 0;border-top:1px solid var(--border-soft);display:flex;flex-direction:column;gap:6px;position:relative}.course-ta-remove-btn{position:absolute;top:10px;right:0;padding:4px;background:transparent;border:none;color:var(--ink-400);cursor:pointer;border-radius:4px;transition:color .12s}.course-ta-remove-btn:hover{color:var(--danger)}.course-ta-add-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed var(--border-strong);border-radius:6px;background:transparent;font-size:13px;color:#718096;cursor:pointer;margin-top:6px;transition:border-color .12s,color .12s}.course-ta-add-btn:hover{border-color:var(--info);color:var(--info)}.course-page-content{padding:28px 40px 60px;display:grid;grid-template-columns:1fr 1fr;gap:16px;overflow:hidden}@media(max-width:768px){.course-page-header{padding:20px 16px 16px;flex-direction:column;gap:12px}.course-page-title{font-size:22px}.course-header-right{flex-wrap:wrap}.course-page-content{grid-template-columns:1fr;padding:16px}.course-section-draggable{grid-column:span 1!important}.section-span-btn{display:none}.course-card{padding:16px}}.course-section-draggable{border-radius:14px;transition:opacity .15s,box-shadow .15s;min-width:0}.section-toolbar{display:flex;align-items:center;gap:2px;margin-bottom:4px;height:20px;opacity:0;transition:opacity .15s}.course-section-draggable:hover .section-toolbar{opacity:1}.section-drag-handle{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:5px;color:#a0aec0;cursor:grab;transition:color .12s,background .12s}.section-drag-handle:active{cursor:grabbing}.section-drag-handle:hover{color:#4a5568;background:var(--border-soft)}.section-span-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:5px;border:none;background:none;color:#a0aec0;cursor:pointer;transition:color .12s,background .12s}.section-span-btn:hover{color:#4a5568;background:var(--border-soft)}.course-section-draggable.section-dragging{opacity:.4}.course-section-draggable.section-drag-over{box-shadow:0 -3px #3182ce;border-radius:14px}.course-card{background:#fff;border-radius:12px;border:1px solid var(--border-soft);padding:24px 28px;min-width:0;overflow:hidden}.course-card-label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}.course-grade-display{display:flex;align-items:center;gap:12px;margin-bottom:10px}.course-grade-number{font-size:42px;font-weight:700;color:#22c55e}.course-letter-badge{font-size:14px;font-weight:600;padding:4px 10px;border-radius:20px;border:1.5px solid}.course-grade-note{font-size:13px;color:#22c55e}.course-info-list{display:flex;flex-direction:column;gap:12px}.course-info-row{display:flex;align-items:center;gap:12px;font-size:14px;color:#2d3748}.course-info-icon{color:#718096;flex-shrink:0}.course-info-link{color:#3182ce;text-decoration:none}.course-info-link:hover{text-decoration:underline}.course-ta-section{margin-top:8px;padding-top:10px;border-top:1px solid #EDF2F7}.course-ta-label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.course-ta-item{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.course-ta-item:last-child{margin-bottom:0}.course-section-header{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:#1a202c;margin-bottom:20px}.course-section-icon{color:#3182ce}.grade-overall-row{display:flex;gap:24px;margin-bottom:24px;padding:16px 20px;background:var(--surface-2);border-radius:10px}.grade-overall-item{display:flex;flex-direction:column;align-items:center;min-width:100px}.grade-overall-label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.04em}.grade-overall-value{font-size:28px;font-weight:700;line-height:1.2;color:#1a202c}.grade-overall-sub{font-size:11px;color:#a0aec0;margin-top:2px}.grade-breakdown-list{display:flex;flex-direction:column;gap:16px}.grade-breakdown-item{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:6px 16px}.grade-breakdown-info{grid-column:1;grid-row:1;display:flex;align-items:center;gap:8px;font-size:14px;color:#2d3748}.grade-breakdown-icon{color:#718096;display:flex}.grade-breakdown-name{font-weight:600}.grade-breakdown-weight{color:#a0aec0;font-size:12px;background:var(--surface-2);padding:2px 7px;border-radius:4px}.grade-breakdown-right{grid-column:2;grid-row:1;display:flex;align-items:center;gap:10px;justify-self:end}.grade-breakdown-score{font-size:14px;font-weight:600;color:#2d3748}.grade-breakdown-percent{font-size:14px;font-weight:700;color:#1a202c;min-width:48px;text-align:right}.grade-breakdown-empty{color:#a0aec0;font-weight:400}.grade-breakdown-bar{grid-column:1 / -1;grid-row:2;height:6px;background:#dfdfe2;border-radius:3px;overflow:hidden}.grade-breakdown-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.grade-breakdown-whatif{display:flex;align-items:center;gap:4px}.grade-whatif-input{width:52px;padding:4px 8px;border:1.5px solid #CBD5E0;border-radius:6px;font-size:13px;font-weight:600;font-family:var(--font-sans);color:#2d3748;text-align:center;outline:none;transition:border-color .15s ease}.grade-whatif-input:focus{border-color:#3182ce}.grade-whatif-input::placeholder{color:#cbd5e0;font-weight:400}.grade-whatif-label{font-size:13px;color:#a0aec0;font-weight:500}.grade-whatif-reset{margin-top:16px;padding:6px 14px;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:13px;font-weight:500;color:#718096;cursor:pointer;transition:all .12s ease}.grade-whatif-reset:hover{background:var(--surface-2);color:#2d3748}.grade-whatif-input::-webkit-outer-spin-button,.grade-whatif-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grade-whatif-input[type=number]{-moz-appearance:textfield}.upcoming-list{display:flex;flex-direction:column;gap:4px}.upcoming-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:8px;border:1px solid #EDF2F7;background:#fff}.upcoming-item:hover{background:#f9fafb}.upcoming-left{display:flex;align-items:flex-start;gap:12px}.upcoming-checkbox{width:18px;height:18px;accent-color:#3182CE;margin-top:2px;flex-shrink:0}.upcoming-title{font-size:15px;font-weight:500;color:#1a202c}.upcoming-title.checked{text-decoration:line-through;color:#cbd5e0}.upcoming-title-link{cursor:pointer}.upcoming-title-link:hover{color:var(--info);text-decoration:underline}.upcoming-meta{display:flex;align-items:center;gap:10px;margin-top:4px}.upcoming-due{font-size:13px;color:#718096}.upcoming-due-badge{font-size:12px;font-weight:600;color:#fff;background:#e53e3e;padding:3px 10px;border-radius:12px}.upcoming-time{font-size:13px;color:#a0aec0}.upcoming-open-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:13px;font-weight:500;color:#2d3748;cursor:pointer;transition:background .12s ease;white-space:nowrap}.upcoming-open-btn:hover{background:var(--surface-2)}.upcoming-right{display:flex;align-items:center;gap:6px}.upcoming-delete-btn{padding:6px;background:transparent;border:none;color:var(--ink-400);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.upcoming-delete-btn:hover{background:#d331311a;color:var(--danger)}.upcoming-edit-btn{padding:2px 4px;background:transparent;border:none;color:#b3b3b3;cursor:pointer;border-radius:4px;display:inline-flex;align-items:center;transition:color .12s}.upcoming-edit-btn:hover{color:var(--info)}.upcoming-date-input{font-size:13px;padding:2px 6px;border:1px solid var(--border-strong);border-radius:6px;outline:none;color:#2d3748}.upcoming-date-input:focus{border-color:var(--info);box-shadow:0 0 0 2px #478cd126}.upcoming-remaining{font-size:12px;font-weight:500;padding:1px 8px;border-radius:10px;white-space:nowrap}.upcoming-remaining-normal{color:#4a5568;background:var(--border-soft)}.upcoming-remaining-yellow{color:#975a16;background:#fdecce}.upcoming-remaining-red{color:#c53030;background:var(--danger-soft)}.upcoming-due-yellow{color:#b7791f!important}.upcoming-due-red{color:#c53030!important;font-weight:600}.past-graded-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.past-graded-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:#1a202c;margin:0}.past-graded-icon{color:#3182ce}.past-graded-group{margin-bottom:6px}.past-graded-group:last-child{margin-bottom:0}.past-graded-group-label{font-size:13px;font-weight:600;color:#a0aec0;text-transform:uppercase;letter-spacing:.3px;padding:12px 0 6px;border-bottom:1px solid #CBD5E0}.past-graded-list{display:flex;flex-direction:column}.past-graded-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #EDF2F7}.past-graded-item:last-child{border-bottom:none}.past-graded-name{font-size:15px;font-weight:500;color:#2d3748}.past-graded-meta{font-size:13px;color:#718096;margin-top:3px}.past-graded-right{text-align:right}.past-graded-score{font-size:15px;font-weight:500;color:#2d3748;display:block}.past-graded-score-value{cursor:text;border-bottom:1px solid transparent;transition:border-color .15s}.past-graded-score-value:hover{border-bottom-color:#cbd5e0}.past-graded-score-input{width:50px;font-size:15px;font-weight:500;color:#2d3748;border:none;border-bottom:1.5px solid #3182CE;outline:none;background:transparent;text-align:right;padding:0;-moz-appearance:textfield}.past-graded-score-input::-webkit-outer-spin-button,.past-graded-score-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.past-graded-percent{font-size:13px;color:#718096}.past-graded-excused{color:#a0aec0;font-style:italic;font-weight:400}.past-graded-revert-btn{background:none;border:1px solid #CBD5E0;border-radius:6px;color:#718096;cursor:pointer;padding:4px 10px;display:inline-flex;align-items:center;gap:5px;font-size:12px;transition:all .15s}.past-graded-revert-btn:hover{color:#3182ce;border-color:#3182ce;background:#ebf8ff}.past-graded-item.past-graded-dropped{opacity:.45}.past-graded-dropped-tag{font-size:10px;color:#a0aec0;background:#edf2f7;border-radius:3px;padding:1px 5px;margin-left:6px}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.course-import-modal{background:#fff;border-radius:16px;padding:32px;width:420px;max-width:90vw;box-shadow:0 20px 60px #00000026}.course-import-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;color:#1a202c}.course-import-modal-header h3{font-size:18px;font-weight:700;margin:0}.course-import-desc{font-size:14px;color:#718096;line-height:1.5;margin:0 0 20px}.import-mode-tabs{display:flex;gap:0;margin-bottom:20px;border:1px solid #E2E8F0;border-radius:8px;overflow:hidden}.import-mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:500;color:#718096;background:#fff;border:none;cursor:pointer;transition:all .12s ease}.import-mode-tab:first-child{border-right:1px solid #E2E8F0}.import-mode-tab.active{background:#3182ce;color:#fff}.import-mode-tab:hover:not(.active){background:var(--surface-2)}.import-file-section{margin-bottom:16px}.import-file-picker{display:flex;align-items:center;gap:10px;padding:14px 16px;border:1.5px solid #E2E8F0;border-radius:10px;cursor:pointer;color:#718096;transition:all .12s ease}.import-file-picker:hover{border-color:#3182ce;color:#3182ce}.import-file-picker span{font-size:14px;font-weight:500}.import-file-hint{margin-left:auto;font-size:12px!important;color:#a0aec0!important;font-weight:400!important}.import-tip{font-size:12px;color:#a0aec0;margin:8px 0 0;line-height:1.4}.import-file-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.course-import-file-input{display:none}.import-file-selected{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1.5px solid #3182CE;border-radius:10px;background:#f5faff}.import-file-icon{color:#3182ce;flex-shrink:0}.import-file-name{flex:1;font-size:14px;font-weight:500;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-file-remove{background:none;border:none;font-size:18px;color:#a0aec0;cursor:pointer;padding:0 4px;line-height:1}.import-file-remove:hover{color:#e53e3e}.import-url-section{margin-bottom:16px}.import-url-input{width:100%;padding:12px 14px;border:1.5px solid #E2E8F0;border-radius:10px;font-size:14px;font-family:var(--font-sans);color:#2d3748;outline:none;transition:border-color .15s ease;box-sizing:border-box}.import-url-input:focus{border-color:#3182ce}.import-url-input::placeholder{color:#cbd5e0}.course-import-status{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:14px;margin-bottom:12px}.import-modal-actions{display:flex;gap:10px}.import-submit-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:none;border-radius:8px;background:#3182ce;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s ease}.import-submit-btn:hover:not(:disabled){background:#2b6cb0}.import-submit-btn:disabled{opacity:.5;cursor:not-allowed}.course-import-status.success{background:#f0fff4;color:#22543d}.course-import-status.error{background:#fff5f5;color:#c53030}.course-import-cancel-btn{flex:1;padding:10px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:background .12s ease}.course-import-cancel-btn:hover{background:var(--surface-2)}.course-notes-card{margin-top:0}.notes-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.notes-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:#1a202c;margin:0;flex:1}.notes-icon{color:#3182ce}.notes-upload-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;border:1px solid #E2E8F0;background:#fff;font-size:13px;font-weight:500;color:#4a5568;cursor:pointer;transition:all .12s ease}.notes-upload-btn:hover{border-color:#3182ce;color:#3182ce}.notes-image-grid{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px;max-width:100%}.notes-image-card{width:280px;min-width:100px;max-width:100%;border:1px solid #E2E8F0;border-radius:10px;background:#fff;overflow:hidden;position:relative;transition:box-shadow .15s ease,border-color .15s ease;display:flex;flex-direction:column}.notes-resize-handle{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:nwse-resize;display:flex;align-items:center;justify-content:center;opacity:1;color:#718096;z-index:1}.notes-image-card:hover{box-shadow:0 2px 10px #00000014}.notes-image-card.dragging{opacity:.4}.notes-image-card.drag-over{border-color:#3182ce;box-shadow:0 0 0 2px #3182ce4d}.notes-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #EDF2F7;background:#f7fafc;flex-shrink:0;cursor:grab}.notes-card-icon{color:#718096;flex-shrink:0}.notes-card-name{flex:1;font-size:13px;font-weight:500;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notes-card-delete{background:none;border:none;color:#cbd5e0;cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:all .12s}.notes-image-card:hover .notes-card-delete{opacity:1}.notes-card-delete:hover{color:#e53e3e}.notes-card-body{overflow:hidden;display:flex;align-items:center;justify-content:center;background:#fafbfc}.notes-card-body img{width:100%;display:block;cursor:zoom-in}.notes-file-list{display:flex;flex-direction:column;gap:4px}.notes-file-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;transition:background .12s ease;width:fit-content}.notes-file-item:hover{background:#f7fafc}.notes-file-icon{color:#718096;display:flex;flex-shrink:0}.notes-file-name{font-size:14px;color:#3182ce;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notes-file-download{color:#718096;display:flex;align-items:center;padding:4px;border-radius:4px;transition:color .12s}.notes-file-download:hover{color:#3182ce}.notes-file-delete{background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:all .12s}.notes-file-item:hover .notes-file-delete{opacity:1}.notes-file-delete:hover{color:#e53e3e}.notes-empty{text-align:center;padding:24px;color:#a0aec0;font-size:14px}.notes-lightbox{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:zoom-out}.course-notes-card.file-drag-over{border-color:#3182ce;background:#f5faff;box-shadow:inset 0 0 0 2px #3182ce}.course-notes-card.file-drag-over .notes-empty{color:#3182ce;font-weight:600}.notes-lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 4px 20px #0000004d}.notes-file-name.clickable{cursor:pointer}.notes-file-name.clickable:hover{text-decoration:underline;color:#2b6cb0}.notes-preview-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.notes-preview-modal{width:85vw;height:85vh;background:#fff;border-radius:12px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000040}.notes-preview-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #E2E8F0;flex-shrink:0}.notes-preview-title{font-size:15px;font-weight:600;color:#1a202c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:16px}.notes-preview-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.notes-preview-download-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;border:1px solid #E2E8F0;background:#fff;font-size:13px;font-weight:500;color:#4a5568;text-decoration:none;transition:all .12s}.notes-preview-download-btn:hover{border-color:#3182ce;color:#3182ce}.notes-preview-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:#718096;cursor:pointer;transition:all .12s}.notes-preview-close-btn:hover{background:#edf2f7;color:#2d3748}.notes-preview-body{flex:1;overflow:hidden}.notes-preview-iframe{width:100%;height:100%;border:none}.courses-list-page{flex:1;overflow-y:auto;background:#f7f7f7;font-family:var(--font-sans)}.courses-list-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center}.courses-list-empty-icon{color:#cbd5e0;margin-bottom:16px}.courses-list-empty-title{font-size:22px;font-weight:700;color:#1a202c;margin:0 0 8px}.courses-list-empty-desc{font-size:15px;color:#718096;margin:0 0 24px;max-width:320px;line-height:1.5}.courses-list-connect-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#3182ce;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .12s ease}.courses-list-connect-btn:hover{background:#2b6cb0}.courses-list-header{padding:32px 40px 24px;background:#fff;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.courses-list-header-left{display:flex;align-items:baseline;gap:12px}.courses-list-title{font-size:28px;font-weight:700;color:#1a202c;margin:0}.courses-list-count{font-size:14px;color:#a0aec0;font-weight:500}.courses-list-header-right{display:flex;align-items:center;gap:12px}.courses-list-sync-time{font-size:13px;color:#a0aec0;white-space:nowrap}.courses-list-sync-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s ease;white-space:nowrap;background:#fff;border:1px solid var(--border);color:#2d3748}.courses-list-sync-btn:hover:not(:disabled){background:var(--surface-2)}.courses-list-sync-btn:disabled{opacity:.6;cursor:not-allowed}.courses-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:28px 40px 60px}.courses-list-card{background:#fff;border-radius:12px;border:1px solid var(--border-soft);overflow:hidden;cursor:pointer;transition:box-shadow .15s ease,transform .15s ease}.courses-list-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.courses-list-card-accent{height:4px;width:100%}.courses-list-card-body{padding:18px 20px 16px}.courses-list-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.courses-list-card-code{font-size:16px;font-weight:700;color:#1a202c;margin:0;line-height:1.3}.courses-list-card-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .15s ease}.courses-list-card:hover .courses-list-card-actions{opacity:1}.courses-list-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:#718096;cursor:pointer;transition:all .12s ease}.courses-list-action-btn:hover{background:var(--surface-2);color:#2d3748}.courses-list-action-delete:hover{background:#fff5f5;color:#e53e3e}.courses-list-card-name{font-size:14px;color:#4a5568;margin:0 0 12px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.courses-list-card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.courses-list-card-term{font-size:12px;color:#718096;background:var(--surface-2);padding:3px 8px;border-radius:4px}.courses-list-card-grade{font-size:13px;font-weight:600;color:#22c55e}.courses-list-color-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid #EDF2F7}.courses-list-color-dot{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .12s ease}.courses-list-color-dot:hover{transform:scale(1.15)}.courses-list-color-dot.selected{border-color:#1a202c;box-shadow:0 0 0 2px #fff,0 0 0 4px #1a202c}.courses-list-delete-modal{background:#fff;border-radius:14px;padding:28px;width:380px;max-width:90vw;box-shadow:0 20px 60px #00000026}.courses-list-delete-modal h3{font-size:18px;font-weight:700;color:#1a202c;margin:0 0 8px}.courses-list-delete-modal p{font-size:14px;color:#718096;line-height:1.5;margin:0 0 20px}.courses-list-delete-modal-actions{display:flex;gap:10px;justify-content:flex-end}.courses-list-modal-cancel{padding:8px 16px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:background .12s ease}.courses-list-modal-cancel:hover{background:var(--surface-2)}.courses-list-modal-delete{padding:8px 16px;border:none;border-radius:8px;background:#e53e3e;font-size:14px;font-weight:500;color:#fff;cursor:pointer;transition:background .12s ease}.courses-list-modal-delete:hover{background:#c53030}.assignment-page{flex:1;overflow-y:auto;background:#e9e9ec;font-family:var(--font-sans)}.assignment-page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:200px;color:#a0aec0;font-size:14px}.assignment-loading-spinner{animation:assignment-spin 1s linear infinite}@keyframes assignment-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.assignment-page-content{padding:28px 40px 60px;max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.assignment-back-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:none;color:#4a5568;font-size:14px;font-weight:500;cursor:pointer;border-radius:6px;transition:background .12s,color .12s;align-self:flex-start}.assignment-back-btn:hover{background:#dce0e5;color:#1a202c}.assignment-card{background:#fff;border-radius:12px;border:1px solid var(--border-soft);padding:24px 28px}.assignment-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.assignment-title{font-size:22px;font-weight:700;color:#1a202c;margin:0;line-height:1.3}.assignment-canvas-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:8px;background:#364563;font-size:13px;font-weight:500;color:#fff;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .12s}.assignment-canvas-btn:hover{background:#2d3953}.assignment-meta{display:flex;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap}.assignment-due{display:flex;align-items:center;gap:5px;font-size:14px;font-weight:500;color:#4a5568}.assignment-due-red{color:#c53030;font-weight:600}.assignment-due-yellow{color:#b7791f}.assignment-remaining{font-size:12px;font-weight:500;padding:2px 10px;border-radius:10px;white-space:nowrap}.assignment-remaining-normal{color:#4a5568;background:var(--border-soft)}.assignment-remaining-yellow{color:#975a16;background:#fdecce}.assignment-remaining-red{color:#c53030;background:var(--danger-soft)}.assignment-points{font-size:14px;color:#718096}.assignment-section-title{font-size:18px;font-weight:700;color:#1a202c;margin:0 0 8px}.assignment-description{font-size:14px;color:#4a5568;line-height:1.6}.assignment-description p{margin:8px 0}.assignment-description a{color:var(--info)}.assignment-description-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-soft)}.assignment-description-section .assignment-section-title{font-size:15px;margin-bottom:12px}.assignment-description-empty{font-size:14px;color:#4a5568;margin:0}.assignment-steps-subtitle{font-size:13px;color:#a0aec0;margin:0 0 16px}.assignment-progress{margin-bottom:16px}.assignment-progress-header{display:flex;justify-content:space-between;font-size:13px;color:#4a5568;margin-bottom:6px}.assignment-progress-bar{height:8px;background:#dfdfe2;border-radius:4px;overflow:hidden}.assignment-progress-fill{height:100%;background:#3182ce;border-radius:4px;transition:width .3s ease}.assignment-steps-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.assignment-step{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;transition:background .1s}.assignment-step:hover{background:var(--surface-2)}.assignment-step-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#3182CE;flex-shrink:0}.assignment-step-title{flex:1;font-size:14px;color:#2d3748}.assignment-step-title.checked{text-decoration:line-through;color:#a0aec0}.assignment-step-delete{padding:4px;background:transparent;border:none;color:transparent;cursor:pointer;border-radius:4px;display:flex;align-items:center;transition:color .12s,background .12s}.assignment-step:hover .assignment-step-delete{color:#b3b3b3}.assignment-step-delete:hover{color:var(--danger)!important;background:#d331311a}.assignment-add-step{display:flex;gap:8px}.assignment-add-step-input{flex:1;padding:8px 12px;border:1px solid var(--border-strong);border-radius:8px;font-size:14px;color:#2d3748;outline:none;font-family:inherit}.assignment-add-step-input:focus{border-color:var(--info);box-shadow:0 0 0 2px #478cd126}.assignment-add-step-input::placeholder{color:#a0aec0}.assignment-add-step-btn{padding:8px 20px;background:var(--border-soft);border:none;border-radius:8px;font-size:14px;font-weight:500;color:#4a5568;cursor:pointer;transition:background .12s}.assignment-add-step-btn:hover:not(:disabled){background:#dce0e5}.assignment-add-step-btn:disabled{opacity:.5;cursor:default}.assignment-section-title-row{display:flex;align-items:center;justify-content:space-between}.assignment-section-title-row .assignment-section-title{margin-bottom:0}.assignment-ai-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:8px;background:transparent;color:#805ad5;cursor:pointer;transition:background .12s,color .12s}.assignment-ai-btn:hover:not(:disabled){background:#f5f0fa;color:#6b46c1}.assignment-ai-btn:disabled{opacity:.6;cursor:default}.ai-preview-section{background:#f7f4fa;border:1px solid hsl(270,30%,90%);border-radius:10px;padding:16px;margin-bottom:16px}.ai-preview-header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#805ad5;margin-bottom:12px}.ai-preview-step{display:flex;align-items:center;gap:10px;padding:8px 0}.ai-preview-number{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#805ad5;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.ai-preview-title{font-size:14px;color:#2d3748}.ai-preview-actions{display:flex;gap:10px;margin-top:14px}.ai-preview-confirm{display:flex;align-items:center;gap:6px;padding:8px 18px;background:#805ad5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s}.ai-preview-confirm:hover{background:#6b46c1}.ai-preview-cancel{padding:8px 18px;background:transparent;border:1px solid var(--border-strong);border-radius:8px;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:background .12s}.ai-preview-cancel:hover{background:var(--border-soft)}.ai-chat-modal{background:#fff;border-radius:16px;padding:28px 32px;width:480px;max-width:90vw;box-shadow:0 20px 60px #00000026}.ai-chat-modal-header{display:flex;align-items:center;gap:10px;color:#805ad5;margin-bottom:8px}.ai-chat-modal-header h3{font-size:18px;font-weight:700;margin:0;flex:1;color:#1a202c}.ai-chat-close{background:transparent;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center}.ai-chat-close:hover{color:#4a5568;background:var(--border-soft)}.ai-chat-desc{font-size:14px;color:#718096;margin:0 0 16px}.ai-chat-textarea{width:100%;padding:12px;border:1px solid var(--border-strong);border-radius:8px;font-size:14px;font-family:inherit;color:#2d3748;resize:vertical;outline:none;box-sizing:border-box}.ai-chat-textarea:focus{border-color:#96c;box-shadow:0 0 0 2px #9966cc26}.ai-chat-textarea::placeholder{color:#a0aec0}.ai-chat-file-label{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px dashed hsl(210,14%,82%);border-radius:8px;font-size:13px;color:#718096;cursor:pointer;margin-top:12px;transition:background .12s}.ai-chat-file-label:hover{background:#f6f7f8}.ai-chat-file-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.ai-chat-file-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--border-soft);border-radius:6px;font-size:12px;color:#4a5568}.ai-chat-file-chip button{background:transparent;border:none;color:#a0aec0;cursor:pointer;padding:2px;display:flex;align-items:center}.ai-chat-file-chip button:hover{color:#e53e3e}.ai-chat-actions{margin-top:16px}.ai-chat-generate-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:#805ad5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s}.ai-chat-generate-btn:hover:not(:disabled){background:#6b46c1}.ai-chat-generate-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spin 1s linear infinite}.year-calendar-layout{flex:1;display:flex;overflow:hidden;background:var(--canvas);font-family:var(--font-sans)}.year-calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.year-calendar-header{padding:24px 32px;background:var(--surface);border-bottom:1px solid var(--border-soft)}.year-nav{display:flex;align-items:center;gap:12px}.year-grid-wrapper{flex:1;overflow-y:auto;padding:28px 32px}.year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.year-mini-month{background:#fff;border-radius:10px;padding:16px;cursor:pointer;transition:box-shadow .15s ease,transform .15s ease;border:1px solid var(--border-soft)}.year-mini-month:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.year-mini-month.current{border-color:#e53e3e}.year-mini-month-title{font-size:15px;font-weight:700;color:#1a202c;margin-bottom:10px;letter-spacing:-.01em}.year-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px 0}.year-mini-weekday{font-size:10px;font-weight:600;color:#a0aec0;text-align:center;padding:2px 0 4px;text-transform:uppercase}.year-mini-day{display:flex;flex-direction:column;align-items:center;padding:2px 0;min-height:22px;position:relative}.year-mini-day.empty{min-height:22px}.year-mini-day-num{font-size:11px;font-weight:400;color:#4a5568;line-height:1;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%}.year-mini-day.today .year-mini-day-num{background:#e53e3e;color:#fff;font-weight:700}.year-mini-day.holiday .year-mini-day-num{color:#e53e3e;font-weight:600}.year-mini-dots{display:flex;gap:2px;margin-top:1px}.year-mini-dot{width:4px;height:4px;border-radius:50%}@media(max-width:768px){.year-calendar-layout{flex-direction:column}.year-calendar-header{padding:16px}.year-calendar-header h1{font-size:22px}.year-calendar-grid{padding:16px;grid-template-columns:repeat(2,1fr);gap:16px}}@media(max-width:480px){.year-calendar-grid{grid-template-columns:1fr}}.analytics-page{flex:1;display:flex;flex-direction:column;overflow-y:auto;background:var(--canvas);font-family:var(--font-sans);color:var(--ink-900)}.analytics-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 32px 18px;border-bottom:1px solid var(--border-soft)}.analytics-header h1{font-size:var(--fs-20);font-weight:600;letter-spacing:var(--tracking-tighter);line-height:var(--lh-tight)}.analytics-subtitle{margin-top:4px;font-size:var(--fs-13);color:var(--ink-500)}.analytics-header-actions{display:flex;gap:6px;align-items:center}.analytics-body{padding:24px 32px 40px;display:flex;flex-direction:column;gap:24px;max-width:1200px}.analytics-2col{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;align-items:stretch}.analytics-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:16px}.analytics-section-title{font-size:var(--fs-14);font-weight:600;letter-spacing:var(--tracking-tighter);color:var(--ink-900)}.analytics-section-sub{font-size:var(--fs-12);color:var(--ink-500);margin-top:2px}.analytics-section-meta{font-size:11px;color:var(--ink-400)}.analytics-kpis{padding:20px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.kpi-cell{min-width:0}.kpi-value{font-size:28px;font-weight:600;letter-spacing:-.025em;margin-top:6px;color:var(--ink-900)}.kpi-meta{font-size:var(--fs-12);color:var(--ink-500);margin-top:2px}.analytics-heatmap-card{padding:20px}.heatmap-legend{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-400)}.heatmap-legend-cell{width:11px;height:11px;border-radius:3px}.heatmap-grid-wrap{display:flex;gap:8px;align-items:flex-start}.heatmap-side-labels{display:flex;flex-direction:column;gap:3px;padding-top:16px;font-size:10px;color:var(--ink-400)}.heatmap-side-labels>div{height:11px;line-height:11px}.heatmap-grid{display:grid;gap:3px;flex:1;position:relative;padding-top:14px}.heatmap-month-row{position:absolute;top:0;left:0;right:0;display:grid;height:14px;font-size:10px;color:var(--ink-400);grid-template-columns:inherit}.heatmap-month-row>span{grid-row:1}.heatmap-col{display:flex;flex-direction:column;gap:3px}.heatmap-cell{aspect-ratio:1;border-radius:3px;background:var(--surface-2);min-height:11px}.heatmap-cell.today{outline:1px solid var(--ink-700)}.heatmap-cell.outside{background:transparent!important}.analytics-courses-card{padding:20px;display:flex;flex-direction:column}.course-bars{display:flex;flex-direction:column;gap:12px}.course-bar-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:5px}.course-bar-meta{display:flex;align-items:center;gap:8px;min-width:0}.course-bar-code{font-size:11.5px;color:var(--ink-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-bar-h{font-size:var(--fs-12);color:var(--ink-900);flex:none}.course-bar-track{height:4px;background:var(--surface-2);border-radius:99px;overflow:hidden}.course-bar-fill{height:100%;border-radius:inherit}.analytics-week-card{padding:20px}.analytics-week-tabs{display:flex;gap:4px}.week-bars{display:flex;align-items:flex-end;gap:14px;height:170px;margin-top:18px}.week-bar-cell{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}.week-bar-value{font-size:11px;color:var(--ink-500)}.week-bar-fill{width:100%;background:var(--ink-200);border-radius:4px}.week-bar-fill.today{background:var(--accent)}.week-bar-day{font-size:11px;color:var(--ink-500)}.week-bar-day.today{color:var(--ink-900);font-weight:600}.analytics-insights-card{padding:20px;display:flex;flex-direction:column;gap:12px}.insight-row{display:flex;gap:10px;padding-top:12px;border-top:1px solid var(--border-soft)}.insight-row:first-of-type{padding-top:0;border-top:0}.insight-icon{width:24px;height:24px;border-radius:7px;background:var(--surface-2);display:grid;place-items:center;color:#006738;color:oklch(45% .13 155);flex:none}.insight-icon-warn{color:var(--warn)}.insight-icon-accent{color:var(--accent)}.insight-title{font-size:12.5px;font-weight:500}.insight-sub{font-size:11.5px;color:var(--ink-500);margin-top:2px}.analytics-skeleton-card{padding:20px;display:flex;flex-direction:column;gap:12px}.skel.skel-row{height:28px}.loading-meta{display:flex;align-items:center;gap:8px;color:var(--ink-500);font-size:var(--fs-13);padding:6px 4px}.loading-spin{animation:analytics-spin 1s linear infinite}@keyframes analytics-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1100px){.analytics-2col{grid-template-columns:1fr}.analytics-kpis{grid-template-columns:repeat(2,1fr)}}.today-page{flex:1;display:flex;flex-direction:column;overflow-y:auto;background:var(--canvas);font-family:var(--font-sans);color:var(--ink-900)}.today-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 32px 18px;border-bottom:1px solid var(--border-soft)}.today-header h1{font-size:var(--fs-20);font-weight:600;letter-spacing:var(--tracking-tighter);line-height:var(--lh-tight)}.today-sub{margin-top:4px;color:var(--ink-500);font-size:var(--fs-13)}.today-sub-divider{color:var(--ink-300)}.today-sub-strong{color:var(--ink-700);font-weight:500}.today-header-actions{display:flex;gap:8px}.today-grid{display:grid;grid-template-columns:1fr 320px;gap:28px;padding:24px 32px 40px;align-items:flex-start}.today-main{display:flex;flex-direction:column;gap:24px;min-width:0}.today-hero{padding:20px;display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;gap:20px;align-items:center}.today-hero-cell{min-width:0}.today-hero-title{font-size:var(--fs-16);font-weight:600;letter-spacing:var(--tracking-tighter);line-height:var(--lh-tight);margin-top:6px}.today-hero-empty{color:var(--ink-400);font-weight:500}.today-hero-meta{margin-top:4px;font-size:var(--fs-12);color:var(--ink-500);display:flex;align-items:center;gap:4px}.today-hero-stat{display:flex;align-items:baseline;gap:6px;margin-top:6px}.today-hero-stat .mono{font-size:var(--fs-24);font-weight:500;letter-spacing:var(--tracking-tighter);color:var(--ink-900)}.today-hero-stat-meta{font-size:var(--fs-12);color:var(--ink-400)}.today-hero-bar{display:flex;height:4px;border-radius:99px;overflow:hidden;margin-top:8px;background:var(--surface-2)}.today-hero-heat{display:flex;gap:3px;margin-top:8px}.today-hero-heat-bar{flex:1;height:4px;border-radius:2px}.today-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.today-section-title{font-size:var(--fs-15);font-weight:600;letter-spacing:var(--tracking-tighter);color:var(--ink-900)}.today-section-tabs{display:flex;gap:4px}.today-tab-active{color:var(--ink-900)}.today-tab-muted{color:var(--ink-400)}.today-empty{padding:16px;background:var(--surface-2);border:1px dashed var(--border);border-radius:var(--r-12);color:var(--ink-500);font-size:var(--fs-13);display:flex;align-items:center;gap:10px}.today-tl-row{display:grid;grid-template-columns:80px 1fr;gap:16px;align-items:flex-start;padding-bottom:14px}.today-tl-time{padding-top:6px}.today-tl-time-main{font-size:var(--fs-12);font-weight:500;color:var(--ink-700)}.today-tl-time-sub{font-size:11px;color:var(--ink-400);margin-top:2px}.today-tl-block{padding:12px 14px;border-radius:var(--r-10);border-left:3px solid var(--ink-300);background:var(--surface-2);position:relative}.today-tl-block.ended{opacity:.55}.today-tl-block.ended .today-tl-title{text-decoration:line-through;color:var(--ink-400)}.today-tl-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.today-tl-title{font-size:var(--fs-14);font-weight:500;color:var(--ink-900)}.today-tl-chip-class,.today-tl-chip-personal{height:18px;font-size:10.5px;padding:0 6px;text-transform:uppercase;letter-spacing:var(--tracking-wide);background:var(--surface);color:var(--ink-500);border-color:var(--border-soft)}.today-tl-chip-now{height:18px;font-size:10.5px;padding:0 6px}.today-tl-meta{font-size:var(--fs-12);color:var(--ink-500);margin-top:3px}.today-rail{display:flex;flex-direction:column;gap:20px;position:sticky;top:24px}.today-rail-card{padding:16px}.today-rail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.today-rail-title{font-size:var(--fs-13);font-weight:600}.today-rail-count{font-size:11px;color:var(--ink-400)}.today-rail-empty{font-size:var(--fs-12);color:var(--ink-500);padding:8px 0}.today-rail-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0}.today-rail-item.has-divider{border-top:1px solid var(--border-soft)}.today-rail-checkbox{width:14px;height:14px;border-radius:4px;border:1.5px solid var(--ink-300);background:transparent;margin-top:3px;flex:none}.today-rail-item-body{flex:1;min-width:0}.today-rail-item-meta{display:flex;align-items:center;gap:6px}.today-rail-item-code{font-size:10.5px;color:var(--ink-400);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.today-rail-soon{height:16px;padding:0 5px;font-size:10px}.today-rail-item-title{font-size:var(--fs-13);font-weight:500;margin-top:1px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.today-rail-item-due{font-size:11.5px;color:var(--ink-500);margin-top:2px;display:flex;gap:4px}@media(max-width:1100px){.today-grid{grid-template-columns:1fr}.today-rail{position:static}}@media(max-width:720px){.today-hero{grid-template-columns:1fr}.today-hero .divider-v{display:none}}.alltasks-page{flex:1;display:flex;flex-direction:column;overflow-y:auto;background:var(--canvas);font-family:var(--font-sans);color:var(--ink-900)}.alltasks-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 32px 18px;border-bottom:1px solid var(--border-soft)}.alltasks-header h1{font-size:var(--fs-20);font-weight:600;letter-spacing:var(--tracking-tighter);line-height:var(--lh-tight)}.alltasks-sub{margin-top:4px;font-size:var(--fs-13);color:var(--ink-500)}.alltasks-sub-strong{color:var(--ink-700)}.alltasks-header-actions{display:flex;gap:8px;align-items:center}.alltasks-search{position:relative;display:flex;align-items:center}.alltasks-search>svg{position:absolute;left:10px;color:var(--ink-400);pointer-events:none}.alltasks-search input{width:220px;height:32px;padding:0 10px 0 28px;border-radius:var(--r-8);border:1px solid var(--border);background:var(--surface);color:var(--ink-900);font-family:var(--font-sans);font-size:var(--fs-13);outline:none}.alltasks-search input:focus{border-color:var(--ink-700)}.alltasks-body{padding:18px 32px 40px;display:flex;flex-direction:column;gap:14px}.alltasks-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.alltasks-vdivider{height:18px}.alltasks-chip{display:inline-flex;align-items:center;gap:4px}.alltasks-chip-active{background:var(--ink-900)!important;color:var(--surface)!important;border-color:var(--ink-900)!important}.alltasks-chip-count{font-size:11px;margin-left:2px;opacity:.6}.alltasks-chip-active .alltasks-chip-count{color:var(--surface);opacity:.7}.alltasks-groupby{margin-left:auto;display:flex;align-items:center;gap:6px}.alltasks-groupby-label{font-size:11px;color:var(--ink-400)}.alltasks-list{padding:4px 6px}.alltasks-empty{padding:40px 16px;text-align:center;color:var(--ink-500);font-size:var(--fs-13)}.alltasks-group.has-divider{border-top:1px solid var(--border-soft);margin-top:6px}.alltasks-group-head{display:flex;align-items:center;gap:10px;padding:14px 16px 6px}.alltasks-group-title{font-size:var(--fs-12);font-weight:600;color:var(--ink-900)}.alltasks-group-count{font-size:11px;color:var(--ink-400)}.alltasks-group-load{height:18px;font-size:10.5px;padding:0 6px}.alltasks-row{display:grid;grid-template-columns:24px auto 1fr 64px 60px 70px 24px;gap:14px;align-items:center;padding:10px 16px;border-radius:var(--r-8)}.alltasks-row:hover{background:var(--surface-2)}.alltasks-row-checkbox{width:16px;height:16px;border-radius:5px;border:1.5px solid var(--ink-300);background:transparent;display:grid;place-items:center;cursor:pointer;color:var(--ink-500);padding:0}.alltasks-row.done .alltasks-row-title{text-decoration:line-through;color:var(--ink-400)}.alltasks-row-code{font-size:var(--fs-12);color:var(--ink-400);white-space:nowrap}.alltasks-row-titlewrap{display:inline-flex;align-items:center;gap:10px;min-width:0}.alltasks-row-title{font-size:var(--fs-13);font-weight:500;color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.alltasks-row-type{height:18px;font-size:10.5px;padding:0 6px;background:transparent;border:1px solid var(--border);color:var(--ink-500);flex-shrink:0}.alltasks-row-due,.alltasks-row-est{font-size:var(--fs-12);color:var(--ink-500)}.alltasks-row-prio{display:inline-flex;align-items:center;gap:5px;font-size:var(--fs-12);color:var(--ink-300)}.alltasks-row-prio.prio-high{color:var(--accent)}.alltasks-row-prio.prio-med{color:var(--warn)}.alltasks-row-prio.prio-low{color:var(--ink-300)}.alltasks-row-more{background:transparent;border:0;color:var(--ink-300);cursor:pointer;padding:0;display:grid;place-items:center}.alltasks-row-more:hover{color:var(--ink-700)}@media(max-width:900px){.alltasks-row{grid-template-columns:24px 1fr auto}.alltasks-row-code,.alltasks-row-due,.alltasks-row-est,.alltasks-row-prio,.alltasks-row-more{display:none}}@media(min-width:1280px){.alltasks-header h1{font-size:var(--fs-24)}.alltasks-sub{font-size:var(--fs-14)}.alltasks-search input{font-size:var(--fs-14);height:34px}.alltasks-group-title{font-size:var(--fs-14)}.alltasks-row{padding:12px 18px}.alltasks-row-code{font-size:var(--fs-13)}.alltasks-row-title{font-size:var(--fs-15)}.alltasks-row-type{height:20px;font-size:var(--fs-12);padding:0 8px}.alltasks-row-due,.alltasks-row-est,.alltasks-row-prio{font-size:var(--fs-13)}}@media(min-width:1600px){.alltasks-header h1{font-size:var(--fs-28)}.alltasks-sub{font-size:var(--fs-15)}.alltasks-search input{font-size:var(--fs-15);height:36px}.alltasks-group-title{font-size:var(--fs-15)}.alltasks-row{padding:14px 20px}.alltasks-row-code{font-size:var(--fs-14)}.alltasks-row-title{font-size:var(--fs-16)}.alltasks-row-type{font-size:var(--fs-13)}.alltasks-row-due,.alltasks-row-est,.alltasks-row-prio{font-size:var(--fs-14)}}.daily-review-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.daily-review-modal{background:#fff;border-radius:12px;padding:24px 28px;width:420px;max-width:90vw;box-shadow:0 12px 40px #00000026}.daily-review-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.daily-review-header h3{margin:0;font-size:18px;color:#2d3748}.daily-review-icon{font-size:20px}.daily-review-desc{color:#718096;font-size:14px;margin:0 0 16px}.daily-review-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.daily-review-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.daily-review-title{font-size:14px;color:#2d3748;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.daily-review-input-group{display:flex;align-items:center;gap:4px;flex-shrink:0}.daily-review-input{width:60px;padding:4px 8px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;text-align:right;outline:none}.daily-review-input:focus{border-color:#3182ce}.daily-review-unit{font-size:13px;color:#a0aec0}.daily-review-actions{display:flex;justify-content:flex-end;gap:10px}.daily-review-skip{padding:8px 16px;border:1px solid #E2E8F0;border-radius:8px;background:#fff;color:#718096;font-size:14px;cursor:pointer}.daily-review-skip:hover{background:#f7fafc}.daily-review-save{padding:8px 20px;border:none;border-radius:8px;background:#3182ce;color:#fff;font-size:14px;cursor:pointer}.daily-review-save:hover{background:#2b6cb0}.app-layout{display:flex;height:100vh;font-family:var(--font-sans);background:var(--canvas);color:var(--ink-900);overflow:hidden;font-size:var(--fs-14);letter-spacing:var(--tracking-tight)}.panel-divider{width:4px;cursor:col-resize;background:var(--border-soft);flex-shrink:0;transition:background var(--dur) var(--ease-out);position:relative}.panel-divider:after{content:"";position:absolute;inset:0 -4px}.panel-divider:hover{background:var(--accent)}.right-panel-animated{display:flex;animation:panelFadeSlideIn .25s ease-out}@keyframes panelFadeSlideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.app-loading-spinner{animation:app-spin 1s linear infinite}@keyframes app-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.app-layout{flex-direction:column;height:100vh}.panel-divider{display:none}}
