@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #f6f1e7;--bg-2: #fcf9f2;--surface: rgba(255, 255, 255, .55);--surface-2: rgba(255, 255, 255, .78);--stroke: rgba(31, 26, 22, .1);--stroke-strong: rgba(31, 26, 22, .2);--text: #221c2e;--text-soft: rgba(34, 28, 46, .66);--text-dim: rgba(34, 28, 46, .42);--coral: #ff6a3d;--peach: #ffb27a;--emerald: #0fae8c;--lime: #9bd84f;--berry: #e44d8c;--plum: #6c2d6b;--grad-main: linear-gradient(120deg, #ff6a3d 0%, #ff8f5c 50%, #ffb27a 100%);--grad-pink: linear-gradient(120deg, #e44d8c 0%, #ff6a3d 100%);--grad-lime: linear-gradient(120deg, #0fae8c 0%, #9bd84f 100%);--r-xl: 32px;--r-lg: 24px;--r-md: 18px;--r-sm: 12px;--r-pill: 100px;--ease: cubic-bezier(.22, 1, .36, 1);--spring: cubic-bezier(.34, 1.56, .64, 1);--font: "Space Grotesk", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--maxw: 1200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.bg-mesh{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:radial-gradient(42% 52% at 12% 8%,rgba(255,106,61,.28),transparent 70%),radial-gradient(46% 46% at 88% 4%,rgba(15,174,140,.2),transparent 70%),radial-gradient(52% 56% at 78% 82%,rgba(228,77,140,.18),transparent 70%),radial-gradient(42% 42% at 8% 92%,rgba(155,216,79,.22),transparent 70%);filter:blur(10px);pointer-events:none}.bg-grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;opacity:.04;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:.95rem;font-weight:600;padding:14px 26px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer;transition:transform .4s var(--spring),box-shadow .3s,background .3s,border-color .3s;white-space:nowrap;text-decoration:none;line-height:1}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--grad-main);color:#fff;box-shadow:0 10px 30px -8px #ff6a3d8c}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px -8px #ff6a3db3}.btn-glass{background:var(--surface);border-color:var(--stroke);color:var(--text);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn-glass:hover{background:var(--surface-2);border-color:var(--stroke-strong);transform:translateY(-3px)}.btn-sm{padding:9px 18px;font-size:.875rem}.glass-card{background:var(--surface);border:1px solid var(--stroke);border-radius:var(--r-lg);padding:28px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:transform .5s var(--ease),border-color .3s,background .3s}.glass-card:hover{border-color:var(--stroke-strong);background:var(--surface-2)}.glass-card--no-hover:hover{transform:none}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;letter-spacing:.04em;padding:7px 15px;border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--stroke);color:var(--text-soft);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);margin-bottom:22px}.eyebrow .eyebrow-icon{font-size:.95rem}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:.875rem;font-weight:600;color:var(--text-soft)}.field-input{width:100%;padding:12px 16px;font-family:var(--font-body);font-size:.95rem;color:var(--text);background:var(--surface-2);border:1px solid var(--stroke);border-radius:var(--r-md);outline:none;transition:border-color .2s,box-shadow .2s}.field-input:focus{border-color:var(--coral);box-shadow:0 0 0 3px #ff6a3d26}.field-input--error{border-color:var(--berry)}.field-input--error:focus{box-shadow:0 0 0 3px #e44d8c26}.field-error{font-size:.82rem;color:var(--berry);font-weight:500}.field-input::placeholder{color:var(--text-dim)}.logo{display:inline-flex;align-items:center;gap:11px;text-decoration:none}.logo-mark{width:38px;height:38px;border-radius:12px;background:var(--grad-main);display:grid;place-items:center;box-shadow:0 6px 18px -6px #ff6a3d99;flex-shrink:0}.logo-mark svg{width:22px;height:22px}.logo-text{font-family:var(--font);font-size:1.3rem;font-weight:700;letter-spacing:.06em;color:var(--text)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;gap:12px}.loading-dot{width:8px;height:8px;border-radius:50%;background:var(--coral);animation:loading-bounce 1.2s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.15s}.loading-dot:nth-child(3){animation-delay:.3s}@keyframes loading-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.grad-text{background:var(--grad-main);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.alert{padding:12px 16px;border-radius:var(--r-md);font-size:.9rem;font-weight:500}.alert-error{background:#e44d8c1a;border:1px solid rgba(228,77,140,.3);color:var(--plum)}.alert-success{background:#0fae8c1a;border:1px solid rgba(15,174,140,.3);color:var(--emerald)}.alert-info{background:#ff6a3d1a;border:1px solid rgba(255,106,61,.3);color:var(--coral)}.auth-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.auth-split-brand{background:var(--grad-main);display:flex;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}.auth-split-brand:before{content:"";position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:radial-gradient(circle at 60% 40%,rgba(255,255,255,.18),transparent 60%);pointer-events:none}.auth-brand-inner{display:flex;flex-direction:column;gap:20px;position:relative}.auth-brand-title{font-family:var(--font);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:700;color:#fff;line-height:1.15;letter-spacing:-.02em}.auth-brand-sub{font-size:1.05rem;color:#ffffffd1;max-width:360px;line-height:1.6}.auth-split-form{display:flex;align-items:center;justify-content:center;padding:48px 24px;background:var(--bg)}.auth-form-inner{width:100%;max-width:400px;display:flex;flex-direction:column;gap:24px}.auth-centered{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.auth-card{width:100%;max-width:420px;display:flex;flex-direction:column;gap:24px}.auth-card-logo{display:flex;justify-content:center}.auth-form-header{display:flex;flex-direction:column;gap:6px}.auth-form-title{font-family:var(--font);font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--text);line-height:1.15}.auth-form-subtitle{font-size:.95rem;color:var(--text-soft)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form-row{display:flex;align-items:center}.auth-form-row--right{justify-content:flex-end}.auth-form-row--two-col{gap:12px}.auth-form-row--two-col>*{flex:1}.auth-link{font-size:.875rem;color:var(--text-soft);text-decoration:none;transition:color .2s}.auth-link:hover{color:var(--coral)}.auth-link--accent{color:var(--coral);font-weight:600}.auth-footer-text{font-size:.875rem;color:var(--text-soft);text-align:center}.logo--lg .logo-text{font-size:1.6rem}.logo-mark--lg{width:48px;height:48px;border-radius:14px}.logo-mark--lg svg{width:28px;height:28px}.onboarding-page{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:0 24px 64px}.onboarding-header{padding:28px 0 12px}.onboarding-body{display:flex;flex-direction:column;align-items:center;width:100%;max-width:540px;gap:28px;margin-top:8px}.onboarding-card{width:100%;display:flex;flex-direction:column;gap:24px}.onboarding-card--wide{max-width:600px}.step-indicator{display:flex;align-items:center;gap:0;width:100%;max-width:360px}.step-indicator-item{display:flex;align-items:center;flex:1}.step-indicator-item:first-child{flex:none}.step-indicator-line{flex:1;height:2px;background:var(--stroke);margin:0 8px;transition:background .3s}.step-indicator-line--done{background:var(--coral)}.step-indicator-circle{width:32px;height:32px;border-radius:50%;background:var(--surface);border:1px solid var(--stroke);display:grid;place-items:center;font-family:var(--font);font-size:.82rem;font-weight:700;color:var(--text-dim);transition:background .3s,border-color .3s,color .3s;flex-shrink:0}.step-indicator-circle--active{background:var(--grad-main);border-color:transparent;color:#fff;box-shadow:0 4px 14px -4px #ff6a3d99}.step-indicator-circle--done{background:var(--coral);border-color:transparent;color:#fff}.step-indicator-label{font-size:.78rem;font-weight:500;color:var(--text-dim);margin-left:8px;white-space:nowrap;transition:color .3s}.step-indicator-label--active{color:var(--text);font-weight:700}.quiz-group{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.quiz-legend{font-size:.875rem;font-weight:600;color:var(--text-soft);display:flex;flex-direction:column;gap:2px;margin-bottom:4px}.quiz-legend-sub{font-size:.78rem;color:var(--text-dim);font-weight:400}.quiz-options{display:flex;flex-wrap:wrap;gap:8px}.quiz-options--grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.quiz-options--column{flex-direction:column;flex-wrap:nowrap;gap:6px}.quiz-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-md);background:var(--surface);border:1.5px solid var(--stroke);cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text);transition:border-color .2s,background .2s;-webkit-user-select:none;user-select:none}.quiz-option:hover{border-color:var(--stroke-strong);background:var(--surface-2)}.quiz-option--selected{border-color:var(--coral);background:#ff6a3d12;color:var(--coral)}.quiz-option-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.quiz-other-field{margin-top:4px;display:flex;flex-direction:column;gap:4px}.plan-selection-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.plan-loading{color:var(--text-dim);font-size:.95rem}.plan-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;width:100%;max-width:580px}.plan-card{display:flex;flex-direction:column;gap:10px;padding:22px 18px;border-radius:var(--r-lg);background:var(--surface);border:2px solid var(--stroke);cursor:pointer;text-align:left;transition:border-color .2s,background .2s,transform .3s var(--ease);position:relative}.plan-card:hover{border-color:var(--stroke-strong);background:var(--surface-2);transform:translateY(-3px)}.plan-card--selected{border-color:var(--coral);background:#ff6a3d0f}.plan-card-name{font-family:var(--font);font-size:1.05rem;font-weight:700;color:var(--text)}.plan-card-price{display:flex;align-items:baseline;gap:2px}.plan-card-price-amount{font-family:var(--font);font-size:1.7rem;font-weight:700;color:var(--coral);line-height:1}.plan-card-price-period{font-size:.82rem;color:var(--text-dim)}.plan-card-limit{font-size:.82rem;color:var(--text-soft);font-weight:500}.plan-card-promo{font-size:.78rem;color:var(--emerald);font-weight:600}.plan-card-check{position:absolute;top:10px;right:12px;width:22px;height:22px;border-radius:50%;background:var(--coral);color:#fff;font-size:.75rem;font-weight:700;display:grid;place-items:center}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-nav{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--stroke);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.app-nav-inner{display:flex;align-items:center;gap:20px;max-width:var(--maxw);margin:0 auto;padding:0 24px;height:60px}.app-nav-links{display:flex;align-items:center;gap:4px;flex:1;margin-left:16px}.app-nav-link{font-size:.875rem;font-weight:600;color:var(--text-soft);text-decoration:none;padding:6px 14px;border-radius:var(--r-pill);transition:color .2s,background .2s}.app-nav-link:hover{color:var(--text);background:var(--surface-2)}.app-nav-link--active{color:var(--coral);background:#ff6a3d14}.app-nav-logout{margin-left:auto;font-size:.875rem;font-weight:600;color:var(--text-soft);background:none;border:none;cursor:pointer;padding:6px 14px;border-radius:var(--r-pill);transition:color .2s,background .2s}.app-nav-logout:hover{color:var(--text);background:var(--surface-2)}.app-main{flex:1;display:flex;flex-direction:column}.subjects-page{max-width:var(--maxw);width:100%;margin:0 auto;padding:40px 24px 64px;display:flex;flex-direction:column;gap:24px}.subjects-loading{color:var(--text-dim);font-size:.95rem}.subjects-header{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.subjects-header-text{display:flex;flex-direction:column;gap:4px}.subjects-title{font-family:var(--font);font-size:1.8rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.subjects-usage{font-size:.875rem;color:var(--text-soft);font-weight:500}.subjects-add-form{display:flex;gap:12px;align-items:flex-start;max-width:480px}.subjects-add-input{flex:1}.subjects-add-error,.subjects-limit-banner{max-width:480px}.subjects-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;text-align:center}.subjects-empty-text{font-size:1rem;color:var(--text-soft)}.subjects-empty-action{font-size:.875rem;color:var(--text-dim)}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.subject-card{display:flex;flex-direction:column;gap:16px}.subject-card-name{font-family:var(--font);font-size:1.05rem;font-weight:700;color:var(--text);word-break:break-word}.subject-card-btn{align-self:flex-start}.subjects-recent{display:flex;flex-direction:column;gap:12px;padding-top:8px}.subjects-recent-title{font-size:1rem;font-weight:700;color:var(--text-soft);letter-spacing:.02em}.subjects-recent-list{display:flex;flex-direction:column;gap:8px}.recent-chat-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--stroke);cursor:pointer;text-align:left;transition:background .2s,border-color .2s;width:100%}.recent-chat-item:hover{background:var(--surface-2);border-color:var(--stroke-strong)}.recent-chat-title{font-size:.9rem;font-weight:600;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-chat-subject{font-size:.8rem;color:var(--text-dim);white-space:nowrap}.chat-page{display:flex;flex-direction:column;height:calc(100vh - 60px);max-width:800px;width:100%;margin:0 auto}.chat-page--error{padding:40px 24px;gap:16px}.chat-header{display:flex;align-items:center;gap:12px;padding:16px 24px;border-bottom:1px solid var(--stroke);flex-shrink:0}.chat-back-btn{font-size:1.2rem;color:var(--text-soft);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:var(--r-md);transition:color .2s,background .2s;line-height:1}.chat-back-btn:hover{color:var(--text);background:var(--surface-2)}.chat-header-info{display:flex;flex-direction:column;gap:2px;min-width:0}.chat-header-title{font-family:var(--font);font-size:1rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:40px}.chat-empty-title{font-family:var(--font);font-size:1.2rem;font-weight:700;color:var(--text-soft)}.chat-empty-subtitle{font-size:.9rem;color:var(--text-dim);max-width:320px}.chat-message{display:flex;flex-direction:column;gap:4px;max-width:85%}.chat-message--user{align-self:flex-end;align-items:flex-end}.chat-message--assistant{align-self:flex-start;align-items:flex-start}.chat-message-role{font-size:.75rem;font-weight:700;letter-spacing:.05em;color:var(--text-dim);text-transform:uppercase}.chat-message-bubble{padding:12px 16px;border-radius:var(--r-md);font-size:.95rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}.chat-message--user .chat-message-bubble{background:var(--grad-main);color:#fff;border-bottom-right-radius:4px}.chat-message--assistant .chat-message-bubble{background:var(--surface);border:1px solid var(--stroke);color:var(--text);border-bottom-left-radius:4px}.chat-cursor{display:inline-block;width:2px;height:1em;background:var(--text-soft);margin-left:2px;vertical-align:middle;animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.chat-thinking-indicator{display:flex;align-items:center;gap:6px;padding:10px 14px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--stroke);align-self:flex-start;max-width:200px}.chat-thinking-dot{width:7px;height:7px;border-radius:50%;background:var(--coral);animation:loading-bounce 1.2s ease-in-out infinite}.chat-thinking-dot:nth-child(2){animation-delay:.15s}.chat-thinking-dot:nth-child(3){animation-delay:.3s}.chat-thinking-label{font-size:.82rem;color:var(--text-soft);font-weight:500}.chat-send-error{margin:0 24px;flex-shrink:0}.chat-input-area{display:flex;gap:12px;align-items:flex-end;padding:16px 24px 24px;border-top:1px solid var(--stroke);flex-shrink:0;background:var(--bg)}.chat-textarea{flex:1;resize:none;font-family:var(--font-body);font-size:.95rem;color:var(--text);background:var(--surface-2);border:1px solid var(--stroke);border-radius:var(--r-md);padding:12px 16px;outline:none;transition:border-color .2s,box-shadow .2s;line-height:1.5;min-height:48px;max-height:160px;overflow-y:auto}.chat-textarea:focus{border-color:var(--coral);box-shadow:0 0 0 3px #ff6a3d26}.chat-textarea::placeholder{color:var(--text-dim)}@media(max-width:768px){.app-nav-inner{padding:0 16px;gap:12px}.app-nav-links{gap:0;margin-left:8px}.app-nav-link{padding:6px 10px;font-size:.82rem}.subjects-page{padding:24px 16px 48px;gap:20px}.subjects-title{font-size:1.4rem}.subjects-add-form{max-width:100%}.subjects-grid{grid-template-columns:1fr 1fr}.chat-page{height:calc(100vh - 60px)}.chat-header{padding:12px 16px}.chat-messages{padding:16px;gap:12px}.chat-input-area{padding:12px 16px 16px}.chat-message{max-width:92%}.auth-split{grid-template-columns:1fr}.auth-split-brand{padding:32px 24px 24px;min-height:200px;align-items:flex-start}.auth-brand-title{font-size:1.5rem}.auth-brand-sub{display:none}.auth-split-form{align-items:flex-start;padding-top:32px}.plan-cards{grid-template-columns:1fr}.step-indicator,.onboarding-card--wide{max-width:100%}}@media(max-width:480px){.auth-form-row--two-col{flex-direction:column}.quiz-options--grid{grid-template-columns:1fr 1fr}}.field-hint{font-size:.82rem;color:var(--text-soft);font-style:italic;margin-bottom:4px}.settings-page{max-width:720px;margin:0 auto;padding:40px 24px;display:flex;flex-direction:column;gap:24px}.settings-header{display:flex;align-items:center;gap:12px}.settings-title{font-family:var(--font);font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.settings-tabs{display:flex;gap:8px;border-bottom:1px solid var(--stroke);padding-bottom:0}.settings-tab{padding:10px 20px;font-family:var(--font-body);font-size:.9rem;font-weight:600;color:var(--text-soft);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .2s,border-color .2s;margin-bottom:-1px}.settings-tab:hover{color:var(--text)}.settings-tab--active{color:var(--coral);border-bottom-color:var(--coral)}.settings-card{width:100%}.settings-card-header{display:flex;flex-direction:column;gap:4px;margin-bottom:20px}.settings-card-title{font-family:var(--font);font-size:1.15rem;font-weight:700;color:var(--text);margin-bottom:8px}.settings-card-subtitle{font-size:.9rem;color:var(--text-soft)}.settings-form{display:flex;flex-direction:column;gap:16px}.settings-form-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.settings-checkbox-label{display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:500;cursor:pointer;color:var(--text-soft)}.settings-subscription-link{display:flex}.subscription-info{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.subscription-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.9rem}.subscription-label{color:var(--text-soft);font-weight:500}.subscription-value{color:var(--text)}.subscription-value--strong{font-weight:700;font-size:1rem}.subscription-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--r-pill);font-size:.8rem;font-weight:600}.subscription-badge--trialing{background:#ffa5001f;color:#c47a00;border:1px solid rgba(255,165,0,.3)}.subscription-badge--active{background:#0fae8c1f;color:var(--emerald);border:1px solid rgba(15,174,140,.3)}.subscription-badge--past_due,.subscription-badge--incomplete,.subscription-badge--unpaid{background:#e44d8c1f;color:var(--berry);border:1px solid rgba(228,77,140,.3)}.subscription-badge--canceled{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--stroke)}.subscription-cancel-notice{margin-top:8px}.subscription-actions{display:flex;gap:12px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--stroke)}.plan-change-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--stroke);display:flex;flex-direction:column;gap:16px}.plan-change-title{font-family:var(--font);font-size:1rem;font-weight:700;color:var(--text)}.plan-change-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.plan-option{display:flex;flex-direction:column;gap:6px;padding:16px;background:var(--surface-2);border:2px solid var(--stroke);border-radius:var(--r-lg);cursor:pointer;text-align:left;transition:border-color .2s,background .2s;font-family:var(--font-body)}.plan-option:hover:not(:disabled){border-color:var(--coral);background:var(--surface)}.plan-option--selected{border-color:var(--coral);background:#ff6a3d0f}.plan-option--current{opacity:.6;cursor:default}.plan-option-name{font-weight:700;font-size:.95rem;color:var(--text)}.plan-option-price{font-size:1.1rem;font-weight:700;font-family:var(--font);color:var(--coral)}.plan-option-subjects{font-size:.8rem;color:var(--text-soft)}.plan-option-current-badge{font-size:.75rem;font-weight:600;color:var(--emerald);margin-top:4px}.plan-change-preview-loading{font-size:.9rem;color:var(--text-soft);font-style:italic}.plan-change-preview{display:flex;flex-direction:column;gap:12px}.plan-change-confirm{display:flex}.admin-layout{display:flex;gap:0;min-height:calc(100vh - 64px)}.admin-sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--stroke);padding:24px 0}.admin-nav{display:flex;flex-direction:column;gap:4px;padding:0 12px}.admin-nav-link{display:block;padding:10px 14px;border-radius:var(--r-md);font-size:.9rem;font-weight:500;color:var(--text-soft);text-decoration:none;transition:color .2s,background .2s}.admin-nav-link:hover{color:var(--text);background:var(--surface-2)}.admin-nav-link--active{color:var(--coral);background:#ff6a3d14;font-weight:600}.admin-content{flex:1;overflow:auto;min-width:0}.admin-page{padding:32px 40px;max-width:1100px;display:flex;flex-direction:column;gap:24px}.admin-page-header{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.admin-page-title{font-family:var(--font);font-size:1.6rem;font-weight:700;letter-spacing:-.02em;color:var(--text);flex:1}.admin-empty{color:var(--text-soft);font-size:.95rem}.admin-table-wrapper{display:flex;flex-direction:column;gap:16px;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{padding:10px 14px;text-align:left;font-weight:600;color:var(--text-soft);border-bottom:1px solid var(--stroke);white-space:nowrap}.admin-table td{padding:12px 14px;border-bottom:1px solid var(--stroke);color:var(--text);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--surface-2)}.admin-table-email{color:var(--text-soft);font-size:.85rem}.admin-table-date{color:var(--text-soft);white-space:nowrap}.admin-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--r-pill);font-size:.78rem;font-weight:600;white-space:nowrap}.admin-badge--admin{background:#ff6a3d1f;color:var(--coral);border:1px solid rgba(255,106,61,.25)}.admin-badge--student{background:var(--surface-2);color:var(--text-soft);border:1px solid var(--stroke)}.admin-badge--onboarding-completed{background:#0fae8c1a;color:var(--emerald);border:1px solid rgba(15,174,140,.2)}.admin-badge--onboarding-pending_quiz,.admin-badge--onboarding-pending_payment{background:#ffa5001a;color:#c47a00;border:1px solid rgba(255,165,0,.2)}.admin-badge--inactive{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--stroke)}.admin-badge--sub-trialing{background:#ffa5001a;color:#c47a00;border:1px solid rgba(255,165,0,.2)}.admin-badge--sub-active{background:#0fae8c1a;color:var(--emerald);border:1px solid rgba(15,174,140,.2)}.admin-badge--sub-past_due,.admin-badge--sub-incomplete,.admin-badge--sub-unpaid{background:#e44d8c1a;color:var(--berry);border:1px solid rgba(228,77,140,.2)}.admin-badge--sub-canceled{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--stroke)}.admin-badge--synced{background:#0fae8c1a;color:var(--emerald);border:1px solid rgba(15,174,140,.2)}.admin-badge--unsynced{background:#e44d8c1a;color:var(--berry);border:1px solid rgba(228,77,140,.2)}.admin-sync-results{list-style:none;margin:0 0 20px;padding:0;display:flex;flex-direction:column;gap:8px}.admin-sync-result{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--stroke);font-size:.9rem}.admin-sync-result-name{font-weight:700;color:var(--text)}.admin-sync-result-action{color:var(--text-soft)}.admin-sync-result-error{color:var(--berry);font-size:.82rem}.admin-sync-result--error{border-color:#e44d8c4d}.admin-pagination{display:flex;align-items:center;gap:12px;justify-content:center;padding:8px 0}.admin-pagination-info{font-size:.9rem;color:var(--text-soft)}.admin-plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.admin-plan-card{display:flex;flex-direction:column;gap:12px}.admin-plan-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.admin-plan-name{font-family:var(--font);font-size:1.1rem;font-weight:700;color:var(--text)}.admin-plan-details{display:flex;flex-direction:column;gap:4px}.admin-plan-price{font-size:1.2rem;font-weight:700;font-family:var(--font);color:var(--coral)}.admin-plan-subjects{font-size:.85rem;color:var(--text-soft)}.admin-plan-promo{font-size:.8rem;color:var(--emerald);font-style:italic}.admin-plan-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;padding-top:12px;border-top:1px solid var(--stroke)}.admin-add-admin-form{max-width:520px}.admin-chat-messages{display:flex;flex-direction:column;gap:16px}.admin-chat-message{display:flex;flex-direction:column;gap:10px}.admin-chat-message--user{align-self:flex-end;max-width:80%}.admin-chat-message--assistant{align-self:flex-start;max-width:90%}.admin-chat-message-role{font-size:.8rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em}.admin-chat-message-content{font-size:.95rem;line-height:1.6;white-space:pre-wrap}.admin-chat-export-actions{display:flex;gap:8px;flex-wrap:wrap}.admin-thinking-block{margin-top:8px;border-top:1px dashed var(--stroke);padding-top:10px}.admin-thinking-toggle{display:flex;align-items:center;gap:8px;background:transparent;border:none;cursor:pointer;font-family:var(--font-body);font-size:.82rem;font-weight:600;color:var(--text-soft);padding:4px 0;transition:color .2s}.admin-thinking-toggle:hover{color:var(--text)}.admin-thinking-chevron{font-size:.7rem}.admin-thinking-content{margin-top:10px;padding:14px;background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--stroke)}.admin-thinking-label{font-size:.8rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.admin-thinking-text{font-family:var(--font-body);font-size:.875rem;line-height:1.6;white-space:pre-wrap;word-break:break-word;color:var(--text-soft);margin:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal-card{width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.modal-close{background:transparent;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-soft);line-height:1;padding:2px 6px;border-radius:var(--r-sm);transition:color .2s,background .2s;flex-shrink:0}.modal-close:hover{color:var(--text);background:var(--surface-2)}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--stroke);padding:12px 0}.admin-nav{flex-direction:row;flex-wrap:wrap;overflow-x:auto}.admin-page{padding:20px 16px}.admin-chat-message--user,.admin-chat-message--assistant{max-width:100%}.plan-change-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.settings-page{padding:24px 16px}.plan-change-grid{grid-template-columns:1fr}.subscription-row{flex-direction:column;align-items:flex-start;gap:4px}}
