:root,[data-theme=dark]{--bg: #09090b;--bg2: #0d0d10;--panel: #131316;--panel2: #1a1a20;--border: #26262e;--text: #f4f4f5;--muted: #8b8b96;--primary: #2f6bff;--primary2: #38bdf8;--success: #34d399;--danger: #fb7185;--link: #7ab3ff;--accent-soft: linear-gradient(135deg, #2f6bff24, #38bdf818);--accent-border: #2f6bff4d;--accent-text: #9cc4ff;--hover-border: #3a3a46;--card-shadow: 0 20px 60px #00000080;--hero-glow: radial-gradient(1200px 600px at 80% -10%, #12235a66, transparent);--alert-bg: #fb718520;--alert-border: #fb718550;--alert-text: #fda4af;--streak-bg: linear-gradient(135deg, #f9731620, #ef444420);--streak-border: #f9731650;--streak-text: #fdba74;--scheme: dark;--radius: 14px}[data-theme=light]{--bg: #fafafa;--bg2: #ffffff;--panel: #ffffff;--panel2: #f1f2f4;--border: #e4e4e9;--text: #18181b;--muted: #6b7280;--primary: #2563eb;--primary2: #0ea5e9;--success: #10b981;--danger: #e11d48;--link: #1d4ed8;--accent-soft: linear-gradient(135deg, #2563eb14, #0ea5e90f);--accent-border: #2563eb3d;--accent-text: #1e40af;--hover-border: #c9cdd6;--card-shadow: 0 20px 60px #64748b22;--hero-glow: radial-gradient(1200px 600px at 80% -10%, #bfdbfe4d, transparent);--alert-bg: #ffe4e6;--alert-border: #fda4af;--alert-text: #be123c;--streak-bg: linear-gradient(135deg, #ffedd5, #fee2e2);--streak-border: #fdba74;--streak-text: #c2410c;--scheme: light}[data-theme=reading]{--bg: #f6f1e7;--bg2: #fbf7ee;--panel: #fbf7ee;--panel2: #f0e9da;--border: #e0d6c2;--text: #3d3427;--muted: #857a63;--primary: #b45309;--primary2: #d97706;--success: #4d7c0f;--danger: #b91c1c;--link: #92400e;--accent-soft: linear-gradient(135deg, #b4530918, #d9770612);--accent-border: #b4530940;--accent-text: #92400e;--hover-border: #cbbc9e;--card-shadow: 0 20px 60px #857a6326;--hero-glow: radial-gradient(1200px 600px at 80% -10%, #fde68a44, transparent);--alert-bg: #fee2e2;--alert-border: #fca5a5;--alert-text: #991b1b;--streak-bg: linear-gradient(135deg, #fef3c7, #fde68a80);--streak-border: #fbbf24;--streak-text: #92400e;--scheme: light}*{box-sizing:border-box;margin:0;padding:0}html{color-scheme:var(--scheme)}body{font-family:Inter,system-ui,sans-serif;background:var(--hero-glow),var(--bg);color:var(--text);min-height:100vh;transition:background .3s ease,color .3s ease}[data-theme=reading] body{font-family:Iowan Old Style,Palatino Linotype,Palatino,Georgia,serif}a{color:var(--link);text-decoration:none}a:hover{text-decoration:underline}.muted{color:var(--muted)}.center{text-align:center}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg);display:grid;place-items:center;opacity:1;transition:opacity .5s ease}.splash.leaving{opacity:0;pointer-events:none}.splash-inner{display:flex;flex-direction:column;align-items:center;gap:14px}.splash-logo path{stroke-dasharray:100;stroke-dashoffset:100;animation:ess-draw .7s ease-out forwards}.splash-logo path:nth-of-type(1){animation-delay:.1s}.splash-logo path:nth-of-type(2){animation-delay:.45s}.splash-logo path:nth-of-type(3){animation-delay:.65s}.splash-logo{animation:ess-pop .5s ease 1.05s both;filter:drop-shadow(0 8px 30px color-mix(in srgb,var(--primary) 45%,transparent))}@keyframes ess-draw{to{stroke-dashoffset:0}}@keyframes ess-pop{0%{transform:scale(1)}50%{transform:scale(1.12)}to{transform:scale(1)}}.splash-name{font-size:26px;font-weight:800;letter-spacing:-.6px;opacity:0;animation:ess-fade .5s ease .8s forwards}.splash-name .grad{background:linear-gradient(90deg,var(--primary),var(--primary2));-webkit-background-clip:text;background-clip:text;color:transparent}.splash-tag{font-size:13px;color:var(--muted);opacity:0;animation:ess-fade .5s ease 1.05s forwards}@keyframes ess-fade{to{opacity:1}}.theme-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:var(--panel2);border:1px solid var(--border);border-radius:999px;padding:8px 14px;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--text);transition:border-color .2s,box-shadow .2s,transform .1s}.theme-btn:hover{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-border)}.theme-btn:active{transform:scale(.94)}.theme-btn.compact{padding:9px}.theme-btn-icon{display:grid;place-items:center;color:var(--accent-text);animation:theme-pop .25s ease}@keyframes theme-pop{0%{transform:rotate(-90deg) scale(.4);opacity:0}to{transform:rotate(0) scale(1);opacity:1}}.landing{min-height:100vh;display:flex;flex-direction:column}.wb-strip{display:flex;align-items:center;gap:16px;padding:12px 6vw;background:var(--accent-soft);border-bottom:1px solid var(--accent-border)}.wb-ring{--pct: 0;width:44px;height:44px;border-radius:50%;flex-shrink:0;background:conic-gradient(var(--primary) calc(var(--pct) * 1%),var(--panel2) 0);display:grid;place-items:center}.wb-ring span{width:33px;height:33px;border-radius:50%;background:var(--bg);display:grid;place-items:center;font-size:10.5px;font-weight:800}.wb-text{flex:1;font-size:14px;color:var(--text)}.wb-strip .btn{padding:9px 18px}@media (max-width: 600px){.wb-text{font-size:12.5px}}.landing-nav{display:flex;align-items:center;gap:20px;padding:18px 6vw;position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 80%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.landing-nav .logo{font-size:19px;font-weight:800;letter-spacing:-.5px}.landing-nav .brand-mark{width:34px;height:34px;font-size:17px;border-radius:10px}.landing-nav .brand-name{font-size:17px}.auth-card .brand{margin-bottom:4px}.landing-nav .nav-spacer{flex:1}.landing-nav .nav-links{display:flex;gap:22px;font-size:14px;font-weight:500}.landing-nav .nav-links a{color:var(--muted)}.landing-nav .nav-links a:hover{color:var(--text);text-decoration:none}.hero{position:relative;padding:96px 6vw 84px;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;max-width:1220px;margin:0 auto;width:100%}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:26px 26px;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 30%,transparent 75%);opacity:.55;pointer-events:none}.hero>*{position:relative}.hero-badge{display:inline-flex;align-items:center;gap:9px;background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent-text);font-size:13px;font-weight:600;padding:7px 16px;border-radius:999px;margin-bottom:24px}.hero-badge:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--primary2);box-shadow:0 0 0 0 var(--primary2);animation:badge-pulse 2s ease-out infinite}@keyframes badge-pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--primary2) 55%,transparent)}70%{box-shadow:0 0 0 8px transparent}to{box-shadow:0 0 0 0 transparent}}.hero h1{font-size:clamp(30px,3.6vw,46px);line-height:1.12;letter-spacing:-1.2px;font-weight:800;margin-bottom:16px;max-width:15ch}.hero h1 .grad{background:linear-gradient(90deg,var(--primary),var(--primary2));-webkit-background-clip:text;background-clip:text;color:transparent}.hero-sub{font-size:17px;line-height:1.65;color:var(--muted);max-width:520px;margin-bottom:30px}.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.btn-lg{padding:14px 26px;font-size:15px;border-radius:12px}.hero-note{font-size:13px;color:var(--muted);margin-top:14px}.hero-stats{display:flex;gap:34px;margin-top:38px;flex-wrap:wrap}.hero-stat .hs-num{font-size:26px;font-weight:800;letter-spacing:-1px}.hero-stat .hs-label{font-size:13px;color:var(--muted);margin-top:2px}.hero-visual{position:relative}.hero-visual:before{content:"";position:absolute;top:-8%;right:-6%;bottom:-8%;left:-6%;background:radial-gradient(ellipse at center,color-mix(in srgb,var(--primary) 22%,transparent),transparent 68%);filter:blur(10px);pointer-events:none}.mock-card{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:22px;box-shadow:var(--card-shadow);transform:rotate(-1.2deg);transition:transform .35s ease}.hero-visual:hover .mock-card{transform:rotate(0) translateY(-4px)}.mock-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.mock-title{font-weight:700;font-size:15px}.mock-streak{background:var(--streak-bg);border:1px solid var(--streak-border);color:var(--streak-text);font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px}.mock-task{display:flex;gap:12px;align-items:center;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:10px}.mock-check{width:20px;height:20px;border-radius:6px;flex-shrink:0;border:2px solid var(--border);display:grid;place-items:center;font-size:11px;color:#fff}.mock-task.done .mock-check{background:linear-gradient(135deg,var(--primary),var(--primary2));border-color:transparent}.mock-task.done .mock-text{text-decoration:line-through;opacity:.55}.mock-text{font-size:13.5px;font-weight:500}.mock-slot{margin-left:auto;font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;white-space:nowrap}.mock-progress{margin-top:14px}.float-chip{position:absolute;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:10px 16px;font-size:13px;font-weight:700;box-shadow:var(--card-shadow);display:flex;gap:8px;align-items:center}.float-chip{z-index:3}.float-chip.chip-a{top:-14px;right:8px;animation:floaty 5s ease-in-out infinite}.float-chip.chip-b{bottom:-12px;left:4px;animation:floaty 6s ease-in-out .8s infinite}.hero-visual{padding:18px 0}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.stack-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--panel) 55%,transparent);padding:30px 6vw;text-align:center}.stack-strip-label{font-size:12px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-bottom:20px}.stack-logos{display:flex;gap:34px;justify-content:center;align-items:center;flex-wrap:wrap;max-width:1100px;margin:0 auto}.stack-logo{display:flex;flex-direction:column;align-items:center;gap:7px;opacity:.75;filter:grayscale(35%);transition:opacity .2s,filter .2s,transform .2s}.stack-logo:hover{opacity:1;filter:none;transform:translateY(-3px)}.stack-logo img{width:34px;height:34px;object-fit:contain}.stack-logo span{font-size:11px;font-weight:600;color:var(--muted)}.goal-chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;max-width:900px;margin:0 auto}.goal-chip{background:var(--panel);border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:600;padding:9px 16px;border-radius:999px;transition:all .2s}.goal-chip:hover{color:var(--accent-text);border-color:var(--accent-border);background:var(--accent-soft);transform:translateY(-2px)}.section{padding:70px 6vw;max-width:1200px;margin:0 auto;width:100%}.section-head{text-align:center;max-width:640px;margin:0 auto 44px}.section-head h2{font-size:clamp(26px,3vw,36px);letter-spacing:-1px;margin-bottom:12px}.section-head p{color:var(--muted);font-size:16px;line-height:1.6}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}@media (max-width: 1100px){.feature-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.feature-grid{grid-template-columns:1fr}}.feature-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:26px;transition:transform .2s,border-color .2s}.feature-card:hover{transform:translateY(-3px);border-color:var(--accent-border)}.feature-icon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent-text);font-size:21px;margin-bottom:16px}.feature-card h3{font-size:16.5px;margin-bottom:8px;letter-spacing:-.3px}.feature-card p{font-size:14px;line-height:1.6;color:var(--muted)}.timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.tl-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:22px;position:relative;overflow:hidden}.tl-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--primary),var(--primary2))}.tl-time{font-size:13px;font-weight:700;color:var(--accent-text);margin-bottom:6px}.tl-name{font-weight:700;margin-bottom:6px}.tl-desc{font-size:13.5px;color:var(--muted);line-height:1.55}.road-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.road-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;gap:14px;align-items:flex-start}.road-num{width:38px;height:38px;border-radius:11px;flex-shrink:0;background:var(--accent-soft);border:1px solid var(--accent-border);display:grid;place-items:center;font-weight:800;color:var(--accent-text);font-size:14px}.road-card h4{font-size:14.5px;margin-bottom:4px}.road-card p{font-size:12.5px;color:var(--muted);line-height:1.5}.cta-band{text-align:center;background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:24px;padding:60px 30px}.cta-band h2{font-size:clamp(24px,3vw,34px);letter-spacing:-1px;margin-bottom:12px}.cta-band p{color:var(--muted);margin-bottom:26px;font-size:16px}.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}@media (max-width: 900px){.how-grid{grid-template-columns:1fr}}.step-card{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:30px 26px 26px;overflow:hidden}.step-num{font-size:44px;font-weight:800;letter-spacing:-2px;line-height:1;background:linear-gradient(135deg,var(--primary),var(--primary2));-webkit-background-clip:text;background-clip:text;color:transparent;opacity:.9;margin-bottom:14px}.step-card h3{font-size:17px;letter-spacing:-.3px;margin-bottom:8px}.step-card p{font-size:14px;line-height:1.65;color:var(--muted)}.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.faq-item{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:0 20px}.faq-q{all:unset;box-sizing:border-box;width:100%;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:17px 0;font-weight:600;font-size:15px;color:var(--text);font-family:inherit;line-height:1.45}.faq-q:focus-visible{outline:2px solid var(--primary);outline-offset:4px;border-radius:8px}.faq-caret{color:var(--accent-text);font-weight:700;flex-shrink:0}.faq-a{overflow:hidden}.faq-item p{padding:0 0 18px;margin:0;font-size:14px;line-height:1.7;color:var(--muted)}.faq-item{transition:border-color .25s ease}.faq-item:hover{border-color:color-mix(in srgb,var(--accent-border) 60%,var(--border))}.faq-item.open{border-color:var(--accent-border)}.landing-footer{border-top:1px solid var(--border);padding:26px 6vw;display:flex;align-items:center;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:13.5px}.landing-footer .nav-spacer{flex:1}.footer-brand{display:flex;flex-direction:column;gap:3px}.footer-sub{font-size:12px;color:var(--muted)}.footer-links{display:flex;gap:18px;font-size:13px;font-weight:500}.footer-links a{color:var(--muted)}.footer-links a:hover{color:var(--text);text-decoration:none}.onboard-card{max-width:520px}.dropzone{border:2px dashed var(--border);border-radius:16px;padding:26px 18px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--bg2);margin:8px 0 4px}.dropzone:hover{border-color:var(--primary)}.dropzone.has-file{border-style:solid;border-color:var(--accent-border)}.drop-icon{font-size:34px;margin-bottom:8px}.drop-caption{font-size:12.5px;color:var(--muted);margin-top:6px}.resume-preview{max-height:180px;max-width:100%;border-radius:10px;border:1px solid var(--border);object-fit:contain}.pdf-chip{display:flex;align-items:center;gap:12px;text-align:left;padding:4px 2px}.pdf-icon{flex-shrink:0;width:44px;height:52px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:8px;color:#fff;display:grid;place-items:center;font-size:11px;font-weight:800;letter-spacing:.5px;box-shadow:0 4px 12px #ef444440}.pdf-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.pdf-info b{font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pdf-info small{font-size:12px;color:var(--muted)}.pdf-check{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--success);color:#fff;font-weight:800;font-size:13px;display:grid;place-items:center}.weeks-range{width:100%;accent-color:var(--primary);margin-top:4px}.range-marks{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-bottom:4px}.alert.notice{background:var(--accent-soft);border-color:var(--accent-border);color:var(--accent-text)}.chip-row{display:flex;gap:8px;flex-wrap:wrap;margin:4px 0 6px}.pick-chip{background:var(--bg2);border:1px solid var(--border);color:var(--muted);font-family:inherit;font-size:12.5px;font-weight:600;padding:8px 13px;border-radius:999px;cursor:pointer;transition:all .15s}.pick-chip:hover{border-color:var(--accent-border);color:var(--text)}.pick-chip.on{background:linear-gradient(135deg,var(--primary),var(--primary2));border-color:transparent;color:#fff;box-shadow:0 4px 14px color-mix(in srgb,var(--primary) 40%,transparent)}.pick-chip.day{min-width:48px;text-align:center}.pick-chip:disabled{cursor:not-allowed;opacity:.4}.pick-chip:disabled:hover{border-color:var(--border);color:var(--muted)}.chips-disabled{opacity:.55}.week-editor{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:14px;margin:4px 0;display:flex;flex-direction:column;gap:9px}.we-head{display:flex;align-items:center;gap:9px}.we-grip{cursor:grab;color:var(--muted);font-size:15px;-webkit-user-select:none;user-select:none}.we-grip:active{cursor:grabbing}.week-editor.dragging{opacity:.45;border-style:dashed}.we-num{font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--accent-text)}.we-row{display:flex;gap:9px}.we-row input{flex:1;min-width:0}.we-row .we-cat{max-width:190px}.week-editor input,.week-editor textarea{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text);font-family:inherit;font-size:13.5px;resize:vertical}.week-editor input:focus,.week-editor textarea:focus{outline:none;border-color:var(--primary)}.q-block{margin:6px 0 10px}.q-text{display:flex;align-items:baseline;gap:9px;font-size:14.5px;font-weight:600;margin-bottom:9px;line-height:1.45}.q-num{flex-shrink:0;width:22px;height:22px;border-radius:7px;background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent-text);display:inline-grid;place-items:center;font-size:11.5px;font-weight:800}.q-multi{margin-left:6px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-border);padding:2px 8px;border-radius:999px}.sched-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:4px 0 6px}.sched-grid .field-label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px}.sched-grid input,.sched-grid select{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text);font-family:inherit;font-size:14px;color-scheme:var(--scheme)}.sched-grid input:focus,.sched-grid select:focus{outline:none;border-color:var(--primary)}.slot-preview{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin:6px 0 4px;display:flex;flex-direction:column;gap:7px}.slot-preview-title{font-size:12px;font-weight:700;color:var(--accent-text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.slot-line{display:flex;justify-content:space-between;align-items:center;font-size:13px}.slot-line b{font-weight:700;font-variant-numeric:tabular-nums}.slot-line.dim{color:var(--muted)}.slot-line.dim b{color:var(--muted);font-weight:600}.cat-section{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.cat-head{display:flex;align-items:center;gap:9px;margin-top:6px}.cat-ico{width:18px;height:18px;object-fit:contain}.cat-emoji{font-size:15px;line-height:1}.cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cat-title{font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.6px}.cat-count{font-size:12px;color:var(--muted);font-weight:600;margin-left:auto}.app-shell{display:flex;min-height:100vh}.sidebar{width:256px;flex-shrink:0;background:linear-gradient(180deg,var(--bg2),color-mix(in srgb,var(--bg2) 85%,var(--panel2)));border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh}.sidebar-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.notif{position:relative}.notif-btn{position:relative;width:38px;height:38px;border-radius:11px;cursor:pointer;background:var(--panel2);border:1px solid var(--border);font-size:16px;display:grid;place-items:center;transition:border-color .15s,background .15s}.notif-btn:hover{border-color:var(--accent-border)}.notif-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:#ef4444;color:#fff;font-size:10.5px;font-weight:800;display:grid;place-items:center;border:2px solid var(--bg2)}.notif-panel{position:absolute;top:calc(100% + 10px);z-index:60;width:312px;max-width:88vw;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 60px -14px #000a,0 2px 8px #00000040;overflow:visible;animation:notif-pop .16s ease}@keyframes notif-pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.notif-panel:before{content:"";position:absolute;top:-6px;width:12px;height:12px;background:var(--panel);border-left:1px solid var(--border);border-top:1px solid var(--border);transform:rotate(45deg)}.notif-panel.to-left{right:0;left:auto}.notif-panel.to-left:before{right:14px}.notif-panel.to-right{left:0;right:auto}.notif-panel.to-right:before{left:14px}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;font-weight:800;font-size:14px}.notif-clear{background:none;border:none;color:var(--accent-text);font-weight:700;font-size:12px;cursor:pointer}.notif-enable{display:flex;align-items:center;gap:8px;width:calc(100% - 24px);margin:0 12px 10px;padding:9px 12px;cursor:pointer;border-radius:10px;font-weight:700;font-size:12.5px;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-border);transition:background .15s}.notif-enable:hover{background:color-mix(in srgb,var(--primary) 18%,transparent)}.notif-perm-on{padding:0 15px 10px;font-size:11.5px;color:var(--muted);font-weight:600}.notif-list{max-height:320px;overflow-y:auto;padding:4px 6px 8px;border-top:1px solid var(--border)}.notif-empty{padding:26px 16px;text-align:center;color:var(--muted);font-size:13px}.notif-item{display:flex;gap:11px;align-items:flex-start;padding:11px 12px;border-radius:12px;transition:background .15s}.notif-item:hover{background:var(--panel2)}.notif-ico{font-size:18px;line-height:1.2;flex-shrink:0}.notif-body{flex:1;min-width:0}.notif-title{font-weight:700;font-size:13.5px}.notif-text{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.4}.notif-time{font-size:10.5px;color:var(--accent-text);font-weight:700;white-space:nowrap;flex-shrink:0}.topbar{display:none}.hamburger{display:inline-flex;flex-direction:column;justify-content:center;gap:4px;width:40px;height:40px;padding:9px;border-radius:11px;cursor:pointer;background:var(--panel2);border:1px solid var(--border)}.hamburger span{display:block;height:2px;border-radius:2px;background:var(--text);transition:.2s}.topbar-brand{display:flex;align-items:center;gap:9px}.topbar-brand .brand-name{font-size:15px;font-weight:800;letter-spacing:-.3px}.brand-mark.sm{width:32px;height:32px;border-radius:10px;font-size:15px}.sidebar-close{display:none}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade-in .18s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.brand{display:flex;align-items:center;gap:11px;padding:2px 4px}.brand-mark{width:40px;height:40px;border-radius:12px;flex-shrink:0;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;color:#fff;font-weight:800;font-size:20px;box-shadow:0 6px 18px color-mix(in srgb,var(--primary) 45%,transparent)}.brand-mark svg{display:block}.brand-name{font-size:16.5px;font-weight:800;letter-spacing:-.4px;line-height:1.15}.brand-name .grad{background:linear-gradient(90deg,var(--primary),var(--primary2));-webkit-background-clip:text;background-clip:text;color:transparent}.brand-sub{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.4px}.logo{font-size:20px;font-weight:800;letter-spacing:-.5px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:11px;color:var(--muted);font-weight:500;font-size:14.5px;border:1px solid transparent;transition:all .15s}.nav-ico{font-size:15px;width:20px;text-align:center}.sidebar nav a:hover{background:var(--panel2);color:var(--text);text-decoration:none}.sidebar nav a.active{background:var(--accent-soft);color:var(--accent-text);border:1px solid var(--accent-border);font-weight:600;box-shadow:0 4px 14px color-mix(in srgb,var(--primary) 18%,transparent)}.plan-select{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:11px;color:var(--text);font-family:inherit;font-size:13px;font-weight:600;padding:10px 12px;cursor:pointer}.plan-select:focus{outline:none;border-color:var(--primary)}.plan-badge{display:flex;align-items:center;gap:10px;background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:14px;padding:11px 13px;transition:box-shadow .2s,transform .15s}.plan-badge:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 18px color-mix(in srgb,var(--primary) 25%,transparent)}.plan-badge-spark{font-size:17px}.plan-badge-info{flex:1;display:flex;flex-direction:column;gap:1px}.plan-badge-info b{font-size:12.5px;color:var(--accent-text);font-weight:700}.plan-badge-info small{font-size:11px;color:var(--muted)}.plan-badge-edit{font-size:11px;font-weight:700;color:var(--accent-text);border:1px solid var(--accent-border);border-radius:999px;padding:3px 9px}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:12px}.footer-row{display:flex;align-items:center;gap:10px;justify-content:space-between}.user-chip{display:flex;gap:10px;align-items:center;min-width:0;padding:6px;margin:-6px;border-radius:12px;transition:background .15s}.user-chip:hover{background:var(--panel2);text-decoration:none}.avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;overflow:hidden;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;font-weight:700;color:#fff}.avatar-img{width:100%;height:100%;object-fit:cover;display:block}.user-name{font-weight:600;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.user-email{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.profile-hero{display:flex;gap:22px;align-items:center;flex-wrap:wrap}.profile-avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:12px}.profile-avatar{width:108px;height:108px;border-radius:50%;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;color:#fff;box-shadow:0 10px 28px -8px color-mix(in srgb,var(--primary) 55%,transparent);border:3px solid var(--panel)}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-initials{font-size:40px;font-weight:800;letter-spacing:1px}.profile-avatar-load{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0008;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.profile-avatar-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.profile-hero-info{flex:1;min-width:200px}.profile-name{font-size:22px;font-weight:800;letter-spacing:-.4px}.profile-email{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--muted);margin:4px 0 6px;font-size:14px}.verify-tag{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:999px;color:var(--success);background:color-mix(in srgb,var(--success) 15%,transparent);border:1px solid color-mix(in srgb,var(--success) 45%,transparent)}.verify-tag.unverified{color:#f59e0b;background:#f59e0b22;border-color:#f59e0b55}.profile-form{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;margin-top:4px}.profile-form .field-label{margin-bottom:8px}.profile-form input{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:13px 15px;color:var(--text);font-family:inherit;font-size:14.5px;font-weight:500;transition:border-color .15s,box-shadow .15s,background .15s;color-scheme:var(--scheme)}.profile-form input:hover:not(:disabled){border-color:var(--accent-border)}.profile-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}.profile-form input:disabled{opacity:.7;cursor:not-allowed;background:var(--panel2);color:var(--muted)}.profile-form>button{grid-column:1 / -1;justify-self:start;margin-top:2px;min-width:160px}.profile-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.task-card,.panel,.stat-card,.week-card{box-shadow:0 1px 2px #00000010}.task-card:hover{box-shadow:0 8px 24px #00000018}.btn-primary{box-shadow:0 4px 14px color-mix(in srgb,var(--primary) 35%,transparent)}button:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.main{flex:1;padding:32px 40px;max-width:1320px;min-width:0}.dash-grid{display:grid;grid-template-columns:292px minmax(0,1fr);gap:24px;align-items:start}.dash-left{position:sticky;top:32px;display:flex;flex-direction:column;gap:16px}.dash-main{min-width:0}.mini-cal{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:16px;box-shadow:0 1px 2px #00000010}.mini-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.mini-cal-title{font-weight:700;font-size:14.5px;letter-spacing:-.2px}.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.mini-cal-grid.dow{margin-bottom:4px}.mini-cal-dow{text-align:center;font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;padding:4px 0}.mini-cal-day{position:relative;aspect-ratio:1;border:1px solid transparent;background:none;border-radius:10px;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}.mini-cal-day:hover{background:var(--panel2)}.mini-cal-day.today{border-color:var(--accent-border);color:var(--accent-text)}.mini-cal-day.sel{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 45%,transparent)}.mini-cal-day.drop-target{border-color:var(--primary);background:var(--accent-soft);transform:scale(1.12)}.drag-hint{font-size:11.5px;color:var(--muted);text-align:center;padding:0 8px}.task-card[draggable=true]{cursor:grab}.task-card[draggable=true]:active{cursor:grabbing}.cal-dot{position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:5px;height:5px;border-radius:50%;background:var(--muted);display:inline-block}.cal-dot.all{background:var(--success)}.cal-dot.part{background:var(--primary)}.cal-dot.none{background:var(--muted);opacity:.6}.mini-cal-day.sel .cal-dot{background:#fff}.mini-cal-legend{display:flex;gap:12px;justify-content:center;margin-top:12px;padding-top:10px;border-top:1px solid var(--border);font-size:11px;color:var(--muted)}.mini-cal-legend span{display:inline-flex;align-items:center;gap:5px}.mini-cal-legend .cal-dot{position:static;transform:none}.verify-banner{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--streak-bg);border:1px solid var(--streak-border);color:var(--streak-text);border-radius:14px;padding:12px 16px;margin-bottom:20px;font-size:13.5px;font-weight:600}.verify-banner .btn{padding:7px 14px;font-size:12.5px}.verify-msg{font-size:12.5px;font-weight:500;opacity:.9}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:22px}.page-header h1{font-size:30px;letter-spacing:-.8px;margin:2px 0 10px}.hello{font-size:13.5px}.header-pills{display:flex;gap:8px;flex-wrap:wrap}.week-pill{display:inline-flex;align-items:center;gap:6px;background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent-text);font-size:12.5px;font-weight:700;padding:6px 13px;border-radius:999px}.week-pill.soft{background:var(--panel);border-color:var(--border);color:var(--muted);font-weight:600}.week-pill.off{background:var(--panel);border-color:var(--border);color:var(--muted)}.header-right{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.streak-badge{background:var(--panel);border:1px solid var(--border);color:var(--muted);padding:9px 16px;border-radius:999px;font-weight:700;font-size:14px;transition:all .2s}.streak-badge.lit{background:var(--streak-bg);border-color:var(--streak-border);color:var(--streak-text);box-shadow:0 4px 16px #f9731630}.date-nav{display:flex;align-items:center;gap:0;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:3px;box-shadow:0 1px 2px #00000010}.nav-arrow{background:none;border:none;color:var(--muted);cursor:pointer;font-family:inherit;font-size:15px;font-weight:700;padding:8px 12px;border-radius:9px;transition:all .15s}.nav-arrow:hover{background:var(--panel2);color:var(--text)}.date-nav input[type=date]{background:transparent;border:none;color:var(--text);padding:8px 6px;font-family:inherit;font-size:13.5px;font-weight:600;color-scheme:var(--scheme)}.date-nav input[type=date]:focus{outline:none}.date-nav .btn{margin-left:4px;padding:8px 14px}.progress-card{display:flex;align-items:center;gap:20px;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:18px 22px;margin-bottom:24px;box-shadow:0 1px 2px #00000010}.progress-ring{--pct: 0;width:62px;height:62px;border-radius:50%;flex-shrink:0;background:conic-gradient(var(--primary) calc(var(--pct) * 1%),var(--panel2) 0);display:grid;place-items:center;transition:background .4s}.progress-ring span{width:48px;height:48px;border-radius:50%;background:var(--panel);display:grid;place-items:center;font-size:13px;font-weight:800;letter-spacing:-.3px}.progress-body{flex:1;display:flex;flex-direction:column;gap:8px}.progress-title{font-weight:700;font-size:15px;letter-spacing:-.2px}.progress-strip{display:flex;align-items:center;gap:14px;margin-bottom:22px}.progress-bar{flex:1;height:10px;background:var(--panel2);border-radius:999px;overflow:hidden;border:1px solid var(--border)}.progress-bar.small{height:7px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary2));border-radius:999px;transition:width .4s ease}.progress-label{font-size:13px;color:var(--muted);white-space:nowrap}.task-list{display:flex;flex-direction:column;gap:12px}.task-card{display:flex;gap:14px;align-items:flex-start;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;transition:all .2s}.task-card:hover{border-color:var(--hover-border);transform:translateY(-1px)}.task-card.done{opacity:.6}.task-card.done .task-title{text-decoration:line-through}.check{width:26px;height:26px;flex-shrink:0;margin-top:2px;border-radius:8px;border:2px solid var(--border);background:transparent;color:#fff;font-weight:800;cursor:pointer;transition:all .15s}.check:hover{border-color:var(--primary)}.task-card.done .check{background:linear-gradient(135deg,var(--primary),var(--primary2));border-color:transparent}.task-body{flex:1}.task-meta{display:flex;gap:8px;align-items:center;margin-bottom:6px;flex-wrap:wrap}.slot{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.chip{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;border:1px solid}.task-title{font-size:15px;line-height:1.5;font-weight:500}.task-actions{display:flex;gap:4px}.icon-btn{background:none;border:none;cursor:pointer;font-size:16px;opacity:.6;transition:opacity .15s;padding:4px}.icon-btn:hover{opacity:1}.notes-area{margin-top:10px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}.notes-area textarea{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:10px;color:var(--text);padding:10px;font-family:inherit;font-size:14px;resize:vertical}.add-task{display:flex;gap:10px;margin-top:18px}.add-task input{flex:1;background:var(--panel);border:1px dashed var(--border);border-radius:12px;padding:12px 16px;color:var(--text);font-family:inherit;font-size:14px}.add-task input:focus{outline:none;border-color:var(--primary)}.empty-state{text-align:center;padding:56px 24px;background:var(--panel);border-radius:20px;border:1px solid var(--border);box-shadow:0 1px 2px #00000010}.empty-icon{font-size:44px;margin-bottom:12px}.empty-state h3{font-size:19px;letter-spacing:-.4px;margin-bottom:6px}.empty-state p{max-width:420px;margin:0 auto;line-height:1.6}.empty-actions{display:flex;gap:10px;justify-content:center;margin-top:22px}.pw-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}.field-label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}.pw-form input{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:11px 13px;color:var(--text);font-family:inherit;font-size:14px}.pw-form input:focus{outline:none;border-color:var(--primary)}.pw-form .alert{margin-bottom:12px}.week-list{display:flex;flex-direction:column;gap:12px}.week-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:relative;transition:border-color .18s,box-shadow .18s,transform .18s}.week-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--primary),var(--primary2));opacity:.9}.week-card:hover{border-color:var(--accent-border);box-shadow:0 10px 30px -12px color-mix(in srgb,var(--primary) 45%,transparent);transform:translateY(-1px)}.week-card.week-done{border-color:var(--success)}.week-card.week-done:before{background:var(--success)}.week-head{display:flex;align-items:center;gap:16px;width:100%;background:none;border:none;color:var(--text);padding:16px 20px;cursor:pointer;font-family:inherit;text-align:left}.week-num{width:52px;height:52px;border-radius:14px;flex-shrink:0;background:var(--accent-soft);border:1px solid var(--accent-border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-weight:800;color:var(--accent-text);box-shadow:inset 0 1px #ffffff10}.week-ico{width:22px;height:22px;object-fit:contain}.week-emoji{font-size:18px;line-height:1}.week-w{font-size:10px;font-weight:800;letter-spacing:.5px;opacity:.85}.week-info{flex:1}.week-theme{font-weight:700;margin-bottom:8px;letter-spacing:-.01em}.week-pct{font-weight:800;font-size:13px;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-border);padding:3px 10px;border-radius:999px;min-width:46px;text-align:center}.week-card.week-done .week-pct{color:#fff;background:var(--success);border-color:transparent}.week-caret{color:var(--muted);font-size:12px}.week-days{border-top:1px solid var(--border);padding:8px 20px 20px;background:color-mix(in srgb,var(--bg2) 35%,transparent)}.day-block{margin-top:16px}.day-label{font-size:11.5px;font-weight:800;color:var(--accent-text);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.mini-task{display:flex;gap:12px;font-size:13.5px;padding:8px 10px;align-items:center;border-radius:10px;transition:background .15s}.mini-task:hover{background:var(--accent-soft)}.mini-task.done{opacity:.8}.mini-task.done .mini-title{text-decoration:line-through;opacity:.55}.mini-check{flex-shrink:0;font-size:14px;line-height:1}.mini-date{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:52px;padding:4px 8px;border-radius:9px;background:var(--bg2);border:1px solid var(--border);line-height:1.15}.mini-date b{font-size:11px;font-weight:800;color:var(--accent-text)}.mini-date span{font-size:10.5px;color:var(--muted);white-space:nowrap}.mini-slot{flex-shrink:0;color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;min-width:62px}.mini-title{line-height:1.45}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:20px}.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;gap:16px;align-items:center}.stat-big{font-size:30px;font-weight:800;letter-spacing:-1px}.stat-emoji{font-size:40px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:18px}.panel h2{font-size:17px;margin-bottom:14px}.bar-chart{display:flex;gap:8px;align-items:flex-end}.bar-col{flex:1;text-align:center}.bar-track{position:relative;display:flex;align-items:flex-end;justify-content:center}.bar-total,.bar-done{position:absolute;bottom:0;width:70%;border-radius:6px 6px 0 0}.bar-total{background:var(--panel2)}.bar-done{background:linear-gradient(180deg,var(--primary2),var(--primary))}.bar-label{font-size:11px;color:var(--muted);margin-top:6px}.chart-duo{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media (max-width: 860px){.chart-duo{grid-template-columns:1fr}}.heatmap{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}.hm-rows{display:flex;flex-direction:column;gap:3px;padding-top:1px}.hm-rows span{height:13px;font-size:9px;color:var(--muted);line-height:13px}.hm-grid{display:flex;gap:3px;overflow-x:auto;padding-bottom:4px}.hm-col{display:flex;flex-direction:column;gap:3px}.hm-cell{width:13px;height:13px;border-radius:3px;display:inline-block;background:var(--panel2)}.hm-cell.l1{background:color-mix(in srgb,var(--primary) 18%,var(--panel2))}.hm-cell.l2{background:color-mix(in srgb,var(--primary) 45%,var(--panel2))}.hm-cell.l3{background:color-mix(in srgb,var(--primary) 72%,var(--panel2))}.hm-cell.l4{background:var(--primary);box-shadow:0 0 6px color-mix(in srgb,var(--primary) 55%,transparent)}.hm-legend{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--muted);width:100%;justify-content:flex-end;margin-top:4px}.donut-wrap{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.donut-legend{flex:1;min-width:160px;display:flex;flex-direction:column;gap:6px}.dl-row{display:flex;align-items:center;gap:8px;font-size:13px}.dl-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.dl-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dl-val{color:var(--muted);font-variant-numeric:tabular-nums}.trend-svg{color:var(--text);max-width:420px}.cat-row{display:flex;align-items:center;gap:14px;padding:7px 0}.cat-name{width:130px;font-size:14px;font-weight:500}.cat-row .progress-bar{flex:1}.cat-pct{width:64px;text-align:right;font-size:13px;color:var(--muted)}.settings-row{display:flex;align-items:center;gap:12px;margin:16px 0}.switch{position:relative;width:48px;height:26px;display:inline-block}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--panel2);border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:.2s}.slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:4px;transition:.2s;box-shadow:0 1px 3px #00000040}.switch input:checked+.slider{background:linear-gradient(135deg,var(--primary),var(--primary2));border-color:transparent}.switch input:checked+.slider:before{transform:translate(21px)}.rhythm{list-style:none;display:flex;flex-direction:column;gap:10px}.rhythm li{padding-left:4px;font-size:14.5px;color:var(--muted)}.rhythm li b{color:var(--text)}.btn{font-family:inherit;font-weight:600;font-size:14px;border-radius:10px;padding:10px 18px;cursor:pointer;border:none;transition:all .15s}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}.btn-primary:hover{filter:brightness(1.12);text-decoration:none}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{background:var(--panel);color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--hover-border);text-decoration:none}a.btn{display:inline-flex;align-items:center;justify-content:center}a.btn:hover{text-decoration:none}.auth-page{min-height:100vh;display:grid;place-items:center;padding:20px;position:relative}.auth-theme{position:absolute;top:20px;right:20px}.auth-card{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:36px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--card-shadow)}.auth-emoji{font-size:40px}.auth-card h1{font-size:24px;letter-spacing:-.5px}.auth-card label{font-size:13px;font-weight:600;color:var(--muted);margin-top:8px}.auth-card input{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-family:inherit;font-size:14px}.auth-card input:focus{outline:none;border-color:var(--primary)}.auth-card .btn{margin-top:14px}.alert{background:var(--alert-bg);border:1px solid var(--alert-border);color:var(--alert-text);padding:10px 14px;border-radius:10px;font-size:14px}.page-loader{padding:80px;text-align:center;color:var(--muted)}.daily-quote{display:flex;align-items:center;gap:12px;margin:0 0 20px;padding:13px 18px;border-radius:14px;background:linear-gradient(100deg,color-mix(in srgb,var(--primary) 14%,transparent),color-mix(in srgb,var(--primary2) 10%,transparent));border:1px solid var(--accent-border)}.dq-icon{font-size:18px;line-height:1;flex-shrink:0}.dq-text{font-weight:600;font-style:italic;letter-spacing:.1px;line-height:1.4}.trial-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:11px 16px;border-radius:12px;margin-bottom:16px;font-weight:600;font-size:13.5px;background:linear-gradient(100deg,color-mix(in srgb,var(--primary) 16%,transparent),color-mix(in srgb,var(--primary2) 12%,transparent));border:1px solid var(--accent-border)}.trial-banner.expired{background:#f59e0b18;border-color:#f59e0b66}.trial-banner .btn{flex-shrink:0}.cycle-toggle{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:var(--bg2);border:1px solid var(--border);margin-bottom:18px}.cycle-btn{border:none;background:none;font-family:inherit;font-weight:700;font-size:13px;color:var(--muted);padding:8px 16px;border-radius:999px;cursor:pointer}.cycle-btn.on{background:var(--panel);color:var(--accent-text);box-shadow:0 2px 8px #0000001a}.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.price-card{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:22px}.price-card.popular{border:2px solid var(--primary);box-shadow:0 12px 30px -14px color-mix(in srgb,var(--primary) 50%,transparent)}.price-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#f59e0b;color:#fff;font-size:10.5px;font-weight:800;padding:3px 12px;border-radius:999px}.price-tier{font-weight:800;font-size:16px}.price-amt{font-size:34px;font-weight:800;margin:6px 0 2px}.price-suffix{font-size:15px;font-weight:600;color:var(--muted)}.price-cta{width:100%;margin:14px 0 6px}.price-feats{margin-top:12px;display:flex;flex-direction:column;gap:9px}.price-feat{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;line-height:1.4}.price-feat.feat-head{font-weight:700;color:var(--accent-text)}.pf-check{font-weight:800;flex-shrink:0}.pf-check.free{color:#22c55e}.pf-check.std{color:var(--primary)}.pf-check.prem{color:var(--primary2)}.price-note{margin-top:14px;font-size:12px;font-weight:700;color:#22c55e}.overdue-card{background:var(--panel);border:1px solid #f0b86e88;border-radius:var(--radius);padding:16px 18px;margin-bottom:18px;box-shadow:0 1px 2px #00000010;border-left:4px solid #f0a94e}.overdue-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}.overdue-title{font-weight:800;font-size:15px;color:var(--text)}.overdue-list{display:flex;flex-direction:column;gap:8px}.overdue-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg2);border:1px solid var(--border);border-radius:12px}.overdue-item .check.sm{width:26px;height:26px;font-size:13px;flex-shrink:0}.overdue-date{font-size:11px;font-weight:800;color:#b06d1e;background:#f0a94e22;border:1px solid #f0a94e55;border-radius:999px;padding:2px 8px;white-space:nowrap;flex-shrink:0}.overdue-text{flex:1;min-width:0;font-size:13.5px;line-height:1.4}.btn.sm{padding:6px 11px;min-height:0;font-size:12.5px;flex-shrink:0}.nav-build{display:flex;align-items:center;gap:10px;margin:8px 0 4px;padding:10px 12px;border-radius:10px;text-decoration:none;font-weight:700;font-size:13.5px;color:var(--accent-text);background:var(--accent-soft);border:1px dashed var(--accent-border);transition:all .15s}.nav-build:hover{border-style:solid;box-shadow:0 4px 14px color-mix(in srgb,var(--primary) 25%,transparent)}.res-search{display:flex;gap:10px}.res-search input{flex:1}.res-suggest-label{font-size:12px;font-weight:700;margin-top:14px}.btn.btn-sm{padding:7px 12px;min-height:0;font-size:13px}.btn.danger{color:#ef4444}.btn.danger:hover{border-color:#ef4444;background:#ef444414}.rename-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.rename-row input{font-size:22px;font-weight:700;padding:6px 12px;border-radius:10px;background:var(--bg2);border:1px solid var(--border);color:var(--text);min-width:240px;max-width:100%}.rename-row input:focus{outline:none;border-color:var(--primary)}.res-block-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.res-dismiss{background:var(--panel2);border:1px solid var(--border);color:var(--muted);width:28px;height:28px;border-radius:8px;cursor:pointer;font-size:14px;flex-shrink:0}.res-dismiss:hover{color:var(--text);border-color:var(--accent-border)}.res-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.res-src{font-size:11.5px;font-weight:800;padding:3px 10px;border-radius:999px;color:var(--muted);background:var(--bg2);border:1px solid var(--border);white-space:nowrap}.res-src.ai{color:var(--accent-text);background:var(--accent-soft);border-color:var(--accent-border)}.res-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:14px}.res-card{display:flex;gap:12px;align-items:flex-start;text-decoration:none;color:var(--text);background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:14px;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative}.res-card:hover{border-color:var(--accent-border);transform:translateY(-2px);box-shadow:0 10px 26px -14px color-mix(in srgb,var(--primary) 50%,transparent)}.res-emoji{font-size:22px;line-height:1.2;flex-shrink:0}.res-body{flex:1;min-width:0}.res-title{font-weight:700;line-height:1.35}.res-why{font-size:12.5px;color:var(--muted);margin-top:4px;line-height:1.4}.res-meta{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.res-tag{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-border);padding:2px 8px;border-radius:999px}.res-tag.ghost{color:var(--muted);background:transparent;border-color:var(--border)}.res-arrow{color:var(--muted);font-weight:800;flex-shrink:0}.hero-tagline{font-size:14px;font-weight:800;letter-spacing:.3px;margin:14px 0 6px;background:linear-gradient(90deg,var(--primary),var(--primary2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.try-box{max-width:860px;margin:0 auto;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:22px}.try-goals{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.try-chip{font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;padding:9px 15px;border-radius:999px;color:var(--muted);background:var(--bg2);border:1px solid var(--border);transition:all .15s}.try-chip:hover{color:var(--text);border-color:var(--accent-border)}.try-chip.on{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--primary),var(--primary2));box-shadow:0 4px 14px color-mix(in srgb,var(--primary) 40%,transparent)}.try-empty,.try-building{text-align:center;color:var(--muted);padding:28px 12px;font-weight:600}.try-building{display:flex;align-items:center;justify-content:center;gap:10px}.try-spinner{width:18px;height:18px;border-radius:50%;border:2.5px solid var(--border);border-top-color:var(--primary);animation:try-spin .7s linear infinite}@keyframes try-spin{to{transform:rotate(360deg)}}.try-plan-head{display:flex;align-items:center;gap:10px;margin:20px 4px 12px;font-size:14px}.try-badge{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-border);padding:2px 8px;border-radius:999px}.try-weeks{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}.try-week{display:flex;gap:12px;align-items:flex-start;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:12px 14px}.try-wnum{width:36px;height:36px;flex-shrink:0;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-border)}.try-wtitle{font-weight:700;font-size:13.5px}.try-wfocus{font-size:12.5px;color:var(--muted);margin-top:3px;line-height:1.4}.try-cta{text-align:center;margin-top:20px}.try-note{display:block;margin-top:10px;font-size:12.5px;color:var(--muted)}@media (max-width: 900px){.hero{grid-template-columns:1fr;padding-top:56px;gap:44px}.hero-visual{max-width:480px}.float-chip.chip-a{right:4px}.float-chip.chip-b{left:0}}@media (max-width: 1020px){.dash-grid{grid-template-columns:1fr}.dash-left{position:static;max-width:360px}}@media (max-width: 860px){.app-shell{flex-direction:column}.topbar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:44;padding:10px 14px;background:color-mix(in srgb,var(--bg2) 88%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.sidebar{position:fixed;top:0;left:0;z-index:50;width:82%;max-width:300px;height:100vh;height:100dvh;padding:20px 16px;gap:18px;border-right:1px solid var(--border);transform:translate(-105%);transition:transform .26s cubic-bezier(.4,0,.2,1);box-shadow:0 0 40px #0005;overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-close{display:grid;place-items:center;position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:10px;cursor:pointer;background:var(--panel2);border:1px solid var(--border);color:var(--muted);font-size:15px}.sidebar .brand{padding-right:40px}.sidebar-head .notif{display:none}.user-chip div:last-child{display:block}.main{padding:18px 15px}.landing-nav .nav-links{display:none}.section{padding:50px 5vw}.page-header{flex-direction:column;align-items:stretch;gap:14px}.page-header h1{font-size:24px}.header-right{justify-content:space-between;width:100%}.date-nav{flex:1}.date-nav input[type=date]{flex:1;min-width:0}.profile-form{grid-template-columns:1fr}.profile-hero{justify-content:center;text-align:center}.res-grid,.try-weeks,.stat-grid,.chart-duo,.price-grid{grid-template-columns:1fr}.res-search{flex-direction:column}.res-search .btn{width:100%}.btn{min-height:42px}.pick-chip,.try-chip{padding:10px 15px}}@media (max-width: 460px){.main{padding:16px 12px}.page-header h1{font-size:21px}.panel{padding:16px 14px}.profile-avatar{width:92px;height:92px}.daily-quote{padding:11px 14px}.dq-text{font-size:13.5px}.hero h1{font-size:30px}.hero-ctas{flex-direction:column}.hero-ctas .btn{width:100%}.week-head{gap:12px;padding:14px}.mini-slot{display:none}}.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#2f6bff,#38bdf8);transform-origin:0 50%;z-index:1000;pointer-events:none}.landing{overflow-x:clip}.footer-right{text-align:right}.nav-burger{display:none;flex-direction:column;align-items:center;justify-content:center;gap:4.5px;width:40px;height:40px;flex-shrink:0;border-radius:10px;cursor:pointer;background:var(--panel2);border:1px solid var(--border)}.nav-burger span{display:block;width:17px;height:2px;border-radius:2px;background:var(--text);transition:transform .2s ease,opacity .2s ease}.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.nav-burger.open span:nth-child(2){opacity:0}.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{position:absolute;top:100%;left:0;right:0;display:flex;flex-direction:column;gap:2px;padding:12px 5vw 16px;background:color-mix(in srgb,var(--bg) 96%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);box-shadow:0 24px 40px -24px #0006}.mobile-menu a{padding:12px 10px;border-radius:10px;color:var(--text);font-weight:600;font-size:15px}.mobile-menu a:hover{background:var(--panel2);text-decoration:none}.mobile-menu .mm-cta{display:flex;gap:10px;margin-top:10px}.mm-cta .btn{flex:1;text-align:center;justify-content:center;padding:12px}@media (min-width: 861px){.mobile-menu{display:none}}@media (min-width: 861px) and (max-width: 1080px){.price-grid{grid-template-columns:repeat(2,1fr)}.price-card.popular{grid-column:1 / -1}}@media (max-width: 860px){.nav-burger{display:flex}.landing-nav{gap:10px;padding:12px 4vw}.landing-nav .nav-signin{display:none}.hero{padding:60px 5vw 52px;gap:40px}.hero-visual{margin:0 auto;width:100%}}@media (max-width: 700px){.landing-footer{flex-direction:column;text-align:center;gap:12px;padding:24px 5vw}.landing-footer .nav-spacer{display:none}.footer-links{justify-content:center;flex-wrap:wrap;row-gap:8px}.footer-right{text-align:center}.footer-brand{align-items:center}}@media (max-width: 600px){.wb-strip{flex-wrap:wrap;row-gap:8px;padding:10px 4.5vw}.wb-text{flex-basis:calc(100% - 60px)}.wb-strip .btn{margin-left:auto}.section{padding:44px 4.5vw}.section-head{margin-bottom:30px}.section-head p{font-size:14.5px}.hero-sub{font-size:15.5px}.hero-stats{gap:22px;margin-top:30px}.try-box{padding:16px 13px}.cta-band{padding:44px 20px;border-radius:18px}.mock-card{transform:none;padding:16px}.float-chip{font-size:12px;padding:8px 12px}.float-chip.chip-a{top:-8px;right:0}.float-chip.chip-b{bottom:-6px;left:0}.goal-chips{gap:8px}.stack-strip{padding-left:4.5vw;padding-right:4.5vw}}@media (max-width: 460px){.landing-nav{gap:8px;padding:10px 3.5vw}.landing-nav .brand-name{font-size:15px}.landing-n{}}
