@font-face{font-family:Lindt-Titles;src:url(/assets/OPTIMAMEDIUM-DOddB9VC.OTF) format("opentype"),url(/assets/Optima-CIvURNOL.ttc) format("truetype")}:root{--color-primary: #ceb163;--color-primary-dark: #917236;--color-primary-light: #ceb163;--color-primary-bg: #f6f2c3;--color-accent: #ceb163;--color-accent-danger: #E05555;--color-accent-success: #4CAF82;--color-pretty-purple: #cac5e2;--color-bg: #f6f4f1;--color-surface: #FFFFFF;--color-surface-alt: #e6e3df;--color-border: #E4E1EF;--color-border-light: #EDEBF5;--color-text-primary: #1C1B2E;--color-text-secondary: #2f2f2f;--color-text-muted: #c6c6c6;--color-text-inverse: #FFFFFF;--color-topbar-bg: #FFFFFF;--color-topbar-border: #E4E1EF;--color-sidebar-bg: #FFFFFF;--color-sidebar-active: #ECEAE4;--color-sidebar-hover: #F5F4F0;--color-bubble-user: #ECEAE4;--color-bubble-ai: #ECEAE4;--color-bubble-input: #ECEAE4;--color-chip-bg: var(--color-primary);--color-chip-text: #FFFFFF;--color-chip-hover: #ceb163;--color-voice-ring: var(--color-primary);--color-voice-bg-icon: var(--color-primary);--color-answer-bg: var(--color-primary);--color-answer-text: #FFFFFF;--color-answer-correct: #4CAF82;--color-answer-wrong: #E05555;--color-startscreen-bg: var(--color-bg);--color-startscreen-card: #FFFFFF;--color-startscreen-hero-bg: #1C1B2E;--color-leaderboard-gold: #F5C842;--color-leaderboard-silver: #B0B8C1;--color-leaderboard-bronze: #C8956C;--font-display: sans-serif;--font-body: "Lindt-Titles", sans-serif;--font-logo: "Lindt-Titles", sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 17px;--text-lg: 20px;--text-xl: 26px;--text-2xl: 32px;--text-3xl: 42px;--weight-regular: 400;--weight-medium: 500;--weight-semi: 600;--weight-bold: 700;--tracking-tight: -.3px;--tracking-normal: 0px;--tracking-wide: .5px;--tracking-wider: 1.2px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--topbar-height: 56px;--sidebar-width: 260px;--content-max-w: 720px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--shadow-sidebar: 4px 0 24px rgba(0,0,0,.07);--transition-fast: .12s ease;--transition-normal: .22s ease;--transition-slow: .36s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg);line-height:1.55;transition:background-color var(--transition-normal),color var(--transition-normal);overflow-x:hidden}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font-body);cursor:pointer;border:none;background:none;padding:0}input,textarea{font-family:var(--font-body);font-size:var(--text-base);border:none;outline:none;background:none}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.items-center{align-items:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:var(--tracking-wide)}.tracking-wider{letter-spacing:var(--tracking-wider)}.font-bold{font-weight:var(--weight-bold)}.font-medium{font-weight:var(--weight-medium)}.w-full{width:100%}.h-full{height:100%}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page-layout{display:flex;flex-direction:column;min-height:100vh;padding-top:var(--topbar-height)}.content-wrap{width:100%;max-width:var(--content-max-w);margin:0 auto;padding:0 var(--space-4)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);background:var(--color-primary);color:var(--color-text);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);border:none;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);background:transparent;color:var(--color-text-secondary);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.btn-ghost:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.icon-btn:hover{background:var(--color-sidebar-hover);color:var(--color-text-primary)}.icon-disabled{color:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .28s ease both}@keyframes pulse-ring{0%{transform:scale(1);opacity:.7}50%{transform:scale(1.08);opacity:1}to{transform:scale(1);opacity:.7}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .9s linear infinite}@media (max-width: 600px){.hide-mobile{display:none!important}}@media (min-width: 601px){.hide-desktop{display:none!important}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-4)}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);width:100%;max-width:400px;box-shadow:var(--shadow-lg);animation:fadeIn .3s ease both}.auth-card__logo{text-align:center;margin-bottom:var(--space-4)}.auth-card__tabs{display:flex;border-bottom:1.5px solid var(--color-border);margin-bottom:var(--space-6)}.auth-card__tab{flex:1;padding:var(--space-2) 0;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-text-muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:color var(--transition-fast),border-color var(--transition-fast)}.auth-card__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-form__field{display:flex;flex-direction:column;gap:var(--space-1)}.auth-form__label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-secondary)}.auth-form__input{background:var(--color-surface-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-base);color:var(--color-text-primary);width:100%;transition:border-color var(--transition-fast)}.auth-form__input:focus{border-color:var(--color-primary);outline:none}.auth-form__input::placeholder{color:var(--color-text-muted)}.auth-form__error{font-size:var(--text-sm);color:var(--color-accent-danger);text-align:center;padding:var(--space-2);background:#e0555514;border-radius:var(--radius-md)}.auth-form .btn-primary{width:100%;padding:var(--space-4);font-size:var(--text-sm);margin-top:var(--space-2)}.auth-form__privacy{margin-top:var(--space-1)}.auth-form__privacy-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.auth-form__privacy-check{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.auth-form__privacy-link{color:var(--color-primary-dark);text-decoration:underline;font-weight:var(--weight-medium);cursor:pointer}.auth-form__privacy-link:hover{color:var(--color-primary)}.start-screen{min-height:100vh;padding-top:var(--topbar-height);background:var(--color-startscreen-bg);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-bottom:var(--space-12);animation:fadeIn .35s ease both}.start-screen__header{text-align:center;padding:var(--space-8) var(--space-4) var(--space-4)}.start-screen__title{font-family:var(--font-logo);font-size:clamp(var(--text-2xl),5vw,var(--text-3xl));font-weight:var(--weight-regular);color:var(--color-text-primary);line-height:1.2;letter-spacing:var(--tracking-tight);margin-bottom:var(--space-3)}.start-screen__subtitle{font-size:var(--text-base);color:var(--color-text-secondary);max-width:600px;line-height:1.6}.start-screen__speakers{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);margin-bottom:var(--space-5)}.start-screen__speakers-icon{height:40px}.start-screen__speakers-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-secondary)}.start-screen__speakers-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);width:100%;max-width:1200px;padding:0 var(--space-4)}.start-screen__speaker-card{position:relative;border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4 / 3;box-shadow:var(--shadow-md)}.start-screen__speaker-img{width:100%;height:100%;object-fit:cover;object-position:right center;display:block}.start-screen__speaker-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(to bottom,#0009,#0000000d 30%,#0000000d 55%,#000000bf);padding:var(--space-16) var(--space-12) var(--space-16)}.start-screen__speaker-overlay-top{display:flex;flex-direction:column;gap:var(--space-1)}.start-screen__speaker-domain{font-family:var(--font-logo);font-size:var(--text-3xl);font-weight:var(--weight-regular);color:#fff;letter-spacing:var(--tracking-wide)}.start-screen__speaker-tagline{font-family:var(--font-logo);font-size:var(--text-sm);color:#fffc;margin:0;font-weight:var(--weight-medium)}.start-screen__speaker-btn{border-radius:var(--radius-full);padding:var(--space-3) var(--space-5);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;border:none;cursor:pointer;align-self:flex-start;transition:background var(--transition-fast),transform var(--transition-fast);white-space:nowrap}.start-screen__speaker-btn--active{background:#b8892a;color:#fff}.start-screen__speaker-btn--active:hover{background:#d4a03a;transform:translateY(-1px)}.start-screen__speaker-btn--soon{background:#ffffff2e;color:#ffffffa6;cursor:default;border:1px solid rgba(255,255,255,.25)}@media (max-width: 900px){.start-screen__speaker-domain{font-size:var(--text-3xl)}.start-screen__speakers-grid{grid-template-columns:1fr;max-width:600px}.start-screen__speaker-overlay{padding:var(--space-16) var(--space-12) var(--space-16)}}@media (max-width: 600px){.start-screen__speakers-grid{grid-template-columns:1fr;max-width:380px}.start-screen__speaker-card{aspect-ratio:4 / 3}.start-screen__speaker-domain{font-size:var(--text-2xl)}.start-screen__speaker-overlay{padding:var(--space-8) var(--space-6) var(--space-8)}}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);background:var(--color-topbar-bg);border-bottom:1px solid var(--color-topbar-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-3);z-index:30;transition:background var(--transition-normal),border-color var(--transition-normal)}.topbar__left{display:flex;align-items:center;gap:var(--space-1);min-width:120px}.topbar__center{position:absolute;left:50%;transform:translate(-50%);pointer-events:none}.topbar__logo{height:60px;pointer-events:auto;cursor:pointer;text-decoration:none}.topbar__right{display:flex;align-items:center;gap:var(--space-2);min-width:120px;justify-content:flex-end}.topbar__help-btn{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-secondary);background:none;border:none;cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.topbar__help-btn:hover{color:var(--color-text-primary);background:var(--color-surface-alt)}.topbar__search{display:flex;align-items:center;gap:var(--space-2);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:5px var(--space-3);height:30px;width:140px;transition:width var(--transition-normal),border-color var(--transition-fast)}.topbar__search:focus-within{border-color:var(--color-primary-light);width:180px}.topbar__search input{font-size:var(--text-xs);color:var(--color-text-primary);width:100%;background:none}.topbar__search input::placeholder{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-size:var(--text-xs)}.topbar__search-icon{color:var(--color-text-muted);font-size:11px;flex-shrink:0}.topbar__user-badge{display:flex;align-items:center;gap:var(--space-2);background:var(--color-primary);color:var(--color-text);border-radius:var(--radius-full);padding:8px var(--space-6);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;cursor:pointer;border:none;transition:background var(--transition-fast);white-space:nowrap}.topbar__user-badge:hover{background:var(--color-primary-dark)}.topbar__user-badge--admin{background:#1c1b2e;color:#fff}.topbar__user-badge--admin:hover{background:#2f2e45}.topbar__user-badge-icon{font-size:10px;opacity:.85}.topbar__user{position:relative}.topbar__user-menu{position:absolute;right:0;top:110%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.topbar__user-menu-item{padding:10px 16px;background:none;border:none;width:100%;text-align:left;cursor:pointer;color:var( --color-text-primary)}.topbar__user-menu-item:hover{background:var(--color-surface-alt)}.topbar__theme-btn{color:var(--color-text-secondary);font-size:15px}.topbar__theme-btn:hover{color:var(--color-text-primary)}@media (max-width: 800px){.topbar__search,.topbar__help-btn{display:none}}.sidebar__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:40;animation:fadeIn .18s ease both}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--color-sidebar-bg);border-right:1px solid var(--color-border);z-index:50;display:flex;flex-direction:column;transform:translate(-100%);transition:transform var(--transition-slow),background var(--transition-normal);box-shadow:none;overflow:visible}.sidebar--open{transform:translate(0);box-shadow:var(--shadow-sidebar)}.sidebar__top{height:var(--topbar-height);display:flex;align-items:center;padding:0 var(--space-3);gap:var(--space-1);border-bottom:1px solid var(--color-border);flex-shrink:0}.sidebar__content{flex:1;overflow-y:auto;overflow-x:visible;padding:var(--space-6) 0;clip-path:none}.sidebar__section{margin-bottom:28px}.sidebar__section-label-wrap{padding:0 var(--space-5) var(--space-2)}.sidebar__section-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:var(--tracking-wide);text-transform:uppercase;padding-bottom:var(--space-2);border-bottom:1.5px solid var(--color-border)}.sidebar__items{padding:var(--space-1) var(--space-3) 0;display:flex;flex-direction:column;gap:2px}.sidebar__nav-item-wrap{position:relative}.sidebar__nav-item{display:flex;align-items:center;gap:var(--space-3);padding:9px var(--space-3);border-radius:var(--radius-md);border:none;background:none;cursor:pointer;width:100%;text-align:left;transition:background var(--transition-fast);color:var(--color-text-secondary)}.sidebar__nav-item:hover{background:var(--color-sidebar-hover)}.sidebar__nav-item--active{background:var(--color-sidebar-active)!important}.sidebar__nav-item-icon{display:flex;align-items:center;flex-shrink:0;font-size:14px;color:var(--color-text-secondary);width:18px}.sidebar__nav-item--active .sidebar__nav-item-icon{color:var(--color-text-primary)}.sidebar__nav-item--muted .sidebar__nav-item-icon{color:var(--color-text-muted)}.sidebar__nav-item-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-text-secondary)}.sidebar__nav-item--active .sidebar__nav-item-label{font-weight:var(--weight-bold);color:var(--color-text-primary)}.sidebar__nav-item--muted .sidebar__nav-item-label{color:var(--color-text-muted)}.sidebar__tooltip-portal{position:fixed;transform:translateY(-50%);background:var(--color-primary);color:var(--color-text);font-family:var(--font-display);font-size:var(--text-s);font-weight:var(--weight-medium);white-space:nowrap;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);box-shadow:var(--shadow-md);pointer-events:none;z-index:9999;animation:fadeIn .1s ease both}.sidebar__tooltip-portal:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:var(--color-primary-dark)}@media (max-width: 600px){.sidebar__tooltip-portal{display:none}}.chat-screen{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-height));background:var(--color-bg);animation:fadeIn .25s ease both}.chat-welcome{display:flex;flex-direction:column;align-items:center;padding:var(--space-12) var(--space-4) var(--space-6);text-align:center;flex-shrink:0;gap:var(--space-3)}.chat-welcome__image{height:70px;width:70px;border-radius:var(--radius-full)}.chat-welcome__image-patrick{height:120px;width:120px;border-radius:var(--radius-full)}.chat-welcome__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-2)}.chat-welcome__greeting{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.55;white-space:pre-line}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-5)}.chat-messages__inner{width:100%;max-width:var(--content-max-w);margin:0 auto}.chat-message{display:flex;flex-direction:column;gap:var(--space-1);animation:fadeIn .2s ease both}.chat-message__sender{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);color:var(--color-text-secondary);text-transform:uppercase;padding:0 var(--space-2)}.chat-message__bubble{background:var(--color-bubble-user);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);font-size:var(--text-base);color:var(--color-text-primary);line-height:1.6;max-width:100%;position:relative}.chat-message__bubble:after{content:"";position:absolute;bottom:-8px;width:0;height:0;border-style:solid}.chat-message--user .chat-message__bubble:after{right:20px;border-width:8px 8px 0 8px;border-color:var(--color-bubble-user) transparent transparent transparent}.chat-message--ai .chat-message__bubble:after{left:-8px;bottom:auto;top:18px;border-width:8px 8px 8px 0;border-color:transparent var(--color-bubble-ai) transparent transparent}.chat-message__loading{display:flex;gap:5px;align-items:center;padding:var(--space-1) 0}.chat-message__dot{width:7px;height:7px;background:var(--color-text-muted);border-radius:var(--radius-full);animation:dotBounce 1.2s ease-in-out infinite}.chat-message__dot:nth-child(2){animation-delay:.2s}.chat-message__dot:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:scale(.7);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-message--ai{flex-direction:row;gap:var(--space-3);align-items:flex-start}.chat-message__ai-avatar{margin-top:18px}.chat-message__ai-avatar-image{height:40px;border-radius:var(--radius-full)}.chat-message--ai .chat-message__content{flex:1}.chat-suggested{padding:var(--space-4) var(--space-4) var(--space-2);display:flex;flex-direction:column;gap:var(--space-2);max-width:var(--content-max-w);margin:0 auto;width:100%}.chat-suggested__label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text);text-align:center;margin-bottom:var(--space-1)}.chat-suggested__btn{background:var(--color-chip-bg);color:var(--color-text);border:none;border-radius:var(--radius-full);padding:var(--space-3) var(--space-5);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);text-align:center;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);width:100%}.chat-suggested__btn:hover{background:var(--color-chip-hover);transform:translateY(-1px)}.chat-input-wrap{padding:var(--space-3) var(--space-4) var(--space-5);flex-shrink:0}.chat-input{width:100%;max-width:var(--content-max-w);margin:0 auto;background:var(--color-bubble-input);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);position:relative;border-bottom:none}.chat-input:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:0;height:0;border-style:solid;border-width:10px 10px 0 10px;border-color:var(--color-bubble-input) transparent transparent transparent}.chat-input__sender-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);color:var(--color-text-muted);text-transform:uppercase}.chat-input textarea{width:100%;resize:none;background:none;font-size:var(--text-base);color:var(--color-text-primary);line-height:1.5;min-height:44px;max-height:120px;overflow-y:auto}.chat-input textarea::placeholder{color:var(--color-text-muted)}.chat-input__actions{display:flex;align-items:center;justify-content:space-between}.chat-input__add-btn{width:32px;height:32px;border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:none;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color var(--transition-fast),color var(--transition-fast);font-size:13px}.chat-input__add-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.chat-input__mic-btn{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-text-primary);color:var(--color-bg);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:background var(--transition-fast),transform var(--transition-fast)}.chat-input__mic-btn:hover{background:var(--color-primary);transform:scale(1.05)}.chat-input__send-btn{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background var(--transition-fast),transform var(--transition-fast)}.chat-input__send-btn:hover{background:var(--color-primary-dark);transform:scale(1.05)}.chat-input__send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}@media (max-width: 600px){.chat-welcome{padding-top:var(--space-3);gap:var(--space-3)}.chat-welcome__image{height:70px;width:70px}.chat-welcome__greeting{font-size:var(--text-m);margin-top:var(--space-6)}.chat-welcome__avatar{width:90px;height:90px;font-size:22px}.chat-welcome__image-patrick{height:100px;width:100px;margin-bottom:var(--space-8)}.chat-welcome{padding-top:var(--space-4);gap:var(--space-2)}}.chat-input__mic-btn--active{background:var(--color-accent-danger)!important;animation:pulse-ring 1s ease-in-out infinite}.chat-input__tts-btn{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-text-inverse);color:var(--color-text);border:1.5px solid var(--color-border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.chat-input__tts-btn:hover{background:var(--color-primary-bg);color:var(--color-primary-dark);border-color:var(--color-primary)}.chat-input__tts-btn--active{background:var(--color-primary)!important;color:var(--color-text-inverse)!important;border-color:var(--color-primary)!important}.chat-mic-error{max-width:var(--content-max-w);margin:0 auto var(--space-2);width:calc(100% - var(--space-8));background:#e055551a;border:1px solid rgba(224,85,85,.3);color:var(--color-accent-danger);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);text-align:center;animation:fadeIn .2s ease both}.md-content{display:flex;flex-direction:column;gap:0}.md-p{margin:0 0 4px;line-height:1.65}.md-p:last-child{margin-bottom:0}.md-spacer{height:8px}.md-h1,.md-h2,.md-h3{font-family:var(--font-display);font-weight:var(--weight-bold);color:var(--color-text-primary);margin:8px 0 4px;line-height:1.3}.md-h1{font-size:var(--text-md)}.md-h2{font-size:var(--text-base)}.md-h3{font-size:var(--text-sm)}.md-list{margin:6px 0;padding-left:20px;display:flex;flex-direction:column;gap:4px}.md-list li{line-height:1.55;font-size:var(--text-base)}.chat-screen--empty{justify-content:center}.chat-screen--empty .chat-messages{flex:0 0 auto;overflow:visible;padding:0 var(--space-4)}.chat-screen--empty .chat-input-wrap{margin-top:var(--space-6)}.chat-screen--empty .chat-suggested{margin-top:var(--space-2)}.voice-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - var(--topbar-height));padding:var(--space-8) var(--space-4);background:var(--color-bg);animation:fadeIn .3s ease both}.voice__image{height:120px;width:120px;border-radius:var(--radius-full)}.voice-screen__header{text-align:center;margin-bottom:var(--space-10)}.voice-screen__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-2)}.voice-screen__subtitle{font-size:var(--text-base);color:var(--color-text-secondary);white-space:pre-line;line-height:1.5}.voice-ring-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:160px;height:160px;margin-bottom:var(--space-6)}.voice-ring{position:absolute;top:0;left:0;width:100%;height:100%}.voice-ring__track{fill:none;stroke:var(--color-border);stroke-width:5}.voice-ring__progress{fill:none;stroke:var(--color-voice-ring);stroke-width:5;stroke-linecap:round;stroke-dasharray:440;stroke-dashoffset:0;transform-origin:center;transform:rotate(-90deg);transition:stroke-dashoffset .3s ease}.voice-ring--listening .voice-ring__progress{animation:spin 1.8s linear infinite;stroke-dashoffset:110;transition:stroke-dashoffset .35s ease}.voice-ring--speaking .voice-ring__progress{animation:pulse-ring 1s ease-in-out infinite}.voice-ring--processing .voice-ring__progress{animation:spin .9s linear infinite;stroke:var(--color-primary-dark);opacity:.6}.voice-ring__icon{position:relative;width:100px;height:100px;border-radius:var(--radius-full);background:var(--color-voice-bg-icon);display:flex;align-items:center;justify-content:center;font-size:42px;color:#fff}.voice-status{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-8);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--space-8)}.voice-transcript{max-width:460px;text-align:center;font-size:var(--text-base);color:var(--color-text-secondary);min-height:48px;margin-bottom:var(--space-6);line-height:1.5;font-style:italic}.voice-controls{display:flex;align-items:center;gap:var(--space-5)}.voice-btn{width:58px;height:58px;border-radius:var(--radius-full);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:transform var(--transition-fast),background var(--transition-fast)}.voice-btn:hover{transform:scale(1.06)}.voice-btn--mic{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-md)}.voice-btn--mic.muted{background:var(--color-accent-danger);color:#fff}.voice-btn--hangup{background:var(--color-accent-danger);color:#fff;box-shadow:var(--shadow-md)}.voice-btn--start{background:var(--color-primary);color:#fff;width:70px;height:70px;font-size:24px;box-shadow:var(--shadow-lg)}.voice-permission-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);max-width:440px;width:100%;text-align:center;box-shadow:var(--shadow-md);animation:fadeIn .3s ease both;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.voice-permission-icon{width:64px;height:64px;border-radius:var(--radius-full);background:#e055551a;color:var(--color-accent-danger);display:flex;align-items:center;justify-content:center;font-size:26px}.voice-permission-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--color-text-primary)}.voice-permission-desc{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.6}.voice-permission-steps{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);text-align:left;width:100%}.voice-permission-steps-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--space-3)}.voice-permission-steps ol{padding-left:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.voice-permission-steps li{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5}.voice-permission-steps strong{color:var(--color-text-primary)}@media (max-width: 600px){.voice-permission-card{padding:var(--space-8) var(--space-4)}}.voice-screen__mode-badge{display:inline-block;margin-top:var(--space-2);background:var(--color-primary-bg);color:var(--color-primary-dark);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);text-align:center}.voice-perm-nudge{font-size:var(--text-sm);color:var(--color-text-secondary);font-style:italic;text-align:center;max-width:340px;margin-bottom:var(--space-4);animation:fadeIn .3s ease both}.avatar-screen{display:flex;flex-direction:column;align-items:center;min-height:calc(100vh - var(--topbar-height));padding:var(--space-6) var(--space-4);background:var(--color-bg);animation:fadeIn .3s ease both}.avatar-video-wrap{background:#000}.avatar-screen__header{margin-top:var(--space-10);text-align:center;margin-bottom:var(--space-10)}.avatar-screen__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.avatar-screen__subtitle{padding-top:var(--space-6);font-size:var(--text-base);color:var(--color-text-secondary)}.avatar-video-wrap{width:100%;max-width:700px;aspect-ratio:16 / 9;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-startscreen-hero-bg);position:relative;box-shadow:var(--shadow-lg)}.avatar-video-wrap img,.avatar-video-wrap iframe,.avatar-video-wrap video{width:100%;height:100%;object-fit:cover;display:block;border:none}.avatar-timer{position:absolute;top:var(--space-3);left:var(--space-3);background:#00000073;color:#fff;border-radius:var(--radius-md);padding:var(--space-1) var(--space-3);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-medium);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.avatar-controls{position:absolute;bottom:var(--space-4);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-2)}.avatar-controls__left{position:absolute;bottom:var(--space-4);left:var(--space-4)}.avatar-controls__right{position:absolute;bottom:var(--space-4);right:var(--space-4);display:flex;gap:var(--space-2)}.avatar-btn{width:42px;height:42px;border-radius:var(--radius-full);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:transform var(--transition-fast),background var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.avatar-btn:hover{transform:scale(1.06)}.avatar-btn--default{background:var(--color-surface);color:var(--color-text)}.avatar-btn--hangup{background:var(--color-accent-danger);color:#fff}.avatar-btn--active{background:var(--color-primary);color:var(--color-text)}.avatar-btn--more{background:#ffffff80;color:#000;font-size:12px;letter-spacing:2px}.avatar-iframe{width:100%;height:100%;border:none;display:block;border-radius:var(--radius-xl)}.avatar-start-wrap{gap:var(--space-2)}.avatar-start-wrap{margin-top:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.avatar-start-btn{padding:var(--space-4) var(--space-10);font-size:var(--text-base);color:var(--color-text)}.avatar-start-note{font-size:var(--text-sm);color:var(--color-text)}@media (max-width: 600px){.avatar-video-wrap{aspect-ratio:3 / 4}.avatar-transcript{bottom:70px;font-size:var(--text-xs)}}.leaderboard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:60;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .2s ease both}.leaderboard-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeIn .25s ease both}.leaderboard-modal__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.leaderboard-modal__title{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-bold);color:var(--color-text-primary)}.leaderboard-modal__title-icon{color:var(--color-leaderboard-gold);font-size:var(--text-lg)}.leaderboard-modal__close{color:var(--color-text-muted);font-size:var(--text-lg);transition:color var(--transition-fast)}.leaderboard-modal__close:hover{color:var(--color-text-primary)}.leaderboard-list{overflow-y:auto;flex:1;padding:var(--space-4)}.leaderboard-empty{text-align:center;padding:var(--space-10);color:var(--color-text-muted);font-size:var(--text-base)}.leaderboard-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);transition:background var(--transition-fast);animation:fadeIn .2s ease both}.leaderboard-row:hover{background:var(--color-surface-alt)}.leaderboard-row__rank{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);flex-shrink:0;background:var(--color-surface-alt);color:var(--color-text-secondary)}.leaderboard-row__rank--gold{background:var(--color-leaderboard-gold);color:#5a4000}.leaderboard-row__rank--silver{background:var(--color-leaderboard-silver);color:#333}.leaderboard-row__rank--bronze{background:var(--color-leaderboard-bronze);color:#5a2e00}.leaderboard-row__info{flex:1;min-width:0}.leaderboard-row__name{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semi);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-row__topic{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-row__score{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--color-primary);flex-shrink:0}.leaderboard-row__date{font-size:var(--text-xs);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.tutorial-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;pointer-events:none}.tutorial-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000085;pointer-events:auto}.tutorial-waiting{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:auto}.tutorial-bubble{position:fixed;width:260px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);pointer-events:auto;opacity:0;transition:opacity .15s ease;animation:tutorialPop .2s ease both}.tutorial-bubble--center{position:relative;opacity:1}@keyframes tutorialPop{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.tutorial-bubble:before{content:"";position:absolute;width:0;height:0;border-style:solid}.tutorial-bubble--right:before{left:-9px;top:50%;transform:translateY(-50%);border-width:8px 9px 8px 0;border-color:transparent var(--color-surface) transparent transparent}.tutorial-bubble--left:before{right:-9px;top:50%;transform:translateY(-50%);border-width:8px 0 8px 9px;border-color:transparent transparent transparent var(--color-surface)}.tutorial-bubble--bottom:before{top:-9px;left:50%;transform:translate(-50%);border-width:0 8px 9px 8px;border-color:transparent transparent var(--color-surface) transparent}.tutorial-bubble--top:before{bottom:-9px;left:50%;transform:translate(-50%);border-width:9px 8px 0 8px;border-color:var(--color-surface) transparent transparent transparent}.tutorial-bubble--right:after,.tutorial-bubble--left:after,.tutorial-bubble--bottom:after,.tutorial-bubble--top:after{content:"";position:absolute;width:0;height:0;border-style:solid;z-index:-1}.tutorial-bubble--right:after{left:-11px;top:50%;transform:translateY(-50%);border-width:9px 11px 9px 0;border-color:transparent var(--color-border) transparent transparent}.tutorial-bubble--left:after{right:-11px;top:50%;transform:translateY(-50%);border-width:9px 0 9px 11px;border-color:transparent transparent transparent var(--color-border)}.tutorial-bubble--bottom:after{top:-11px;left:50%;transform:translate(-50%);border-width:0 9px 11px 9px;border-color:transparent transparent var(--color-border) transparent}.tutorial-bubble--top:after{bottom:-11px;left:50%;transform:translate(-50%);border-width:11px 9px 0 9px;border-color:var(--color-border) transparent transparent transparent}.tutorial-close{position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;border-radius:var(--radius-full);background:var(--color-surface-alt);border:none;cursor:pointer;font-size:11px;color:var(--color-text);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.tutorial-close:hover{background:var(--color-border);color:var(--color-text-primary)}.tutorial-dots{display:flex;gap:var(--space-1);align-items:center}.tutorial-dot{width:6px;height:6px;border-radius:var(--radius-full);background:var(--color-border);transition:background var(--transition-fast),transform var(--transition-fast)}.tutorial-dot--active{background:var(--color-primary);transform:scale(1.3)}.tutorial-step-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--color-text-primary);margin:0;padding-right:var(--space-4)}.tutorial-step-body{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.55;margin:0}.tutorial-actions{display:flex;gap:var(--space-2);justify-content:flex-end;margin-top:var(--space-1)}.tutorial-btn{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:none;cursor:pointer;background:var(--color-primary);color:var(--color-text);transition:background var(--transition-fast),transform var(--transition-fast)}.tutorial-btn:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.tutorial-btn--ghost{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.tutorial-btn--ghost:hover{background:var(--color-surface-alt);color:var(--color-text-primary);transform:none}.tutorial-highlight-ring{outline:2.5px solid var(--color-primary)!important;outline-offset:4px!important;border-radius:var(--radius-md)!important;animation:tutorialRingPulse 1.4s ease-in-out infinite!important;position:relative;z-index:8999!important}@keyframes tutorialRingPulse{0%,to{outline-color:var(--color-primary);box-shadow:0 0 #f7b2cd66}50%{outline-color:var(--color-primary-dark);box-shadow:0 0 0 6px #f7b2cd00}}@media (max-width: 480px){.tutorial-bubble{width:210px}}.score-screen{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--topbar-height));background:var(--color-bg);padding:var(--space-8) var(--space-4)}.score-wrap{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);max-width:480px;width:100%;text-align:center}.score-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.score-trophy-icon{font-size:48px;color:var(--color-leaderboard-gold);filter:drop-shadow(0 4px 12px rgba(245,200,66,.3))}.score-title{font-family:var(--font-logo);font-size:var(--text-2xl);font-weight:var(--weight-regular);color:var(--color-text-primary);letter-spacing:var(--tracking-tight)}.score-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);width:100%}.score-stat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.score-stat--primary{background:var(--color-primary-bg);border-color:var(--color-primary)}.score-stat__value{font-family:var(--font-logo);font-size:var(--text-2xl);font-weight:var(--weight-regular);color:var(--color-text-primary);line-height:1}.score-stat__label{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-display);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase}.score-history{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);width:100%;text-align:left}.score-history__label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-4)}.score-history__row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);font-size:var(--text-sm)}.score-history__row:last-child{border-bottom:none}.score-history__topic{flex:1;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.score-history__result{font-family:var(--font-display);font-weight:var(--weight-bold);color:var(--color-primary-dark);flex-shrink:0}.score-text{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.7}.score-text strong{color:var(--color-text-primary);font-weight:var(--weight-bold)}.mc-screen{min-height:calc(100vh - var(--topbar-height));background:var(--color-bg);padding:var(--space-12) var(--space-6) var(--space-12);animation:fadeIn .28s ease both}.mc-page-header{display:flex;flex-direction:column;gap:var(--space-6);margin-bottom:var(--space-8);max-width:1100px;margin-left:auto;margin-right:auto;margin-top:20px}@media (min-width: 700px){.mc-page-header{flex-direction:row;align-items:center;justify-content:space-between}}.mc-page-title-block{display:flex;flex-direction:column;gap:var(--space-1)}.mc-page-eyebrow{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted)}.mc-page-title{font-family:var(--font-logo);font-size:clamp(var(--text-xl),3vw,var(--text-2xl));font-weight:var(--weight-regular);color:var(--color-text-primary);letter-spacing:var(--tracking-tight)}.mc-header-actions{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap}.mc-scenario-input{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-primary);width:240px;transition:border-color var(--transition-fast)}.mc-scenario-input:focus{border-color:var(--color-primary);outline:none}.mc-layout{display:grid;gap:var(--space-6);max-width:1100px;margin:0 auto;grid-template-columns:1fr}.mc-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.mc-card__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-3)}.mc-card__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--color-text-primary)}.mc-card__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.mc-tabs{display:flex;border-bottom:1.5px solid var(--color-border);margin-bottom:var(--space-5)}.mc-tab{flex:1;padding:var(--space-3) 0;font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1.5px;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.mc-tab--active{color:var(--color-primary-dark);border-bottom-color:var(--color-primary)}.mc-field{display:flex;flex-direction:column;gap:var(--space-1)}.mc-field--span2{grid-column:1 / -1}.mc-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-secondary)}.mc-input{background:var(--color-surface-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-primary);width:100%;font-family:var(--font-body);transition:border-color var(--transition-fast)}.mc-input:focus{border-color:var(--color-primary);outline:none}.mc-textarea{background:var(--color-surface-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-primary);width:100%;font-family:var(--font-body);resize:vertical;min-height:90px;transition:border-color var(--transition-fast)}.mc-textarea:focus{border-color:var(--color-primary);outline:none}.mc-select{background:var(--color-surface-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-primary);width:100%;font-family:var(--font-body);cursor:pointer;transition:border-color var(--transition-fast)}.mc-select:focus{border-color:var(--color-primary);outline:none}.mc-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media (max-width: 600px){.mc-grid-2{grid-template-columns:1fr}}.mc-avatar-picker{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.mc-avatar-option{border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);text-align:left;cursor:pointer;background:var(--color-surface-alt);transition:border-color var(--transition-fast),background var(--transition-fast);display:flex;align-items:center;gap:var(--space-3)}.mc-avatar-option--selected{border-color:var(--color-primary);background:var(--color-primary-bg)}.mc-avatar-dot{width:36px;height:36px;border-radius:var(--radius-full);background:#000;border:1.5px solid #000;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--weight-bold);font-size:var(--text-sm);color:#fff;flex-shrink:0}.mc-avatar-option--selected .mc-avatar-dot{background:#000;color:#fff;border-color:#000}.mc-avatar-name{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-primary)}.mc-preview{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);display:flex;gap:var(--space-3);align-items:flex-start}.mc-preview__dot{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-text-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);flex-shrink:0}.mc-preview__bubble{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);flex:1}.mc-preview__name{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.mc-preview__text{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5}.mc-field-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-1)}.mc-scenario-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.mc-scenario-card__header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.mc-scenario-card__title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-2)}.mc-scenario-card__body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.mc-scenario-delete{width:32px;height:32px;border-radius:var(--radius-md);background:none;border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;transition:background var(--transition-fast),color var(--transition-fast)}.mc-scenario-delete:hover:not(:disabled){background:#e055551a;color:var(--color-accent-danger);border-color:var(--color-accent-danger)}.mc-scenario-delete:disabled{opacity:.3;cursor:default}.mc-score-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media (max-width: 600px){.mc-score-grid{grid-template-columns:1fr}}.mc-score-item{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.mc-score-item__top{display:flex;align-items:center;justify-content:space-between}.mc-score-item__label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);color:var(--color-text-secondary)}.mc-score-item__value{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--color-text-primary)}.mc-score-bar-track{height:8px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.mc-score-bar-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .3s ease}.mc-score-number-input{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text-primary);width:100%;font-family:var(--font-body)}.mc-score-number-input:focus{border-color:var(--color-primary);outline:none}.mc-final-score{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}.mc-final-score__row{display:flex;align-items:center;justify-content:space-between}.mc-final-score__label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-primary)}.mc-final-score__badge{background:var(--color-primary);color:var(--color-text);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);padding:var(--space-1) var(--space-4);border-radius:var(--radius-full)}.mc-final-score-bar{height:10px;background:#4caf8226;border-radius:var(--radius-full);overflow:hidden}.mc-final-score-bar-fill{height:100%;width:100%;background:var(--color-accent-success);border-radius:var(--radius-full)}.mc-json-section{max-width:1100px;margin:var(--space-6) auto 0}.mc-json-pre{background:#1c1b2e;color:#e0ddf5;border-radius:var(--radius-md);padding:var(--space-4);font-family:var(--font-mono, monospace);font-size:11px;line-height:1.6;overflow:auto;max-height:400px;white-space:pre-wrap;word-break:break-all}.mc-final-score--warn{border-color:var(--color-accent-danger, #E05555);background:#e055550f}.mc-final-score__badge--warn{background:var(--color-accent-danger, #E05555)}.mc-score-warning{font-size:var(--text-sm);color:var(--color-accent-danger, #E05555);margin:0;font-weight:var(--weight-medium)}.mc-btn-saved{background:var(--color-accent-success, #4CAF82);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);transition:background var(--transition-fast)}.mc-add-scenario-wrap{margin-top:var(--space-2)}.btn-sm{font-size:var(--text-xs);padding:var(--space-2) var(--space-4)}.mch-page{min-height:calc(100vh - var(--topbar-height));background:var(--color-bg);padding:var(--space-8) var(--space-6) var(--space-12);max-width:1200px;margin:0 auto;animation:fadeIn .28s ease both}.mch-eyebrow{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-3)}.mch-headline{margin-bottom:var(--space-8)}.mch-title{font-family:var(--font-logo);font-size:clamp(var(--text-xl),3vw,var(--text-3xl));font-weight:var(--weight-regular);color:var(--color-text-primary);letter-spacing:var(--tracking-tight);margin:0 0 var(--space-2)}.mch-subtitle{font-size:var(--text-base);color:var(--color-text-secondary);margin:0}.mch-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}@media (max-width: 900px){.mch-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.mch-stats-grid{grid-template-columns:1fr}}.mch-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);min-height:100px}.mch-stat-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-surface-alt);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.mch-stat-icon--soft{background:var(--color-primary-bg)}.mch-stat-icon--blue{background:#dcecf4}.mch-stat-value{font-family:var(--font-logo);font-size:var(--text-2xl);font-weight:var(--weight-regular);color:var(--color-text-primary);line-height:1;margin-bottom:var(--space-1)}.mch-stat-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.mch-main-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:var(--space-5);align-items:start}@media (max-width: 960px){.mch-main-grid{grid-template-columns:1fr}}.mch-stack{display:flex;flex-direction:column;gap:var(--space-5)}.mch-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.mch-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}.mch-panel-title{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--color-text-primary)}.mch-panel-badge{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:11px}.mch-panel-badge--gold{background:#fdf3e0;color:#c08b2a}.mch-panel-badge--warn{background:#fff0e0;color:#cc7b2f}.mch-panel-body{padding:var(--space-5)}.mch-link-btn{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--color-primary-dark);background:none;border:none;cursor:pointer;padding:0;letter-spacing:var(--tracking-wide)}.mch-link-btn:hover{text-decoration:underline}.mch-shortcuts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}@media (max-width: 700px){.mch-shortcuts-grid{grid-template-columns:1fr}}.mch-shortcut{border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;justify-content:space-between;gap:var(--space-4);min-height:180px;border:1px solid rgba(255,255,255,.4)}.mch-shortcut--manage{background:var(--color-pretty-purple);color:var(--color-text-primary)}.mch-shortcut--create{background:var(--color-primary-light);color:var(--color-text-primary)}.mch-shortcut--import{background:linear-gradient(135deg,#dcebf3,#cde2ee);color:var(--color-text-primary)}.mch-shortcut-top{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.mch-shortcut-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;background:#ffffff38;flex-shrink:0}.mch-shortcut-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-bold);margin:0;letter-spacing:var(--tracking-tight)}.mch-shortcut-desc{font-size:var(--text-sm);line-height:1.5;opacity:.88;margin:0 0 var(--space-3)}.mch-action-btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap;align-self:flex-start}.mch-action-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.mch-action-btn:disabled{opacity:.4;cursor:default}.mch-attention-list{display:flex;flex-direction:column;gap:var(--space-3)}.mch-attention-item{display:grid;grid-template-columns:1fr auto;gap:var(--space-3);align-items:center;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt)}@media (max-width: 600px){.mch-attention-item{grid-template-columns:1fr}}.mch-attention-content{display:flex;align-items:center;gap:var(--space-3);min-width:0}.mch-mini-icon{width:28px;height:28px;border-radius:var(--radius-full);background:#fff0e0;color:#cc7b2f;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.mch-row-item{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-3);align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.mch-row-item:last-child{border-bottom:none}.mch-avatar{width:38px;height:38px;border-radius:var(--radius-full);background:var(--color-primary-bg);color:var(--color-primary-dark);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--weight-bold);font-size:var(--text-sm);flex-shrink:0}.mch-avatar--file{background:#f8d7e3;color:#b04a76}.mch-row-info{min-width:0}.mch-item-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mch-item-subtitle{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.mch-time{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;padding-left:var(--space-2)}.scl-page{min-height:calc(100vh - var(--topbar-height));background:var(--color-bg);padding:var(--space-8) var(--space-6) var(--space-12);max-width:800px;margin:60px auto;animation:fadeIn .25s ease both}.scl-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-8);flex-wrap:wrap}.scl-eyebrow{font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-1)}.scl-title{font-family:var(--font-logo);font-size:var(--text-2xl);font-weight:var(--weight-regular);color:var(--color-text-primary);letter-spacing:var(--tracking-tight);margin:0}.scl-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);padding:var(--space-16) var(--space-4);text-align:center;color:var(--color-text)}.scl-list{display:flex;flex-direction:column;gap:var(--space-3)}.scl-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);cursor:pointer;transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.scl-row:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.scl-row__dot{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-primary-bg);color:var(--color-primary-dark);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--weight-bold);flex-shrink:0}.scl-row__name{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--color-text-primary)}.scl-row__meta{display:flex;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);margin-top:3px;flex-wrap:wrap}.scl-row__arrow{color:var(--color-text-muted);font-size:var(--text-base)}.scl-back{margin-bottom:var(--space-5)}.scl-detail-title{font-family:var(--font-logo);font-size:var(--text-xl);font-weight:var(--weight-regular);color:var(--color-text-primary);margin:0 0 var(--space-1)}.scl-detail-saved{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-5)}.scl-json{background:#1c1b2e;color:#e0ddf5;border-radius:var(--radius-md);padding:var(--space-5);font-family:var(--font-mono, monospace);font-size:11px;line-height:1.6;overflow:auto;white-space:pre-wrap;word-break:break-all}.scl-detail{display:flex;flex-direction:column;gap:20px}.scl-auto-section{background:#fff;border:1px solid #eaeaea;border-radius:14px;padding:16px 18px;box-shadow:0 2px 6px #0000000a;display:flex;flex-direction:column;gap:12px}.scl-auto-row{display:flex;gap:12px;align-items:flex-start}.scl-auto-label{min-width:160px;font-weight:600;color:#666}.scl-auto-value{flex:1;color:#222}.scl-auto-array{display:flex;flex-direction:column;gap:10px}.scl-auto-array-item{background:#f8f9fb;border-radius:10px;padding:12px;border:1px solid #eee}.scl-auto-array-item .scl-auto-section{background:transparent;border:none;box-shadow:none;padding:0}.scl-auto-value>.scl-auto-section{margin-top:6px}.scl-auto-heading{font-size:14px;font-weight:700;color:#111;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid #eee;text-transform:capitalize}.trainer-screen{display:flex;flex-direction:column;min-height:calc(100vh - var(--topbar-height));background:var(--color-bg);animation:fadeIn .25s ease both}.trainer-messages{flex:1;overflow-y:auto;padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-5)}.trainer-messages__inner{width:100%;max-width:var(--content-max-w);margin:0 auto}.trainer-counter{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);margin-bottom:var(--space-4)}.trainer-question-bubble{background:var(--color-bubble-ai);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);font-size:var(--text-base);color:var(--color-text-primary);line-height:1.6;position:relative;margin-bottom:var(--space-1)}.trainer-question-bubble:after{content:"";position:absolute;bottom:-8px;left:20px;width:0;height:0;border-style:solid;border-width:8px 8px 0 8px;border-color:var(--color-bubble-ai) transparent transparent transparent}.trainer-choose-label{text-align:center;font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-secondary);margin:var(--space-6) 0 var(--space-3)}.trainer-answers{display:flex;flex-direction:column;gap:var(--space-3);max-width:var(--content-max-w);margin:0 auto;width:100%;padding:0 var(--space-4) var(--space-8)}.trainer-answer-btn{width:100%;background:var(--color-answer-bg);color:var(--color-answer-text);border:none;border-radius:var(--radius-full);padding:var(--space-4) var(--space-6);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);text-align:center;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.trainer-answer-btn:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.trainer-answer-btn--correct{background:var(--color-answer-correct)!important}.trainer-answer-btn--wrong{background:var(--color-answer-wrong)!important}.trainer-answer-btn:disabled{cursor:default}.trainer-input-wrap{padding:var(--space-3) var(--space-4) var(--space-6)}.trainer-result{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:var(--space-10) var(--space-4);text-align:center;animation:fadeIn .3s ease both}.trainer-result__icon{font-size:56px;color:var(--color-primary);margin-bottom:var(--space-4)}.trainer-result__score{font-family:var(--font-logo);font-size:var(--text-3xl);color:var(--color-text-primary);margin-bottom:var(--space-2)}.trainer-result__label{font-size:var(--text-base);color:var(--color-text-secondary);margin-bottom:var(--space-8)}.trainer-result__actions{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.trainer-length-select{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:var(--space-12) var(--space-4);text-align:center;gap:var(--space-4)}.trainer-length-select__img{width:90px;height:90px;border-radius:var(--radius-full);object-fit:cover}.trainer-length-select__title{font-family:var(--font-logo);font-size:var(--text-2xl);font-weight:var(--weight-regular);color:var(--color-text-primary);letter-spacing:var(--tracking-tight)}.trainer-length-select__subtitle{font-size:var(--text-base);color:var(--color-text-secondary)}.trainer-length-options{display:flex;flex-direction:column;gap:var(--space-3);width:100%;max-width:360px;margin-top:var(--space-4)}.trainer-length-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.trainer-length-btn:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.trainer-length-btn__label{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-bold);color:var(--color-text-primary)}.trainer-length-btn__desc{font-size:var(--text-sm);color:var(--color-text-muted)}.trainer-result__pct{font-family:var(--font-logo);font-size:var(--text-xl);color:var(--color-primary);margin-bottom:var(--space-2)}.trainer-loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.2rem;font-weight:600;text-align:center}.cc-page{--cc-purple: #6b5aaa;--cc-purple-mid: #8b78cc;--cc-purple-lite: #ede8fc;--cc-purple-soft: #f4f0fc;--cc-ink: #1e1830;--cc-ink-mid: #4a4268;--cc-ink-lite: #9088b8;--cc-border: #e2daf5;--cc-white: #ffffff;--cc-green: #4cbb82;--cc-danger: #e04060}.cc-page{min-height:calc(100vh - var(--topbar-height));background:var(--color-bg);padding:var(--space-6) var(--space-4) var(--space-12);display:flex;flex-direction:column;align-items:center;animation:fadeIn .3s ease both}.cc-topbar{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:620px;margin-bottom:var(--space-6)}.cc-logo{display:flex;align-items:center;gap:var(--space-2)}.cc-logo-text{font-family:var(--font-display);font-weight:var(--weight-bold);font-size:var(--text-sm);color:var(--cc-purple);letter-spacing:var(--tracking-wide)}.cc-date-badge{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--cc-ink-lite);background:var(--cc-purple-lite);border:1px solid var(--cc-border);padding:5px 12px;border-radius:var(--radius-full);letter-spacing:.02em}.cc-card{background:var(--color-surface);border:1.5px solid var(--cc-border);border-radius:28px;padding:32px 32px 28px;box-shadow:0 4px 40px #6b5aaa1a;width:100%;max-width:620px;position:relative;overflow:hidden;animation:fadeIn .4s ease .1s both}.cc-card:after{content:"";position:absolute;top:0;left:32px;right:32px;height:3px;background:linear-gradient(90deg,var(--cc-purple),var(--cc-purple-mid),#a090e8);border-radius:0 0 4px 4px}.cc-coach-header{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-6)}.cc-avatar-ring{width:72px;height:72px;border-radius:var(--radius-full);background:var(--cc-purple-lite);border:2.5px solid var(--cc-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.cc-avatar-ring:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:var(--radius-full);border:1.5px solid #d0c4f0;opacity:.6}.cc-avatar-dot{position:absolute;bottom:2px;right:2px;width:12px;height:12px;background:var(--cc-green);border-radius:var(--radius-full);border:2px solid var(--color-surface);z-index:2}.cc-coach-greeting{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--cc-ink-lite);letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px}.cc-coach-name{font-family:var(--font-logo);font-size:var(--text-xl);color:var(--cc-ink);line-height:1.15;margin-bottom:3px}.cc-coach-role{font-size:var(--text-xs);color:var(--cc-ink-lite);display:flex;align-items:center;gap:var(--space-2)}.cc-role-dot{width:6px;height:6px;background:var(--cc-purple-mid);border-radius:var(--radius-full);display:inline-block;flex-shrink:0}.cc-divider{height:1px;background:var(--cc-border);margin:0 0 var(--space-5)}.cc-question-label{font-size:11px;font-weight:var(--weight-bold);color:var(--cc-purple);letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.cc-question-label:before{content:"";width:20px;height:2px;background:var(--cc-purple-mid);border-radius:2px;display:inline-block}.cc-context-chip{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--cc-purple-lite);border:1px solid var(--cc-border);border-radius:var(--radius-full);padding:5px 12px;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--cc-purple);margin-bottom:var(--space-4)}.cc-context-chip svg{width:13px;height:13px;flex-shrink:0}.cc-question-text{font-family:var(--font-logo);font-size:var(--text-xl);line-height:1.45;color:var(--cc-ink);margin-bottom:var(--space-5);min-height:64px}.cc-cursor{display:inline-block;width:2px;height:22px;background:var(--cc-purple);border-radius:1px;margin-left:3px;vertical-align:middle;animation:ccBlink .9s step-end infinite}@keyframes ccBlink{0%,to{opacity:1}50%{opacity:0}}.cc-answer-area{position:relative;margin-bottom:var(--space-3)}.cc-textarea{width:100%;min-height:110px;border:1.5px solid var(--cc-border);border-radius:16px;padding:16px 18px;font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);line-height:1.6;resize:none;outline:none;background:var(--color-surface-alt);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-sizing:border-box}.cc-textarea::placeholder{color:var(--cc-ink-lite)}.cc-textarea:focus{border-color:var(--cc-purple-mid);box-shadow:0 0 0 4px #8b78cc1f;background:var(--color-surface)}.cc-textarea:disabled{opacity:.65;cursor:not-allowed}.cc-char-count{position:absolute;bottom:12px;right:50px;font-size:11px;color:var(--cc-ink-lite);font-weight:var(--weight-medium);pointer-events:none}.cc-mic-btn{position:absolute;bottom:10px;right:10px;width:32px;height:32px;border-radius:var(--radius-full);border:1.5px solid var(--cc-border);background:var(--color-surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);color:var(--cc-purple);flex-shrink:0}.cc-mic-btn svg{width:16px;height:16px}.cc-mic-btn:hover:not(:disabled){border-color:var(--cc-purple-mid);background:var(--cc-purple-lite)}.cc-mic-btn:disabled{opacity:.35;cursor:default}.cc-mic-btn--recording{border-color:var(--cc-danger);background:#fff0f3;animation:ccMicPulse 1.2s ease-in-out infinite;color:var(--cc-danger)}@keyframes ccMicPulse{0%,to{box-shadow:0 0 #e040604d}50%{box-shadow:0 0 0 7px #e0406000}}.cc-rec-status{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);margin-bottom:var(--space-2);font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--cc-danger);animation:fadeIn .3s ease both}.cc-rec-dot{width:8px;height:8px;background:var(--cc-danger);border-radius:var(--radius-full);animation:ccMicPulse 1s ease-in-out infinite;flex-shrink:0}.cc-wave{display:flex;align-items:center;gap:2px;height:16px}.cc-wave span{display:block;width:3px;background:var(--cc-danger);border-radius:2px;animation:ccWaveBar .8s ease-in-out infinite}.cc-wave span:nth-child(1){height:6px;animation-delay:0s}.cc-wave span:nth-child(2){height:12px;animation-delay:.1s}.cc-wave span:nth-child(3){height:8px;animation-delay:.2s}.cc-wave span:nth-child(4){height:14px;animation-delay:.15s}.cc-wave span:nth-child(5){height:6px;animation-delay:.05s}@keyframes ccWaveBar{0%,to{transform:scaleY(1)}50%{transform:scaleY(.4)}}.cc-rec-stop{margin-left:auto;font-weight:var(--weight-medium);color:var(--cc-ink-lite);cursor:pointer}.cc-mic-unsupported{font-size:var(--text-xs);color:var(--cc-ink-lite);margin-bottom:var(--space-2);font-weight:var(--weight-medium)}.cc-actions{display:flex;gap:var(--space-3);align-items:center;margin-top:var(--space-2)}.cc-btn-submit{flex:1;background:var(--cc-purple);color:#fff;border:none;border-radius:14px;padding:14px 24px;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 4px 18px #6b5aaa47;letter-spacing:.01em}.cc-btn-submit:hover:not(:disabled){background:#5a4a98;box-shadow:0 6px 24px #6b5aaa5c}.cc-btn-submit:active:not(:disabled){transform:scale(.97)}.cc-btn-submit:disabled{background:#c8c0e0;box-shadow:none;cursor:not-allowed}.cc-btn-skip{background:none;border:1.5px solid var(--cc-border);border-radius:14px;padding:14px 18px;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--cc-ink-lite);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.cc-btn-skip:hover{border-color:var(--cc-purple-mid);color:var(--cc-purple)}.cc-saved-strip{display:flex;align-items:center;gap:var(--space-2);background:#edf8f2;border:1.5px solid #b8e8cc;border-radius:12px;padding:10px 14px;margin-top:var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-bold);color:#2a7a50;animation:fadeIn .4s ease both}.cc-saved-strip svg{width:16px;height:16px;flex-shrink:0}.cc-success{text-align:center;padding:var(--space-6) 0 var(--space-2);animation:fadeIn .5s ease both;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.cc-success-icon{width:56px;height:56px;background:#edf8f2;border:2px solid #b8e8cc;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.cc-success-title{font-family:var(--font-logo);font-size:var(--text-xl);color:var(--cc-ink)}.cc-success-sub{font-size:var(--text-sm);color:var(--cc-ink-lite);line-height:1.6;max-width:380px}.cc-btn-next{background:var(--cc-purple-lite);border:1.5px solid var(--cc-border);border-radius:13px;padding:11px 22px;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--cc-purple);cursor:pointer;transition:all var(--transition-fast)}.cc-btn-next:hover{background:#e0d8f8;border-color:#c4b4f0}.cc-progress-section{width:100%;max-width:620px;margin-top:var(--space-6);animation:fadeIn .5s ease .2s both}.cc-progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2);font-size:var(--text-xs);color:var(--cc-ink-lite);font-weight:var(--weight-medium)}.cc-progress-label strong{font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--cc-purple)}.cc-progress-track{height:6px;background:var(--cc-purple-lite);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-4)}.cc-progress-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--cc-purple),var(--cc-purple-mid));transition:width 1s cubic-bezier(.34,1.56,.64,1)}.cc-topics{display:flex;flex-wrap:wrap;gap:var(--space-2)}.cc-topic{display:flex;align-items:center;gap:var(--space-1);padding:6px 12px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-medium);border:1.5px solid var(--cc-border);background:var(--color-surface);color:var(--cc-ink-mid);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-display)}.cc-topic:hover{border-color:var(--cc-purple-mid);color:var(--cc-purple)}.cc-topic--done{background:var(--cc-purple-lite);border-color:#c4b4f0;color:var(--cc-purple)}.cc-topic--active{background:var(--cc-purple);border-color:var(--cc-purple);color:#fff;box-shadow:0 3px 12px #6b5aaa47}.cc-topic-dot{width:6px;height:6px;border-radius:var(--radius-full);background:currentColor;flex-shrink:0}.cc-footer{margin-top:var(--space-6);font-size:var(--text-xs);color:var(--cc-ink-lite);text-align:center;animation:fadeIn .5s ease .3s both}.cc-footer a{color:var(--cc-purple-mid);text-decoration:none;font-weight:var(--weight-medium)}.cc-toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%) translateY(10px);background:#1e1830;color:#fff;font-size:var(--text-xs);font-weight:var(--weight-medium);padding:12px 20px;border-radius:14px;white-space:nowrap;opacity:0;transition:all .3s ease;z-index:999;box-shadow:0 6px 24px #0000002e;pointer-events:none}.cc-toast--show{opacity:1;transform:translate(-50%) translateY(0)}@media (max-width: 600px){.cc-card{padding:var(--space-5) var(--space-4) var(--space-5);border-radius:20px}.cc-question-text{font-size:var(--text-lg)}}
