@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600&display=swap";.home-hero{min-height:100vh;padding:var(--spacing-2xl) var(--spacing-2xl) var(--spacing-2xl) 8%;isolation:isolate;flex-direction:column;justify-content:center;align-items:flex-start;display:flex;position:relative}.home-hero:before{content:"";opacity:.78;filter:brightness(.96)saturate(.92);z-index:-1;background-image:url(/hero-bg.png);background-position:50% 20%;background-size:cover;position:absolute;inset:0}.home-content{text-align:left;max-width:480px;animation:fadeInUp var(--transition-slow) ease both;-webkit-backdrop-filter:blur(6px);background:#ffffffdb;border-radius:20px;padding:44px 48px}.home-headline{letter-spacing:-.5px;color:#0f0f0f;margin-bottom:var(--spacing-lg);font-size:36px;font-weight:700;line-height:1.2}.home-subtext{color:#3a3a3a;margin-bottom:var(--spacing-xl);font-size:15px;line-height:1.65}.home-cta-row{flex-wrap:wrap;justify-content:flex-start;gap:12px;display:flex}.home-content .btn-large{padding:15px 30px;font-size:17px}.home-scroll-hint{color:var(--color-text-secondary);opacity:.5;animation:2s ease-in-out infinite scrollBounce;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}@keyframes scrollBounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(6px)}}.home-showcase{background:var(--color-bg);border-top:.5px solid var(--color-border);padding:var(--spacing-4xl) var(--spacing-2xl)}.home-showcase-inner{max-width:1100px;margin:0 auto}.home-showcase-header{text-align:center;margin-bottom:var(--spacing-3xl)}.home-showcase-title{letter-spacing:-.3px;color:var(--color-text-primary);margin:0 0 var(--spacing-sm);font-size:28px;font-weight:700}.home-showcase-sub{color:var(--color-text-secondary);margin:0;font-size:15px}.home-showcase-rows{flex-direction:column;gap:80px;display:flex}.home-feature-row{opacity:0;align-items:center;gap:60px;transition:opacity .55s,transform .55s;display:flex;transform:translateY(24px)}.home-feature-row.is-visible{opacity:1;transform:none}.home-feature-row.is-reversed{flex-direction:row-reverse}.home-feature-screenshot{flex:0 0 58%}.home-feature-screenshot img{border:1px solid var(--color-border);border-radius:10px;width:100%;display:block;box-shadow:0 6px 32px #00000017}.home-feature-copy{flex:1;min-width:0}.home-feature-pain{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-secondary);margin:0 0 12px;font-size:11px;font-weight:600}.home-feature-headline{color:var(--color-text-primary);letter-spacing:-.3px;margin:0 0 14px;font-size:22px;font-weight:700;line-height:1.3}.home-feature-body{color:var(--color-text-secondary);margin:0;font-size:15px;line-height:1.75}.home-showcase-cta{padding-top:var(--spacing-3xl);margin-top:var(--spacing-3xl);text-align:center;border-top:.5px solid var(--color-border)}@media (width<=600px){.home-hero{padding:var(--spacing-xl) var(--spacing-lg);align-items:center}.home-content{text-align:center;max-width:100%;padding:32px 24px}.home-headline{font-size:30px}.home-subtext{font-size:16px}.home-cta-row{justify-content:center}.home-showcase{padding:var(--spacing-2xl) var(--spacing-lg)}.home-showcase-title{font-size:22px}.home-showcase-rows{gap:48px}.home-feature-row,.home-feature-row.is-reversed{flex-direction:column;gap:28px}.home-feature-screenshot{flex:none;width:100%}}.auth-page{min-height:100vh;padding:var(--spacing-2xl);justify-content:center;align-items:center;display:flex}.auth-card{width:100%;max-width:420px;padding:var(--spacing-2xl)}.onboarding-page{height:100vh;padding:var(--spacing-xl) var(--spacing-lg) var(--spacing-lg);flex-direction:column;align-items:center;display:flex;overflow:hidden}.onboarding-progress{margin-bottom:var(--spacing-3xl);gap:8px;display:flex}.onboarding-dot{background-color:var(--color-border);width:8px;height:8px;transition:all var(--transition-normal);border-radius:50%}.onboarding-dot.active{background-color:var(--color-primary);transform:scale(1.3)}.onboarding-dot.completed{background-color:var(--color-primary);opacity:.4}.onboarding-content{width:100%;max-width:560px;min-height:0;padding-bottom:var(--spacing-md);flex:1;overflow-y:auto}.onboarding-nav{width:100%;max-width:560px;margin-top:var(--spacing-2xl);padding-top:var(--spacing-lg);align-items:center;display:flex}.step-heading{margin-bottom:var(--spacing-lg);font-size:24px;font-weight:600;line-height:1.3}.step-subtext{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);font-size:15px;line-height:1.6}.language-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.language-card{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-md);flex-direction:column;display:flex}.language-card .emoji{font-size:36px;line-height:1}.language-card .name{font-size:15px;font-weight:500}.level-grid{gap:var(--spacing-md);flex-direction:column;display:flex}.level-card{text-align:left}.level-card .level-name{margin-bottom:4px;font-size:16px;font-weight:600}.level-card .level-desc{color:var(--color-text-primary);font-size:15px;line-height:1.55}.level-floor-hint{color:var(--color-text-secondary);margin-top:var(--spacing-lg);opacity:.85;font-size:13px;line-height:1.5}.level-reassurance{color:var(--color-text-secondary);margin-top:var(--spacing-sm);font-size:13px;line-height:1.5}.level-card .level-features{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.level-feature-chip{color:var(--color-text-secondary);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-pill);white-space:nowrap;padding:3px 9px;font-size:11px;font-weight:500}.card-selected .level-feature-chip{color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, transparent);border-color:color-mix(in srgb, var(--color-primary) 30%, transparent)}.pill-grid{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.goal-grid{gap:var(--spacing-md);flex-direction:column;display:flex}.goal-card{text-align:left}.goal-card .goal-title{margin-bottom:4px;font-size:16px;font-weight:600}.goal-card .goal-desc{color:var(--color-text-secondary);font-size:14px;line-height:1.5}.persona-grid{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.persona-card{text-align:left}.persona-card .persona-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.persona-card .persona-name{font-size:16px;font-weight:600}.persona-card .persona-meta{color:var(--color-text-secondary);margin-top:2px;font-size:13px}.persona-preview-btn{border:1.5px solid var(--color-primary);width:30px;height:30px;color:var(--color-primary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;transition:background .15s,color .15s,opacity .15s;display:flex}.persona-preview-btn:hover:not(:disabled),.persona-preview-btn.playing{background:var(--color-primary);color:#fff}.persona-preview-btn.unavailable{border-color:var(--color-text-secondary);color:var(--color-text-secondary);opacity:.35;cursor:default}.persona-card .persona-bio{color:var(--color-text-secondary);margin-bottom:10px;font-size:14px;line-height:1.5}.persona-card .persona-traits{flex-wrap:wrap;gap:6px;display:flex}.persona-card .trait-pill{border-radius:var(--radius-pill);background-color:var(--color-bg);color:var(--color-text-secondary);padding:4px 10px;font-size:12px;font-weight:500}.subcategory-group{margin-bottom:var(--spacing-xl)}.subcategory-group .group-label{margin-bottom:var(--spacing-sm);color:var(--color-text-primary);font-size:15px;font-weight:600}.subcategory-freetext{margin-top:var(--spacing-sm);border-radius:var(--radius-input);border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text-primary);transition:border-color var(--transition-fast);outline:none;padding:8px 12px;font-size:13px}.subcategory-freetext:focus{border-color:var(--color-primary)}.subcategory-freetext::placeholder{color:var(--color-text-secondary)}.subcategory-loading{justify-content:center;align-items:center;gap:var(--spacing-md);padding:var(--spacing-4xl) 0;text-align:center;flex-direction:column;display:flex}.subcategory-loading-bar-track{background:var(--color-border);border-radius:999px;width:280px;height:4px;overflow:hidden}.subcategory-loading-bar-fill{background:var(--color-primary);border-radius:999px;width:0%;height:100%;animation:10s ease-out forwards loadingBar}@keyframes loadingBar{0%{width:0%}60%{width:75%}85%{width:88%}to{width:93%}}.subcategory-loading-text{color:var(--color-text-primary);margin:0;font-size:16px;font-weight:600}.subcategory-loading-sub{color:var(--color-text-secondary);max-width:320px;margin:0;font-size:14px}.onboarding-save-page{min-height:100vh;padding:var(--spacing-2xl);justify-content:center;align-items:center;display:flex}.onboarding-save-page .auth-card{width:100%;max-width:420px;padding:var(--spacing-2xl)}.settings-overlay{z-index:100;background-color:#0003;animation:.2s both fadeIn;position:fixed;inset:0}.settings-panel{background-color:var(--color-surface);z-index:101;flex-direction:column;width:440px;max-width:100vw;animation:.25s both slideInRight;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 24px #00000014}.settings-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.settings-body{padding:var(--spacing-xl);flex:1;overflow-y:auto}.settings-group{margin-bottom:var(--spacing-xl)}.settings-group .form-label{margin-bottom:var(--spacing-sm);display:block}.settings-footer{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-border);flex-wrap:wrap;flex-shrink:0;display:flex}.settings-footer-actions{gap:var(--spacing-sm);margin-left:auto;display:flex}.settings-save-error{width:100%;margin:0}.settings-hint,.settings-voice-hint{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:13px;line-height:1.5}.settings-panel .persona-grid{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.settings-panel .persona-card{text-align:left}.settings-panel .persona-card .persona-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.settings-panel .persona-card .persona-name{font-size:15px;font-weight:600}.settings-panel .persona-card .persona-meta{color:var(--color-text-secondary);margin-top:2px;font-size:12px}.settings-panel .persona-preview-btn{border:1.5px solid var(--color-primary);width:28px;height:28px;color:var(--color-primary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;transition:background .15s,color .15s,opacity .15s;display:flex}.settings-panel .persona-preview-btn:hover:not(:disabled),.settings-panel .persona-preview-btn.playing{background:var(--color-primary);color:#fff}.settings-panel .persona-preview-btn.unavailable{border-color:var(--color-text-secondary);color:var(--color-text-secondary);opacity:.35;cursor:default}.settings-panel .persona-card .persona-bio{color:var(--color-text-secondary);margin-bottom:8px;font-size:13px;line-height:1.5}.settings-panel .persona-card .persona-traits{flex-wrap:wrap;gap:5px;display:flex}.settings-panel .persona-card .trait-pill{border-radius:var(--radius-pill);background-color:var(--color-bg);color:var(--color-text-secondary);padding:3px 8px;font-size:11px;font-weight:500}.settings-danger-zone{margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:1px solid var(--color-border)}.settings-delete-btn{color:#ef4444;border-radius:var(--radius-md);cursor:pointer;background:0 0;border:1px solid #ef4444;padding:8px 16px;font-size:14px;transition:background .15s,color .15s}.settings-delete-btn:hover:not(:disabled){color:#fff;background:#ef4444}.settings-delete-btn:disabled{opacity:.6;cursor:not-allowed}.settings-delete-confirm{gap:var(--spacing-md);flex-direction:column;display:flex}.settings-delete-message{color:var(--color-text-secondary);margin:0;font-size:14px;line-height:1.5}.settings-delete-actions{gap:var(--spacing-sm);display:flex}.dashboard-page{min-height:100vh;padding:var(--spacing-2xl) var(--spacing-lg)}.dashboard-container{max-width:640px;margin:0 auto}.dashboard-header{margin-bottom:var(--spacing-2xl);justify-content:space-between;align-items:center;display:flex}.dashboard-greeting{color:var(--color-text-secondary);font-size:16px;font-weight:400}.dashboard-header-actions{align-items:center;gap:4px;display:flex}.dashboard-settings{border-radius:50%;padding:8px}.dashboard-greeting-wrap{flex-direction:column;gap:2px;display:flex}.dashboard-greeting-sub{color:var(--color-text-secondary);opacity:.85;font-size:14px}.dashboard-cta{width:100%;margin-bottom:var(--spacing-2xl);padding:22px 40px;font-size:18px}.dashboard-container .card{border:.5px solid var(--color-border);box-shadow:none}.relationship-card{padding:var(--spacing-lg) var(--spacing-xl);margin-bottom:var(--spacing-xl);background:var(--color-transcript-ai,var(--color-surface))}.relationship-title{color:var(--color-text-primary);margin-bottom:var(--spacing-md);font-size:17px;font-weight:500;line-height:1.4}.relationship-facts{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.relationship-fact{color:var(--color-text-primary);padding-left:18px;font-size:15px;line-height:1.5;position:relative}.relationship-fact:before{content:"";background:var(--color-primary);border-radius:50%;width:6px;height:6px;position:absolute;top:9px;left:2px}.relationship-more{margin-top:var(--spacing-md);color:var(--color-primary);text-underline-offset:2px;cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;text-decoration:underline}.relationship-more:hover{opacity:.75}.memory-modal-hint{color:var(--color-text-secondary);padding-bottom:var(--spacing-sm);border-bottom:.5px solid var(--color-border);margin-bottom:4px;font-size:12px}.memory-modal-list{padding:var(--spacing-md) var(--spacing-xl);flex-direction:column;gap:4px;margin:0;list-style:none;display:flex;overflow-y:auto}.memory-modal-fact{color:var(--color-text-primary);font-size:15px;line-height:1.6}.memory-fact-view-row{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:6px 4px;transition:background .12s;display:flex}.memory-fact-view-row:hover{background:var(--color-bg-hover,#0000000a)}.memory-fact-text{word-break:break-word;flex:1}.memory-fact-actions{opacity:0;flex-shrink:0;gap:2px;transition:opacity .12s;display:flex}.memory-fact-view-row:hover .memory-fact-actions{opacity:1}.memory-fact-action{color:var(--color-text-secondary);border-radius:var(--radius-sm);padding:4px}.memory-fact-action:hover{color:var(--color-text-primary)}.memory-fact-delete:hover{color:#c0392b}.memory-fact-edit-row{align-items:center;gap:6px;padding:2px 4px;display:flex}.memory-fact-input{border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text-primary);outline:none;flex:1;padding:5px 8px;font-size:15px}.relationship-empty{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);text-align:center;font-size:14px;line-height:1.6}@media (width>=900px){.dashboard-container{max-width:1040px}.dashboard-layout{column-gap:var(--spacing-2xl);grid-template-rows:auto 1fr;grid-template-columns:1fr 340px;align-items:start;display:grid}.dashboard-cta-slot{grid-area:1/1}.dashboard-sidebar-col{grid-area:1/2/3}.dashboard-sessions-col{grid-area:2/1}.dashboard-cta{margin-bottom:var(--spacing-2xl)}}.footprint-grid{gap:var(--spacing-md);margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(3,1fr);display:grid}.footprint-item{text-align:center;flex-direction:column;align-items:center;gap:2px;display:flex}.footprint-number{color:var(--color-text-primary);font-size:30px;font-weight:500;line-height:1.1}.footprint-label{color:var(--color-text-secondary);font-size:13px}.footprint-progress-link{color:var(--color-text-secondary);text-align:center;grid-column:1/-1;margin-top:2px;padding:0;font-size:13px}.produced-section{margin-bottom:var(--spacing-2xl)}.produced-section .heading-section{margin-bottom:var(--spacing-md)}.produced-grid{gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);display:grid}.produced-item{background:var(--color-surface);border:.5px solid var(--color-border);border-radius:var(--radius-input,10px);flex-direction:column;gap:2px;min-width:0;padding:10px 12px;display:flex}.produced-word{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:500;overflow:hidden}.produced-meta{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.produced-more{width:100%;margin-top:var(--spacing-md);color:var(--color-text-secondary);text-align:center;transition:color var(--transition-fast);padding:4px 0;font-size:13px;display:block}.produced-more:hover{color:var(--color-text-primary)}.stats-row{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);grid-template-columns:1fr 1fr;display:grid}.stat-card{padding:var(--spacing-xl) var(--spacing-md);text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex;position:relative}.stat-icon{color:var(--color-primary);margin-bottom:4px}.stat-number{color:var(--color-text-primary);font-size:32px;font-weight:500;line-height:1.1}.stat-label{color:var(--color-text-secondary);font-size:13px;font-weight:400}.stat-chevron{color:var(--color-text-secondary);position:absolute;top:12px;right:12px}.vocab-list{margin-bottom:var(--spacing-xl);padding:var(--spacing-md);max-height:320px;overflow-y:auto}.vocab-item{border-bottom:1px solid var(--color-border);flex-direction:column;padding:10px 0;display:flex}.vocab-item:last-child{border-bottom:none}.vocab-word{color:var(--color-text-primary);font-size:15px;font-weight:500}.vocab-translation{color:var(--color-text-secondary);margin-top:2px;font-size:13px}.sessions-section{margin-top:var(--spacing-lg)}.sessions-section .heading-section{margin-bottom:var(--spacing-md)}.sessions-list{gap:var(--spacing-sm);flex-direction:column;max-height:520px;padding-right:4px;display:flex;overflow-y:auto}.session-card{padding:var(--spacing-md) var(--spacing-lg)}.session-header{justify-content:space-between;align-items:flex-start;display:flex}.session-topic-block{margin-right:var(--spacing-md);flex-direction:column;flex:1;gap:3px;display:flex}.session-topic{color:var(--color-text-primary);font-size:15px;font-weight:700}.session-topic-en{color:var(--color-text-secondary);font-size:13px;font-weight:400}.session-meta{color:var(--color-text-secondary);white-space:nowrap;font-size:13px}.session-feedback{color:var(--color-text-secondary);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);font-size:14px;line-height:1.6}.sessions-load-more{width:100%;margin-top:var(--spacing-md);color:var(--color-text-secondary);font-size:14px}.words-modal-backdrop{z-index:200;background:#00000059;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}@media (width>=540px){.words-modal-backdrop{padding:var(--spacing-lg);align-items:center}}.words-modal{background:var(--color-surface);border-radius:var(--radius-card) var(--radius-card) 0 0;flex-direction:column;width:100%;max-width:600px;max-height:80vh;display:flex;overflow:hidden}@media (width>=540px){.words-modal{border-radius:var(--radius-card);max-height:70vh}}.words-modal-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:.5px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.words-modal-title{color:var(--color-text-primary);font-size:16px;font-weight:500}.words-modal-close{color:var(--color-text-secondary);border-radius:50%;padding:6px}.words-modal-grid{gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);grid-template-columns:repeat(3,1fr);display:grid;overflow-y:auto}.words-modal-grid .produced-word,.words-modal-grid .produced-meta{white-space:normal;text-overflow:clip;word-break:break-word;overflow:visible}.session-start-page{min-height:100vh;padding:var(--spacing-2xl);justify-content:center;align-items:center;display:flex}.session-start-container{text-align:center;width:100%;max-width:900px}.topic-grid{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=700px){.topic-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.topic-grid{grid-template-columns:1fr}}.topic-card{padding:var(--spacing-lg);text-align:left;transition:all var(--transition-normal)}.topic-card:hover{border-color:var(--color-primary)}.topic-text{color:var(--color-text-primary);font-size:15px;line-height:1.5}.topic-card-skeleton{background:linear-gradient(90deg, var(--color-surface) 25%, var(--color-bg) 50%, var(--color-surface) 75%);background-size:200% 100%;height:80px;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.surprise-btn{margin-top:var(--spacing-sm)}.custom-topic-section{margin-top:var(--spacing-xl)}.custom-topic-divider{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);color:var(--color-text-muted);font-size:.85rem;display:flex}.custom-topic-divider:before,.custom-topic-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.custom-topic-input-row{gap:var(--spacing-sm);max-width:560px;margin:0 auto;display:flex}.custom-topic-input{padding:10px var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);transition:border-color var(--transition-normal);flex:1;font-size:.95rem}.custom-topic-input::placeholder{color:var(--color-text-muted)}.custom-topic-input:focus{border-color:var(--color-primary);outline:none}.custom-topic-submit{flex-shrink:0;padding:10px 14px}.duration-picker{margin-bottom:var(--spacing-md)}.duration-label{color:var(--color-text-muted);margin-bottom:var(--spacing-sm);font-size:.85rem;display:block}.duration-chips{gap:var(--spacing-sm);justify-content:center;display:flex}.duration-chip{max-width:200px;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;transition:border-color var(--transition-normal), background var(--transition-normal);flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.duration-chip:hover{border-color:var(--color-primary)}.duration-chip-selected{border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, var(--color-surface))}.duration-chip-label{color:var(--color-text-primary);font-size:.95rem;font-weight:600}.duration-chip-selected .duration-chip-label{color:var(--color-primary)}.duration-chip-sublabel{color:var(--color-text-muted);font-size:.78rem}@media (width<=480px){.duration-chips{flex-direction:column;align-items:stretch}.duration-chip{justify-content:center;gap:var(--spacing-sm);flex-direction:row;max-width:none}}.session-ready-page{min-height:100vh;padding:var(--spacing-2xl);justify-content:center;align-items:center;display:flex}.session-ready-container{text-align:center;align-items:center;gap:var(--spacing-lg);flex-direction:column;width:100%;max-width:480px;display:flex}.session-ready-icon{background:var(--color-primary);color:#fff;width:72px;height:72px;margin-bottom:var(--spacing-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.session-ready-topic{color:var(--color-text-secondary);margin:0;font-size:15px}.session-ready-topic em{color:var(--color-text-primary);font-style:normal;font-weight:500}.session-ready-body{gap:var(--spacing-sm);text-align:center;margin-top:var(--spacing-sm);flex-direction:column;display:flex}.session-ready-body p{color:var(--color-text-secondary);margin:0;font-size:16px;line-height:1.65}.session-ready-cta{width:100%;margin-top:var(--spacing-sm);padding:var(--spacing-md);font-size:16px}.session-page{flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.session-topbar{padding:12px var(--spacing-lg);border-bottom:1px solid var(--color-border);background-color:var(--color-surface);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.topbar-left{align-items:center;gap:var(--spacing-sm);min-width:0;display:flex}.topbar-persona{white-space:nowrap;font-size:15px;font-weight:600}.topbar-divider{color:var(--color-text-secondary)}.topbar-topic{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.topbar-end{color:var(--color-text-secondary);white-space:nowrap;font-size:14px}.session-horizon-bar{background-color:var(--color-border);cursor:default;flex-shrink:0;height:6px;overflow:hidden}.session-horizon-bar-fill{background-color:var(--color-primary);opacity:.55;height:100%;transition:width 1s linear}.session-horizon-bar-fill.horizon-reached{opacity:.9}.horizon-choice-strip{justify-content:center;align-items:center;gap:var(--spacing-md);padding:10px var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-surface);flex-wrap:wrap;flex-shrink:0;display:flex}.horizon-choice-text{color:var(--color-text-secondary);font-size:13px}.horizon-btn{padding:6px 14px;font-size:13px}.turn-translation{color:var(--color-text-secondary);margin:5px 0 0;font-size:13px;line-height:1.5}.session-body{flex:1;grid-template-columns:3fr 1px 1fr;min-height:0;display:grid}.transcript-zone{flex-direction:column;min-width:0;display:flex;overflow:hidden}.transcript-scroll{padding:var(--spacing-xl) var(--spacing-2xl);flex:1;overflow-y:auto}.transcript-turn{margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-card);animation:.2s both fadeInUp}.turn-ai{background-color:var(--color-transcript-ai);position:relative}.turn-replay-btn{border:1px solid var(--color-border);background:var(--color-surface);width:26px;height:26px;color:var(--color-text-secondary);opacity:.55;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:opacity .15s,color .15s,border-color .15s,background .15s;display:flex;position:absolute;top:8px;right:8px}.turn-ai:hover .turn-replay-btn{opacity:1}.turn-replay-btn:hover{color:var(--color-primary);border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, transparent)}.turn-replay-btn-active{opacity:1;color:var(--color-primary);border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 12%, transparent);animation:1s ease-in-out infinite cs-play-pulse}.turn-user{background-color:#0000;position:relative}.turn-delete-btn{width:22px;height:22px;color:var(--color-text-secondary);opacity:0;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:opacity .15s,color .15s,background .15s;display:flex;position:absolute;top:8px;right:8px}.turn-user:hover .turn-delete-btn{opacity:.45}.turn-delete-btn:hover{color:#e25c5c;background:#e25c5c14;opacity:1!important}.turn-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);align-items:center;gap:8px;margin-bottom:4px;font-size:12px;font-weight:600;display:flex}.turn-simplified-badge{letter-spacing:.4px;text-transform:uppercase;color:var(--color-primary);background-color:rgba(var(--color-primary-rgb,99, 102, 241), .1);border:1px solid rgba(var(--color-primary-rgb,99, 102, 241), .25);border-radius:999px;align-items:center;padding:1px 7px;font-size:10px;font-weight:600;animation:.2s both fadeInUp;display:inline-flex}.turn-text{color:var(--color-text-primary);font-size:16px;line-height:1.65}.turn-user-placeholder{opacity:.45;animation:.2s both fadeInUp}.turn-placeholder-text{color:var(--color-text-secondary);margin:0;font-size:15px;font-style:italic;line-height:1.65}.turn-translation{color:var(--color-text-secondary);border-top:1px solid var(--color-border);margin:6px 0 0;padding-top:6px;font-size:14px;font-style:italic;line-height:1.55;animation:.15s both fadeInUp}.typing-cursor{background-color:var(--color-primary);vertical-align:text-bottom;width:2px;height:16px;margin-left:2px;animation:1s infinite pulse;display:inline-block}.highlight-correct{color:#22c55e;transition:color .9s ease-out}.highlight-correct.highlight-fading{color:var(--color-text-primary)}.listening-wave{vertical-align:middle;align-items:center;gap:3px;height:20px;display:inline-flex}.listening-wave span{background-color:var(--color-primary);border-radius:2px;width:3px;animation:1.1s ease-in-out infinite listening-wave;display:block}.listening-wave span:first-child{height:7px;animation-delay:0s}.listening-wave span:nth-child(2){height:13px;animation-delay:.15s}.listening-wave span:nth-child(3){height:18px;animation-delay:.3s}.listening-wave span:nth-child(4){height:13px;animation-delay:.45s}.listening-wave span:nth-child(5){height:7px;animation-delay:.6s}@keyframes listening-wave{0%,to{opacity:.5;transform:scaleY(.4)}50%{opacity:1;transform:scaleY(1)}}@keyframes listening-pulse{0%,60%,to{opacity:.25;transform:scale(.85)}30%{opacity:1;transform:scale(1.1)}}.mic-bar{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-2xl);border-top:1px solid var(--color-border);background-color:var(--color-surface);flex-shrink:0;display:flex}.speed-control{background:var(--color-surface-raised,color-mix(in srgb, var(--color-border) 30%, transparent));border:1px solid var(--color-border);border-radius:var(--radius-md,10px);flex-direction:column;gap:5px;margin-left:auto;padding:7px 10px 8px;display:flex}.speed-header{color:var(--color-text-secondary);-webkit-user-select:none;user-select:none;letter-spacing:.02em;align-items:center;gap:4px;font-size:11px;font-weight:500;display:flex}.speed-row{align-items:center;gap:6px;display:flex}.speed-label{color:var(--color-text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:11px}.speed-value{color:var(--color-text-secondary);text-align:right;-webkit-user-select:none;user-select:none;min-width:56px;font-size:11px;font-weight:600;transition:color .2s}.speed-value--applied{color:var(--color-primary)}.speed-value--pending{color:color-mix(in srgb, var(--color-primary) 70%, var(--color-text-secondary));font-style:italic}.speed-slider{appearance:none;background:var(--color-border);cursor:pointer;border-radius:999px;outline:none;width:150px;height:5px;transition:opacity .15s}.speed-slider:disabled{opacity:.35;cursor:default}.speed-slider::-webkit-slider-thumb{appearance:none;background:var(--color-primary);cursor:pointer;border-radius:50%;width:15px;height:15px;transition:transform .1s;box-shadow:0 1px 3px #0000002e}.speed-slider:not(:disabled)::-webkit-slider-thumb:hover{transform:scale(1.2)}.speed-slider::-moz-range-thumb{background:var(--color-primary);cursor:pointer;border:none;border-radius:50%;width:15px;height:15px;box-shadow:0 1px 3px #0000002e}.pause-btn{pointer-events:auto;align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.pause-btn-active{color:var(--color-primary)}.ptt-btn{color:var(--color-surface);background:var(--color-primary);border-radius:var(--radius-pill);cursor:pointer;pointer-events:auto;border:none;align-items:center;gap:6px;padding:9px 18px;font-size:14px;font-weight:600;animation:2s ease-in-out infinite ptt-pulse;display:flex}.ptt-btn:hover{opacity:.9}@keyframes ptt-pulse{0%,to{box-shadow:0 0 0 0 color-mix(in srgb, var(--color-primary) 40%, transparent)}50%{box-shadow:0 0 0 8px color-mix(in srgb, var(--color-primary) 0%, transparent)}}.ptt-btn-listening{cursor:default;pointer-events:none;opacity:.92;gap:8px;animation:none}.ptt-listening-wave{align-items:center;gap:2px;height:16px;display:inline-flex}.ptt-listening-wave span{background-color:var(--color-surface);border-radius:2px;width:2.5px;animation:1.1s ease-in-out infinite listening-wave;display:block}.ptt-listening-wave span:first-child{height:5px;animation-delay:0s}.ptt-listening-wave span:nth-child(2){height:10px;animation-delay:.15s}.ptt-listening-wave span:nth-child(3){height:14px;animation-delay:.3s}.ptt-listening-wave span:nth-child(4){height:10px;animation-delay:.45s}.ptt-listening-wave span:nth-child(5){height:5px;animation-delay:.6s}.ptt-waiting{vertical-align:middle;align-items:center;gap:5px;height:20px;display:inline-flex}.ptt-waiting span{background-color:var(--color-text-secondary);opacity:.35;border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite ptt-waiting-pulse;display:block}.turn-flash{color:var(--color-text-secondary);text-align:center;pointer-events:none;padding:2px 0 10px;font-size:12px;font-style:italic;animation:2.8s ease-out forwards turn-flash-anim}@keyframes turn-flash-anim{0%{opacity:0}12%{opacity:1}70%{opacity:1}to{opacity:0}}.end-confirm{align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-2xl);border-top:1px solid var(--color-border);background-color:var(--color-surface);text-align:center;flex-direction:column;flex-shrink:0;animation:.15s ease-out end-confirm-in;display:flex}@keyframes end-confirm-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.end-confirm-stat{color:var(--color-text-primary);margin:0;font-size:15px;font-weight:500}.end-confirm-actions{gap:var(--spacing-md);align-items:center;display:flex}.end-confirm-keep{font-size:14px;font-weight:600}.end-confirm-end{color:var(--color-text-secondary);font-size:14px}.ptt-waiting span:nth-child(2){animation-delay:.2s}.ptt-waiting span:nth-child(3){animation-delay:.4s}@keyframes ptt-waiting-pulse{0%,60%,to{opacity:.2;transform:scale(.85)}30%{opacity:.6;transform:scale(1.1)}}.translate-toggle-btn{color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-pill);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:7px 14px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s,background .15s;display:flex}.translate-toggle-btn:hover{color:var(--color-text-primary);border-color:var(--color-text-primary)}.translate-toggle-btn-active{color:var(--color-primary);border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 10%, transparent)}.translate-toggle-btn-active:hover{color:var(--color-primary);border-color:var(--color-primary)}.turn-translation-loading{color:var(--color-text-secondary);border-top:1px solid var(--color-border);opacity:.5;margin:6px 0 0;padding-top:6px;font-size:14px;font-style:italic}.pause-strip{padding:9px var(--spacing-2xl);background-color:color-mix(in srgb, #d9a441 13%, var(--color-surface));border-top:1px solid color-mix(in srgb, #d9a441 32%, var(--color-border));color:#9a6a12;flex-shrink:0;align-items:center;gap:8px;font-size:13px;font-weight:500;animation:.15s both fadeInUp;display:flex}.mic-help-controls{align-items:center;gap:8px;display:flex}.mic-help-label{color:var(--color-text-secondary);-webkit-user-select:none;user-select:none;font-size:12px}.help-toggle{border-radius:var(--radius-pill);border:1.5px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s,background .15s;display:flex}.help-toggle:hover{color:var(--color-text-primary);border-color:var(--color-text-primary)}.help-toggle-on,.help-toggle-on:hover{color:var(--color-primary);border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 10%, transparent)}.help-toggle-state{text-transform:uppercase;letter-spacing:.04em;opacity:.7;font-size:11px;font-weight:600}.help-rung-row{flex-shrink:0;justify-content:flex-start;margin-top:-4px;margin-bottom:12px;padding:0;display:flex}.simplify-row{padding:10px var(--spacing-2xl) 0;flex-shrink:0;justify-content:center;margin-bottom:16px;display:flex}.simplify-btn{color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-pill);cursor:pointer;background:0 0;padding:5px 14px;font-size:13px;transition:color .15s,border-color .15s;animation:.2s both fadeInUp}.simplify-btn:hover{color:var(--color-text-primary);border-color:var(--color-text-primary)}.simplify-loading{color:var(--color-text-secondary);align-items:center;gap:8px;font-size:13px;animation:.2s both fadeInUp;display:flex}.simplify-loading-dots{align-items:center;gap:3px;display:inline-flex}.simplify-loading-dots span{background-color:var(--color-text-secondary);opacity:.5;border-radius:50%;width:4px;height:4px;animation:1.4s ease-in-out infinite listening-pulse;display:block}.simplify-loading-dots span:nth-child(2){animation-delay:.22s}.simplify-loading-dots span:nth-child(3){animation-delay:.44s}.keywords-spinner{border:1.5px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite btn-spin;display:block}@keyframes btn-spin{to{transform:rotate(360deg)}}.turn-translation{color:var(--color-text-secondary);margin-top:6px;font-size:13px;font-style:italic;line-height:1.4;animation:.2s both fadeInUp}.turn-gist{color:var(--color-text-primary);background-color:rgba(var(--color-primary-rgb,99, 102, 241), .08);border-left:3px solid var(--color-primary);border-radius:0 var(--radius-input) var(--radius-input) 0;margin-bottom:8px;padding:6px 10px;font-size:13px;font-weight:500;line-height:1.4;animation:.2s both fadeInUp}.turn-text.has-keywords{line-height:3.4}.keyword-highlight{vertical-align:baseline;text-align:center;line-height:1;display:inline-block;position:relative}.keyword-word{color:var(--color-primary);font-weight:600;display:inline}.keyword-translation{color:var(--color-text-secondary);white-space:normal;text-align:center;pointer-events:none;max-width:max(100%,9ch);margin-top:3px;font-size:.625em;line-height:1.3;position:absolute;top:100%;left:50%;transform:translate(-50%)}.session-divider{background-color:var(--color-border);width:1px}.cheatsheet-panel{background-color:var(--color-suggestions-panel);flex-direction:column;flex:1;gap:0;min-width:0;padding:14px 12px;display:flex;overflow-y:auto}.cs-section-header{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-secondary);flex-shrink:0;margin-bottom:10px;font-size:13px;font-weight:700}.cs-dynamic-wrap{flex-shrink:0;padding-bottom:12px}.cs-dynamic{flex-direction:column;align-items:stretch;gap:16px;display:flex}.cs-dynamic-col{flex-direction:column;gap:6px;min-width:0;display:flex}.cs-phrases-col{width:100%}.cs-vocab-col{width:100%;min-width:0}.cs-col-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);opacity:.75;margin-bottom:5px;font-size:11px;font-weight:700}.cs-phrase-list{flex-direction:column;gap:6px;display:flex}.cs-phrase-item{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-input);flex-direction:row;align-items:center;gap:8px;padding:10px 13px;display:flex}.cs-vocab-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.cs-vocab-item{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-input);flex-direction:row;align-items:center;gap:4px;min-width:0;padding:6px 8px;display:flex;overflow:hidden}.cs-item-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.cs-play-btn{border:1.5px solid var(--color-border);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,border-color .15s,background .15s;display:flex}.cs-play-btn:hover{color:var(--color-primary);border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, transparent)}.cs-play-btn-active{color:var(--color-primary);border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 12%, transparent);animation:1s ease-in-out infinite cs-play-pulse}@keyframes cs-play-pulse{0%,to{opacity:1}50%{opacity:.55}}.cs-vocab-item .cs-play-btn{border-width:1px;width:22px;height:22px}.cs-target{color:var(--color-text-primary);white-space:normal;word-break:break-word;font-size:15px;font-weight:500;line-height:1.35}.cs-translation{color:var(--color-text-secondary);white-space:normal;word-break:break-word;font-size:13px;line-height:1.2}.cs-phrase-item .cs-target{font-size:17px}.cs-phrase-item .cs-translation{font-size:14px}.cs-dynamic-placeholder{padding:10px 0}.cs-loading{align-items:center;gap:10px;display:flex}.cs-loading-text{color:var(--color-text-secondary);font-size:14px}.cs-loading-dots{align-items:center;gap:4px;display:inline-flex}.cs-loading-dots span{background-color:var(--color-primary);opacity:.4;border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite listening-pulse;display:block}.cs-loading-dots span:nth-child(2){animation-delay:.22s}.cs-loading-dots span:nth-child(3){animation-delay:.44s}.cheatsheet-empty{color:var(--color-text-secondary);font-size:14px;line-height:1.5}.session-startup{background-color:var(--color-background);flex-direction:column;height:100vh;display:flex}.startup-topbar{align-items:center;gap:var(--spacing-sm);padding:12px var(--spacing-lg);border-bottom:1px solid var(--color-border);background-color:var(--color-surface);flex-shrink:0;display:flex}.startup-content{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.startup-status{color:var(--color-text-secondary);margin:0;font-size:15px}.startup-breathe{background-color:var(--color-text-secondary);border-radius:50%;width:52px;height:52px;animation:3.6s ease-in-out infinite startup-breath}@keyframes startup-breath{0%,to{opacity:.18;transform:scale(.8)}45%,55%{opacity:.32;transform:scale(1.15)}}.win-screen{background-color:var(--color-background);justify-content:center;align-items:center;height:100vh;display:flex}.win-content{text-align:center;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:480px;padding:0 32px;display:flex}.win-check{color:var(--color-primary);font-size:22px;font-weight:700;animation:.28s both fadeInUp}.win-heading{color:var(--color-text-primary);margin:0;font-size:26px;font-weight:600;line-height:1.35;animation:.32s 60ms both fadeInUp}.win-meta{color:var(--color-text-secondary);margin:0;font-size:14px;animation:.36s .12s both fadeInUp}.win-topic{font-style:italic}.win-dot{opacity:.5}.win-line{color:var(--color-text-secondary);margin:4px 0;font-size:15px;line-height:1.55;animation:.4s .18s both fadeInUp}.win-cta{align-items:center;gap:8px;margin-top:16px;animation:.44s .26s both fadeInUp;display:flex}.win-cta-spinner{border:2px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite btn-spin;display:block}.end-session-page{min-height:100vh;padding:var(--spacing-2xl);justify-content:center;align-items:center;display:flex}.end-session-container{text-align:center;width:100%;max-width:540px;transition:max-width .2s}:is(.end-session-container:has(.goal-metrics-count-2),.end-session-container:has(.goal-metrics-count-3),.end-session-container:has(.goal-metrics-count-4)){max-width:900px}.goal-metrics-grid{margin-top:var(--spacing-lg);gap:var(--spacing-lg);width:100%;display:grid}.goal-metrics-count-1{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}.goal-metrics-count-2{grid-template-columns:repeat(2,1fr)}.goal-metrics-count-3{grid-template-columns:repeat(3,1fr)}.goal-metrics-count-4{grid-template-columns:repeat(2,1fr)}.feedback-card{margin-top:var(--spacing-xl);padding:var(--spacing-2xl);text-align:left;align-items:center;gap:var(--spacing-md);flex-direction:column;display:flex}.feedback-text{color:var(--color-text-primary);width:100%;max-width:60ch;margin:0;font-size:16.5px;line-height:1.75}.next-session-section{margin-top:var(--spacing-lg);text-align:left;width:100%;max-width:540px;margin-left:auto;margin-right:auto}.next-session-heading{text-transform:uppercase;letter-spacing:.07em;color:var(--color-primary);text-align:center;justify-content:center;align-items:center;gap:6px;margin:0 0 14px;font-size:13px;font-weight:700;display:flex}.next-session-card.card{padding:var(--spacing-lg) var(--spacing-xl);background:color-mix(in srgb, var(--color-primary) 6%, transparent);border-left:3px solid var(--color-primary);border-radius:0 10px 10px 0}.next-session-text{color:var(--color-text-primary);margin:0;font-size:16px;line-height:1.7}.goal-metric-card{padding:var(--spacing-xl);text-align:center}.goal-metric-title{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);margin-bottom:14px;font-size:12px;font-weight:700}.goal-metric-value{color:var(--color-text-primary);letter-spacing:-.02em;font-size:3rem;font-weight:700;line-height:1}.goal-metric-unit{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-top:6px;font-size:13px}.goal-metric-sparkline{margin-top:16px;margin-left:-4px;margin-right:-4px}.goal-metric-tier{color:var(--color-primary);margin-top:8px;font-size:15px;font-weight:600}.goal-metric-explanation{color:var(--color-text-secondary);text-align:left;margin-top:14px;font-size:14px;line-height:1.6}.goal-metric-delta{margin-top:14px;font-size:13px}.delta-up{color:var(--color-success,#22c55e)}.delta-down{color:var(--color-text-secondary)}.grammar-recap-section{margin-top:var(--spacing-xl);text-align:left;width:100%;max-width:540px;margin-left:auto;margin-right:auto}.grammar-recap-heading{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);text-align:center;margin:0 0 14px;font-size:13px;font-weight:700}.grammar-recap-list{gap:var(--spacing-md);flex-direction:column;display:flex}.grammar-recap-card{padding:var(--spacing-lg) var(--spacing-xl);text-align:left;animation:.3s both fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.grammar-recap-row{align-items:baseline;gap:10px;display:flex}.grammar-recap-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);white-space:nowrap;min-width:80px;font-size:10px;font-weight:700}.grammar-recap-said{color:var(--color-text-secondary);font-size:15px;font-style:italic}.grammar-recap-arrow{color:var(--color-primary);opacity:.6;padding:4px 0 4px 90px;font-size:16px}.grammar-recap-natural{color:var(--color-text-primary);font-size:15px;font-weight:600}.grammar-recap-note{color:var(--color-text-secondary);border-top:1px solid var(--color-border,#00000014);margin:12px 0 0;padding-top:10px;font-size:13.5px;line-height:1.55}.end-session-ctas{flex-direction:column;align-items:center;gap:12px;margin-top:24px;display:flex}.loading-spinner-small{border:3px solid var(--color-border,#0000001a);border-top-color:var(--color-primary,#6366f1);width:28px;height:28px;margin-bottom:var(--spacing-md);border-radius:50%;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.diagnostics-page{max-width:800px;margin:40px auto;padding:0 24px}.diagnostics-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.diagnostics-summary{border-radius:12px;align-items:center;gap:12px;margin-bottom:32px;padding:16px 20px;font-weight:500;animation:.3s ease-out fadeIn;display:flex}.summary-success{color:#10b981;background-color:#10b9811a;border:1px solid #10b98133}.summary-error{color:#ef4444;background-color:#ef44441a;border:1px solid #ef444433}.diagnostics-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:40px;display:grid}@media (width<=768px){.diagnostics-grid{grid-template-columns:1fr}}.diag-card{background:var(--bg-card,#fff);border:1px solid var(--border-color,#e2e8f0);border-radius:12px;flex-direction:column;justify-content:space-between;padding:20px;transition:transform .2s,box-shadow .2s;display:flex}.diag-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.diag-title-group{flex-direction:column;display:flex}.diag-name{color:var(--text-primary,#1e293b);font-size:1.1rem;font-weight:600}.diag-type{color:var(--text-secondary,#64748b);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:.75rem}.diag-status-badge{border-radius:9999px;padding:4px 8px;font-size:.75rem;font-weight:600}.badge-pending{color:#64748b;background-color:#e2e8f080}.badge-checking{color:#3b82f6;background-color:#3b82f61a;animation:1.5s infinite pulse}.badge-success{color:#10b981;background-color:#10b9811a}.badge-error{color:#ef4444;background-color:#ef44441a}.diag-message{color:var(--text-secondary,#475569);margin-bottom:8px;font-size:.9rem;line-height:1.4}.diag-details{background:var(--bg-body,#f8fafc);color:#e2e8f0;white-space:pre-wrap;word-break:break-all;background-color:#0f172a;border-radius:6px;max-height:120px;margin-top:8px;padding:10px;font-family:monospace;font-size:.8rem;overflow-x:auto}.diag-footer-actions{border-top:1px solid var(--border-color,#e2e8f0);justify-content:flex-end;gap:16px;padding-top:24px;display:flex}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-page{color:#1a1d2e;background:#f5f6f8;flex-direction:column;width:100%;min-height:100vh;font-family:Inter,system-ui,sans-serif;font-size:14px;display:flex}.admin-header{background:#fff;border-bottom:1px solid #e4e6ed;padding:24px 48px 20px}.admin-title{color:#1a1d2e;margin-bottom:2px;font-size:22px;font-weight:700}.admin-subtitle{color:#9099b0;font-size:13px}.admin-tabs{background:#fff;border-bottom:1px solid #e4e6ed;flex-shrink:0;padding:0 48px;display:flex}.admin-tab{color:#9099b0;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:13px 24px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.admin-tab:hover{color:#4b5268}.admin-tab.active{color:#5a4fff;border-bottom-color:#5a4fff}.admin-panel{flex:1;width:100%;padding:36px 48px}.admin-error{color:#c0392b;background:#fff0f0;border:1px solid #fbbfbf;border-radius:8px;margin:20px 48px;padding:12px 16px;font-size:14px}.admin-loading,.admin-empty{color:#9099b0;text-align:center;padding:80px 0;font-size:14px}.funnel-container{width:100%}.funnel-header-row{gap:48px;margin-bottom:32px;display:flex}.funnel-header-row span{color:#9099b0;font-size:13px;font-weight:500}.funnel-header-row strong{color:#1a1d2e;margin-top:4px;font-size:28px;font-weight:700;display:block}.funnel-chart-wrap{align-items:flex-start;gap:0;width:100%;margin-top:8px;display:flex}.funnel-yaxis{color:#9099b0;text-align:right;flex-direction:column;flex-shrink:0;justify-content:space-between;width:38px;height:240px;margin-bottom:52px;padding-right:8px;font-size:11px;display:flex}.funnel-chart-body{flex-direction:column;flex:1;display:flex}.funnel-bars-row{background-image:linear-gradient(90deg,#eef0f6 1px,#0000 1px),repeating-linear-gradient(0deg,#0000,#0000 59px,#eef0f6 59px 60px);background-size:100% 100%,100% 60px;border-bottom:2px solid #d8dae4;align-items:flex-end;gap:8px;height:240px;padding:0 2px;display:flex}.funnel-bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.funnel-bar-col--final .funnel-bar-fill{background:linear-gradient(#34d399,#1a9e5f)}.funnel-bar-pct{color:#5a4fff;margin-bottom:4px;font-size:11px;font-weight:600}.funnel-bar-col--final .funnel-bar-pct{color:#1a9e5f}.funnel-bar-fill{background:linear-gradient(#8b7fff,#5a4fff);border-radius:3px 3px 0 0;width:80%;min-height:4px;transition:height .4s}.funnel-xlabels{gap:8px;margin-top:8px;padding:0 2px;display:flex}.funnel-xlabel{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.funnel-xlabel-name{color:#4b5268;text-align:center;white-space:nowrap;font-size:11px;font-weight:500}.funnel-xlabel-count{color:#9099b0;font-variant-numeric:tabular-nums;font-size:10px}.users-table-wrap{background:#fff;border:1px solid #e4e6ed;border-radius:12px;width:100%;overflow-x:auto}.users-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:13px}.users-table th{text-align:left;color:#9099b0;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em;text-overflow:ellipsis;background:#fafbfc;border-bottom:1px solid #e4e6ed;padding:12px 16px;font-size:11px;font-weight:600;overflow:hidden}.users-table th:first-child{width:130px}.users-table th:nth-child(2){width:200px}.users-table th:nth-child(3){width:90px}.users-table th:nth-child(4){width:130px}.users-table th:nth-child(5){width:155px}.users-table th:nth-child(6){width:65px}.users-table th:nth-child(7){width:75px}.users-table th:nth-child(8){width:145px}.users-table td{vertical-align:middle;color:#4b5268;border-bottom:1px solid #f0f1f5;padding:12px 16px}.user-row:last-child td{border-bottom:none}.user-row:hover td,.user-row-expanded td{background:#fafbff}.td-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.td-name-inner{color:#1a1d2e;align-items:center;gap:8px;font-weight:600;display:flex}.td-email{color:#6b7490}.td-num{text-align:right;font-variant-numeric:tabular-nums;color:#1a1d2e;font-weight:600}.td-date{white-space:nowrap;color:#9099b0;font-size:12px}.expand-btn{cursor:pointer;color:#c0c6d8;background:0 0;border:none;flex-shrink:0;padding:2px;line-height:1;transition:color .15s}.expand-btn:hover{color:#5a4fff}.expand-arrow{font-size:10px;transition:transform .15s;display:inline-block}.expand-arrow.expanded{transform:rotate(90deg)}.sessions-row>td{background:#f7f8fc!important;border-bottom:1px solid #e4e6ed!important;padding:0 0 0 48px!important}.sessions-loading,.sessions-empty{color:#9099b0;padding:16px 16px 16px 0;font-size:13px}.sessions-table{border-collapse:collapse;width:100%;font-size:12px}.sessions-table th{text-align:left;color:#b0b8cc;white-space:nowrap;text-transform:uppercase;letter-spacing:.07em;background:0 0;border-bottom:1px solid #eaecf2;padding:10px 14px;font-size:10px;font-weight:600}.sessions-table td{color:#6b7490;border-bottom:1px solid #eef0f6;padding:10px 14px}.sessions-table tr:last-child td{border-bottom:none}.td-topic{text-overflow:ellipsis;white-space:nowrap;color:#1a1d2e;max-width:260px;font-weight:500;overflow:hidden}.topic-en{color:#b0b8cc;font-size:11px}.td-muted{color:#c0c6d8}.exit-badge{white-space:nowrap;border-radius:10px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-block}.exit-completed{color:#1a9e5f;background:#edfaf4}.exit-ended-early{color:#b87010;background:#fff8ec}.exit-dropped{color:#8891a8;background:#f2f3f6}.exit-extended{color:#5a4fff;background:#eef0ff}.progress-page{min-height:100vh;padding:var(--spacing-2xl) var(--spacing-lg)}.progress-container{max-width:640px;margin:0 auto}.progress-header{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl);display:flex}.progress-back{color:var(--color-text-secondary);border-radius:50%;padding:6px}.progress-title{color:var(--color-text-primary);flex:1;font-size:22px;font-weight:500}.progress-header-right{flex-shrink:0;position:relative}.progress-metrics-btn{color:var(--color-text-secondary);border-radius:var(--radius-input);transition:border-color var(--transition-fast), color var(--transition-fast);border:.5px solid #0000;align-items:center;gap:5px;padding:6px 10px;font-size:13px;display:flex}.progress-metrics-btn:hover,.progress-metrics-btn.active{color:var(--color-text-primary);border-color:var(--color-border)}.metrics-picker{background:var(--color-surface);border:.5px solid var(--color-border);border-radius:var(--radius-card);padding:var(--spacing-md) var(--spacing-lg);z-index:50;width:260px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 24px #0000001a}.metrics-picker-label{color:var(--color-text-secondary);letter-spacing:.02em;margin-bottom:10px;font-size:12px}.metrics-picker-grid{flex-direction:column;gap:6px;display:flex}.metrics-picker-chip{text-align:left;border-radius:var(--radius-input);border:.5px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;font-size:14px;font-family:var(--font-family);transition:border-color var(--transition-fast), color var(--transition-fast), background var(--transition-fast);background:0 0;padding:8px 12px}.metrics-picker-chip:hover:not(:disabled){border-color:var(--color-text-secondary);color:var(--color-text-primary)}.metrics-picker-chip.active{background:var(--color-text-primary);color:var(--color-surface);border-color:var(--color-text-primary)}.metrics-picker-chip:disabled{cursor:default;opacity:.6}.progress-lang-switcher{margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:6px;display:flex}.progress-lang-pill{border-radius:var(--radius-pill);border:.5px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast), background var(--transition-fast);-webkit-user-select:none;user-select:none;font-size:13px;font-family:var(--font-family);background:0 0;padding:6px 16px}.progress-lang-pill:hover:not(:disabled){border-color:var(--color-text-secondary);color:var(--color-text-primary)}.progress-lang-pill:disabled{cursor:default}.progress-lang-pill.active{background:var(--color-text-primary);color:var(--color-surface);border-color:var(--color-text-primary)}.progress-card{background:var(--color-surface);border:.5px solid var(--color-border);border-radius:var(--radius-card);margin-bottom:12px;padding:1.25rem 1.5rem}.progress-card-label{color:var(--color-text-secondary);letter-spacing:.02em;margin-bottom:10px;font-size:12px}.progress-hero-row{align-items:flex-end;gap:1rem;display:flex}.progress-hero-num{color:var(--color-text-primary);font-size:48px;font-weight:500;line-height:1}.progress-hero-unit{color:var(--color-text-secondary);padding-bottom:8px;font-size:14px}.progress-hero-delta{color:#0f6e56;margin-top:6px;font-size:13px}.progress-hero-delta.negative{color:var(--color-text-secondary)}.progress-chart{margin-top:16px}.progress-chart-dates{justify-content:space-between;margin-top:4px;display:flex}.progress-chart-date{color:var(--color-text-secondary);font-size:11px}.progress-stat-hero-row{align-items:flex-end;gap:10px;margin-bottom:10px;display:flex}.progress-stat-secondary-row{border-top:.5px solid var(--color-border);align-items:center;gap:8px;padding-top:10px;display:flex}.progress-stat-secondary-item{font-size:14px}.progress-stat-secondary-num{color:var(--color-text-primary);font-weight:500}.progress-stat-secondary-label{color:var(--color-text-secondary)}.progress-stat-divider{color:var(--color-text-secondary);font-size:14px}.progress-indep-summary{color:var(--color-text-secondary);margin-bottom:14px;font-size:13px;line-height:1.5}.progress-indep-bars{align-items:stretch;gap:4px;display:flex}.progress-indep-bar-col{cursor:pointer;flex-direction:column;flex:1;align-items:center;display:flex}.progress-indep-bar-wrapper{flex:1;align-items:flex-end;width:100%;height:72px;display:flex;position:relative}.progress-indep-bar{border-radius:2px 2px 0 0;width:100%;min-height:4px;transition:opacity .15s}.progress-indep-bar-date{color:var(--color-text-secondary);text-align:center;white-space:nowrap;text-overflow:clip;margin-top:5px;font-size:9px;overflow:hidden}.indep-tooltip{background:var(--color-text-primary);color:var(--color-surface);white-space:nowrap;z-index:30;pointer-events:none;border-radius:8px;min-width:130px;padding:8px 10px;font-size:11px;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.indep-tooltip-date{opacity:.65;margin-bottom:5px;font-size:10px}.indep-tooltip-row{align-items:center;gap:6px;margin-top:3px;display:flex}.indep-tooltip-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.sparkline-tooltip{background:var(--color-text-primary);color:var(--color-surface);white-space:nowrap;pointer-events:none;z-index:10;text-align:center;border-radius:7px;padding:6px 10px;font-size:11px;position:absolute;transform:translate(-50%,calc(-100% - 10px));box-shadow:0 4px 12px #00000026}.sparkline-tooltip-value{font-size:13px;font-weight:500;line-height:1.2}.sparkline-tooltip-date{opacity:.65;margin-top:2px;font-size:10px}.progress-empty{text-align:center;padding:3rem var(--spacing-lg);color:var(--color-text-secondary);font-size:15px;line-height:1.6}.progress-empty-hint{color:var(--color-text-secondary);margin-top:var(--spacing-md);opacity:.7;font-size:13px}.progress-sparse-note{color:var(--color-text-secondary);margin-top:10px;font-size:13px;font-style:italic}@media (width>=900px){.progress-container{max-width:980px}.progress-goals-grid{grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:12px;display:grid}.progress-goals-grid .progress-card{margin-bottom:0}.progress-secondary-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px;margin-bottom:12px;display:grid}.progress-secondary-grid .progress-card{margin-bottom:0}.progress-card--full{grid-column:1/-1}}.progress-dashboard-cta{justify-content:center;margin-top:32px;margin-bottom:16px;display:flex}.progress-dashboard-btn{align-items:center;gap:8px;padding:12px 28px;font-size:15px;display:flex}:root{--color-bg:#f8f7f4;--color-surface:#fff;--color-primary:#2a9d8f;--color-primary-hover:#238f82;--color-secondary:#e9c46a;--color-text-primary:#1c1c1a;--color-text-secondary:#6b6b67;--color-border:#e5e4e0;--color-transcript-ai:#f0f4f3;--color-suggestions-panel:#f2f1ee;--color-error:#d94f4f;--color-success:#2a9d8f;--font-family:"Plus Jakarta Sans", sans-serif;--radius-button:12px;--radius-card:16px;--radius-input:10px;--radius-pill:999px;--shadow-card:0 1px 3px #0000000a, 0 1px 2px #00000005;--shadow-card-hover:0 4px 12px #0000000f, 0 1px 3px #0000000a;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--spacing-3xl:64px;--spacing-4xl:96px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{font-family:var(--font-family);color:var(--color-text-primary);background-color:var(--color-bg);min-height:100vh;font-size:16px;font-weight:400;line-height:1.65}#app{min-height:100vh}img,svg{max-width:100%;display:block}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}ul,ol{list-style:none}.heading-page{color:var(--color-text-primary);font-size:24px;font-weight:600;line-height:1.3}.heading-section{color:var(--color-text-primary);font-size:18px;font-weight:600;line-height:1.4}.text-body{color:var(--color-text-primary);font-size:16px;font-weight:400;line-height:1.65}.text-label{font-size:15px;font-weight:500;line-height:1.4}.text-caption{color:var(--color-text-secondary);font-size:13px;font-weight:400;line-height:1.5}.text-secondary{color:var(--color-text-secondary)}.btn{justify-content:center;align-items:center;gap:var(--spacing-sm);font-family:var(--font-family);border-radius:var(--radius-button);cursor:pointer;transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;padding:14px 28px;font-size:15px;font-weight:500;line-height:1;display:inline-flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-secondary{color:var(--color-text-primary);border:1.5px solid var(--color-border);background-color:#0000}.btn-secondary:hover:not(:disabled){border-color:var(--color-text-secondary);background-color:#00000005}.btn-ghost{color:var(--color-text-secondary);background-color:#0000;padding:10px 16px}.btn-ghost:hover:not(:disabled){color:var(--color-text-primary);background-color:#00000008}.btn-large{border-radius:14px;padding:18px 40px;font-size:17px;font-weight:600}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:var(--spacing-lg);transition:box-shadow var(--transition-normal), border-color var(--transition-normal)}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-card-hover)}.card-selected{border-color:var(--color-primary);box-shadow:0 0 0 2px #2a9d8f26}input[type=text],input[type=email],input[type=password],textarea{font-family:var(--font-family);color:var(--color-text-primary);background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-input);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:14px 16px;font-size:16px;font-weight:400;line-height:1.5}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2a9d8f1a}input::placeholder,textarea::placeholder{color:var(--color-text-secondary);opacity:.6}textarea{resize:vertical;min-height:120px}.pill{font-family:var(--font-family);border:1.5px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;white-space:nowrap;justify-content:center;align-items:center;padding:10px 20px;font-size:14px;font-weight:500;line-height:1;display:inline-flex}.pill:hover{border-color:var(--color-text-secondary);background-color:#00000005}.pill-selected{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pill-selected:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.form-group{gap:var(--spacing-sm);flex-direction:column;display:flex}.form-label{color:var(--color-text-primary);font-size:15px;font-weight:500}.form-hint{color:var(--color-text-secondary);font-size:13px;font-weight:400;line-height:1.5}.form-error{color:var(--color-error);font-size:13px;font-weight:400}.page-container{max-width:640px;padding:var(--spacing-2xl) var(--spacing-lg);margin:0 auto}.page-container-wide{max-width:960px;padding:var(--spacing-2xl) var(--spacing-lg);margin:0 auto}.page-container-full{width:100%;height:100vh}.flex-center{justify-content:center;align-items:center;display:flex}.flex-col-center{flex-direction:column;justify-content:center;align-items:center;display:flex}.stack{flex-direction:column;display:flex}.stack-sm{gap:var(--spacing-sm)}.stack-md{gap:var(--spacing-md)}.stack-lg{gap:var(--spacing-lg)}.stack-xl{gap:var(--spacing-xl)}.stack-2xl{gap:var(--spacing-2xl)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease both}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease both}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
