:root{--color-bg-canvas:#f8f5ee;--color-bg-sidebar:#f8f5ee;--color-bg-card:#fff;--color-bg-card-accent:#faf6f2;--color-bg-streak:#f0ebe3;--color-bg-badge-beginner:#e8f3ea;--color-bg-badge-intermediate:#fef3e2;--color-bg-badge-advanced:#fce8e8;--color-text-primary:#141826;--color-text-secondary:#3a4257;--color-text-tertiary:#6b7388;--color-border-default:#d5cab0;--color-border-focus:#3a4257;--color-accent-editorial:#7a2e2e;--color-interactive-primary:#141826;--color-interactive-text:#fff;--color-interactive-disabled:#9ca3af;--color-feedback-error:#8b3a3a;--color-feedback-success:#5f8a5e;--color-badge-beginner:#3d6b4f;--color-badge-intermediate:#9a6b2e;--color-badge-advanced:#8b3a3a;--color-avatar-bg:#5f8a5e;--font-display:"Fraunces", Georgia, serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-size-display-lg:40px;--font-size-display-sm:32px;--font-size-logo:24px;--font-size-body:14px;--font-size-button:16px;--font-size-caption:13px;--font-size-label:11px;--font-size-section:18px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-display-lg:-.8px;--tracking-display-sm:-.64px;--tracking-logo:-.48px;--leading-display:48px;--leading-body:24px;--leading-caption:21px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px;--space-8:32px;--space-9:36px;--space-13:52px;--space-20:80px;--radius-input:8px;--radius-button:12px;--radius-full:9999px;--size-otp-cell-w:56px;--size-otp-cell-h:64px;--size-otp-cell-w-mobile:48px;--size-otp-cell-h-mobile:56px;--size-input-h:52px;--size-button-h:52px;--size-progress-w:120px;--size-progress-h:8px;--size-orb:80px;--size-content-max:480px;--size-text-max:560px;--size-container-max:720px;--size-sidebar-w:260px;--size-avatar:40px;--size-avatar-sm:36px;--size-icon-btn:24px;--size-mic-circle:64px}*{box-sizing:border-box}body{font-family:var(--font-body);font-size:var(--font-size-body);line-height:var(--leading-body);background-color:var(--color-bg-canvas);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}#root{min-height:100dvh}.auth-layout{min-height:100vh;padding:var(--space-6);flex-direction:column;justify-content:center;align-items:center;display:flex}.auth-container{width:100%;max-width:var(--size-container-max);text-align:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.auth-logo,.home-sidebar-logo{font-family:var(--font-display);font-weight:var(--font-weight-semibold);font-size:var(--font-size-logo);letter-spacing:var(--tracking-logo);color:var(--color-text-primary);margin:0}.app-brand-accent{color:var(--color-accent-editorial)}.auth-logo{padding:var(--space-9) 0}.auth-progress{width:var(--size-progress-w);height:var(--size-progress-h);border-radius:var(--space-1);background:var(--color-border-default);overflow:hidden}.auth-progress-fill{background:var(--color-text-primary);border-radius:var(--space-1);height:100%;transition:width .3s}.auth-header{align-items:center;gap:var(--space-3);max-width:var(--size-text-max);flex-direction:column;display:flex}.auth-header h1{font-family:var(--font-display);font-size:var(--font-size-display-lg);font-weight:var(--font-weight-regular);letter-spacing:var(--tracking-display-lg);line-height:var(--leading-display);color:var(--color-text-primary);margin:0}.auth-header p{font-family:var(--font-body);font-weight:var(--font-weight-regular);font-size:var(--font-size-body);line-height:var(--leading-body);color:var(--color-text-secondary);margin:0}.text-desktop{display:block}.text-mobile{display:none}@media (width<=640px){.auth-header h1{font-size:var(--font-size-display-sm);letter-spacing:var(--tracking-display-sm)}.text-desktop{display:none}.text-mobile{display:block}}.auth-form{width:100%;max-width:var(--size-content-max);align-items:center;gap:var(--space-8);flex-direction:column;display:flex}.auth-form input[type=email]{width:100%;height:var(--size-input-h);border:1px solid var(--color-border-default);border-radius:var(--radius-input);padding:0 var(--space-4);font-size:var(--font-size-body);font-family:var(--font-body);background:var(--color-bg-canvas);color:var(--color-text-primary);outline:none;transition:border-color .15s,border-width .15s}.auth-form input[type=email]:focus{border:3px solid var(--color-border-focus)}.auth-form input[type=email]::placeholder{color:var(--color-text-tertiary)}.otp-cells{gap:var(--space-3);justify-content:center;display:flex}.otp-cell{width:var(--size-otp-cell-w);height:var(--size-otp-cell-h);border:1px solid var(--color-border-default);border-radius:var(--radius-input);background:var(--color-bg-canvas);font-family:var(--font-display);font-size:var(--font-size-logo);font-weight:var(--font-weight-regular);font-variant-numeric:tabular-nums;text-align:center;color:var(--color-text-primary);caret-color:var(--color-accent-editorial);outline:none;transition:border-color .15s}.otp-cell:focus{border-color:var(--color-border-focus)}@media (width<=640px){.otp-cells{gap:var(--space-2)}.otp-cell{width:var(--size-otp-cell-w-mobile);height:var(--size-otp-cell-h-mobile);font-size:20px}}.otp-resend{font-size:var(--font-size-body);color:var(--color-text-tertiary)}.otp-resend button{color:var(--color-accent-editorial);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);cursor:pointer;font-family:var(--font-body);background:0 0;border:none;padding:0}.otp-resend button:disabled{cursor:default}.btn-primary{width:100%;max-width:var(--size-content-max);height:var(--size-button-h);border-radius:var(--radius-button);background:var(--color-interactive-primary);color:var(--color-interactive-text);cursor:pointer;font-size:var(--font-size-button);font-weight:var(--font-weight-medium);font-family:var(--font-body);border:0;transition:opacity .2s}.btn-primary:hover{opacity:.9}.btn-primary:disabled{background:var(--color-interactive-disabled);cursor:not-allowed}.auth-terms{font-size:var(--font-size-body);color:var(--color-text-tertiary);line-height:var(--leading-caption);margin:0}.auth-terms a{color:var(--color-accent-editorial);font-weight:var(--font-weight-bold);text-decoration:none}.auth-terms a:hover{text-decoration:underline}.auth-success{align-items:center;gap:var(--space-8);flex-direction:column;display:flex}.auth-success h1{font-family:var(--font-display);font-size:var(--font-size-display-lg);font-weight:var(--font-weight-regular);letter-spacing:var(--tracking-display-lg);line-height:var(--leading-display);color:var(--color-text-primary);text-align:center;margin:0}@media (width<=640px){.auth-success h1{font-size:var(--font-size-display-sm);letter-spacing:var(--tracking-display-sm)}}.success-message{align-items:center;gap:var(--space-6);flex-direction:column;display:flex}.success-orb{width:var(--size-orb);height:var(--size-orb);border-radius:var(--radius-full);background:var(--color-feedback-success);justify-content:center;align-items:center;display:flex}.success-orb svg{color:#fff;width:36px;height:36px}.redirect-text{color:var(--color-text-tertiary);font-size:var(--font-size-body);margin:0}.error-text{color:var(--color-feedback-error);font-size:var(--font-size-caption);margin:0}.terms-layout{background:var(--color-bg-canvas);flex-direction:column;height:100vh;display:flex}.terms-scroll{scrollbar-width:thin;scrollbar-color:var(--color-accent-editorial) transparent;flex:1;overflow-y:auto}.terms-scroll::-webkit-scrollbar{width:6px}.terms-scroll::-webkit-scrollbar-track{background:0 0}.terms-scroll::-webkit-scrollbar-thumb{background:var(--color-accent-editorial);border-radius:var(--radius-full)}.terms-inner{width:100%;max-width:var(--size-container-max);padding:var(--space-20) var(--space-6) 120px;margin:0 auto}.terms-eyebrow{font-family:var(--font-body);font-size:var(--font-size-caption);font-weight:var(--font-weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-editorial);margin:0 0 var(--space-6)}.terms-title{font-family:var(--font-display);font-size:var(--font-size-display-lg);font-weight:var(--font-weight-regular);letter-spacing:var(--tracking-display-lg);line-height:var(--leading-display);color:var(--color-text-primary);margin:0 0 var(--space-3)}.terms-date{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin:0 0 var(--space-13)}.terms-body{font-family:var(--font-body);font-size:var(--font-size-body);line-height:var(--leading-body);color:var(--color-text-primary)}.terms-body h2,.terms-body h3{font-family:var(--font-display);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:var(--space-8) 0 var(--space-4)}.terms-body h2{font-size:20px;line-height:28px}.terms-body h3{font-size:17px;line-height:24px}.terms-body p{margin:0 0 var(--space-4);color:var(--color-text-secondary)}.terms-body a{color:var(--color-accent-editorial);text-decoration:none}.terms-body a:hover{text-decoration:underline}.terms-footer{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--color-bg-canvas);border-top:1px solid var(--color-border-default);display:flex;position:sticky;bottom:0}.terms-footer-progress{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);white-space:nowrap}.terms-footer .btn-primary{width:auto;padding:0 var(--space-8);max-width:200px}.terms-status{font-family:var(--font-body);font-size:var(--font-size-body);color:var(--color-text-tertiary);flex:1;place-items:center;display:grid}.terms-status-error{color:var(--color-feedback-error)}@media (width<=640px){.terms-inner{padding:var(--space-8) var(--space-4) 120px}.terms-title{font-size:var(--font-size-display-sm);letter-spacing:var(--tracking-display-sm)}.terms-footer{padding:var(--space-3) var(--space-4)}}.home-shell{background:var(--color-bg-canvas);min-height:100vh;display:flex}.home-sidebar-overlay{display:none}.home-sidebar{width:var(--size-sidebar-w);background:var(--color-bg-sidebar);border-right:1px solid var(--color-border-default);height:100vh;padding:var(--space-6) var(--space-4);flex-direction:column;flex-shrink:0;display:flex;position:sticky;top:0}.home-sidebar-top{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.home-icon-btn{width:var(--size-icon-btn);height:var(--size-icon-btn);border-radius:var(--radius-input);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.home-icon-btn:hover{background:#1418260f}.home-icon-btn svg{width:20px;height:20px}.home-new-conversation{justify-content:center;align-items:center;gap:var(--space-2);width:100%;height:var(--size-button-h);padding:0 var(--space-4);border-radius:var(--radius-button);background:var(--color-interactive-primary);color:var(--color-interactive-text);font-family:var(--font-body);font-size:var(--font-size-button);font-weight:var(--font-weight-medium);cursor:pointer;border:0;display:flex}.home-new-conversation svg{width:18px;height:18px}.home-recent{margin-top:var(--space-8);flex:1;min-height:0}.home-recent-label{margin:0 0 var(--space-3);font-family:var(--font-body);font-size:var(--font-size-label);font-weight:var(--font-weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary)}.home-recent-list{gap:var(--space-1);flex-direction:column;display:flex}.home-recent-item{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-input);text-align:left;cursor:pointer;background:0 0;border:none;transition:background .15s;display:block}.home-recent-item:hover{background:var(--color-bg-card-accent)}.home-recent-item-header{justify-content:space-between;align-items:baseline;gap:var(--space-2);display:flex}.home-recent-item-title{font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.home-recent-item-time{font-family:var(--font-body);font-size:var(--font-size-label);color:var(--color-text-tertiary);white-space:nowrap;flex-shrink:0}.home-recent-item-preview{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin:var(--space-1) 0 0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.home-recent-empty{font-family:var(--font-body);font-size:var(--font-size-caption);line-height:var(--leading-caption);color:var(--color-text-tertiary);margin:0}.home-sidebar-user{align-items:center;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border-default);display:flex;position:relative}.home-avatar{width:var(--size-avatar);height:var(--size-avatar);border-radius:var(--radius-full);background:var(--color-avatar-bg);color:var(--color-interactive-text);font-family:var(--font-body);font-size:var(--font-size-caption);font-weight:var(--font-weight-semibold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.home-avatar-sm{width:var(--size-avatar-sm);height:var(--size-avatar-sm);font-size:12px}.home-sidebar-user-info{flex:1;min-width:0}.home-sidebar-user-name{font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;overflow:hidden}.home-sidebar-user-level{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin:0}.home-user-menu{bottom:calc(100% + var(--space-2));padding:var(--space-2);border:1px solid var(--color-border-default);border-radius:var(--radius-input);background:var(--color-bg-card);z-index:10;position:absolute;left:0;right:0;box-shadow:0 4px 16px #14182614}.home-user-menu-item{width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-input);font-family:var(--font-body);font-size:var(--font-size-body);color:var(--color-text-secondary);text-align:left;cursor:pointer;background:0 0;border:0;display:block}.home-user-menu-item:hover{background:#1418260a}.home-mobile-bar{display:none}.home-main{min-width:0;padding:var(--space-13) var(--space-8);flex:1;overflow-y:auto}.home-content{max-width:var(--size-container-max);gap:var(--space-8);flex-direction:column;margin:0 auto;display:flex}.home-header{gap:var(--space-3);flex-direction:column;display:flex}.home-eyebrow{font-family:var(--font-body);font-size:var(--font-size-label);font-weight:var(--font-weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-editorial);margin:0}.home-greeting{font-family:var(--font-display);font-size:var(--font-size-display-lg);font-weight:var(--font-weight-regular);letter-spacing:var(--tracking-display-lg);line-height:var(--leading-display);color:var(--color-text-primary);margin:0}.home-subtitle{font-family:var(--font-body);font-size:var(--font-size-body);line-height:var(--leading-body);color:var(--color-text-secondary);margin:0}.home-streak{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--color-bg-streak);font-family:var(--font-body);font-size:var(--font-size-caption);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);align-self:flex-start;align-items:center;display:inline-flex}.home-section-label{margin:0 0 var(--space-4);font-family:var(--font-body);font-size:var(--font-size-section);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.home-conversation-card{align-items:center;gap:var(--space-6);padding:var(--space-6);border:1px solid var(--color-border-default);border-radius:var(--radius-button);background:var(--color-bg-card-accent);display:flex}.home-conversation-mic{width:var(--size-mic-circle);height:var(--size-mic-circle);border-radius:var(--radius-full);background:var(--color-accent-editorial);color:var(--color-interactive-text);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.home-conversation-mic:before,.home-conversation-mic:after{content:"";border-radius:var(--radius-full);background:var(--color-accent-editorial);opacity:0;animation:2.4s ease-out infinite mic-wave;position:absolute;inset:0}.home-conversation-mic:after{animation-delay:.8s}@keyframes mic-wave{0%{opacity:.4;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}.home-conversation-mic svg{width:28px;height:28px}.home-conversation-body{gap:var(--space-2);flex-direction:column;flex:1;min-width:0;display:flex}.home-conversation-label{font-family:var(--font-body);font-size:var(--font-size-label);font-weight:var(--font-weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);margin:0}.home-conversation-title{font-family:var(--font-body);font-size:var(--font-size-button);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.home-conversation-desc{font-family:var(--font-body);font-size:var(--font-size-body);line-height:var(--leading-body);color:var(--color-text-secondary);margin:0}.home-conversation-actions{align-items:center;gap:var(--space-3);flex-direction:column;flex-shrink:0;display:flex}.home-btn-primary{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);background:var(--color-interactive-primary);color:var(--color-interactive-text);font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);white-space:nowrap;cursor:pointer;border:0;display:inline-flex}.home-btn-primary svg{width:16px;height:16px}.home-link-secondary{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);cursor:pointer;background:0 0;border:0;padding:0;text-decoration:underline}.home-link-secondary:hover{color:var(--color-text-secondary)}.home-scenarios-header{justify-content:space-between;align-items:baseline;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.home-scenarios-header .home-section-label{margin:0}.home-view-all{align-items:center;gap:var(--space-1);font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-accent-editorial);cursor:pointer;white-space:nowrap;background:0 0;border:0;padding:0;display:inline-flex}.home-view-all svg{width:16px;height:16px}.home-scenarios-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.scenario-card{gap:var(--space-3);padding:var(--space-4);border:1px solid var(--color-border-default);border-radius:var(--radius-button);background:var(--color-bg-card);cursor:pointer;text-align:left;flex-direction:column;transition:border-color .15s;display:flex}.scenario-card:hover{border-color:var(--color-border-focus)}.scenario-card-title{font-family:var(--font-display);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.scenario-card-desc{font-family:var(--font-body);font-size:var(--font-size-caption);line-height:var(--leading-caption);color:var(--color-text-secondary);flex:1;margin:0}.scenario-card-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.scenario-card-duration{align-items:center;gap:var(--space-1);font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);display:inline-flex}.scenario-card-duration svg{width:14px;height:14px}.scenario-card-arrow{color:var(--color-text-tertiary)}.scenario-card-arrow svg{width:18px;height:18px}.badge{padding:2px var(--space-2);border-radius:var(--radius-input);font-family:var(--font-body);font-size:var(--font-size-label);font-weight:var(--font-weight-semibold);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;display:inline-flex}.badge-beginner{background:var(--color-bg-badge-beginner);color:var(--color-badge-beginner)}.badge-intermediate{background:var(--color-bg-badge-intermediate);color:var(--color-badge-intermediate)}.badge-advanced{background:var(--color-bg-badge-advanced);color:var(--color-badge-advanced)}.badge-roleplay{background:var(--color-bg-badge-beginner);color:var(--color-badge-beginner)}.badge-grammar{background:var(--color-bg-badge-intermediate);color:var(--color-badge-intermediate)}.badge-vocabulary{background:var(--color-bg-badge-advanced);color:var(--color-badge-advanced)}.scenario-card-skeleton{pointer-events:none;cursor:default}.scenario-skeleton-badge,.scenario-skeleton-title,.scenario-skeleton-desc{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--color-border-default) 25%, var(--color-bg-card-accent) 50%, var(--color-border-default) 75%);background-size:200% 100%;animation:1.4s ease-in-out infinite scenario-skeleton-shimmer;display:block}.scenario-skeleton-badge{width:72px;height:20px;margin-bottom:var(--space-2)}.scenario-skeleton-title{width:60%;height:16px;margin-bottom:var(--space-3)}.scenario-skeleton-desc{width:100%;height:13px;margin-bottom:var(--space-1)}.scenario-skeleton-desc.scenario-skeleton-desc-short{width:75%}@keyframes scenario-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.home-scenarios-feedback{padding:var(--space-8) 0;font-family:var(--font-body);font-size:var(--font-size-body);color:var(--color-text-tertiary);text-align:center;grid-column:1/-1;margin:0}.home-scenarios-feedback.home-scenarios-error{color:var(--color-feedback-error)}@media (width<=768px){.home-shell{flex-direction:column}.home-mobile-bar{z-index:20;padding:var(--space-3) var(--space-4);background:var(--color-bg-sidebar);border-bottom:1px solid var(--color-border-default);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.home-mobile-bar .home-sidebar-logo{position:absolute;left:50%;transform:translate(-50%)}.home-sidebar-overlay{z-index:29;cursor:pointer;background:#14182666;border:0;display:block;position:fixed;inset:0}.home-sidebar{z-index:30;height:100vh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.home-sidebar.is-open{transform:translate(0)}.home-main{padding:var(--space-6) var(--space-4)}.home-greeting{font-size:var(--font-size-display-sm);letter-spacing:var(--tracking-display-sm)}.home-conversation-card{text-align:center;flex-direction:column;align-items:stretch}.home-conversation-mic{align-self:center}.home-conversation-actions{width:100%}.home-btn-primary{justify-content:center;width:100%}.home-scenarios-grid{grid-template-columns:1fr}}.chat-shell{background:var(--color-bg-canvas);height:100dvh;display:flex;overflow:hidden}.chat-mobile-bar{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-sidebar);border-bottom:1px dotted var(--color-border-default);flex-shrink:0;display:none}.chat-mobile-bar .home-icon-btn,.chat-mobile-bar .chat-preferences-btn{flex-shrink:0}.chat-mobile-title{min-width:0;font-family:var(--font-display);font-size:var(--font-size-logo);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-logo);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;text-align:center;flex:1;margin:0;overflow:hidden}.chat-sidebar{width:var(--size-sidebar-w);background:var(--color-bg-sidebar);border-right:1px solid var(--color-border-default);height:100vh;padding:var(--space-6) var(--space-4);flex-direction:column;flex-shrink:0;display:flex;position:sticky;top:0}.chat-sidebar-top{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.chat-sidebar-overlay{display:none}.chat-sessions-header{justify-content:space-between;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.chat-sessions-header .home-recent-label{margin:0}.chat-search-toggle.is-active{background:var(--color-bg-card-accent);color:var(--color-accent-editorial)}.chat-sidebar-search{margin-bottom:var(--space-3);position:relative}.chat-sidebar-search-icon{top:50%;left:var(--space-3);width:16px;height:16px;color:var(--color-text-tertiary);pointer-events:none;display:inline-flex;position:absolute;transform:translateY(-50%)}.chat-sidebar-search-icon svg{width:100%;height:100%}.chat-sidebar-search-input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) calc(var(--space-3) + 16px + var(--space-2));border:1px solid var(--color-border-default);border-radius:var(--radius-input);font-family:var(--font-body);font-size:var(--font-size-body);background:var(--color-bg-card);color:var(--color-text-primary);outline:none;transition:border-color .15s}.chat-sidebar-search-input:focus{border-color:var(--color-border-focus)}.chat-sidebar-search-input:focus+.chat-sidebar-search-icon,.chat-sidebar-search:focus-within .chat-sidebar-search-icon{color:var(--color-text-secondary)}.chat-sidebar-sessions{margin-top:var(--space-8);flex:1;min-height:0}.chat-sidebar-footer{padding:var(--space-4);border-top:1px solid var(--color-border-default)}.chat-sidebar-logout{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-button);font-family:var(--font-body);font-size:var(--font-size-body);color:var(--color-text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;transition:color .15s}.chat-sidebar-logout:hover{color:var(--color-accent-editorial)}.chat-session-list{gap:var(--space-1);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.chat-sessions-empty{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);padding:var(--space-2) 0}.chat-session-item{width:100%;padding:var(--space-3);border-radius:var(--radius-input);text-align:left;cursor:pointer;background:0 0;border:none;transition:background .15s;display:block}.chat-session-item:hover{background:var(--color-bg-card-accent)}.chat-session-item.is-active{background:var(--color-bg-card);border-left:3px solid var(--color-accent-editorial)}.chat-session-item-header{justify-content:space-between;align-items:baseline;gap:var(--space-2);display:flex}.chat-session-item-title{font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.chat-session-item-time{font-family:var(--font-body);font-size:var(--font-size-label);color:var(--color-text-tertiary);white-space:nowrap;flex-shrink:0}.chat-session-item-preview{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin:var(--space-1) 0 0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.chat-main{flex-direction:column;flex:1;min-width:0;height:100dvh;min-height:0;display:flex}.chat-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-default);background:var(--color-bg-card);justify-content:space-between;align-items:center;display:flex}.chat-header-title{font-family:var(--font-body);font-size:var(--font-size-section);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.chat-header-meta{font-family:var(--font-body);font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin:var(--space-1) 0 0;text-transform:uppercase;letter-spacing:.5px}.chat-end-session{padding:var(--space-2) var(--space-4);border-radius:var(--radius-button);font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-accent-editorial);cursor:pointer;background:0 0;border:none;transition:opacity .15s}.chat-end-session:hover{opacity:.7}.chat-messages{-webkit-overflow-scrolling:touch;padding:var(--space-6);gap:var(--space-4);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.chat-session-marker{font-family:var(--font-body);font-size:var(--font-size-label);font-weight:var(--font-weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0 0 var(--space-2);text-align:center;align-self:center}.chat-messages-empty{padding:var(--space-8);flex:1;justify-content:center;align-items:center;display:flex}.chat-messages-empty-text{font-family:var(--font-body);font-size:var(--font-size-body);color:var(--color-text-tertiary);text-align:center;max-width:400px;line-height:var(--leading-body)}.chat-message-row{gap:var(--space-2);flex-direction:column;max-width:75%;display:flex}.chat-message-row-user{align-self:flex-end;align-items:flex-end}.chat-message-row-assistant{align-self:flex-start;align-items:flex-start}.chat-message-row .chat-bubble{max-width:100%}.chat-bubble{max-width:75%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-button);position:relative}.chat-bubble-user{background:var(--color-interactive-primary);color:var(--color-interactive-text);align-self:flex-end}.chat-bubble-assistant{background:var(--color-bg-card-accent);color:var(--color-text-primary);border:none;align-self:flex-start}.chat-bubble-audio{background:var(--color-bg-card-accent);color:var(--color-text-primary)}.chat-bubble-audio.chat-bubble-user{align-self:flex-end}.chat-bubble-audio.chat-bubble-assistant{align-self:flex-start}.chat-bubble-content{font-family:var(--font-body);font-size:var(--font-size-body);line-height:var(--leading-body);white-space:pre-wrap;word-wrap:break-word;overflow-wrap:anywhere;margin:0}.chat-bubble-translation{font-family:var(--font-body);font-size:var(--font-size-caption);line-height:var(--leading-caption);margin:var(--space-2) 0 0;opacity:.75}.chat-bubble-user .chat-bubble-translation{color:var(--color-interactive-text)}.chat-bubble-assistant .chat-bubble-translation{color:var(--color-text-secondary)}.chat-bubble-voice{align-items:center;gap:var(--space-3);min-width:180px;display:flex}.chat-bubble-voice+.chat-bubble-content,.chat-bubble-voice+.chat-bubble-translation{margin-top:var(--space-2)}.chat-voice-play{border-radius:var(--radius-full);background:var(--color-accent-editorial);color:#fff;cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:flex}.chat-voice-play svg{width:14px;height:14px}.chat-voice-track{border-radius:var(--radius-full);background:var(--color-bg-streak);flex:1;min-width:0;height:4px;overflow:hidden}.chat-voice-progress{border-radius:inherit;background:var(--color-accent-editorial);height:100%}.chat-voice-duration{font-family:var(--font-body);font-size:var(--font-size-label);opacity:.7;text-align:right;flex-shrink:0;min-width:2.5rem}.chat-audio-player{align-items:center;gap:var(--space-3);min-width:220px;max-width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);background:var(--color-bg-card-accent);display:flex}.chat-audio-player-loading{animation:1.4s ease-in-out infinite chat-audio-pulse}.chat-audio-player .chat-voice-play:disabled{cursor:default;opacity:.6}@keyframes chat-audio-pulse{0%,to{opacity:1}50%{opacity:.55}}.chat-bubble-cursor{vertical-align:text-bottom;background:currentColor;width:2px;height:1em;margin-left:2px;animation:.8s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.chat-bubble-skeleton{gap:var(--space-2);padding:var(--space-1) 0;flex-direction:column;display:flex}.chat-bubble-skeleton-line{border-radius:var(--radius-full);opacity:.18;background:linear-gradient(90deg,currentColor 25%,#0000 50%,currentColor 75%) 0 0/200% 100%;height:.7em;animation:1.2s ease-in-out infinite chat-bubble-skeleton-shimmer;display:block}.chat-bubble-skeleton-line:first-child{width:80%}.chat-bubble-skeleton-line:last-child{width:55%}@keyframes chat-bubble-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.chat-bubble-time{font-family:var(--font-body);font-size:var(--font-size-label);color:inherit;opacity:.6;margin-top:var(--space-1);display:block}.chat-bubble-user .chat-bubble-time{text-align:right}.chat-bubble-assistant .chat-bubble-time{text-align:left}.chat-input-form{align-items:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px dotted var(--color-border-default);background:var(--color-bg-card);flex-shrink:0;display:flex}.chat-input-wrap{align-items:center;gap:var(--space-2);min-height:48px;padding:var(--space-2) var(--space-2) var(--space-2) var(--space-4);border:1px solid var(--color-border-default);border-radius:var(--radius-full);background:var(--color-bg-canvas);flex:1;min-width:0;display:flex}.chat-input-field{padding:var(--space-2) 0;font-family:var(--font-body);font-size:var(--font-size-body);color:var(--color-text-primary);resize:none;line-height:var(--leading-body);background:0 0;border:none;border-radius:0;outline:none;flex:1;min-width:0;max-height:120px}.chat-input-field:focus{border-color:#0000}.chat-input-field::placeholder{color:var(--color-text-tertiary)}.chat-input-mic{border:1px solid var(--color-border-default);border-radius:var(--radius-full);background:var(--color-bg-card);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.chat-input-mic:disabled{opacity:.4;cursor:not-allowed}.chat-input-mic.chat-input-mic-active,.chat-input-mic.chat-input-mic-active:disabled{opacity:1;border-color:var(--color-feedback-error);background:var(--color-feedback-error);color:#fff;animation:1.2s ease-in-out infinite chat-recording-pulse}.chat-input-mic svg{width:18px;height:18px}.chat-input-action{border-radius:var(--radius-button);background:var(--color-interactive-primary);width:48px;height:48px;color:var(--color-interactive-text);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .15s;display:flex}.chat-input-action svg{width:20px;height:20px}.chat-input-action:disabled{opacity:.4;cursor:not-allowed}.chat-input-action:not(:disabled):hover{opacity:.85}.chat-input-form-vad{justify-content:center}.chat-input-action.chat-input-action-vad{width:80%;height:56px;padding:0 var(--space-4);gap:var(--space-3);border-radius:var(--radius-full)}.chat-input-action-label{font-size:var(--font-size-caption);flex-shrink:0;font-weight:600}.chat-input-action-waveform{flex:1;justify-content:space-between;align-items:center;gap:3px;min-width:0;height:40px;display:flex;overflow:hidden}.chat-input-action-bar{border-radius:var(--radius-full);background:var(--color-interactive-text);transform-origin:50%;flex:1;min-width:2px;max-width:4px;height:100%;transition:transform .1s linear;transform:scaleY(.08)}.chat-recording-bar{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px dotted var(--color-border-default);background:var(--color-bg-card);flex-shrink:0;display:flex}.chat-recording-main{align-items:center;gap:var(--space-3);min-height:48px;padding:var(--space-2) var(--space-4);border:1px solid var(--color-border-default);border-radius:var(--radius-full);background:var(--color-bg-canvas);flex:1;min-width:0;display:flex}.chat-recording-dot{border-radius:var(--radius-full);background:var(--color-feedback-error);flex-shrink:0;width:8px;height:8px;animation:1s ease-in-out infinite chat-recording-pulse}@keyframes chat-recording-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.25)}}.chat-recording-waveform{flex:1;align-items:center;gap:2px;min-width:0;height:28px;display:flex;overflow:hidden}.chat-recording-bar-line{border-radius:var(--radius-full);background:var(--color-text-secondary);transform-origin:50%;flex:1;min-width:2px;max-width:4px;height:100%;transition:transform .1s linear;transform:scaleY(.08)}.chat-recording-timer{font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);font-variant-numeric:tabular-nums;color:var(--color-text-primary);text-align:right;flex-shrink:0;min-width:40px}.chat-recording-btn{border-radius:var(--radius-button);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;padding:0;transition:opacity .15s;display:flex}.chat-recording-btn:hover{opacity:.85}.chat-recording-btn svg{width:20px;height:20px}.chat-recording-btn.cancel{border:1px solid var(--color-border-default);background:var(--color-bg-card);width:48px;color:var(--color-text-secondary)}.chat-recording-btn.confirm{background:var(--color-interactive-primary);color:var(--color-interactive-text)}.chat-loading{font-family:var(--font-body);font-size:var(--font-size-body);color:var(--color-text-tertiary);flex:1;justify-content:center;align-items:center;display:flex}.chat-error{padding:var(--space-3) var(--space-6);background:var(--color-bg-badge-advanced);color:var(--color-feedback-error);font-family:var(--font-body);font-size:var(--font-size-caption)}@media (width<=768px){.chat-shell{flex-direction:column}.chat-mobile-bar{z-index:20;display:flex;position:sticky;top:0}.chat-mobile-bar .home-icon-btn{border:1px solid var(--color-border-default);border-radius:var(--radius-button);background:var(--color-bg-card-accent);width:36px;height:36px;color:var(--color-text-primary)}.chat-sidebar{z-index:100;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.chat-sidebar.is-open{transform:translate(0)}.chat-sidebar-overlay{z-index:99;cursor:pointer;background:#14182666;border:none;display:block;position:fixed;inset:0}.chat-main{flex:1;height:auto;min-height:0}.chat-header{display:none}.chat-messages{padding:var(--space-4);gap:var(--space-3)}.chat-input-form{padding:var(--space-3) var(--space-4);gap:var(--space-2);background:var(--color-bg-sidebar)}.chat-bubble{max-width:85%}.chat-error{padding:var(--space-3) var(--space-4)}}.chat-header-actions{align-items:center;gap:var(--space-3);display:flex}.chat-preferences-btn{border-radius:var(--radius-md);border:1px solid var(--neutral-200);width:36px;height:36px;color:var(--neutral-500);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:all .15s;display:flex}.chat-preferences-btn svg{width:18px;height:18px}.chat-preferences-btn:hover{background:var(--neutral-100);color:var(--neutral-700);border-color:var(--neutral-300)}.chat-preferences-overlay{z-index:200;cursor:default;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;border:none;position:fixed;inset:0}.chat-preferences-drawer{z-index:201;background:var(--color-bg-canvas);flex-direction:column;width:360px;max-width:90vw;animation:.25s slide-in-right;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 24px #00000014}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-preferences-drawer-header{padding:var(--space-6) var(--space-6) var(--space-4);border-bottom:1px solid var(--color-border-default);position:relative}.chat-preferences-eyebrow{letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:var(--space-1);text-transform:uppercase;font-size:.65rem;font-weight:700;display:block}.chat-preferences-heading{color:var(--color-text-primary);margin:0;font-size:1.15rem;font-weight:600}.chat-preferences-close{top:var(--space-4);right:var(--space-4);border-radius:var(--radius-input);width:32px;height:32px;color:var(--color-text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute}.chat-preferences-close svg{width:18px;height:18px}.chat-preferences-close:hover{background:var(--color-bg-card-accent);color:var(--color-text-secondary)}.chat-preferences-body{padding:var(--space-6) var(--space-6);flex:1;overflow-y:auto}.chat-preferences-section{margin-bottom:var(--space-6)}.chat-preferences-section:last-child{margin-bottom:0}.chat-preferences-section-title{color:var(--color-text-primary);margin:0 0 var(--space-1) 0;font-size:.85rem;font-weight:600}.chat-preferences-section-desc{color:var(--color-text-tertiary);margin:0 0 var(--space-3) 0;font-size:.75rem}.chat-preferences-segmented{background:var(--color-bg-card-accent);border-radius:var(--radius-input);border:1px solid var(--color-border-default);gap:2px;padding:3px;display:flex}.chat-preferences-segment{padding:var(--space-2) var(--space-3);border-radius:calc(var(--radius-input) - 2px);color:var(--color-text-tertiary);cursor:pointer;white-space:nowrap;background:0 0;border:none;flex:1;font-size:.8rem;font-weight:500;transition:all .15s}.chat-preferences-segment:hover{color:var(--color-text-secondary)}.chat-preferences-segment.is-active{background:var(--color-bg-card);color:var(--color-text-primary);font-weight:600;box-shadow:0 1px 3px #00000014}.chat-preferences-slider{align-items:center;gap:var(--space-3);display:flex}.chat-preferences-slider-label{color:var(--color-text-tertiary);white-space:nowrap;min-width:40px;font-size:.75rem}.chat-preferences-slider-label:last-child{text-align:right}.chat-preferences-slider input[type=range]{appearance:none;background:var(--color-border-default);cursor:pointer;border-radius:2px;outline:none;flex:1;height:4px}.chat-preferences-slider input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-bg-card);border:2px solid var(--color-text-primary);cursor:pointer;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 3px #00000026}.chat-preferences-slider input[type=range]::-moz-range-thumb{background:var(--color-bg-card);border:2px solid var(--color-text-primary);cursor:pointer;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 3px #00000026}.chat-preferences-toggle{align-items:center;gap:var(--space-3);cursor:pointer;background:0 0;border:none;padding:0;display:flex}.chat-preferences-toggle-thumb{background:var(--color-border-default);border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.chat-preferences-toggle-thumb:after{content:"";background:var(--color-bg-card);border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.chat-preferences-toggle.is-on .chat-preferences-toggle-thumb{background:var(--color-feedback-success)}.chat-preferences-toggle.is-on .chat-preferences-toggle-thumb:after{transform:translate(20px)}.chat-preferences-toggle-label{color:var(--color-text-secondary);font-size:.8rem;font-weight:500}@media (width<=480px){.chat-preferences-drawer{width:100vw;max-width:100vw}}
