@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[data-color-mode=dark]{--canvas: oklch(18% .008 60);--surface: oklch(22% .008 60);--surface-2: oklch(26% .008 60);--surface-3: oklch(30% .008 60);--surface-hover: oklch(28% .008 60);--ink-900: oklch(96% .005 60);--ink-700: oklch(82% .005 60);--ink-500: oklch(64% .006 60);--ink-400: oklch(54% .006 60);--ink-300: oklch(42% .006 60);--ink-200: oklch(32% .006 60);--ink-100: oklch(26% .006 60);--border: oklch(36% .006 60);--border-strong: oklch(46% .006 60);--border-soft: oklch(30% .006 60)}@media(min-width:1280px){:root{--fs-12: 13px;--fs-13: 14px;--fs-14: 15px;--fs-15: 16px;--fs-16: 17px;--fs-18: 19px;--fs-20: 22px;--fs-24: 26px;--fs-28: 30px;--fs-32: 34px;--fs-40: 42px}}@media(min-width:1600px){:root{--fs-12: 13px;--fs-13: 14px;--fs-14: 16px;--fs-15: 17px;--fs-16: 18px;--fs-18: 20px;--fs-20: 24px;--fs-24: 28px;--fs-28: 32px;--fs-32: 36px;--fs-40: 44px}}@media(prefers-color-scheme:dark){html[data-color-mode=auto]{--canvas: oklch(18% .008 60);--surface: oklch(22% .008 60);--surface-2: oklch(26% .008 60);--surface-3: oklch(30% .008 60);--surface-hover: oklch(28% .008 60);--ink-900: oklch(96% .005 60);--ink-700: oklch(82% .005 60);--ink-500: oklch(64% .006 60);--ink-400: oklch(54% .006 60);--ink-300: oklch(42% .006 60);--ink-200: oklch(32% .006 60);--ink-100: oklch(26% .006 60);--border: oklch(36% .006 60);--border-strong: oklch(46% .006 60);--border-soft: oklch(30% .006 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}.help-widget-overlay{position:fixed;inset:0;background:#14141452;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1200;animation:help-widget-fade .18s ease-out}@keyframes help-widget-fade{0%{opacity:0}to{opacity:1}}.help-widget-card{width:420px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);background:var(--surface, #fff);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 48px #0000002e,0 4px 12px #0000000f;animation:help-widget-pop .22s ease-out}@keyframes help-widget-pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.help-widget-header{position:relative;background:#1f1915;color:#fff;padding:32px 22px 28px}.help-widget-close{position:absolute;top:12px;right:12px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:none;background:transparent;color:#ffffffb3;cursor:pointer;transition:background .15s ease,color .15s ease}.help-widget-close:hover{background:#ffffff1a;color:#fff}.help-widget-title{font-size:18px;font-weight:600;letter-spacing:-.02em;margin:0;line-height:1.25}.help-widget-body{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:8px}.help-widget-status,.help-widget-row,.help-widget-search{background:var(--surface);border-radius:12px;box-shadow:0 2px 6px #0000000a,0 0 0 1px #0000000a}.help-widget-status{display:flex;align-items:center;gap:12px;padding:14px 16px}.help-widget-status-icon{color:var(--ok, #48BB78);flex-shrink:0}.help-widget-status-text{flex:1;min-width:0}.help-widget-status-title{font-size:var(--fs-14, 14px);font-weight:600;color:var(--info, #3B82F6)}.help-widget-status-sub{font-size:12px;color:var(--ink-500);margin-top:2px}.help-widget-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;text-decoration:none;color:var(--ink-900);cursor:pointer;transition:background .12s ease}.help-widget-row:hover{background:var(--surface-hover, var(--surface-2))}.help-widget-row-title{font-size:var(--fs-14, 14px);font-weight:600}.help-widget-row-arrow{color:var(--info, #3B82F6);flex-shrink:0}.help-widget-search{position:relative;padding:0}.help-widget-search input{width:100%;height:42px;padding:0 38px 0 14px;border:none;background:transparent;font-size:var(--fs-14, 14px);font-family:var(--font-sans, inherit);color:var(--ink-900);outline:none;border-radius:12px;box-sizing:border-box}.help-widget-search input::placeholder{color:var(--ink-500)}.help-widget-search-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--info, #3B82F6);pointer-events:none}.help-widget-faq{display:flex;flex-direction:column;background:var(--surface);border-radius:12px;box-shadow:0 2px 6px #0000000a,0 0 0 1px #0000000a;overflow:hidden}.help-widget-faq-item+.help-widget-faq-item{border-top:1px solid var(--border-soft)}.help-widget-faq-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border:none;background:transparent;cursor:pointer;font-family:var(--font-sans, inherit);text-align:left;transition:background .12s ease}.help-widget-faq-head:hover{background:var(--surface-2)}.help-widget-faq-title{font-size:var(--fs-14, 14px);font-weight:500;color:var(--ink-900);letter-spacing:-.005em}.help-widget-faq-chev{color:var(--info, #3B82F6);flex-shrink:0}.help-widget-faq-body{padding:0 16px 14px;font-size:var(--fs-13, 13px);color:var(--ink-700);line-height:1.6}.help-widget-faq-body code{background:var(--surface-2);padding:1px 6px;border-radius:4px;font-family:var(--font-mono, ui-monospace);font-size:12px}.help-widget-faq-body strong{color:var(--ink-900)}.help-widget-faq-empty{padding:24px 16px;text-align:center;font-size:var(--fs-13, 13px);color:var(--ink-500)}.help-widget-faq-empty a{color:var(--accent-ink);text-decoration:underline}.search-overlay{position:fixed;inset:0;background:#14141452;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;z-index:1200;padding-top:12vh;animation:search-fade .15s ease-out}@keyframes search-fade{0%{opacity:0}to{opacity:1}}.search-card{width:560px;max-width:calc(100vw - 32px);max-height:76vh;background:var(--surface);border:1px solid var(--border-soft);border-radius:14px;box-shadow:0 24px 48px #0000002e,0 4px 12px #0000000f;display:flex;flex-direction:column;overflow:hidden;animation:search-pop .2s ease-out}@keyframes search-pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.search-input-row{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-soft)}.search-input-icon{color:var(--ink-400);flex-shrink:0}.search-input{flex:1;border:none;background:transparent;font-size:var(--fs-15, 15px);color:var(--ink-900);font-family:var(--font-sans, inherit);outline:none;letter-spacing:var(--tracking-tight, -.018em)}.search-input::placeholder{color:var(--ink-400)}.search-close{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-400);border-radius:5px;cursor:pointer;flex-shrink:0}.search-close:hover{background:var(--surface-2);color:var(--ink-900)}.search-results{flex:1;overflow-y:auto;padding:6px 6px 8px}.search-hint{padding:28px 16px;text-align:center;color:var(--ink-400);font-size:var(--fs-13, 13px)}.search-group-label{padding:10px 12px 6px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-400)}.search-row{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;text-align:left;font-family:var(--font-sans, inherit);transition:background .12s ease}.search-row:hover{background:var(--surface-2)}.search-row-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.search-row-icon{color:var(--ink-500);flex-shrink:0;display:inline-flex}.search-row-title{flex:1;font-size:var(--fs-13, 13px);font-weight:500;color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.search-row-meta{font-size:11.5px;color:var(--ink-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.search-row-arrow{color:var(--ink-300);flex-shrink:0}.quickadd-overlay{position:fixed;inset:0;background:#14141452;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;z-index:1200;padding-top:14vh;animation:quickadd-fade .15s ease-out}@keyframes quickadd-fade{0%{opacity:0}to{opacity:1}}.quickadd-card{width:520px;max-width:calc(100vw - 32px);background:var(--surface);border:1px solid var(--border-soft);border-radius:14px;box-shadow:0 24px 48px #0000002e,0 4px 12px #0000000f;overflow:hidden;animation:quickadd-pop .2s ease-out}@keyframes quickadd-pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.quickadd-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border-soft)}.quickadd-input-icon{color:var(--accent);flex-shrink:0}.quickadd-input{flex:1;border:none;background:transparent;font-size:var(--fs-15, 15px);color:var(--ink-900);font-family:var(--font-sans, inherit);outline:none;letter-spacing:var(--tracking-tight, -.018em)}.quickadd-input::placeholder{color:var(--ink-400)}.quickadd-close{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-400);border-radius:5px;cursor:pointer;flex-shrink:0}.quickadd-close:hover{background:var(--surface-2);color:var(--ink-900)}.quickadd-cats{display:flex;align-items:center;gap:6px;padding:10px 12px;background:var(--surface-2)}.quickadd-cat{display:inline-flex;align-items:center;height:26px;padding:0 12px;border:1px solid var(--border-soft);background:var(--surface);color:var(--ink-700);font-size:var(--fs-12, 12px);font-weight:500;border-radius:var(--r-pill, 999px);cursor:pointer;font-family:var(--font-sans, inherit);transition:background .12s ease,border-color .12s ease,color .12s ease}.quickadd-cat:hover{background:var(--surface-hover);border-color:var(--border-strong)}.quickadd-cat.active{background:var(--ink-900);color:var(--surface);border-color:var(--ink-900)}.quickadd-hint{margin-left:auto;font-size:11px;color:var(--ink-500)}.sidebar{width:240px;flex:none;background:var(--canvas);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;padding:14px 10px 6px;gap:4px;font-family:var(--font-sans);color:var(--ink-900)}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:4px 6px 10px}.sidebar-brand-name{flex:1;min-width:0}.sidebar-brand-search{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-400);border-radius:6px;cursor:pointer;transition:background .12s ease,color .12s ease;flex-shrink:0}.sidebar-brand-search:hover:not(:disabled){background:var(--surface-2);color:var(--ink-900)}.sidebar-brand-search:disabled{cursor:not-allowed;opacity:.55}.sidebar-brand-mark{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;flex-shrink:0;overflow:hidden}.sidebar-brand-mark img{display:block;width:100%;height:100%;object-fit:cover}.sidebar-brand-name{font-weight:600;font-size:var(--fs-15, 15px);letter-spacing:var(--tracking-tight)}.sidebar-quickadd{display:inline-flex;align-items:center;gap:8px;height:32px;margin:0 4px 8px;padding:0 10px;border-radius:var(--r-8);font-size:var(--fs-13, 13px);font-weight:500;color:var(--ink-500);background:var(--surface);border:1px solid var(--border-soft);cursor:pointer;font-family:var(--font-sans, inherit);transition:background var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.sidebar-quickadd:hover:not(:disabled){background:var(--surface-2);color:var(--ink-900)}.sidebar-quickadd:disabled{cursor:not-allowed;opacity:.7}.sidebar-quickadd-label{flex:1;text-align:left}.sidebar-quickadd-keys{margin-left:auto;display:inline-flex;align-items:center;gap:2px}.sidebar-quickadd-keys .kbd{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 3px;border-radius:3px;background:var(--surface-2);border:1px solid var(--border-soft);color:var(--ink-500);font-family:var(--font-mono, ui-monospace);font-size:10px;font-weight:500}.nav-item{display:flex;align-items:center;gap:10px;height:36px;padding:0 10px;border-radius:var(--r-8, 8px);color:var(--ink-700);font-size:var(--fs-14, 14px);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:30px;padding-left:26px;padding-right:8px;border-radius:var(--r-6);color:var(--ink-700);font-size:var(--fs-13, 13px);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:6px 4px 0;border-top:1px solid var(--border-soft);position:relative}.sidebar-account{display:flex;align-items:center;gap:10px;width:100%;padding:6px 8px;border:none;background:transparent;border-radius:var(--r-8, 8px);cursor:pointer;font-family:var(--font-sans, inherit);text-align:left;transition:background .12s ease}.sidebar-account:hover,.sidebar-account.open{background:var(--surface-2)}.sidebar-avatar{width:28px;height:28px;border-radius:50%;background:var(--c-amber);color:#fff;font-size:12px;font-weight:600;display:grid;place-items:center;flex:none}.sidebar-user{flex:1;overflow:hidden;min-width:0}.sidebar-user-name{font-size:13px;font-weight:500;color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-meta{font-size:11px;color:var(--ink-500);margin-top:1px}.sidebar-account-chevron{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;color:var(--ink-400);flex:none}.sidebar-account-menu{position:absolute;bottom:calc(100% + 4px);left:8px;right:8px;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-10, 10px);box-shadow:0 8px 24px #00000014,0 2px 6px #0000000a;padding:4px;z-index:50;display:flex;flex-direction:column;gap:1px}.sidebar-account-menu-email{padding:8px 10px 4px;font-size:11.5px;color:var(--ink-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-account-menu-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border:none;background:transparent;color:var(--ink-900);font-size:12.5px;font-weight:500;cursor:pointer;border-radius:6px;font-family:var(--font-sans, inherit);text-align:left;transition:background .12s ease}.sidebar-account-menu-item svg{color:var(--ink-500);flex-shrink:0;width:16px;height:16px}.sidebar-account-menu-item:hover{background:var(--surface-2)}.sidebar-account-menu-item:hover svg{color:var(--ink-900)}.sidebar-account-menu-divider{height:1px;background:var(--border-soft);margin:4px 6px}.sidebar-account-menu-logout{color:var(--ink-700)}.sidebar-account-menu-logout:hover{color:var(--accent-ink, #9B2C2C);background:var(--accent-softer, #FFF5F5)}.sidebar-account-menu-logout:hover svg{color:var(--accent-ink, #9B2C2C)}.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;background:var(--canvas);min-width:0}.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:0}.view-toggle-btn{height:26px;padding:0 12px;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,box-shadow .15s ease;letter-spacing:var(--tracking-tight, -.018em)}.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,0 0 0 1px #00000005;font-weight:600}.auto-schedule-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;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);letter-spacing:var(--tracking-tight, -.018em);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:12px 28px;gap:10px;flex-shrink:0;border-bottom:1px solid var(--border-soft);background:var(--canvas)}.nav-btn-group{display:inline-flex;align-items:center;height:28px;padding:1px;border:1px solid var(--border, #E2E8F0);border-radius:8px;background:var(--surface, #fff);gap:0}.nav-btn-group .nav-btn{width:24px;height:24px;border-radius:6px;border:none;background:transparent;color:var(--ink-700, #4A5568)}.nav-btn-group .nav-btn:hover{background:var(--surface-2, #F7FAFC);color:var(--ink-900, #1A202C)}.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:var(--tracking-tight, -.018em)}.nav-label{display:inline-flex;align-items:center;height:20px;padding:0 8px;border-radius:var(--r-pill, 999px);background:var(--accent-soft, #FED7D7);color:var(--accent-ink, #9B2C2C);font-size:11px;font-weight:500;letter-spacing:var(--tracking-tight, -.005em)}.today-btn{display:inline-flex;align-items:center;height:20px;padding:0 8px;border-radius:var(--r-pill, 999px);border:1px solid var(--border, #E2E8F0);background:var(--surface, #fff);font-size:11px;font-weight:500;color:var(--ink-700, #4A5568);cursor:pointer;letter-spacing:var(--tracking-tight, -.005em)}.today-btn:hover{background:var(--surface-2, #F7FAFC)}.delete-all-btn{margin-left:auto;display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:6px;border:1px solid var(--accent-soft, #FEB2B2);background:transparent;color:var(--accent-ink, #9B2C2C);font-size:var(--fs-12, 12px);font-weight:500;cursor:pointer;transition:background .15s ease,border-color .15s ease;letter-spacing:var(--tracking-tight, -.005em)}.delete-all-btn:hover{background:var(--accent-softer, #FFF5F5);border-color:var(--accent, #E53E3E);color:var(--accent, #C53030)}.block-legend{margin-left:auto;display:inline-flex;align-items:center;gap:12px;padding:4px 10px;background:var(--surface, #fff);border:1px solid var(--border-soft, #EDF2F7);border-radius:6px}.legend-item{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;color:var(--ink-600, #4A5568);font-weight:500;letter-spacing:var(--tracking-tight, -.005em)}.legend-swatch{width:18px;height:11px;border-radius:2px;flex-shrink:0;position:relative;overflow:hidden;box-sizing:border-box}.legend-swatch.swatch-class{background:var(--c-1, #DDD0BC)}.legend-swatch.swatch-planned,.legend-swatch.swatch-progress{background:transparent;border:1.2px dashed var(--c-1, #DDD0BC)}.legend-swatch.swatch-progress:before{content:"";position:absolute;top:0;left:0;right:0;height:55%;background:var(--c-1-soft, #F2EBDD);border-bottom:1px solid var(--c-1, #DDD0BC)}.legend-swatch.swatch-done{background:var(--c-1-soft, #F2EBDD);border-left:2px solid var(--c-1, #DDD0BC)}.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:var(--canvas);border-bottom:1px solid var(--border-soft);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;background:var(--canvas)}.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 var(--border-soft);background:var(--surface)}.day-column.today-col{background:var(--surface)}.hour-cell{border-bottom:1px solid var(--border-soft);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;max-height:120px;overflow-x:hidden;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.all-day-row::-webkit-scrollbar{width:6px}.all-day-row::-webkit-scrollbar-track{background:transparent}.all-day-row::-webkit-scrollbar-thumb{background:transparent;border-radius:3px;transition:background .2s ease}.all-day-row:hover{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.22) transparent}.all-day-row:hover::-webkit-scrollbar-thumb{background:#00000038}.all-day-row:hover::-webkit-scrollbar-thumb:hover{background:#00000059}.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;min-width:0}.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:none;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}.canvas-badge{display:inline-flex;align-items:center;gap:3px;height:16px;padding:0 6px;border-radius:4px;background:var(--surface-2, #F7FAFC);border:1px solid var(--border-soft, #EDF2F7);color:var(--ink-500, #718096);font-size:9.5px;font-weight:500;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}.settings-content .semester-date-row .form-group{border-top:0;padding:0}.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-swatches-soft{height:14px;margin-top:4px;opacity:.95}.theme-swatch{flex:1;border-radius:var(--r-6)}.theme-swatches-soft .theme-swatch{border-radius:var(--r-4, 4px);border:1px solid rgba(0,0,0,.04)}.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:4px;position:sticky;top:24px}.settings-nav-item{display:flex;align-items:center;gap:8px;height:32px;padding:0 12px;border-radius:var(--r-8, 8px);background:transparent;border:0;font-family:var(--font-sans);font-size:var(--fs-13, 13px);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:not(.section-icon){display:contents}.settings-content .section-header .section-icon,.settings-content .section-header .section-icon svg{display:none!important}.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}.account-info{display:flex;flex-direction:column;gap:1px;background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-8);overflow:hidden;margin-bottom:16px}.account-info-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 14px;background:var(--surface);font-size:var(--fs-13)}.account-info-label{color:var(--ink-500);font-weight:500}.account-info-value{color:var(--ink-900);font-weight:500;text-align:right;word-break:break-all}.account-logout-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-8);border:1px solid var(--border);background:var(--surface);color:var(--ink-700);font-size:var(--fs-13);font-weight:500;cursor:pointer;transition:background .15s ease,border-color .15s ease}.account-logout-btn:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--ink-900)}.courses-list{display:flex;flex-direction:column;gap:6px}.course-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-soft);border-radius:var(--r-8);background:var(--surface)}.course-row-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.course-row-code{font-family:var(--font-mono);font-size:var(--fs-12);color:var(--ink-700);font-weight:500;min-width:90px}.course-row-name{font-size:var(--fs-13);color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.settings-empty{font-size:var(--fs-13);color:var(--ink-500);padding:16px 4px}.notif-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 14px;border:1px solid var(--border-soft);border-radius:var(--r-8);background:var(--surface);margin-bottom:6px;cursor:pointer}.notif-row-text{display:flex;flex-direction:column;gap:2px;min-width:0}.notif-row-title{font-size:var(--fs-13);font-weight:500;color:var(--ink-900)}.notif-row-hint{font-size:var(--fs-12);color:var(--ink-500)}.notif-toggle{width:36px;height:20px;border-radius:var(--r-pill);background:var(--surface-2);border:1px solid var(--border);position:relative;flex-shrink:0;transition:background .15s ease,border-color .15s ease;cursor:pointer}.notif-toggle.on{background:var(--ink-900);border-color:var(--ink-900)}.notif-toggle-knob{position:absolute;top:1px;left:1px;width:16px;height:16px;border-radius:50%;background:var(--surface);box-shadow:0 1px 2px #00000026;transition:transform .15s ease}.notif-toggle.on .notif-toggle-knob{transform:translate(16px)}.billing-plan-card{border:1px solid var(--border-soft);border-radius:var(--r-10);padding:16px;background:var(--surface-2);margin-bottom:18px}.billing-plan-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.billing-plan-name{font-size:var(--fs-16);font-weight:600;color:var(--ink-900);letter-spacing:var(--tracking-tight)}.billing-plan-meta{font-size:var(--fs-12);color:var(--ink-500);margin-top:2px}.billing-upgrade-btn{height:32px;padding:0 14px;border-radius:var(--r-8);border:1px solid var(--ink-900);background:var(--ink-900);color:var(--surface);font-size:var(--fs-13);font-weight:500;cursor:pointer;transition:opacity .15s ease}.billing-upgrade-btn:disabled{opacity:.5;cursor:not-allowed}.billing-feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.billing-feature-list li{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);color:var(--ink-700)}.billing-feature-list svg{color:var(--ok, #48BB78);flex-shrink:0}.billing-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-top:1px solid var(--border-soft)}.billing-row-label{font-size:var(--fs-13);font-weight:500;color:var(--ink-900)}.billing-row-value{font-size:var(--fs-13);color:var(--ink-900)}.billing-row-value.muted{color:var(--ink-500)}.danger-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px;border:1px solid var(--border-soft);border-radius:var(--r-8);background:var(--surface)}.danger-row-text{display:flex;flex-direction:column;gap:2px;min-width:0}.danger-row-title{font-size:var(--fs-13);font-weight:500;color:var(--ink-900)}.danger-row-hint{font-size:var(--fs-12);color:var(--ink-500)}.data-export-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 14px;border-radius:var(--r-8);border:1px solid var(--border);background:var(--surface);color:var(--ink-900);font-size:var(--fs-13);font-weight:500;cursor:pointer;flex-shrink:0;transition:background .15s ease,border-color .15s ease}.data-export-btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.danger-section .section-icon.red-icon{background:var(--accent-soft);color:var(--accent-ink, #9B2C2C)}.account-delete-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 14px;border-radius:var(--r-8);border:1px solid var(--accent-soft, #FEB2B2);background:transparent;color:var(--accent-ink, #9B2C2C);font-size:var(--fs-13);font-weight:500;cursor:pointer;transition:background .15s ease,border-color .15s ease}.account-delete-btn:hover{background:var(--accent-softer, #FFF5F5);border-color:var(--accent, #E53E3E);color:var(--accent, #C53030)}.canvas-section-flat{padding:22px 24px 8px}.canvas-flat-head{margin-bottom:4px}.canvas-flat-title{display:flex;align-items:center;gap:10px;margin:0 0 4px;font-size:var(--fs-18, 18px);font-weight:600;letter-spacing:var(--tracking-tighter, -.025em);color:var(--ink-900)}.canvas-status-pill{display:inline-flex;align-items:center;height:20px;padding:0 9px;border-radius:var(--r-pill, 999px);font-size:11px;font-weight:500;background:var(--ok-soft, oklch(95% .04 145));color:var(--ok, #22A559);border:none;letter-spacing:-.005em}.canvas-status-pill.disconnected{background:var(--surface-2);color:var(--ink-500)}.canvas-flat-sub{margin:0 0 6px;font-size:var(--fs-13, 13px);color:var(--ink-500);line-height:1.5}.canvas-flat-row{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:flex-start;padding:18px 0;border-top:1px solid var(--border-soft)}.canvas-flat-label-title{font-size:var(--fs-13, 13px);font-weight:600;color:var(--ink-900);margin-bottom:4px}.canvas-flat-label-hint{font-size:var(--fs-12, 12px);color:var(--ink-500);line-height:1.5}.canvas-flat-control{display:flex;align-items:center;gap:8px;min-width:0}.canvas-flat-input{flex:1;min-width:0}.canvas-flat-token-control{align-items:stretch}.canvas-flat-sync-control{align-items:center;gap:14px}.canvas-flat-btn{display:inline-flex;align-items:center;gap:5px;height:34px;padding:0 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--ink-900);font-size:var(--fs-13, 13px);font-weight:500;font-family:var(--font-sans, inherit);cursor:pointer;flex-shrink:0;transition:background .12s ease,border-color .12s ease}.canvas-flat-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-strong)}.canvas-flat-btn:disabled{opacity:.6;cursor:not-allowed}.canvas-flat-btn-replace{align-self:center}.canvas-flat-sync-meta{font-size:var(--fs-12, 12px);color:var(--ink-500);white-space:nowrap}.privacy-blurb{margin:4px 0 14px;font-size:var(--fs-13, 13px);color:var(--ink-700);line-height:1.55}.privacy-blurb-link{color:var(--ink-900);text-decoration:underline;text-underline-offset:2px}.privacy-link-list{display:flex;flex-direction:column}.privacy-link-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;font-size:var(--fs-14, 14px);color:var(--ink-900);text-decoration:none;border-top:1px solid var(--border-soft);transition:color .12s ease}.privacy-link-row:first-child{border-top:1px solid var(--border-soft)}.privacy-link-row:hover{color:var(--accent-ink)}.privacy-link-row svg{color:var(--ink-400)}.privacy-collapse{border-top:1px solid var(--border-soft);padding:4px 0}.privacy-collapse summary{list-style:none;cursor:pointer;padding:10px 24px 10px 0;font-size:var(--fs-13, 13px);font-weight:500;color:var(--ink-900);position:relative;-webkit-user-select:none;user-select:none}.privacy-collapse summary::-webkit-details-marker{display:none}.privacy-collapse summary:after{content:"▾";position:absolute;right:4px;top:50%;transform:translateY(-50%) rotate(-90deg);color:var(--ink-400);font-size:12px;transition:transform .15s ease}.privacy-collapse[open] summary:after{transform:translateY(-50%) rotate(0)}.privacy-collapse ul{margin:4px 0 12px;padding-left:18px;display:flex;flex-direction:column;gap:4px}.privacy-collapse li{font-size:12.5px;color:var(--ink-700);line-height:1.55}.color-mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.color-mode-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:0;border:2px solid transparent;background:transparent;border-radius:12px;cursor:pointer;font-family:var(--font-sans, inherit);transition:border-color .15s ease,transform .15s ease}.color-mode-card:hover{transform:translateY(-1px)}.color-mode-card.active{border-color:var(--info, #3B82F6)}.color-mode-card-preview{width:100%;aspect-ratio:16 / 10;border-radius:10px;position:relative;padding:14px 16px;border:1px solid var(--border-soft);display:flex;flex-direction:column;gap:6px;overflow:hidden}.color-mode-card-label{font-size:var(--fs-13, 13px);color:var(--ink-700);font-weight:500}.color-mode-card.active .color-mode-card-label{color:var(--ink-900);font-weight:600}.cm-stroke{height:4px;width:60%;border-radius:99px;background:var(--ink-300)}.cm-stroke.short{width:35%}.cm-bar{margin-top:auto;height:26px;border-radius:6px;background:var(--surface);border:1px solid var(--border-soft);display:flex;align-items:center;padding:0 8px;position:relative}.cm-bar-dot{margin-left:auto;width:9px;height:9px;border-radius:50%;background:var(--accent)}.color-mode-card.color-mode-light .color-mode-card-preview{background:#f7f5f0}.color-mode-card.color-mode-light .cm-stroke{background:#c8c5be}.color-mode-card.color-mode-light .cm-bar{background:#fff;border-color:#e8e6e0}.color-mode-card.color-mode-light .cm-bar-dot{background:#c0633a}.color-mode-card.color-mode-dark .color-mode-card-preview{background:#4a4a4a}.color-mode-card.color-mode-dark .cm-stroke{background:#8a8a8a}.color-mode-card.color-mode-dark .cm-bar{background:#6b6b6b;border-color:#5a5a5a}.color-mode-card.color-mode-dark .cm-bar-dot{background:#c0633a}.color-mode-card.color-mode-auto .color-mode-card-preview{background:linear-gradient(115deg,#f7f5f0 50%,#4a4a4a 50%)}.color-mode-card.color-mode-auto .cm-stroke{background:#969696b3}.color-mode-card.color-mode-auto .cm-bar{background:linear-gradient(115deg,#fff 50%,#6b6b6b 50%);border-color:#96969680}.color-mode-card.color-mode-auto .cm-bar-dot{background:#c0633a}.privacy-settings-section{padding-top:18px}.privacy-settings-heading{font-size:var(--fs-18, 18px);font-weight:600;color:var(--ink-900);letter-spacing:var(--tracking-tighter, -.025em);margin:0 0 14px}.privacy-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;border-top:1px solid var(--border-soft)}.privacy-row:first-of-type{border-top:0;padding-top:4px}.privacy-row-text{flex:1;min-width:0}.privacy-row-title{font-size:var(--fs-14, 14px);font-weight:500;color:var(--ink-900);margin-bottom:2px}.privacy-row-hint{font-size:var(--fs-13, 13px);color:var(--ink-500);line-height:1.5}.privacy-row-btn{display:inline-flex;align-items:center;height:32px;padding:0 14px;border-radius:var(--r-8, 8px);border:1px solid var(--border);background:var(--surface);color:var(--ink-900);font-size:var(--fs-13, 13px);font-weight:500;cursor:pointer;flex-shrink:0;font-family:var(--font-sans, inherit);transition:background .12s ease,border-color .12s ease}.privacy-row-btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.privacy-danger-section{margin-top:18px;background:var(--surface);border:1px solid var(--accent-soft, #FEB2B2)}.privacy-danger-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.privacy-danger-title{font-size:var(--fs-14, 14px);font-weight:600;color:var(--accent-ink, #9B2C2C);margin-bottom:4px}.privacy-danger-hint{font-size:var(--fs-13, 13px);color:var(--ink-500);line-height:1.5;max-width:480px}.course-page{flex:1;overflow-y:auto;background:var(--canvas);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:22px 28px 14px;background:var(--canvas);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:var(--fs-20, 20px);font-weight:600;color:var(--ink-900);margin:0;display:flex;align-items:center;gap:8px;letter-spacing:var(--tracking-tighter, -.025em);line-height:var(--lh-tight, 1.15)}.course-title-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}.course-page-subtitle{font-size:var(--fs-13, 13px);color:var(--ink-500);margin:4px 0 0}.course-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.course-canvas-link{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-13, 13px);color:var(--ink-700);text-decoration:none;padding:0 6px;height:28px;border-radius:6px;transition:background .12s ease,color .12s ease}.course-canvas-link:hover{background:var(--surface-2);color:var(--ink-900)}.course-sync-time{font-size:var(--fs-12, 12px);color:var(--ink-400);white-space:nowrap;margin-right:4px}.course-sync-btn,.course-import-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:8px;font-size:var(--fs-13, 13px);font-weight:500;letter-spacing:var(--tracking-tight, -.018em);cursor:pointer;transition:background .15s ease,border-color .15s ease;white-space:nowrap;font-family:var(--font-sans, inherit)}.course-sync-btn{background:var(--surface);border:1px solid var(--border);color:var(--ink-900)}.course-sync-btn:hover:not(:disabled),.course-import-btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.course-sync-btn:disabled{opacity:.55;cursor:not-allowed}.course-import-btn{background:var(--surface);border:1px solid var(--border);color:var(--ink-900)}.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}.course-page-body{flex:1;display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:18px;padding:18px 28px 40px;align-items:flex-start}@media(max-width:1280px){.course-page-body{grid-template-columns:1fr}}.course-main-column{display:flex;flex-direction:column;gap:16px;min-width:0}.course-side-column{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-12, 12px);overflow:hidden;position:sticky;top:18px;max-height:calc(100vh - 36px)}.course-kpi-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:18px 22px;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-12, 12px)}.course-kpi-cell{display:flex;flex-direction:column;gap:2px;padding-right:18px;border-right:1px solid var(--border-soft)}.course-kpi-cell:last-child{border-right:none}.course-kpi-cell:not(:first-child){padding-left:18px}.course-kpi-label{font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);margin-bottom:4px}.course-kpi-value{font-size:22px;font-weight:600;letter-spacing:-.025em;color:var(--ink-900);line-height:1.1}.course-kpi-grade-row{display:flex;align-items:baseline;gap:8px}.course-kpi-letter{display:inline-flex;align-items:center;height:20px;padding:0 7px;border-radius:var(--r-pill, 999px);background:var(--surface-2);color:var(--ink-700);font-size:11px;font-weight:600}.course-kpi-of{font-size:12px;font-weight:500;color:var(--ink-500)}.course-kpi-meta{font-size:11px;color:var(--ink-500);margin-top:1px}.course-assignments-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-12, 12px);overflow:hidden}.course-assignments-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 22px 12px;border-bottom:1px solid var(--border-soft)}.course-assignments-title-row{display:inline-flex;align-items:center;gap:14px}.course-assignments-title{font-size:var(--fs-14, 14px);font-weight:600;color:var(--ink-900);margin:0;letter-spacing:var(--tracking-tight, -.018em)}.course-assignments-tabs{display:inline-flex;gap:2px}.course-assign-tab{height:24px;padding:0 10px;border:none;background:transparent;font-size:var(--fs-12, 12px);color:var(--ink-500);cursor:pointer;border-radius:6px;transition:background .12s ease,color .12s ease;font-family:var(--font-sans, inherit)}.course-assign-tab:hover{color:var(--ink-900)}.course-assign-tab.active{background:var(--surface-2);color:var(--ink-900);font-weight:600}.course-assignments-edits{display:inline-flex;align-items:center;gap:8px}.course-edits-badge{display:inline-flex;align-items:center;gap:4px;height:20px;padding:0 8px;border-radius:var(--r-pill, 999px);background:var(--accent-soft);color:var(--accent-ink);font-size:11px;font-weight:500}.course-reset-btn{height:24px;padding:0 10px;border:1px solid var(--border);background:var(--surface);border-radius:6px;font-size:var(--fs-12, 12px);color:var(--ink-700);cursor:pointer;transition:background .12s ease,border-color .12s ease;font-family:var(--font-sans, inherit)}.course-reset-btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.course-assignments-table{width:100%;border-collapse:collapse;font-size:var(--fs-13, 13px)}.course-assignments-table thead th{text-align:left;font-size:10px;font-weight:600;letter-spacing:.06em;color:var(--ink-400);padding:10px 22px;border-bottom:1px solid var(--border-soft);background:transparent}.course-assignments-table .ca-col-status,.course-assignments-table .ca-col-score,.course-assignments-table .ca-col-pct,.course-assignments-table .ca-col-actions{width:1%;white-space:nowrap}.course-assignments-table .ca-col-actions{width:60px}.course-assignments-table tbody td{padding:12px 22px;border-bottom:1px solid var(--border-soft);vertical-align:middle}.course-assignments-table tbody tr:last-child td{border-bottom:none}.course-assignments-table tbody tr:hover{background:var(--surface-2)}.course-assignments-empty{text-align:center;color:var(--ink-500);padding:32px 16px!important}.course-assign-title-row{display:flex;align-items:center;gap:8px}.course-assign-title{font-size:var(--fs-14, 14px);font-weight:500;color:var(--ink-900);cursor:pointer;transition:color .12s ease}.course-assign-title:hover{color:var(--accent)}.course-edited-pill,.course-dropped-pill{display:inline-flex;align-items:center;height:18px;padding:0 7px;border-radius:var(--r-pill, 999px);font-size:10px;font-weight:500;letter-spacing:-.005em}.course-edited-pill{background:var(--accent-soft);color:var(--accent-ink)}.course-dropped-pill{background:var(--surface-2);color:var(--ink-500)}.course-assign-sub{font-size:11px;color:var(--ink-500);margin-top:3px;display:flex;align-items:center;gap:6px}.course-due-remaining{font-weight:500}.course-due-red{color:var(--accent)}.course-due-yellow{color:var(--warn)}.course-status-open{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-13, 13px);color:var(--warn);font-weight:500}.course-status-graded{font-size:var(--fs-13, 13px);color:var(--ink-700)}.course-status-excused{font-size:var(--fs-13, 13px);color:var(--ink-400);font-style:italic}.ca-col-score{font-variant-numeric:tabular-nums;color:var(--ink-900)}.course-row-dropped td{opacity:.55}.course-row-revert,.course-row-more{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--ink-400);border-radius:5px;cursor:pointer;transition:background .12s ease,color .12s ease}.course-row-revert:hover,.course-row-more:hover{background:var(--surface-2);color:var(--ink-700)}.course-row-dropped .course-assign-title{text-decoration:line-through}.course-score-open{color:var(--ink-400)}.course-side-tabs{display:flex;align-items:center;gap:2px;padding:12px 14px 0;border-bottom:1px solid var(--border-soft)}.course-side-tab{height:30px;padding:0 12px;border:none;background:transparent;font-size:var(--fs-13, 13px);color:var(--ink-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s ease,border-color .12s ease;font-family:var(--font-sans, inherit)}.course-side-tab:hover{color:var(--ink-900)}.course-side-tab.active{color:var(--ink-900);font-weight:600;border-bottom-color:var(--ink-900)}.course-side-tab-icon{margin-left:auto;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--ink-400);border-radius:5px;cursor:pointer}.course-side-tab-icon:disabled{cursor:not-allowed;opacity:.55}.course-side-pane{flex:1;overflow-y:auto;padding:16px 18px;min-height:280px}.course-notes-pane.file-drag-over{background:var(--surface-2)}.course-syllabus-pane .course-card-label{display:flex;align-items:center;justify-content:space-between;font-size:9.5px;letter-spacing:.06em;color:var(--ink-400);font-weight:600;margin-bottom:12px}.course-syllabus-html{margin-top:18px;padding-top:16px;border-top:1px solid var(--border-soft);font-size:var(--fs-13, 13px);color:var(--ink-700);line-height:1.55}.course-syllabus-html img{max-width:100%;height:auto}.course-links-loading,.course-links-empty{display:flex;align-items:center;gap:6px;padding:24px 16px;text-align:center;font-size:var(--fs-13, 13px);color:var(--ink-500);justify-content:center}.course-links-list{display:flex;flex-direction:column;gap:4px}.course-link-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border-soft);border-radius:var(--r-8, 8px);background:var(--surface);color:var(--ink-900);text-decoration:none;font-size:var(--fs-13, 13px);transition:background .12s ease,border-color .12s ease}.course-link-item:hover{background:var(--surface-2);border-color:var(--border-strong)}.course-link-icon{color:var(--ink-400);flex-shrink:0}.course-link-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-link-source{font-size:10px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;white-space:nowrap}.course-link-arrow{color:var(--ink-300);flex-shrink:0}.course-refined-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.course-refined-head .course-card-label{margin:0}.course-refine-btn{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border:1px solid var(--border);background:var(--surface);color:var(--ink-700);font-size:var(--fs-12, 12px);font-weight:500;border-radius:6px;cursor:pointer;font-family:var(--font-sans, inherit);transition:background .12s ease,border-color .12s ease}.course-refine-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-strong)}.course-refine-btn:disabled{opacity:.6;cursor:not-allowed}.course-refined-pending,.course-refined-error,.course-refined-empty{font-size:var(--fs-12, 12px);color:var(--ink-500);padding:10px 12px;border:1px dashed var(--border-soft);border-radius:var(--r-8, 8px);background:var(--surface-2);margin-bottom:12px}.course-refined-error{color:var(--accent-ink, #9B2C2C);background:var(--accent-softer, #FFF5F5);border-color:var(--accent-soft, #FEB2B2)}.refined-syllabus{display:flex;flex-direction:column;gap:16px;margin-bottom:8px}.refined-meta{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:var(--surface-2);border-radius:var(--r-8, 8px)}.refined-meta-row{display:flex;gap:10px;font-size:var(--fs-12, 12px);color:var(--ink-700)}.refined-meta-label{width:70px;flex-shrink:0;color:var(--ink-500);font-weight:500}.refined-section-title{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);margin-bottom:6px}.refined-weights{display:flex;flex-direction:column;gap:4px}.refined-weight-row{display:grid;grid-template-columns:1fr 80px 50px;align-items:center;gap:8px;font-size:var(--fs-12, 12px)}.refined-weight-name{color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.refined-weight-bar{height:6px;border-radius:var(--r-pill, 999px);background:var(--surface-2);overflow:hidden}.refined-weight-fill{display:block;height:100%;background:var(--accent-soft)}.refined-weight-pct{text-align:right;color:var(--ink-700)}.refined-rules{list-style:disc inside;margin:0;padding:0;font-size:var(--fs-12, 12px);color:var(--ink-700);line-height:1.5}.refined-calendar{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto}.refined-cal-row{display:grid;grid-template-columns:90px 1fr auto;gap:8px;align-items:baseline;padding:5px 0;border-bottom:1px solid var(--border-soft);font-size:var(--fs-12, 12px)}.refined-cal-row:last-child{border-bottom:none}.refined-cal-date{color:var(--ink-500);font-size:11px}.refined-cal-title{color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.refined-cal-type{font-size:10px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.04em}.notes-pane-shell{display:flex;flex-direction:column;gap:12px}.notes-picker-row{display:flex;align-items:center;gap:6px}.notes-picker{flex:1;height:28px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--ink-900);font-family:var(--font-sans, inherit);font-size:var(--fs-13, 13px);padding:0 8px;outline:none;cursor:pointer;appearance:auto;letter-spacing:var(--tracking-tight, -.018em)}.notes-picker:disabled{opacity:.6;cursor:not-allowed;color:var(--ink-500)}.notes-picker-action{display:inline-flex;align-items:center;gap:4px;height:28px;padding:0 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--ink-900);font-size:var(--fs-12, 12px);font-weight:500;cursor:pointer;font-family:var(--font-sans, inherit);transition:background .12s ease,border-color .12s ease}.notes-picker-action:hover{background:var(--surface-2);border-color:var(--border-strong)}.notes-active-card{display:flex;flex-direction:column;border:1px solid var(--border-soft);border-radius:var(--r-10, 10px);background:var(--surface);overflow:hidden}.notes-active-header{display:flex;align-items:center;gap:6px;padding:12px 14px 4px}.notes-active-title{flex:1;border:none;background:transparent;font-size:17px;font-weight:600;color:var(--ink-900);outline:none;padding:4px 6px;border-radius:4px;font-family:var(--font-sans, inherit);letter-spacing:-.02em;min-width:0}.notes-active-title:hover,.notes-active-title:focus{background:var(--surface-2)}.notes-active-mode-btn{display:inline-flex;align-items:center;height:24px;padding:0 8px;border:1px solid var(--border);background:var(--surface);color:var(--ink-700);font-size:11px;font-weight:500;border-radius:5px;cursor:pointer;font-family:var(--font-sans, inherit)}.notes-active-mode-btn:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--ink-900)}.notes-active-delete{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-400);border-radius:5px;cursor:pointer}.notes-active-delete:hover{background:var(--accent-softer, #FFF5F5);color:var(--accent)}.notes-active-meta{font-size:11px;color:var(--ink-400);padding:0 14px 8px;min-height:14px}.notes-active-editor{width:100%;border:none;border-top:1px solid var(--border-soft);background:var(--surface);outline:none;resize:vertical;padding:12px 14px;font-family:var(--font-mono, ui-monospace);font-size:12.5px;color:var(--ink-900);line-height:1.55;min-height:220px;box-sizing:border-box}.notes-active-editor::placeholder{color:var(--ink-400);font-style:italic}.notes-active-preview{border-top:1px solid var(--border-soft);padding:14px 18px 18px;font-size:var(--fs-13, 13px);color:var(--ink-700);line-height:1.6;min-height:220px;cursor:text}.notes-active-preview h1,.notes-active-preview h2,.notes-active-preview h3{color:var(--ink-900);margin:14px 0 6px;letter-spacing:var(--tracking-tight, -.018em)}.notes-active-preview h1{font-size:16px;font-weight:600}.notes-active-preview h2{font-size:15px;font-weight:600}.notes-active-preview h3{font-size:14px;font-weight:600}.notes-active-preview p{margin:8px 0}.notes-active-preview ul,.notes-active-preview ol{padding-left:22px;margin:6px 0;display:flex;flex-direction:column;gap:3px}.notes-active-preview li{line-height:1.55}.notes-active-preview strong{color:var(--ink-900);font-weight:600}.notes-active-preview em{font-style:italic}.notes-active-preview code{background:var(--surface-2);padding:1px 5px;border-radius:4px;font-family:var(--font-mono, ui-monospace);font-size:12px}.notes-active-preview pre{background:var(--surface-2);padding:10px 12px;border-radius:var(--r-8, 8px);overflow-x:auto;font-family:var(--font-mono, ui-monospace);font-size:12px;line-height:1.5;margin:8px 0}.notes-active-preview pre code{background:transparent;padding:0}.notes-active-preview a{color:var(--accent-ink);text-decoration:underline}.notes-active-preview blockquote{border-left:3px solid var(--border-strong);padding:4px 12px;color:var(--ink-500);margin:8px 0}.notes-active-preview hr{border:none;border-top:1px solid var(--border-soft);margin:14px 0}.notes-active-toolbar{display:flex;align-items:center;gap:4px;border-top:1px solid var(--border-soft);padding:6px 10px;background:var(--surface);color:var(--ink-400)}.notes-active-toolbar button{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-500);border-radius:5px;cursor:pointer;font-family:serif;font-size:13px;padding:0}.notes-active-toolbar button:hover{background:var(--surface-2);color:var(--ink-900)}.notes-toolbar-sep{width:1px;height:14px;background:var(--border);margin:0 4px}.notes-toolbar-spacer{flex:1}.notes-toolbar-hint{font-size:10.5px;color:var(--ink-400);padding-right:4px}.notes-active-empty{padding:24px 16px;text-align:center;color:var(--ink-500);font-size:var(--fs-13, 13px);border:1px dashed var(--border);border-radius:var(--r-8, 8px)}.notes-section-label{font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);margin-top:6px;padding:0 2px}.courses-list-page{flex:1;overflow-y:auto;background:var(--canvas);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:22px 28px 18px;background:var(--canvas);border-bottom:1px solid var(--border-soft);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.courses-list-header-left{display:flex;flex-direction:column;gap:4px}.courses-list-title{font-size:var(--fs-24, 24px);font-weight:600;color:var(--ink-900);letter-spacing:var(--tracking-tighter, -.025em);line-height:var(--lh-tight, 1.15);margin:0}.courses-list-subtitle{font-size:var(--fs-13, 13px);color:var(--ink-500);margin:0}.courses-list-header-right{display:flex;align-items:center;gap:8px}.courses-list-sync-btn,.courses-list-add-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:8px;font-size:var(--fs-13, 13px);font-weight:500;letter-spacing:var(--tracking-tight, -.018em);cursor:pointer;transition:background .15s ease,border-color .15s ease;white-space:nowrap;background:var(--surface);border:1px solid var(--border);color:var(--ink-900);font-family:var(--font-sans, inherit)}.courses-list-sync-btn:hover:not(:disabled),.courses-list-add-btn:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-strong)}.courses-list-sync-btn:disabled,.courses-list-add-btn:disabled{opacity:.55;cursor:not-allowed}.courses-list-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;padding:22px 28px 60px}@media(max-width:1100px){.courses-list-grid{grid-template-columns:1fr}}.course-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-12, 12px);padding:18px;display:flex;flex-direction:column;gap:14px;cursor:pointer;transition:box-shadow .15s ease,transform .15s ease,border-color .15s ease;position:relative}.course-card:hover{border-color:var(--border-strong);box-shadow:0 4px 16px #0000000f;transform:translateY(-1px)}.course-card-top{display:flex;align-items:center;gap:12px}.course-avatar{width:40px;height:40px;border-radius:var(--r-10, 10px);color:#fff;display:grid;place-items:center;font-family:var(--font-mono, ui-monospace);font-size:12px;font-weight:600;letter-spacing:.02em;flex-shrink:0}.course-card-id{flex:1;min-width:0}.course-card-name{font-size:var(--fs-15, 15px);font-weight:600;letter-spacing:var(--tracking-tight, -.018em);color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-card-meta{font-size:11px;color:var(--ink-500);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-card-grade{text-align:right;flex-shrink:0}.course-card-grade-num{font-size:17px;font-weight:600;letter-spacing:-.02em;color:var(--ink-900)}.course-card-grade-letter{font-size:11px;color:var(--ink-500);margin-top:1px}.course-card-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .15s ease}.course-card:hover .course-card-actions{opacity:1}.course-card-icon-btn{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:5px;background:transparent;color:var(--ink-400);cursor:pointer;transition:background .12s ease,color .12s ease}.course-card-icon-btn:hover{background:var(--surface-2);color:var(--ink-700)}.course-card-icon-btn-danger:hover{background:var(--accent-softer, #FFF5F5);color:var(--accent, #C53030)}.course-card-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;padding-top:10px;border-top:1px solid var(--border-soft)}.course-card-stat .label-cap,.label-cap{font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);margin-bottom:4px}.course-card-stat-val{font-size:var(--fs-13, 13px);font-weight:500;color:var(--ink-900)}.course-card-stat-next{font-size:11.5px;color:var(--ink-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.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}.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-semester-card{padding:20px}.semester-calendar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:28px 32px;margin-top:6px}.semester-month{min-width:0}.semester-month-title{font-size:var(--fs-13);font-weight:600;color:var(--ink-900);letter-spacing:var(--tracking-tight, -.01em);margin-bottom:8px}.semester-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px 5px}.semester-weekday{font-size:10px;font-weight:600;color:var(--ink-400);text-align:center;padding:0 0 4px;letter-spacing:.04em}.semester-day{aspect-ratio:1;border-radius:4px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;position:relative;min-height:26px;cursor:default;transition:transform .1s ease,box-shadow .1s ease}.semester-day:hover:not(.empty):not(.outside){transform:scale(1.12);box-shadow:0 2px 8px #0000001f;z-index:2}.semester-day.empty{background:transparent}.semester-day.outside{opacity:.35}.semester-day.today{outline:2px solid var(--accent);outline-offset:-1px}.semester-day-num{font-size:10.5px;font-weight:500;color:var(--ink-700);line-height:1}@media(min-width:1280px){.semester-month-title{font-size:var(--fs-14)}.semester-day{min-height:30px}.semester-day-num{font-size:11.5px}}.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:5px;height:30px;padding:0 12px;font-size:var(--fs-13)}.alltasks-chip-active{background:var(--ink-900)!important;color:var(--surface)!important;border-color:var(--ink-900)!important}.alltasks-chip-count{font-size:11.5px;margin-left:2px;opacity:.6}.alltasks-filters .btn-sm{height:30px;padding:0 12px;font-size:var(--fs-13)}.alltasks-filters .btn-sm svg{width:13px;height:13px}.alltasks-chip-active .alltasks-chip-count{color:var(--surface);opacity:.7}.alltasks-groupby{margin-left:auto;display:flex;align-items:center;gap:8px}.alltasks-groupby-label{font-size:var(--fs-13);color:var(--ink-500)}.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 90px 80px 90px 32px;gap:20px;align-items:center;padding:10px 28px 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}}.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)}*{scrollbar-width:thin;scrollbar-color:transparent transparent}*:hover,*:focus-within{scrollbar-color:oklch(70% .005 60 / .35) transparent}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:transparent;border-radius:8px;border:2px solid transparent;background-clip:padding-box;transition:background-color .15s ease}*:hover::-webkit-scrollbar-thumb,*:focus-within::-webkit-scrollbar-thumb{background-color:#a19e9b66;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background-color:#74716f8c;background-clip:padding-box}*::-webkit-scrollbar-button{display:none;width:0;height:0}*::-webkit-scrollbar-corner{background:transparent}.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)}.planner-page{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--canvas);overflow:hidden}.planner-page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 28px 16px;border-bottom:1px solid var(--border-soft);flex-shrink:0;background:var(--canvas)}.planner-page-header-left h1{margin:0;font-size:var(--fs-24, 24px);font-weight:600;color:var(--ink-900);letter-spacing:var(--tracking-tighter, -.025em);line-height:var(--lh-tight, 1.15)}.planner-page-header-left p{margin:4px 0 0;font-size:var(--fs-13, 13px);color:var(--ink-500)}.planner-page-header-right{display:flex;align-items:center;gap:10px}.planner-body{flex:1;display:flex;min-height:0;background:var(--canvas)}.planner-divider{width:1px;cursor:col-resize;background:var(--border-soft);flex-shrink:0;transition:background var(--dur) var(--ease-out);position:relative}.planner-divider:after{content:"";position:absolute;inset:0 -3px}.planner-divider:hover{background:var(--border-strong)}.planner-page-header .view-toggle{display:inline-flex;background:var(--surface-2);border-radius:8px;padding:2px}.planner-page-header .view-toggle-btn{height:26px;padding:0 12px;border:none;border-radius:6px;background:transparent;color:var(--ink-500);font-size:var(--fs-13, 13px);font-weight:500;font-family:var(--font-sans, inherit);cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease;letter-spacing:var(--tracking-tight, -.018em)}.planner-page-header .view-toggle-btn:hover{color:var(--ink-900)}.planner-page-header .view-toggle-btn.active{background:var(--surface);color:var(--ink-900);box-shadow:0 1px 2px #0000000f,0 0 0 1px #00000005;font-weight:600}.planner-page-header .auto-schedule-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--ink-900);font-size:var(--fs-13, 13px);font-weight:500;font-family:var(--font-sans, inherit);letter-spacing:var(--tracking-tight, -.018em);cursor:pointer;transition:background .15s ease,border-color .15s ease}.planner-page-header .auto-schedule-btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.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}}
