@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&display=swap";.global-nav{background-color:var(--color-canvas);border-bottom:1px solid var(--color-divider-soft);z-index:200;-webkit-font-smoothing:antialiased;height:44px;transition:transform var(--transition-normal);position:fixed;top:0;left:0;right:0}.global-nav.hidden{transform:translateY(-100%)}.global-nav-inner{justify-content:space-between;align-items:center;max-width:1440px;height:100%;margin:0 auto;padding:0 20px;display:flex}.global-nav-left{align-items:center;gap:24px;height:100%;display:flex}.nav-logo{color:var(--color-primary);font-size:var(--text-nav);font-weight:var(--weight-bold);letter-spacing:var(--tracking-nav);line-height:var(--leading-nav);transition:opacity var(--transition-fast);align-items:center;gap:6px;text-decoration:none;display:flex}.nav-logo:hover{opacity:.8;color:var(--color-primary)}.nav-links-desktop{align-items:center;gap:4px;height:100%;display:flex}.nav-link{height:100%;font-size:var(--text-nav);font-weight:var(--weight-regular);letter-spacing:var(--tracking-nav);color:var(--color-ink-muted-48);transition:color var(--transition-fast);white-space:nowrap;align-items:center;padding:0 14px;text-decoration:none;display:flex}.nav-link:hover{color:var(--color-ink)}.nav-link.active{color:var(--color-primary);font-weight:var(--weight-semibold)}.global-nav-right,.nav-user{align-items:center;gap:8px;display:flex}.nav-user-name{font-size:var(--text-nav);color:var(--color-ink-muted-48);text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.nav-icon-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-ink-muted-48);transition:color var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.nav-icon-btn:hover{color:var(--color-primary)}.hamburger{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-ink-muted-48);background:0 0;border:none;justify-content:center;align-items:center;display:none}.hamburger:hover{color:var(--color-ink)}.nav-drawer{background:var(--color-canvas);z-index:199;border-top:1px solid var(--color-divider-soft);padding:16px;display:none;position:fixed;inset:44px 0 0;overflow-y:auto}.nav-drawer.open{display:block}.global-nav.hidden~.nav-drawer{top:0}.nav-drawer-links{flex-direction:column;gap:2px;display:flex}.drawer-link{font-size:var(--text-body);font-weight:var(--weight-regular);color:var(--color-ink);border-radius:var(--radius-sm);transition:background var(--transition-fast), color var(--transition-fast);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 16px;font-family:inherit;text-decoration:none;display:flex}.drawer-link:hover,.drawer-link.active{background:var(--color-notes-orange-tint);color:var(--color-primary)}.drawer-login{border-top:1px solid var(--color-divider-soft);margin-top:8px;padding-top:16px}.main-content{min-height:calc(100vh - 44px);margin-top:44px}@media (width<=834px){.nav-links-desktop{display:none}.hamburger{display:flex}.nav-user-name{display:none}}@media (width>=835px){.nav-drawer{display:none!important}}.ai-chat-container{z-index:100;flex-direction:column;align-items:flex-end;display:flex;position:fixed;bottom:24px;right:24px}.chat-bubble-btn{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:52px;height:52px;box-shadow:var(--shadow-product);transition:transform var(--transition-fast);justify-content:center;align-items:center;display:flex}.chat-bubble-btn:hover{background:var(--color-primary-focus);transform:scale(1.05)}.chat-window{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);flex-direction:column;width:380px;height:520px;margin-bottom:12px;display:flex;overflow:hidden}.chat-backdrop{z-index:199;background:#0006;position:fixed;inset:0}.chat-window.expanded{z-index:200;width:min(800px,90vw);height:min(700px,90vh);position:fixed;inset:50% auto auto 50%;transform:translate(-50%,-50%);box-shadow:0 14px 28px #00000040,0 10px 10px #00000026}@media (width<=520px){.chat-window{z-index:200;border-radius:0;width:100%;height:100%;margin-bottom:0;position:fixed;inset:0}.chat-window.expanded{width:100%;height:100%;top:0;left:0;transform:none}.ai-chat-container{bottom:0;right:0}.chat-bubble-btn{width:48px;height:48px;margin:16px}}.chat-header{background:var(--color-canvas-parchment);border-bottom:1px solid var(--color-hairline);font-size:var(--text-body);font-weight:var(--weight-semibold);color:var(--color-ink);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.header-center{padding:0 var(--space-xs);flex:1;justify-content:center;display:flex}.header-actions{gap:4px;display:flex}.voice-select{font-family:inherit;font-size:var(--text-fine);color:var(--color-ink-muted-48);border-radius:var(--radius-pill);cursor:pointer;max-width:130px;transition:border-color var(--transition-fast);background:0 0;border:1px solid #0000;padding:2px 6px}.voice-select:hover{border-color:var(--color-hairline)}.voice-select:focus{border-color:var(--color-primary);outline:none}.close-btn,.expand-btn{color:var(--color-ink-muted-48);border-radius:var(--radius-pill);width:28px;height:28px;transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.close-btn:hover,.expand-btn:hover{background:var(--color-canvas-parchment)}.chat-login-prompt{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-lg);color:var(--color-ink-muted-48);font-size:var(--text-caption);text-align:center;flex-direction:column;flex:1;display:flex}.chat-login-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-pill);font-size:var(--text-caption);cursor:pointer;transition:background var(--transition-fast);border:none;align-items:center;gap:6px;padding:8px 20px;font-family:inherit;display:inline-flex}.chat-login-btn:hover{background:var(--color-primary-focus)}.chat-messages{background:var(--color-canvas);flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.message{max-width:85%}.message.user{align-self:flex-end}.message-content{border-radius:var(--radius-lg);font-size:var(--text-caption);line-height:var(--leading-caption);letter-spacing:var(--tracking-caption);padding:10px 14px}.message.user .message-content{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.message.ai .message-content{color:var(--color-ink);border:1px solid var(--color-hairline);background:#fff;border-bottom-left-radius:4px;box-shadow:0 4px 12px #00000008}.chat-input-area{background:var(--color-canvas);border-top:1px solid var(--color-hairline);gap:8px;padding:12px 16px;display:flex}.chat-input{border-radius:var(--radius-pill);font-family:inherit;font-size:var(--text-caption);color:var(--color-ink);transition:border-color var(--transition-fast);border:1px solid #00000014;outline:none;flex:1;padding:8px 16px}.chat-input:focus{border-color:var(--color-primary)}.chat-speak-btn{border-radius:var(--radius-full);background:var(--color-canvas-parchment);width:36px;height:36px;color:var(--color-ink);transition:background var(--transition-fast);border:1px solid var(--color-hairline);flex-shrink:0;justify-content:center;align-items:center;display:flex}.chat-speak-btn:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.chat-speak-btn:disabled{opacity:.3;cursor:not-allowed}.send-btn{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:36px;height:36px;transition:background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.send-btn:hover:not(:disabled){background:var(--color-primary-focus)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn.limited{background:var(--color-ink-muted-48)}.typing-indicator{align-self:flex-start;align-items:center;padding:4px;display:flex}.message-content h1,.message-content h2,.message-content h3{font-weight:var(--weight-semibold);margin-top:8px;margin-bottom:4px}.message-content h3{font-size:1rem}.message-content h2{font-size:1.1rem}.message-content blockquote{border-left:2px solid var(--color-primary);background:var(--color-notes-orange-tint);border-radius:2px;margin:8px 0;padding:4px 10px;font-style:italic}.message-content li{margin-bottom:4px;margin-left:16px}.message-content hr{border:0;border-top:1px solid var(--color-hairline);margin:10px 0}.message-content strong{font-weight:var(--weight-semibold)}.message.user .message-content a{color:#ffffffe6;text-decoration:underline}.chat-struct-container{flex-direction:column;gap:8px;display:flex}.chat-struct{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-sm);overflow:hidden}.chat-struct .card-header{border-bottom:1px solid var(--color-hairline);background:var(--color-canvas-parchment);align-items:center;gap:6px;padding:8px 10px;display:flex}.chat-struct .card-header h4{font-size:.85rem;font-weight:var(--weight-semibold);margin:0}.chat-struct .card-body{font-size:var(--text-fine);line-height:var(--leading-caption);padding:10px}.explanation-card .card-body p{margin-bottom:6px}.explanation-card .card-body ul,.explanation-card .card-body ol{margin-bottom:6px;padding-left:16px}.explanation-card .card-body li{margin-bottom:3px}.explanation-card .card-body blockquote{border-left:2px solid var(--color-primary);background:var(--color-notes-orange-tint);font-style:italic;font-size:var(--text-fine);border-radius:2px;margin:6px 0;padding:3px 8px}.comparison-card{border-left:3px solid var(--color-primary)}.comparison-grid{grid-template-columns:1fr;gap:6px;padding:8px;display:grid}.comparison-column{border-radius:var(--radius-sm);border:1px solid var(--color-hairline);background:#fff;padding:8px}.comparison-column h5{font-size:.8rem;font-weight:var(--weight-semibold);margin-bottom:4px}.comparison-column li{font-size:var(--text-fine);margin-bottom:3px}.examples-block{margin-top:0}.examples-title{font-size:.85rem;font-weight:var(--weight-semibold);background:var(--color-canvas-parchment);border-bottom:1px solid var(--color-hairline);align-items:center;gap:6px;margin:0;padding:8px 10px;display:flex}.examples-grid{flex-direction:column;gap:6px;padding:8px;display:flex}.example-item{border:1px solid var(--color-hairline);border-radius:var(--radius-sm);background:#fff;padding:8px}.example-sentence{font-size:.85rem;font-weight:var(--weight-semibold);font-style:italic;line-height:var(--leading-body);border-left:2px solid var(--color-hairline);margin-bottom:4px;padding-left:6px}.quiz-card{border-left:3px solid var(--color-primary)}.quiz-question{font-size:.85rem;font-weight:var(--weight-semibold);line-height:var(--leading-body);margin-bottom:10px}.quiz-options-list{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.quiz-opt-btn{text-align:left;border-radius:var(--radius-pill);border:1px solid var(--color-hairline);background:var(--color-canvas);width:100%;color:var(--color-ink);font-size:var(--text-fine);font-weight:var(--weight-regular);transition:all var(--transition-fast);cursor:pointer;font-family:var(--font-body);padding:6px 10px}.quiz-btn{font-size:var(--text-fine);padding:6px 14px}.quiz-feedback{border-radius:var(--radius-sm);border:1px solid #0000;margin-top:8px;padding:8px}.quiz-feedback.correct{background:var(--color-success-bg);border-color:var(--color-success)}.quiz-feedback.incorrect{background:var(--color-error-bg);border-color:var(--color-error)}.correct-answer-reveal{font-weight:var(--weight-semibold);font-size:var(--text-fine);color:var(--color-success);margin-top:4px}.typing-blinker{animation:1s step-end infinite blinker}@keyframes blinker{50%{opacity:0}}.streaming{opacity:.85}.loading-animation{justify-content:center;align-items:center;display:flex}.btn{font-family:var(--font-body);font-weight:var(--weight-regular);line-height:var(--leading-button);border-radius:var(--radius-pill);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-sm{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);padding:8px 16px}.btn-md{font-size:var(--text-body);letter-spacing:var(--tracking-body);padding:11px 22px}.btn-lg{font-size:var(--text-button-large);font-weight:var(--weight-light);letter-spacing:0;padding:14px 28px}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-focus)}.btn-secondary{color:var(--color-primary);border:1px solid var(--color-primary);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--color-notes-orange-tint)}.btn-ghost{color:var(--color-ink-muted-48);background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){color:var(--color-primary);background:var(--color-canvas-parchment)}.btn-pearl{background:var(--color-surface-pearl);color:var(--color-ink-muted-80);border:3px solid var(--color-divider-soft);border-radius:var(--radius-md)}.btn-pearl:hover:not(:disabled){background:var(--color-canvas-parchment)}.btn-dark{background:var(--color-ink);color:var(--color-body-on-dark);border-radius:var(--radius-sm);font-size:var(--text-button-utility);letter-spacing:var(--tracking-button-utility);padding:8px 15px}.btn-dark:hover:not(:disabled){opacity:.9}.btn-icon{align-items:center;display:flex}.card{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.card-pad-sm{padding:var(--space-sm)}.card-pad-md{padding:var(--space-lg)}.card-pad-lg{padding:var(--space-xl)}.card-hover:hover{border-color:var(--color-primary);box-shadow:var(--shadow-hairline)}.card-clickable{cursor:pointer}.card-header{margin-bottom:var(--space-sm)}.card-body{flex:1}.card-footer{margin-top:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.input-wrapper{align-items:center;gap:var(--space-xs);background:var(--color-canvas);border-radius:var(--radius-pill);height:44px;transition:border-color var(--transition-fast);border:1px solid #00000014;padding:12px 20px;display:flex}.input-wrapper:focus-within{border-color:var(--color-primary)}.input-icon{color:var(--color-ink-muted-48);flex-shrink:0;align-items:center;display:flex}.input-field{font-size:var(--text-body);font-weight:var(--weight-regular);font-family:var(--font-body);color:var(--color-ink);letter-spacing:var(--tracking-body);background:0 0;border:none;outline:none;flex:1}.input-field::placeholder{color:var(--color-ink-muted-48)}.badge{width:fit-content;font-weight:var(--weight-semibold);white-space:nowrap;border-radius:var(--radius-pill);font-family:var(--font-body);align-items:center;display:inline-flex}.badge-sm{font-size:var(--text-fine);letter-spacing:var(--tracking-fine);padding:4px 10px}.badge-md{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);padding:6px 14px}.badge-default{background:var(--color-canvas-parchment);color:var(--color-ink-muted-80)}.badge-primary{background:var(--color-primary);color:#fff}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-clickable{cursor:pointer;transition:opacity var(--transition-fast)}.badge-clickable:hover{opacity:.8}.progress-container{width:100%}.progress-label{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);color:var(--color-ink-muted-48);margin-bottom:var(--space-xxs);justify-content:space-between;display:flex}.progress-track{background:var(--color-canvas-parchment);border-radius:var(--radius-pill);overflow:hidden}.progress-sm{height:4px}.progress-md{height:6px}.progress-lg{height:10px}.progress-fill{border-radius:var(--radius-pill);height:100%;transition:width .5s}.progress-fill-primary{background:var(--color-primary)}.progress-fill-accent{background:var(--color-primary-on-dark)}.progress-fill-success{background:var(--color-success)}.home-root{flex-direction:column;display:flex}.product-tile{width:100%;padding:var(--space-section) 0;justify-content:center;display:flex}.tile-light{background:var(--color-canvas)}.tile-parchment{background:var(--color-canvas-parchment)}.tile-dark{background:var(--color-surface-tile-1)}.tile-content{text-align:center;width:100%;max-width:980px;padding:0 24px}.tile-narrow{max-width:840px}.tile-hero{font-family:var(--font-display);font-size:var(--text-hero);font-weight:var(--weight-semibold);line-height:var(--leading-hero);letter-spacing:var(--tracking-hero);color:var(--color-ink);margin-bottom:var(--space-sm)}.tile-heading{font-family:var(--font-display);font-size:var(--text-display-lg);font-weight:var(--weight-semibold);line-height:var(--leading-display-lg);color:var(--color-ink);margin-bottom:var(--space-xl)}.tile-heading-light{color:var(--color-body-on-dark)}.tile-lead{font-family:var(--font-display);font-size:var(--text-lead);font-weight:var(--weight-regular);line-height:var(--leading-lead);letter-spacing:var(--tracking-lead);color:var(--color-ink);margin-bottom:var(--space-xl);max-width:600px;margin-left:auto;margin-right:auto}.tile-actions{justify-content:center;gap:var(--space-sm);display:flex}.tile-header-row{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;display:flex}.tile-link{font-size:var(--text-body);font-weight:var(--weight-regular);letter-spacing:var(--tracking-body);color:var(--color-primary);transition:gap var(--transition-fast);align-items:center;gap:4px;text-decoration:none;display:flex}.tile-link:hover{color:var(--color-primary);gap:8px}.stats-grid{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=640px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-lg);align-items:center;gap:var(--space-sm);text-align:center;flex-direction:column;display:flex}.stat-icon{color:var(--color-primary);opacity:.7}.stat-info{flex-direction:column;gap:2px;display:flex}.stat-value{font-family:var(--font-display);font-size:var(--text-display-md);font-weight:var(--weight-semibold);line-height:var(--leading-display-md);letter-spacing:var(--tracking-display-md);color:var(--color-ink)}.stat-label{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);color:var(--color-ink-muted-48)}.units-mini-grid{gap:var(--space-md);text-align:left;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.unit-mini-card{background:var(--color-surface-tile-2);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-xs);transition:border-color var(--transition-fast), background var(--transition-fast);border:1px solid #0000;flex-direction:column;text-decoration:none;display:flex}.unit-mini-card:hover{border-color:var(--color-primary);background:#f09a380d}.unit-mini-badge{width:fit-content;color:var(--color-body-muted);border-radius:var(--radius-pill);font-size:var(--text-fine);letter-spacing:var(--tracking-fine);font-weight:var(--weight-semibold);background:#ffffff1a;padding:3px 10px;display:inline-block}.unit-mini-title{font-family:var(--font-display);font-size:var(--text-tagline);font-weight:var(--weight-semibold);line-height:var(--leading-tagline);letter-spacing:var(--tracking-tagline);color:var(--color-body-on-dark)}.unit-mini-desc{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);color:var(--color-body-muted);line-height:var(--leading-caption);flex:1}.unit-mini-exercises{font-size:var(--text-fine);letter-spacing:var(--tracking-fine);color:var(--color-ink-muted-48)}.unit-mini-footer{justify-content:space-between;align-items:center;margin-top:.5rem;display:flex}.unit-mini-progress{border-radius:var(--radius-pill);font-variant-numeric:tabular-nums;padding:2px 8px;font-size:.75rem;font-weight:700}.unit-mini-progress-strong{color:#34c759;background:#34c75926}.unit-mini-progress-moderate{color:#f09a38;background:#f09a3826}.unit-mini-progress-weak{color:#ff453a;background:#ff453a26}.unit-mini-progress-ip{color:#007aff;background:#007aff26}@media (width<=768px){.tile-hero{font-size:var(--text-display-lg);line-height:var(--leading-display-lg)}.tile-lead{font-size:var(--text-lead-airy);line-height:var(--leading-lead-airy);letter-spacing:var(--tracking-lead-airy)}.tile-content{padding:0 16px}.product-tile{padding:var(--space-xxl) 0}}@media (width<=480px){.tile-hero{font-size:1.75rem}.tile-heading{font-size:1.5rem}.units-mini-grid{grid-template-columns:1fr}}.units-root{flex-direction:column;display:flex}.units-grid{gap:var(--space-md);text-align:left;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.unit-card-link{text-decoration:none;display:block}.unit-card{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-xs);transition:border-color var(--transition-fast);flex-direction:column;height:100%;display:flex}.unit-card:hover{border-color:var(--color-primary)}.unit-card-badge{background:var(--color-canvas-parchment);width:fit-content;color:var(--color-ink-muted-80);border-radius:var(--radius-pill);font-size:var(--text-fine);letter-spacing:var(--tracking-fine);font-weight:var(--weight-semibold);padding:3px 10px;display:inline-block}.unit-card-title{font-family:var(--font-display);font-size:var(--text-tagline);font-weight:var(--weight-semibold);line-height:var(--leading-tagline);letter-spacing:var(--tracking-tagline);color:var(--color-ink);margin-top:var(--space-xs)}.unit-card-desc{font-size:var(--text-caption);line-height:var(--leading-caption);letter-spacing:var(--tracking-caption);color:var(--color-ink-muted-48);flex:1}.unit-card-footer{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-hairline);justify-content:space-between;align-items:center;display:flex}.unit-card-exercises{font-size:var(--text-fine);letter-spacing:var(--tracking-fine);color:var(--color-ink-muted-48)}.unit-card-progress{border-radius:var(--radius-pill);font-variant-numeric:tabular-nums;padding:2px 8px;font-size:.75rem;font-weight:700}.unit-card-progress-strong{color:#34c759;background:#34c75926}.unit-card-progress-moderate{color:#f09a38;background:#f09a3826}.unit-card-progress-weak{color:#ff453a;background:#ff453a26}.unit-card-progress-ip{color:#007aff;background:#007aff26}.unit-card-cta{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);color:var(--color-primary);font-weight:var(--weight-semibold);transition:gap var(--transition-fast);align-items:center;gap:4px;display:flex}.unit-card:hover .unit-card-cta{gap:8px}@media (width<=480px){.units-grid{grid-template-columns:1fr}}.exercises-container{gap:var(--space-xl);text-align:left;flex-direction:column;display:flex}.exercise-card{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-xl)}@media (width<=480px){.exercise-card{padding:var(--space-lg)}}.exercise-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.exercise-number{font-weight:var(--weight-semibold);color:var(--color-primary);font-size:var(--text-body)}.exercise-question{font-size:var(--text-body);margin-bottom:var(--space-lg);color:var(--color-ink);line-height:var(--leading-body);letter-spacing:var(--tracking-body)}.options-grid{gap:var(--space-sm);flex-direction:column;display:flex}.option-btn{padding:var(--space-sm) var(--space-lg);border:1px solid var(--color-hairline);border-radius:var(--radius-pill);background:var(--color-canvas);color:var(--color-ink);text-align:left;font-size:var(--text-caption);transition:all var(--transition-fast);font-family:var(--font-body)}.option-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-canvas-parchment)}.option-btn.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.option-btn.correct{border-color:var(--color-success);background:var(--color-success-bg);color:var(--color-success)}.option-btn.incorrect{border-color:var(--color-error);background:var(--color-error-bg);color:var(--color-error)}.blank-input{border:none;border-bottom:2px solid var(--color-hairline);color:var(--color-primary);font-size:var(--text-body);font-family:inherit;font-weight:var(--weight-semibold);text-align:center;width:150px;transition:border-color var(--transition-fast);background:0 0;outline:none;padding:4px 8px}.blank-input:focus{border-color:var(--color-primary)}.blank-input.correct{border-color:var(--color-success);color:var(--color-success)}.blank-input.incorrect{border-color:var(--color-error);color:var(--color-error)}.feedback-section{margin-top:var(--space-lg);padding:var(--space-md);border-radius:var(--radius-sm)}.feedback-section.correct{background:var(--color-success-bg);border:1px solid var(--color-success);color:var(--color-success)}.feedback-section.incorrect{background:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error)}.feedback-header{align-items:center;gap:var(--space-xs);font-weight:var(--weight-semibold);margin-bottom:var(--space-xs);display:flex}.check-btn-container{margin-top:var(--space-lg);justify-content:flex-end;display:flex}.unit-reader-container{background:var(--color-canvas-parchment);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);flex-direction:column;height:600px;display:flex;overflow:hidden}@media (width<=768px){.unit-reader-container{height:500px;max-height:60vh}}.unit-reader-header{align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-lg);background:var(--color-canvas-parchment);border-bottom:1px solid var(--color-hairline);color:var(--color-ink);font-weight:var(--weight-semibold);font-size:var(--text-body);display:flex}.unit-reader-workspace{padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;flex:1;display:flex;overflow-y:auto}.reader-card{border:1px solid var(--color-hairline);border-radius:var(--radius-lg);background:#fff;flex-shrink:0;overflow:hidden;box-shadow:0 4px 12px #00000008}.reader-card .card-header{align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-hairline);background:var(--color-canvas-parchment);display:flex}.reader-card .card-header h4{font-size:var(--text-body);font-weight:var(--weight-semibold);color:var(--color-ink);margin:0}.reader-card .card-body{padding:var(--space-lg)}.explanation-card,.comparison-card,.quiz-card{border-left:3px solid var(--color-primary)}.explanation-card .card-body p{margin-bottom:var(--space-sm);color:var(--color-ink);font-size:var(--text-caption);line-height:var(--leading-body)}.explanation-card .card-body p:last-child{margin-bottom:0}.explanation-card .card-body strong{font-weight:var(--weight-semibold)}.explanation-card .card-body ul,.explanation-card .card-body ol{padding-left:var(--space-lg);margin-bottom:var(--space-sm)}.explanation-card .card-body li{color:var(--color-ink);font-size:var(--text-caption);margin-bottom:4px}.explanation-card .card-body blockquote{margin:var(--space-sm) 0;padding:var(--space-xs) var(--space-md);border-left:2px solid var(--color-primary);background:var(--color-notes-orange-tint);font-style:italic;font-size:var(--text-caption);border-radius:2px}.comparison-grid{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=640px){.comparison-grid{grid-template-columns:1fr}}.comparison-column{padding:var(--space-md);border-radius:var(--radius-sm);background:var(--color-canvas);border:1px solid var(--color-hairline)}.comparison-column h5{font-size:var(--text-caption);font-weight:var(--weight-semibold);margin-bottom:var(--space-sm);color:var(--color-ink)}.comparison-column.left-col,.comparison-column.right-col{border-left:3px solid var(--color-primary)}.comparison-column ul{padding-left:var(--space-lg)}.comparison-column li{font-size:var(--text-caption);color:var(--color-ink);margin-bottom:4px}.examples-container-block{margin-top:var(--space-xs);flex-shrink:0}.examples-grid{gap:var(--space-md);flex-direction:column;display:flex}.example-item-card{border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-md);background:#fff;box-shadow:0 4px 12px #00000008}.example-badge{font-size:var(--text-micro);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.05em;background:var(--color-notes-orange-tint);color:#8a4e08;border-radius:var(--radius-pill);margin-bottom:var(--space-sm);padding:4px 8px;display:inline-block}.example-sentence{font-size:var(--text-body);font-weight:var(--weight-semibold);color:var(--color-ink);margin-bottom:var(--space-xs);font-style:italic;line-height:var(--leading-body);border-left:2px solid var(--color-hairline);padding-left:var(--space-sm)}.example-desc{font-size:var(--text-caption);color:#555558;line-height:var(--leading-caption)}.quiz-question{font-size:var(--text-body);font-weight:var(--weight-semibold);color:var(--color-ink);margin-bottom:var(--space-lg);line-height:var(--leading-body)}.quiz-options-list{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.quiz-opt-btn{text-align:left;width:100%;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-pill);border:1px solid var(--color-hairline);background:var(--color-canvas);color:var(--color-ink);font-size:var(--text-caption);font-weight:var(--weight-regular);transition:all var(--transition-fast);cursor:pointer;font-family:var(--font-body)}.quiz-opt-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-canvas-parchment)}.quiz-opt-btn.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.quiz-opt-btn.correct{border-color:var(--color-success);background:var(--color-success-bg);color:var(--color-success)}.quiz-opt-btn.incorrect{border-color:var(--color-error);background:var(--color-error-bg);color:var(--color-error)}.quiz-opt-btn:disabled{cursor:not-allowed}.quiz-action-area{justify-content:flex-end;display:flex}.quiz-feedback{padding:var(--space-md);border-radius:var(--radius-sm);margin-top:var(--space-lg);border:1px solid #0000}.quiz-feedback.correct{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-ink)}.quiz-feedback.incorrect{background:var(--color-error-bg);border-color:var(--color-error);color:var(--color-ink)}.feedback-header{font-size:var(--text-body);font-weight:var(--weight-semibold);margin-bottom:var(--space-xs)}.quiz-feedback.correct .feedback-header{color:var(--color-success)}.quiz-feedback.incorrect .feedback-header{color:var(--color-error)}.feedback-desc{font-size:var(--text-caption);line-height:var(--leading-caption)}.correct-answer-reveal{margin-top:var(--space-xs);font-weight:var(--weight-semibold);font-size:var(--text-caption);color:var(--color-success)}.reader-loading-skeleton{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;flex-shrink:0;display:flex}.skeleton-loader-line.progress{background:linear-gradient(90deg, var(--color-hairline) 25%, var(--color-primary) 50%, var(--color-hairline) 75%);border-radius:var(--radius-pill);background-size:200% 100%;height:4px;animation:1.5s infinite loading-animation}.loading-status{align-items:center;gap:var(--space-xs);color:var(--color-ink-muted-48);font-size:var(--text-caption);display:flex}.spinner{border:2px solid var(--color-hairline);border-top-color:var(--color-primary);border-radius:var(--radius-full);width:18px;height:18px;animation:1s linear infinite spin}.streaming-indicator{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);color:var(--color-ink-muted-48);font-size:var(--text-caption);margin-top:var(--space-xs);align-self:flex-start;display:flex}.unit-reader-input-area{gap:var(--space-xs);padding:var(--space-md);background:var(--color-canvas);border-top:1px solid var(--color-hairline);display:flex}.unit-reader-input{border-radius:var(--radius-pill);background:var(--color-canvas);color:var(--color-ink);font-size:var(--text-caption);font-family:var(--font-body);transition:border-color var(--transition-fast);border:1px solid #00000014;flex:1;padding:8px 16px}.unit-reader-input:focus{border-color:var(--color-primary);outline:none}.unit-reader-send-btn{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:36px;height:36px;transition:background var(--transition-fast);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.unit-reader-send-btn:hover:not(:disabled){background:var(--color-primary-focus)}.unit-reader-send-btn:disabled{opacity:.4;cursor:not-allowed}@keyframes spin{to{transform:rotate(360deg)}}@keyframes loading-animation{0%{background-position:200% 0}to{background-position:-200% 0}}.playground-container{text-align:left;flex-direction:column;min-height:500px;display:flex}.playground-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.playground-header h1{font-family:var(--font-display);font-size:var(--text-display-md);font-weight:var(--weight-semibold);align-items:center;gap:var(--space-sm);color:var(--color-ink);display:flex}.playground-header p{color:var(--color-ink-muted-48);font-size:var(--text-caption)}.playground-workspace{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);flex:1;min-height:400px;overflow:hidden}.chat-area{flex-direction:column;height:100%;display:flex}.messages-list{padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-bubble-container{gap:var(--space-sm);max-width:85%;display:flex}.chat-bubble-container.user{flex-direction:row-reverse;align-self:flex-end}.chat-bubble-container.ai{align-self:flex-start}.chat-bubble-content{gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.chat-bubble{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);font-size:var(--text-caption);line-height:var(--leading-caption)}.chat-bubble-container.user .chat-bubble{background:var(--color-primary);color:#fff}.chat-bubble-container.ai .chat-bubble{background:var(--color-canvas-parchment);color:var(--color-ink);border:1px solid var(--color-hairline)}.chat-bubble p{margin-bottom:var(--space-sm)}.chat-bubble p:last-child{margin-bottom:0}.chat-bubble ul,.chat-bubble ol{margin-left:var(--space-lg);margin-bottom:var(--space-sm)}.chat-bubble blockquote{border-left:2px solid var(--color-primary);padding-left:var(--space-sm);margin:var(--space-sm) 0;color:var(--color-ink-muted-48)}.chat-controls{padding:var(--space-lg);border-top:1px solid var(--color-hairline);background:var(--color-canvas)}.sample-selector-header{align-items:center;gap:var(--space-xs);font-size:var(--text-caption);font-weight:var(--weight-semibold);color:var(--color-ink);margin-bottom:var(--space-md);display:flex}.suggestions-grid{gap:var(--space-sm);grid-template-columns:repeat(2,1fr);display:grid}.suggestion-btn{align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);background:var(--color-canvas-parchment);text-align:left;transition:all var(--transition-fast);font-family:var(--font-body);display:flex}.suggestion-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-notes-orange-tint)}.suggestion-btn:disabled{opacity:.6;cursor:not-allowed}.suggestion-btn .sug-icon{margin-top:2px;font-size:1.5rem;line-height:1}.sug-info{flex-direction:column;gap:2px;display:flex}.suggestion-btn .sug-text{font-size:var(--text-caption);font-weight:var(--weight-semibold);color:var(--color-ink)}.sug-desc{font-size:var(--text-fine);color:var(--color-ink-muted-48);line-height:var(--leading-caption)}.widget-card{border-radius:var(--radius-lg);border:1px solid var(--color-hairline);margin-top:var(--space-xs);flex-direction:column;display:flex;overflow:hidden}.widget-card-header{padding:var(--space-sm) var(--space-lg);background:var(--color-canvas-parchment);border-bottom:1px solid var(--color-hairline);justify-content:space-between;align-items:center;display:flex}.widget-title{align-items:center;gap:var(--space-xs);font-weight:var(--weight-semibold);font-size:var(--text-caption);color:var(--color-ink);display:flex}.widget-tabs{background:var(--color-canvas);border-radius:var(--radius-sm);border:1px solid var(--color-hairline);gap:4px;padding:4px;display:flex}.widget-tabs .tab-btn{font-size:var(--text-fine);font-weight:var(--weight-regular);border-radius:calc(var(--radius-sm) - 2px);color:var(--color-ink-muted-48);transition:all var(--transition-fast);font-family:var(--font-body);align-items:center;gap:4px;padding:4px 12px;display:flex}.widget-tabs .tab-btn:hover{color:var(--color-ink);background:var(--color-canvas-parchment)}.widget-tabs .tab-btn.active{color:var(--color-primary);background:var(--color-notes-orange-tint)}.widget-card-body{padding:var(--space-lg);background:var(--color-canvas);min-height:200px}.code-display{background:var(--color-surface-tile-1);color:var(--color-body-on-dark);padding:var(--space-md);border-radius:var(--radius-sm);font-family:Courier New,Courier,monospace;font-size:var(--text-caption);max-height:400px;margin:0;overflow-x:auto}.active-widget-view{background:var(--color-canvas);flex-direction:column;width:100%;height:100%;display:flex}.active-widget-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-hairline);background:var(--color-canvas-parchment);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.back-chat-btn{align-items:center;gap:var(--space-xs);color:var(--color-primary);cursor:pointer;font-weight:var(--weight-semibold);font-size:var(--text-caption);border-radius:var(--radius-sm);transition:all var(--transition-fast);font-family:var(--font-body);background:0 0;border:none;padding:6px 12px;display:inline-flex}.back-chat-btn:hover{background:var(--color-notes-orange-tint);color:var(--color-primary)}@media (width<=768px){.suggestions-grid{grid-template-columns:1fr}.chat-bubble-container{max-width:95%}}@media (width<=480px){.chat-bubble-container{max-width:100%}.suggestions-grid{grid-template-columns:1fr}}.chat-bubble .chat-struct-container{flex-direction:column;gap:8px;display:flex}.chat-bubble .chat-struct{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-sm);overflow:hidden}.chat-bubble .chat-struct .card-header{border-bottom:1px solid var(--color-hairline);background:var(--color-canvas-parchment);align-items:center;gap:6px;padding:8px 10px;display:flex}.chat-bubble .chat-struct .card-header h4{font-size:.85rem;font-weight:var(--weight-semibold);margin:0}.chat-bubble .chat-struct .card-body{font-size:var(--text-fine);line-height:var(--leading-caption);padding:10px}.chat-bubble .explanation-card{border-left:3px solid var(--color-primary)}.chat-bubble .explanation-card .card-body p{margin-bottom:6px}.chat-bubble .explanation-card .card-body strong{font-weight:var(--weight-semibold)}.chat-bubble .explanation-card .card-body ul,.chat-bubble .explanation-card .card-body ol{margin-bottom:6px;padding-left:16px}.chat-bubble .explanation-card .card-body li{margin-bottom:3px}.chat-bubble .explanation-card .card-body blockquote{border-left:2px solid var(--color-primary);background:var(--color-notes-orange-tint);font-style:italic;font-size:var(--text-fine);border-radius:2px;margin:6px 0;padding:3px 8px}.chat-bubble .comparison-card{border-left:3px solid var(--color-primary)}.chat-bubble .comparison-grid{grid-template-columns:1fr;gap:6px;padding:8px;display:grid}.chat-bubble .comparison-column{border-radius:var(--radius-sm);background:var(--color-canvas-parchment);border:1px solid var(--color-hairline);padding:8px}.chat-bubble .comparison-column h5{font-size:.8rem;font-weight:var(--weight-semibold);margin-bottom:4px}.chat-bubble .comparison-column ul{padding-left:14px}.chat-bubble .comparison-column li{font-size:var(--text-fine);margin-bottom:3px}.chat-bubble .examples-title{font-size:.85rem;font-weight:var(--weight-semibold);background:var(--color-canvas-parchment);border-bottom:1px solid var(--color-hairline);align-items:center;gap:6px;margin:0;padding:8px 10px;display:flex}.chat-bubble .examples-grid{flex-direction:column;gap:6px;padding:8px;display:flex}.chat-bubble .example-item{background:var(--color-canvas-parchment);border:1px solid var(--color-hairline);border-radius:var(--radius-sm);padding:8px}.chat-bubble .example-badge{font-size:.65rem;font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.05em;background:var(--color-notes-orange-tint);color:var(--color-primary);border-radius:var(--radius-pill);margin-bottom:4px;padding:2px 6px;display:inline-block}.chat-bubble .example-sentence{font-size:.85rem;font-weight:var(--weight-semibold);font-style:italic;line-height:var(--leading-body);border-left:2px solid var(--color-hairline);margin-bottom:4px;padding-left:6px}.chat-bubble .example-desc{font-size:var(--text-fine);color:var(--color-ink-muted-48);line-height:var(--leading-caption)}.chat-bubble .quiz-card{border-left:3px solid var(--color-primary)}.chat-bubble .quiz-question{font-size:.85rem;font-weight:var(--weight-semibold);line-height:var(--leading-body);margin-bottom:10px}.chat-bubble .quiz-options-list{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.chat-bubble .quiz-opt-btn{text-align:left;border-radius:var(--radius-pill);border:1px solid var(--color-hairline);background:var(--color-canvas);width:100%;color:var(--color-ink);font-size:var(--text-fine);font-weight:var(--weight-regular);transition:all var(--transition-fast);cursor:pointer;font-family:var(--font-body);padding:6px 10px}.chat-bubble .quiz-opt-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-canvas-parchment)}.chat-bubble .quiz-opt-btn.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.chat-bubble .quiz-opt-btn.correct{border-color:var(--color-success);background:var(--color-success-bg);color:var(--color-success)}.chat-bubble .quiz-opt-btn.incorrect{border-color:var(--color-error);background:var(--color-error-bg);color:var(--color-error)}.chat-bubble .quiz-opt-btn:disabled{cursor:not-allowed}.chat-bubble .quiz-action-area{justify-content:flex-end;display:flex}.chat-bubble .quiz-btn{font-size:var(--text-fine);padding:6px 14px}.chat-bubble .quiz-feedback{border-radius:var(--radius-sm);border:1px solid #0000;margin-top:8px;padding:8px}.chat-bubble .quiz-feedback.correct{background:var(--color-success-bg);border-color:var(--color-success)}.chat-bubble .quiz-feedback.incorrect{background:var(--color-error-bg);border-color:var(--color-error)}.chat-bubble .feedback-header{font-size:.85rem;font-weight:var(--weight-semibold);margin-bottom:4px}.chat-bubble .quiz-feedback.correct .feedback-header{color:var(--color-success)}.chat-bubble .quiz-feedback.incorrect .feedback-header{color:var(--color-error)}.chat-bubble .feedback-desc{font-size:var(--text-fine);line-height:var(--leading-caption)}.chat-bubble .correct-answer-reveal{font-weight:var(--weight-semibold);font-size:var(--text-fine);color:var(--color-success);margin-top:4px}.chat-bubble .typing-blinker{animation:1s step-end infinite blinker}.compile-spin-icon{color:var(--color-primary);animation:1.2s linear infinite spin}.chat-bubble .streaming{opacity:.85}.unit-detail-root{flex-direction:column;display:flex}.detail-topbar{background:var(--color-canvas);border-bottom:1px solid var(--color-divider-soft);z-index:50;height:52px;transition:top var(--transition-normal);justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:44px}.global-nav.hidden~.main-content .detail-topbar{top:0}.detail-back{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);color:var(--color-primary);font-weight:var(--weight-regular);transition:gap var(--transition-fast);align-items:center;gap:6px;text-decoration:none;display:flex}.detail-back:hover{color:var(--color-primary);gap:10px}.detail-topbar-tabs{align-items:center;gap:4px;display:flex}.detail-tab{font-family:var(--font-body);font-size:var(--text-button-utility);letter-spacing:var(--tracking-button-utility);color:var(--color-ink-muted-48);border-radius:var(--radius-pill);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;gap:6px;padding:8px 18px;display:flex}.detail-tab:hover{background:var(--color-notes-orange-tint);color:var(--color-primary)}.detail-tab.active{background:var(--color-primary);color:#fff}.tab-pane{display:none}.tab-pane.active{display:block}.theory-content{font-size:var(--text-body);line-height:var(--leading-body);color:var(--color-ink)}.theory-content h2{font-family:var(--font-display);font-size:var(--text-display-md);font-weight:var(--weight-semibold);line-height:var(--leading-display-md);letter-spacing:var(--tracking-display-md);margin:var(--space-xl) 0 var(--space-sm)}.theory-content h3{font-family:var(--font-display);font-size:var(--text-tagline);font-weight:var(--weight-semibold);line-height:var(--leading-tagline);letter-spacing:var(--tracking-tagline);margin:var(--space-lg) 0 var(--space-xs)}.theory-content p{margin-bottom:var(--space-md)}.theory-content ul,.theory-content ol{margin-bottom:var(--space-md);padding-left:var(--space-lg)}.theory-content li{margin-bottom:var(--space-xs)}.theory-content table{border-collapse:collapse;width:100%;margin:var(--space-lg) 0;background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);overflow:hidden}.theory-content th{background:var(--color-canvas-parchment);font-weight:var(--weight-semibold);text-align:left;padding:var(--space-sm) var(--space-md);font-size:var(--text-caption);letter-spacing:var(--tracking-caption);border-bottom:1px solid var(--color-hairline)}.theory-content td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-hairline);font-size:var(--text-caption)}.theory-content tr:last-child td{border-bottom:none}.theory-content blockquote{margin:var(--space-md) 0;padding:var(--space-sm) var(--space-md);border-left:3px solid var(--color-primary);background:var(--color-notes-orange-tint);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.theory-content code{background:var(--color-canvas-parchment);border-radius:var(--radius-xs);padding:2px 6px;font-size:.9em}.theory-content pre{background:var(--color-surface-tile-1);color:var(--color-body-on-dark);padding:var(--space-md);border-radius:var(--radius-lg);margin:var(--space-md) 0;overflow-x:auto}.theory-content pre code{background:0 0;padding:0}.theory-content img{border-radius:var(--radius-lg);max-width:100%;margin:var(--space-md) 0}.theory-content hr{border:none;border-top:1px solid var(--color-hairline);margin:var(--space-xl) 0}.detail-progress-badge{background:var(--color-canvas-parchment);border-radius:var(--radius-pill);color:var(--color-ink);border:1px solid var(--color-hairline);align-items:center;gap:6px;padding:4px 12px;font-size:.8rem;font-weight:600;display:flex}.detail-progress-pct{font-variant-numeric:tabular-nums}.detail-status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.detail-status-dot.strong{background:var(--color-success)}.detail-status-dot.moderate{background:var(--color-primary)}.detail-status-dot.weak{background:var(--color-error)}.detail-status-dot.in-progress{background:#007aff}@media (width<=768px){.detail-topbar{flex-wrap:wrap;gap:8px;height:auto;min-height:44px;padding:8px 16px}.detail-topbar-tabs{width:100%;overflow-x:auto}}.vocab-root{flex-direction:column;display:flex}.voice-picker{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);color:var(--color-ink-muted-48);align-items:center;gap:8px;display:flex}.voice-picker select{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-sm);color:var(--color-ink);font-size:var(--text-caption);cursor:pointer;font-family:var(--font-body);padding:4px 8px}.vocab-sections{gap:var(--space-sm);text-align:left;flex-direction:column;display:flex}.vocab-section{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);overflow:hidden}.vocab-section:hover,.vocab-section.open{border-color:var(--color-primary)}.vocab-section-header{width:100%;padding:var(--space-md) var(--space-lg);cursor:pointer;font-size:var(--text-body);color:var(--color-ink);text-align:left;transition:background var(--transition-fast);font-family:var(--font-body);background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.vocab-section-header:hover{background:var(--color-canvas-parchment)}.vocab-section-title{align-items:center;gap:var(--space-xs);color:var(--color-ink);display:flex}.vocab-section-title span:first-child{color:var(--color-ink-muted-48)}.vocab-section-body{padding:0 var(--space-lg) var(--space-lg);border-top:1px solid var(--color-hairline)}.vocab-table-wrapper{margin-top:var(--space-md);overflow-x:auto}.vocab-table{border-collapse:collapse;width:100%;font-size:var(--text-caption)}.vocab-table th{text-align:left;padding:var(--space-sm) var(--space-md);background:var(--color-canvas-parchment);color:var(--color-ink-muted-80);font-weight:var(--weight-semibold);font-size:var(--text-fine);letter-spacing:.03em;text-transform:uppercase;border-bottom:1px solid var(--color-hairline)}.vocab-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-hairline);vertical-align:top;line-height:var(--leading-caption)}.vocab-table tr:last-child td{border-bottom:none}.vocab-detail-row td{padding:var(--space-xs) var(--space-md) var(--space-md);font-size:var(--text-fine);color:var(--color-ink-muted-48);line-height:var(--leading-caption);border-bottom:1px solid var(--color-hairline)}.vocab-detail-row td strong{color:var(--color-ink-muted-80);margin-right:4px}.vocab-detail-meaning{display:block}.vocab-detail-example{margin-top:4px;display:block}.vocab-table tr:hover td{background:var(--color-canvas-parchment)}.vocab-word{white-space:normal}.vocab-word strong{color:var(--color-ink)}.vocab-ipa{font-family:DejaVu Sans Mono,Menlo,Consolas,monospace;font-size:var(--text-caption);color:var(--color-ink-muted-48);white-space:nowrap}.vocab-pos{background:var(--color-notes-orange-tint);color:var(--color-primary);border-radius:var(--radius-pill);font-size:var(--text-fine);font-weight:var(--weight-semibold);padding:2px 8px;display:inline-block}.vocab-example{color:var(--color-ink-muted-48);font-size:var(--text-caption)}.vocab-synonyms{line-height:var(--leading-caption)}.speak-btn{border:1px solid var(--color-hairline);border-radius:var(--radius-full);color:var(--color-ink-muted-48);cursor:pointer;vertical-align:middle;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;margin-left:6px;padding:2px 5px;display:inline-flex}.speak-btn:hover{color:var(--color-primary);border-color:var(--color-primary)}.speak-btn:active{transform:scale(.9)}.linking-grid{gap:var(--space-md);margin-top:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.linking-card{background:var(--color-canvas-parchment);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-md)}.linking-category{font-size:var(--text-caption);color:var(--color-primary);font-weight:var(--weight-semibold);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.linking-list{margin:0;padding:0;list-style:none}.linking-list li{font-size:var(--text-caption);color:var(--color-ink);border-bottom:1px dashed var(--color-hairline);padding:6px 0}.linking-list li:last-child{border-bottom:none}.vocab-empty{text-align:center;padding:var(--space-xxl);color:var(--color-ink-muted-48);font-size:var(--text-caption)}@media (width<=768px){.vocab-table{font-size:var(--text-fine)}.vocab-table th,.vocab-table td{padding:var(--space-xs) var(--space-sm)}.vocab-word{white-space:normal}.linking-grid{grid-template-columns:1fr}.word-table thead{display:none}.word-table tbody,.word-table tbody tr{display:block}.word-table tbody tr{background:var(--color-canvas-parchment);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-sm);margin-bottom:var(--space-sm)}.word-table tbody tr:hover td{background:0 0}.word-table td{vertical-align:middle;border:none;padding:4px 0;display:block}.word-table td:before{content:attr(data-label);font-weight:var(--weight-semibold);font-size:var(--text-micro);text-transform:uppercase;letter-spacing:.06em;color:var(--color-ink-muted-48);margin-bottom:2px;display:block}.word-table td.vocab-word:before{display:none}.word-table .vocab-pos{margin-top:2px}.word-table .vocab-detail-row{background:var(--color-canvas-parchment);border:1px solid var(--color-hairline);border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:0 var(--space-sm) var(--space-sm);margin-top:-1px;margin-bottom:var(--space-sm);border-top:none;display:block}.word-table .vocab-detail-row td{font-size:var(--text-fine);color:var(--color-ink-muted-48);border:none;padding:4px 0;display:block}.word-table .vocab-detail-row td strong{color:var(--color-ink-muted-80)}.word-table .vocab-detail-meaning{display:block}.word-table .vocab-detail-example{margin-top:4px;display:block}}.rd-container{max-width:1100px;padding:var(--space-section) var(--space-lg);margin:0 auto}.rd-header{margin-bottom:var(--space-xl)}.rd-header h1{font-family:var(--font-display);font-size:var(--text-display-md);font-weight:var(--weight-semibold);line-height:var(--leading-display-md);letter-spacing:var(--tracking-display-md);color:var(--color-ink);align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);display:flex}.rd-header p{color:var(--color-ink-muted-48);font-size:var(--text-body);letter-spacing:var(--tracking-body)}.rd-controls{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.rd-year-selector{align-items:center;gap:var(--space-sm);display:flex}.rd-year-selector label{font-size:var(--text-caption);font-weight:var(--weight-semibold);color:var(--color-ink-muted-48);white-space:nowrap}.rd-passage-selector{align-items:center;gap:4px;display:flex}.rd-passage-nav{border:1px solid var(--color-hairline);border-radius:var(--radius-sm);background:var(--color-canvas);color:var(--color-ink);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:6px;display:flex}.rd-passage-nav:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-notes-orange-tint)}.rd-passage-nav:disabled{opacity:.4;cursor:not-allowed}.rd-passage-tab{border:1px solid var(--color-hairline);background:var(--color-canvas);color:var(--color-ink);font-size:var(--text-caption);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body);padding:6px 16px}.rd-passage-tab:first-of-type{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.rd-passage-tab:last-of-type{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.rd-passage-tab:hover{background:var(--color-notes-orange-tint);color:var(--color-primary)}.rd-passage-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.rd-tips{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg)}.rd-tip{font-size:var(--text-caption);letter-spacing:var(--tracking-caption);color:var(--color-ink);border-bottom:1px dashed var(--color-hairline);line-height:var(--leading-caption);padding:6px 0}.rd-tip:last-child{border-bottom:none}.rd-content{gap:var(--space-lg);grid-template-columns:1fr 1fr;align-items:start;display:grid}.rd-passage{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-lg);position:sticky;top:60px}.rd-passage-title{font-family:var(--font-display);font-size:var(--text-tagline);font-weight:var(--weight-semibold);line-height:var(--leading-tagline);letter-spacing:var(--tracking-tagline);color:var(--color-ink);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-hairline)}.rd-passage-text{font-size:var(--text-caption);line-height:var(--leading-caption);color:var(--color-ink)}.rd-passage-text p{margin-bottom:var(--space-md)}.rd-passage-text p:last-child{margin-bottom:0}.rd-questions{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-lg)}.rd-questions-title{font-family:var(--font-display);font-size:var(--text-tagline);font-weight:var(--weight-semibold);line-height:var(--leading-tagline);color:var(--color-ink);margin-bottom:var(--space-md);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-hairline)}.rd-questions-list{gap:var(--space-sm);flex-direction:column;display:flex}.rd-q{gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);transition:border-color var(--transition-fast);border:1px solid #0000;display:flex}.rd-q:hover{border-color:var(--color-hairline)}.rd-q.is-correct{border-color:var(--color-success-bg);background:var(--color-success-bg)}.rd-q.is-wrong{border-color:var(--color-error-bg);background:var(--color-error-bg)}.rd-q-num{font-size:var(--text-caption);font-weight:var(--weight-bold);color:var(--color-primary);text-align:right;flex-shrink:0;min-width:1.5rem}.rd-q-body{flex:1;min-width:0}.rd-q-text{font-size:var(--text-caption);color:var(--color-ink);margin-bottom:var(--space-xs);line-height:var(--leading-caption)}.rd-options-row{flex-wrap:wrap;gap:4px;display:flex}.rd-opt-btn{border:1px solid var(--color-hairline);border-radius:var(--radius-pill);background:var(--color-canvas);color:var(--color-ink);font-size:var(--text-fine);font-weight:var(--weight-semibold);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body);padding:6px 14px}.rd-opt-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-notes-orange-tint)}.rd-opt-btn.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.rd-options-vert{flex-direction:column;gap:4px;display:flex}.rd-opt-label{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-caption);color:var(--color-ink);border:1px solid #0000;align-items:flex-start;gap:8px;padding:6px 10px;display:flex}.rd-opt-label:hover{background:var(--color-notes-orange-tint);border-color:var(--color-primary)}.rd-opt-label.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.rd-opt-label input{accent-color:var(--color-primary);margin-top:3px}.rd-opt-label-text{line-height:var(--leading-caption)}.rd-select{border:1px solid var(--color-hairline);border-radius:var(--radius-sm);background:var(--color-canvas);width:100%;color:var(--color-ink);font-size:var(--text-caption);cursor:pointer;font-family:var(--font-body);padding:8px 12px}.rd-select:focus{border-color:var(--color-primary);outline:none}.rd-input{border:1px solid var(--color-hairline);border-radius:var(--radius-sm);background:var(--color-canvas);width:100%;color:var(--color-ink);font-size:var(--text-caption);font-family:var(--font-body);padding:8px 12px}.rd-input:focus{border-color:var(--color-primary);outline:none}.rd-q-feedback{margin-top:var(--space-sm);padding-top:var(--space-xs);font-size:var(--text-fine);line-height:var(--leading-caption);border-top:1px solid}.rd-q.is-correct .rd-q-feedback{border-color:#bbf7d0}.rd-q.is-wrong .rd-q-feedback{border-color:#fecaca}.rd-q-fb-row{align-items:center;gap:4px;margin-top:4px;display:flex}.rd-q-fb-row:first-child{margin-top:0}.rd-q-fb-verdict{font-weight:var(--weight-bold);font-size:var(--text-fine);margin-bottom:2px}.rd-q.is-correct .rd-q-fb-verdict{color:#16a34a}.rd-q.is-wrong .rd-q-fb-verdict{color:#dc2626}.rd-q-fb-label{font-weight:var(--weight-semibold);opacity:.75;flex-shrink:0;min-width:3.5rem}.rd-q-fb-val{font-weight:var(--weight-medium)}.rd-ans-wrong{color:#dc2626;text-decoration:line-through}.rd-ans-correct{color:#16a34a;font-weight:var(--weight-bold)}.rd-q-fb-excerpt{font-size:var(--text-fine);opacity:.85;border-top:1px solid;margin-top:4px;padding-top:4px;font-style:italic}.rd-q.is-correct .rd-q-fb-excerpt{border-color:#bbf7d0}.rd-q.is-wrong .rd-q-fb-excerpt{border-color:#fecaca}.rd-q-fb-excerpt .rd-q-fb-label{margin-bottom:2px;font-style:normal;display:block}.rd-q-fb-excerpt p{margin:0}.rd-actions{gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-hairline);display:flex}.rd-score-banner{justify-content:space-between;align-items:center;gap:var(--space-md);margin-top:var(--space-lg);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);display:flex}.rd-score-banner.pass{color:#166534;background:#dcfce7}.rd-score-banner.fail{color:#991b1b;background:#fef2f2}.rd-score-banner-stats{align-items:center;gap:var(--space-sm);display:flex}.rd-score-banner-pct{font-family:var(--font-display);font-size:var(--text-display-md);font-weight:var(--weight-bold);line-height:1}.rd-score-banner-grade{font-size:var(--text-caption);font-weight:var(--weight-semibold)}.rd-score-banner-detail{font-size:var(--text-fine);opacity:.75}@media (width<=900px){.rd-content{grid-template-columns:1fr}.rd-passage{position:static}}@media (width<=768px){.rd-header h1{font-size:var(--text-display-md)}.rd-passage-selector{overflow-x:auto}.rd-passage-tab{white-space:nowrap;font-size:var(--text-fine);padding:5px 12px}.rd-questions{padding:var(--space-md)}.rd-q{padding:var(--space-xs)}.rd-year-selector{flex-wrap:wrap}}@media (width<=480px){.rd-options-row{gap:3px}.rd-opt-btn{font-size:var(--text-fine);padding:5px 10px}}.gt-root{flex-direction:column;display:flex}.gt-container{width:100%;max-width:800px;margin:0 auto}.gt-header{margin-bottom:var(--space-xl)}.gt-header h1{font-family:var(--font-display);font-size:var(--text-display-md);font-weight:var(--weight-semibold);line-height:var(--leading-display-md);letter-spacing:var(--tracking-display-md);color:var(--color-ink);align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);display:flex}.gt-header p{color:var(--color-ink-muted-48);font-size:var(--text-body);letter-spacing:var(--tracking-body)}.gt-setup{padding-top:var(--space-xxl);justify-content:center;display:flex}.gt-setup-card{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;width:100%;max-width:500px}.gt-setup-card h2{font-family:var(--font-display);font-size:var(--text-display-md);font-weight:var(--weight-semibold);line-height:var(--leading-display-md);color:var(--color-ink);margin-bottom:var(--space-sm)}.gt-setup-card>p{color:var(--color-ink-muted-48);font-size:var(--text-caption);letter-spacing:var(--tracking-caption);margin-bottom:var(--space-lg)}.gt-size-options{gap:var(--space-xs);flex-wrap:wrap;justify-content:center;display:flex}.gt-size-btn{border:1px solid var(--color-hairline);border-radius:var(--radius-pill);background:var(--color-canvas);color:var(--color-ink);font-size:var(--text-caption);font-weight:var(--weight-semibold);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body);padding:10px 20px}.gt-size-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-notes-orange-tint)}.gt-size-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.gt-progress-bar{background:var(--color-canvas-parchment);border-radius:var(--radius-pill);height:6px;margin-bottom:var(--space-lg);position:relative;overflow:hidden}.gt-progress-fill{background:var(--color-primary);border-radius:var(--radius-pill);height:100%;transition:width var(--transition-normal)}.gt-progress-text{font-size:var(--text-fine);letter-spacing:var(--tracking-fine);color:var(--color-ink-muted-48);font-weight:var(--weight-semibold);position:absolute;top:-22px;right:0}.gt-questions{gap:var(--space-lg);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.gt-q{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-lg);transition:border-color var(--transition-fast);text-align:left}.gt-q.correct{border-color:var(--color-success)}.gt-q.wrong{border-color:var(--color-error)}.gt-q-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.gt-q-num{font-weight:var(--weight-bold);color:var(--color-primary);font-size:var(--text-caption)}.gt-q-text{font-size:var(--text-body);letter-spacing:var(--tracking-body);color:var(--color-ink);margin-bottom:var(--space-md);line-height:var(--leading-body)}.gt-options{gap:var(--space-xs);flex-direction:column;display:flex}.gt-opt-btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-hairline);border-radius:var(--radius-pill);background:var(--color-canvas);color:var(--color-ink);text-align:left;font-size:var(--text-caption);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.gt-opt-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-canvas-parchment)}.gt-opt-btn.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.gt-opt-btn.correct{border-color:var(--color-success);background:var(--color-success-bg);color:var(--color-success)}.gt-opt-btn.incorrect{border-color:var(--color-error);background:var(--color-error-bg);color:var(--color-error)}.gt-blank-input{border:none;border-bottom:2px solid var(--color-hairline);color:var(--color-primary);font-size:var(--text-body);font-family:inherit;font-weight:var(--weight-semibold);text-align:center;width:140px;transition:border-color var(--transition-fast);background:0 0;outline:none;padding:2px 6px}.gt-blank-input:focus{border-color:var(--color-primary)}.gt-blank-input.correct{border-color:var(--color-success);color:var(--color-success)}.gt-blank-input.incorrect{border-color:var(--color-error);color:var(--color-error)}.gt-feedback{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm)}.gt-feedback.correct{background:var(--color-success-bg);border:1px solid var(--color-success)}.gt-feedback.incorrect{background:var(--color-error-bg);border:1px solid var(--color-error)}.gt-feedback-header{align-items:center;gap:var(--space-xs);font-weight:var(--weight-semibold);font-size:var(--text-caption);margin-bottom:var(--space-xs);color:var(--color-ink);display:flex}.gt-feedback-exp{font-size:var(--text-caption);color:var(--color-ink);line-height:var(--leading-caption)}.gt-actions{gap:var(--space-sm);padding-top:var(--space-lg);border-top:1px solid var(--color-hairline);display:flex}.gt-results-bar{padding:var(--space-md) 0;position:sticky;bottom:0}.gt-results-bar-inner{padding:var(--space-sm) var(--space-lg);background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;display:flex}.gt-results-badge{font-weight:var(--weight-bold);font-size:var(--text-body);border-radius:var(--radius-pill);padding:6px 16px}.gt-results-badge.pass{background:var(--color-success-bg);color:var(--color-success)}.gt-results-badge.fail{background:var(--color-error-bg);color:var(--color-error)}@media (width<=480px){.gt-q{padding:var(--space-md)}.gt-setup-card{padding:var(--space-lg)}.gt-actions{flex-direction:column}.gt-results-bar-inner{gap:var(--space-sm);text-align:center;flex-direction:column}}.progress-root{flex-direction:column;display:flex}.progress-overview-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.progress-ov-card{background:var(--color-canvas-parchment);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);align-items:center;gap:1rem;padding:1.25rem;display:flex;position:relative}.progress-ov-icon-wrap{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.ov-icon-overall{color:#f09a38;background:#f09a381f}.ov-icon-started{color:#007aff;background:#007aff1f}.ov-icon-strong{color:#34c759;background:#34c7591f}.ov-icon-weak{color:#ff453a;background:#ff453a1f}.progress-ov-info{flex-direction:column;gap:2px;display:flex}.progress-ov-value{font-family:var(--font-display);font-variant-numeric:tabular-nums;color:var(--color-ink);font-size:1.5rem;font-weight:700}.progress-ov-label{color:var(--color-ink-muted-48);font-size:.8rem}.progress-ov-ring{flex-shrink:0;margin-left:auto}.progress-section-header{align-items:center;gap:.5rem;margin-bottom:1.25rem;display:flex}.progress-section-title{font-family:var(--font-display);margin:0;font-size:1.15rem;font-weight:600}.progress-status-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.75rem;display:grid}.progress-status-card{border-radius:var(--radius-lg);transition:border-color var(--transition-fast);flex-direction:column;gap:.35rem;padding:1rem;text-decoration:none;display:flex}.progress-status-card h3{color:var(--color-ink);margin:0;font-size:.85rem;font-weight:600}.status-weak{background:#ff453a0a;border:1px solid #ff453a33}.status-weak:hover{border-color:#ff453a}.status-moderate{background:#f09a380a;border:1px solid #f09a3833}.status-moderate:hover{border-color:#f09a38}.status-inprogress{background:#007aff0a;border:1px solid #007aff33}.status-inprogress:hover{border-color:#007aff}.status-strong{background:#34c7590a;border:1px solid #34c75933}.status-strong:hover{border-color:#34c759}.progress-status-badge{border-radius:var(--radius-pill);letter-spacing:.02em;width:fit-content;padding:2px 10px;font-size:.65rem;font-weight:700;display:inline-block}.badge-weak{color:#ff453a;background:#ff453a1f}.badge-moderate{color:#f09a38;background:#f09a381f}.badge-inprogress{color:#007aff;background:#007aff1f}.badge-strong{color:#34c759;background:#34c7591f}.progress-status-unit{color:var(--color-ink-muted-48);font-size:.7rem;font-weight:600}.progress-status-score{font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:700}.status-weak .progress-status-score{color:#ff453a}.status-moderate .progress-status-score{color:#f09a38}.status-strong .progress-status-score{color:#34c759}.progress-status-subscore{color:var(--color-ink-muted-48);font-variant-numeric:tabular-nums;font-size:1rem;font-weight:600}.progress-cta-link{color:var(--color-primary);align-items:center;gap:4px;margin-top:.25rem;font-size:.75rem;font-weight:600;display:flex}.progress-unit-list{flex-direction:column;gap:.5rem;display:flex}.progress-unit-wrapper{flex-direction:column;gap:0;display:flex}.progress-unit-row{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);cursor:pointer;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1rem;text-decoration:none;display:flex}.progress-unit-row:hover{border-color:var(--color-primary)}.progress-unit-row.expanded{border-color:var(--color-primary);border-bottom-right-radius:0;border-bottom-left-radius:0}.progress-unit-bar-wrap{flex-direction:column;gap:.35rem;min-width:140px;display:flex}.progress-unit-progress-done{padding:.25rem 0}.progress-done-text{color:var(--color-ink-muted-48);font-variant-numeric:tabular-nums;font-size:.8rem;font-weight:600}.progress-expand-icon{transition:transform var(--transition-fast);color:var(--color-ink-muted-48);flex-shrink:0}.progress-expand-icon.open{transform:rotate(180deg)}.progress-unit-detail{border:1px solid var(--color-primary);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);background:var(--color-canvas);border-top:none;flex-direction:column;gap:.35rem;padding:.75rem 1rem;display:flex}.progress-detail-empty{color:var(--color-ink-muted-48);padding:.5rem 0;font-size:.8rem}.progress-exercise-row{border-radius:var(--radius-sm);transition:background var(--transition-fast);justify-content:space-between;align-items:center;gap:.75rem;padding:.5rem;display:flex}.progress-exercise-row:hover{background:var(--color-canvas-parchment)}.progress-exercise-left{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.progress-exercise-num{color:var(--color-ink-muted-48);flex-shrink:0;font-size:.75rem;font-weight:600}.progress-exercise-text{color:var(--color-ink);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.progress-exercise-badge{border-radius:var(--radius-pill);flex-shrink:0;padding:2px 8px;font-size:.65rem;font-weight:600}.detail-icon{flex-shrink:0}.detail-correct .progress-exercise-badge{color:#34c759;background:#34c7591f}.detail-wrong .progress-exercise-badge{color:#ff453a;background:#ff453a1f}.detail-na .progress-exercise-badge{background:var(--color-canvas-parchment);color:var(--color-ink-muted-48)}.detail-icon.detail-correct{color:#34c759}.detail-icon.detail-wrong{color:#ff453a}.detail-icon.detail-na{color:var(--color-ink-muted-48)}.progress-unit-left{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.progress-unit-id{border-radius:var(--radius-md);background:var(--color-canvas-parchment);width:36px;height:36px;color:var(--color-ink-muted-48);flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.progress-unit-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.progress-unit-title-row{align-items:center;gap:.5rem;min-width:0;display:flex}.progress-unit-title{color:var(--color-ink);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.unit-row-status{border-radius:var(--radius-pill);flex-shrink:0;padding:1px 8px;font-size:.65rem;font-weight:700}.unit-row-status-ip{color:#007aff;background:#007aff1f}.unit-row-status-strong{color:#34c759;background:#34c7591f}.unit-row-status-moderate{color:#f09a38;background:#f09a381f}.unit-row-status-weak{color:#ff453a;background:#ff453a1f}.unit-row-status-na{background:var(--color-canvas-parchment);color:var(--color-ink-muted-48)}.progress-unit-sub{color:var(--color-ink-muted-48);font-size:.75rem}.progress-unit-right{flex-direction:column;flex-shrink:0;gap:.35rem;min-width:140px;display:flex}.progress-unit-scores{flex-wrap:wrap;gap:.4rem;display:flex}.progress-unit-score-tag{border-radius:var(--radius-pill);padding:1px 6px;font-size:.65rem;font-weight:600}.score-exercise{color:#007aff;background:#007aff1a}.score-playground{color:#f09a38;background:#f09a381a}.progress-notstarted-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;display:grid}.progress-notstarted-card{background:var(--color-surface-tile-2);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);border:1px solid #0000;flex-direction:column;gap:.35rem;padding:1rem;text-decoration:none;display:flex}.progress-notstarted-card:hover{border-color:var(--color-primary)}.progress-notstarted-card h3{color:var(--color-body-on-dark);margin:0;font-size:.85rem;font-weight:600}@media (width<=640px){.progress-unit-row{flex-direction:column;align-items:flex-start;gap:.75rem}.progress-unit-right{width:100%;min-width:0}.progress-overview-grid{grid-template-columns:1fr 1fr}}.login-page{background:var(--color-canvas);justify-content:center;align-items:center;min-height:calc(100vh - 44px);display:flex}.login-card{background:var(--color-canvas);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-xxl) var(--space-xl);text-align:center;width:100%;max-width:380px}.login-card h1{font-family:var(--font-display);font-size:var(--text-display-lg);font-weight:var(--weight-semibold);line-height:var(--leading-display-lg);color:var(--color-ink);margin-bottom:var(--space-xs)}.login-card p{color:var(--color-ink-muted-48);font-size:var(--text-caption);margin-bottom:var(--space-xl)}.login-error{color:var(--color-error);font-size:var(--text-caption);margin-bottom:var(--space-md);padding:var(--space-xs) var(--space-sm);background:var(--color-error-bg);border-radius:var(--radius-sm)}.google-btn{border-radius:var(--radius-pill);background:var(--color-primary);color:#fff;font-size:var(--text-body);font-family:var(--font-body);font-weight:var(--weight-regular);cursor:pointer;transition:background var(--transition-fast);border:none;align-items:center;gap:10px;padding:11px 28px;display:inline-flex}.google-btn:hover{background:var(--color-primary-focus)}.google-btn:active{transform:scale(.95)}:root{--color-primary:#f09a38;--color-primary-focus:#d87e1f;--color-primary-on-dark:#f09a38;--color-ink:#1c1c1e;--color-body:#1c1c1e;--color-body-on-dark:#f2f2f2;--color-body-muted:#8e8e93;--color-ink-muted-80:#1c1c1e;--color-ink-muted-48:#8e8e93;--color-divider-soft:#edead8;--color-hairline:#edead8;--color-canvas:#fffbed;--color-canvas-parchment:#faf6e3;--color-surface:#fff;--color-bg:#fff1dd;--color-surface-pearl:#fffbed;--color-surface-tile-1:#1a1a1a;--color-surface-tile-2:#262626;--color-surface-tile-3:#333;--color-surface-black:#1a1a1a;--color-surface-chip:#f2edd6;--color-success:#34c759;--color-success-bg:#d1fae5;--color-error:#ff3b30;--color-error-bg:#fee2e2;--color-notes-orange-tint:#fff1dd;--color-folder-yellow:#f5d773;--color-highlight-yellow:#ffeb78;--font-display:"Inter", system-ui, -apple-system, sans-serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--text-hero:3.5rem;--text-display-lg:2.5rem;--text-display-md:2.125rem;--text-lead:1.75rem;--text-lead-airy:1.5rem;--text-tagline:1.3125rem;--text-body:1.0625rem;--text-body-strong:1.0625rem;--text-caption:.875rem;--text-button-large:1.125rem;--text-button-utility:.875rem;--text-fine:.75rem;--text-micro:.625rem;--text-nav:.75rem;--weight-light:300;--weight-regular:400;--weight-semibold:600;--weight-bold:700;--leading-hero:1.07;--leading-display-lg:1.1;--leading-display-md:1.47;--leading-lead:1.14;--leading-lead-airy:1.5;--leading-tagline:1.19;--leading-body:1.47;--leading-dense:2.41;--leading-caption:1.43;--leading-button:1;--leading-fine:1;--leading-micro:1.3;--leading-nav:1;--tracking-hero:-.28px;--tracking-display-lg:0;--tracking-display-md:-.374px;--tracking-lead:.196px;--tracking-lead-airy:0;--tracking-tagline:.231px;--tracking-body:-.374px;--tracking-body-strong:-.374px;--tracking-caption:-.224px;--tracking-button-utility:-.224px;--tracking-fine:-.12px;--tracking-micro:-.08px;--tracking-nav:-.12px;--space-xxs:4px;--space-xs:8px;--space-sm:12px;--space-md:17px;--space-lg:24px;--space-xl:32px;--space-xxl:48px;--space-section:80px;--radius-none:0;--radius-xs:5px;--radius-sm:8px;--radius-md:11px;--radius-lg:18px;--radius-pill:9999px;--radius-full:50%;--shadow-product:#f09a384d 0 4px 12px;--shadow-hairline:0 0 0 1px #00000014;--transition-fast:.15s ease;--transition-normal:.3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);font-size:var(--text-body);font-weight:var(--weight-regular);line-height:var(--leading-body);letter-spacing:var(--tracking-body);background-color:var(--color-canvas);color:var(--color-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-focus)}button{cursor:pointer;background:0 0;border:none;font-family:inherit}img{max-width:100%;height:auto}.text-muted{color:var(--color-ink-muted-48)}.text-center{text-align:center}.apple-pill{font-family:var(--font-body);font-size:var(--text-body);font-weight:var(--weight-regular);line-height:var(--leading-button);border-radius:var(--radius-pill);transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:6px;padding:11px 22px;text-decoration:none;display:inline-flex}.apple-pill:active{transform:scale(.95)}.product-shadow{box-shadow:var(--shadow-product)}.btn-primary{font-family:var(--font-body);font-size:var(--text-caption);font-weight:var(--weight-regular);line-height:var(--leading-button);border-radius:var(--radius-pill);background-color:var(--color-primary);color:#fff;cursor:pointer;transition:background var(--transition-fast);border:none;justify-content:center;align-items:center;gap:6px;padding:11px 22px;text-decoration:none;display:inline-flex}.btn-primary:active{transform:scale(.95)}.btn-primary:hover{background-color:var(--color-primary-focus)}
