:root{--tyf-blue-primary: #4A90E2;--tyf-blue-hover: #357ABD;--tyf-blue-light: #60a5fa;--tyf-orb-idle: #ef4444;--tyf-orb-idle-gradient: radial-gradient(circle at 30% 30%, #f87171 0%, #ef4444 40%, #dc2626 70%, #b91c1c 100%);--tyf-orb-idle-glow: 0 0 40px rgba(239, 68, 68, .5), 0 0 80px rgba(239, 68, 68, .3), 0 0 120px rgba(239, 68, 68, .15);--tyf-orb-listening: #22d3d3;--tyf-orb-listening-gradient: radial-gradient(circle at 30% 30%, #5eead4 0%, #22d3d3 40%, #14b8a6 70%, #0d9488 100%);--tyf-orb-listening-glow: 0 0 40px rgba(34, 211, 211, .5), 0 0 80px rgba(34, 211, 211, .3), 0 0 120px rgba(34, 211, 211, .15);--tyf-orb-processing: #f59e0b;--tyf-orb-processing-gradient: radial-gradient(circle at 30% 30%, #fcd34d 0%, #f59e0b 40%, #d97706 70%, #b45309 100%);--tyf-orb-processing-glow: 0 0 40px rgba(245, 158, 11, .5), 0 0 80px rgba(245, 158, 11, .3);--tyf-record-red: #ef4444;--tyf-record-red-hover: #dc2626;--tyf-record-red-active: #b91c1c;--tyf-stop-gray: rgba(255, 255, 255, .1);--tyf-stop-gray-hover: rgba(255, 255, 255, .15);--tyf-stop-border: rgba(255, 255, 255, .2);--tyf-audio-reference-bg: linear-gradient(135deg, #4da9ff 0%, #007cc3 100%);--tyf-audio-reference-shadow: 0 4px 12px rgba(0, 124, 195, .3);--tyf-audio-user-bg: linear-gradient(135deg, #FF6B6B 0%, #FF8E53 100%);--tyf-audio-user-shadow: 0 4px 12px rgba(255, 107, 107, .3);--tyf-bg-dark: #1a1a2e;--tyf-bg-darker: #0f0f1a;--tyf-bg-card: rgba(255, 255, 255, .05);--tyf-bg-card-hover: rgba(255, 255, 255, .08);--tyf-bg-overlay: rgba(0, 0, 0, .7);--tyf-bg-overlay-blur: blur(4px);--tyf-text-primary: #f5f7fa;--tyf-text-secondary: #9ca3af;--tyf-text-muted: #6b7280;--tyf-text-accent: #FFD700;--tyf-text-success: #22c55e;--tyf-text-error: #ef4444;--tyf-text-warning: #f59e0b;--tyf-border-subtle: rgba(255, 255, 255, .1);--tyf-border-medium: rgba(255, 255, 255, .2);--tyf-border-focus: rgba(59, 130, 246, .5);--tyf-spacing-xs: 4px;--tyf-spacing-sm: 8px;--tyf-spacing-md: 16px;--tyf-spacing-lg: 24px;--tyf-spacing-xl: 32px;--tyf-spacing-2xl: 48px;--tyf-radius-sm: 6px;--tyf-radius-md: 8px;--tyf-radius-lg: 12px;--tyf-radius-xl: 16px;--tyf-radius-pill: 50px;--tyf-radius-circle: 50%;--tyf-transition-fast: .15s ease;--tyf-transition-normal: .2s ease;--tyf-transition-slow: .3s ease;--tyf-z-base: 1;--tyf-z-dropdown: 100;--tyf-z-modal: 1000;--tyf-z-overlay: 9999;--tyf-z-tooltip: 10000;--tyf-gold-gradient: linear-gradient(135deg, #BF953F 0%, #FCF6BA 25%, #B38728 50%, #FBF5B7 75%, #AA771C 100%);--tyf-gold-glow: 0 0 20px rgba(255, 215, 0, .3);--tyf-blue-border: 2px solid var(--tyf-blue-primary);--tyf-blue-glow: 0 0 20px rgba(74, 144, 226, .35), 0 0 40px rgba(74, 144, 226, .15)}@keyframes tyf-pulse-red{0%,to{box-shadow:0 0 40px #ef444480,0 0 80px #ef44444d}50%{box-shadow:0 0 60px #ef444499,0 0 100px #ef444466}}@keyframes tyf-pulse-cyan{0%,to{box-shadow:0 0 40px #22d3d380,0 0 80px #22d3d34d}50%{box-shadow:0 0 60px #22d3d399,0 0 100px #22d3d366}}@keyframes tyf-pulse-amber{0%,to{box-shadow:0 0 30px #f59e0b66,0 0 60px #f59e0b33}50%{box-shadow:0 0 50px #f59e0b80,0 0 80px #f59e0b4d}}@media (max-width: 480px){:root{--tyf-spacing-xs: 2px;--tyf-spacing-sm: 6px;--tyf-spacing-md: 12px;--tyf-spacing-lg: 16px;--tyf-spacing-xl: 24px;--tyf-spacing-2xl: 32px;--tyf-radius-lg: 10px;--tyf-radius-xl: 12px}}@media (max-width: 375px){:root{--tyf-spacing-xs: 2px;--tyf-spacing-sm: 4px;--tyf-spacing-md: 8px;--tyf-spacing-lg: 12px;--tyf-spacing-xl: 20px;--tyf-spacing-2xl: 28px}}.tyf-audio-pill-user{display:flex;justify-content:center;width:100%;background:linear-gradient(135deg,#ff6b6b,#ff8e53);padding:6px;border-radius:50px;box-shadow:0 4px 12px #ff6b6b4d}.tyf-audio-pill-user .inline-audio-player{background-color:#00000040!important;border:1px solid rgba(0,0,0,.1);max-width:none!important;width:100%;border-radius:50px}.tyf-audio-pill-reference{display:flex;justify-content:center;width:100%;background:linear-gradient(135deg,#4a90e2,#357abd);padding:6px;border-radius:50px;box-shadow:0 4px 12px #4a90e24d}.tyf-audio-pill-reference .inline-audio-player{background-color:#00000040!important;border:1px solid rgba(0,0,0,.1);max-width:none!important;width:100%;border-radius:50px}.tyf-recording-buttons{display:flex;flex-direction:row;gap:12px;align-items:center;justify-content:flex-start}.tyf-btn-record{background:#ff5f52;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.tyf-btn-record:hover:not(:disabled){background:#e54940;transform:translateY(-1px);box-shadow:0 4px 12px #ff5f524d}.tyf-btn-record:active:not(:disabled){transform:translateY(0)}.tyf-btn-record:disabled{opacity:.5;cursor:not-allowed}.tyf-btn-record.tyf-recording{animation:tyf-pulse-record 1s infinite}@keyframes tyf-pulse-record{0%,to{box-shadow:0 0 #ff5f5266}50%{box-shadow:0 0 0 10px #ff5f5200}}.tyf-btn-stop{background:#282838;color:#9ca3af;border:1px solid rgba(255,255,255,.2);padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.tyf-btn-stop:hover:not(:disabled){background:#383848;color:#f5f7fa;border-color:#ffffff4d}.tyf-btn-stop:disabled{opacity:.5;cursor:not-allowed}.tyf-score-badge{background:#ef4444;color:#fff;padding:4px 12px;border-radius:20px;font-size:.9rem;font-weight:600}.tyf-score-badge.tyf-score-excellent{background:#22c55e}.tyf-score-badge.tyf-score-good{background:#eab308}.tyf-score-badge.tyf-score-needs-work{background:#ef4444}.tyf-step-label{font-size:.9rem;color:#9ca3af;margin:0 0 12px;font-weight:500}.tyf-step-label-primary{font-size:1rem;color:#ef4444;margin:0 0 12px;font-weight:600}.tyf-btn-nav{padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#9ca3af}.tyf-btn-nav:hover:not(:disabled){background:#ffffff26;color:#f5f7fa}.tyf-btn-nav:disabled{opacity:.5;cursor:not-allowed}.tyf-btn-nav-primary{background:#ef4444;border-color:#ef4444;color:#fff}.tyf-btn-nav-primary:hover:not(:disabled){background:#dc2626}.tyf-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px}.tyf-card-dark{background:#0003;border-radius:8px;padding:16px}@media (max-width: 480px){.tyf-btn-record,.tyf-btn-stop{padding:10px 20px;font-size:.9rem}.tyf-recording-buttons{gap:8px}.tyf-audio-pill-user,.tyf-audio-pill-reference{padding:4px}}.tyf-skin-default{border:var(--tyf-blue-border)!important;box-shadow:var(--tyf-blue-glow);transition:all .3s ease}.tyf-skin-gold{border:3px solid #B38728!important;border-image:linear-gradient(135deg,#bf953f,#fcf6ba,#b38728,#fbf5b7,#aa771c) 1!important;box-shadow:0 0 15px #ffd70066,0 0 30px #bf953f40,inset 0 0 20px #ffd7000d!important;transition:all .3s ease}.tyf-skin-gold:hover{box-shadow:0 0 20px #ffd70080,0 0 40px #bf953f59,inset 0 0 30px #ffd70014!important}.inline-audio-player{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#2d2d2d;border-radius:24px;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;-webkit-user-select:none;user-select:none;min-width:200px;max-width:400px}.inline-audio-player:focus{outline:2px solid #4a9eff;outline-offset:2px}.inline-audio-player:focus:not(:focus-visible){outline:none}.inline-audio-player.compact{padding:6px 10px;gap:6px;min-width:160px;max-width:280px;font-size:12px}.audio-play-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:50%;background-color:#fff;color:#2d2d2d;cursor:pointer;flex-shrink:0;transition:background-color .15s,transform .1s}.audio-play-btn:hover:not(:disabled){background-color:#f0f0f0;transform:scale(1.05)}.audio-play-btn:active:not(:disabled){transform:scale(.95)}.audio-play-btn:disabled{opacity:.5;cursor:not-allowed}.inline-audio-player.compact .audio-play-btn{width:24px;height:24px}.inline-audio-player.compact .audio-play-btn svg{width:14px;height:14px}.audio-time{font-variant-numeric:tabular-nums;color:#b0b0b0;flex-shrink:0;min-width:36px}.audio-time.current{text-align:right}.audio-time.duration{text-align:left}.inline-audio-player.compact .audio-time{min-width:30px;font-size:11px}.audio-progress-container{flex:1;min-width:60px;height:20px;display:flex;align-items:center;cursor:pointer;padding:4px 0}.audio-progress-track{position:relative;width:100%;height:4px;background-color:#505050;border-radius:2px;overflow:visible}.audio-progress-fill{position:absolute;top:0;left:0;height:100%;background-color:#4a9eff;border-radius:2px;transition:width .05s linear}.audio-progress-thumb{position:absolute;top:50%;width:12px;height:12px;background-color:#fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 1px 3px #0000004d;opacity:0;transition:opacity .15s}.audio-progress-container:hover .audio-progress-thumb,.inline-audio-player.playing .audio-progress-thumb{opacity:1}.inline-audio-player.compact .audio-progress-track{height:3px}.inline-audio-player.compact .audio-progress-thumb{width:10px;height:10px}.audio-volume-wrapper{position:relative;flex-shrink:0}.audio-volume-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:50%;background-color:transparent;color:#b0b0b0;cursor:pointer;transition:color .15s,background-color .15s}.audio-volume-btn:hover{color:#fff;background-color:#ffffff1a}.inline-audio-player.compact .audio-volume-btn{width:24px;height:24px}.inline-audio-player.compact .audio-volume-btn svg{width:14px;height:14px}.audio-volume-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:12px 8px;background-color:#3d3d3d;border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:100;margin-bottom:8px}.audio-volume-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#3d3d3d}.audio-volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:4px;background:#505050;border-radius:2px;outline:none;cursor:pointer}.audio-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0000004d}.audio-volume-slider::-moz-range-thumb{width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 1px 3px #0000004d}.audio-menu-wrapper{position:relative;flex-shrink:0}.audio-menu-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:50%;background-color:transparent;color:#b0b0b0;cursor:pointer;transition:color .15s,background-color .15s}.audio-menu-btn:hover{color:#fff;background-color:#ffffff1a}.inline-audio-player.compact .audio-menu-btn{width:24px;height:24px}.inline-audio-player.compact .audio-menu-btn svg{width:14px;height:14px}.audio-menu-dropdown{position:absolute;bottom:100%;right:0;min-width:180px;padding:8px 0;background-color:#3d3d3d;border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:100;margin-bottom:8px}.audio-menu-section{padding:8px 12px;border-bottom:1px solid #505050}.audio-menu-section:last-child{border-bottom:none}.audio-menu-label{display:block;font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.audio-speed-options{display:flex;flex-wrap:wrap;gap:4px}.audio-speed-btn{padding:4px 8px;border:1px solid #505050;border-radius:4px;background-color:transparent;color:#b0b0b0;font-size:12px;cursor:pointer;transition:all .15s}.audio-speed-btn:hover{background-color:#ffffff1a;color:#fff}.audio-speed-btn.active{background-color:#4a9eff;border-color:#4a9eff;color:#fff}.audio-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background-color:transparent;color:#e0e0e0;font-size:13px;text-align:left;cursor:pointer;transition:background-color .15s}.audio-menu-item:hover{background-color:#ffffff1a}.audio-menu-item svg{flex-shrink:0;color:#b0b0b0}@media (max-width: 640px){.inline-audio-player{padding:6px 10px;gap:6px;min-width:160px;max-width:100%;font-size:12px}.inline-audio-player .audio-time.duration{display:none}.audio-play-btn{width:24px;height:24px}.audio-play-btn svg{width:14px;height:14px}}.score-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:.8rem;font-weight:600;border:1px solid;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease}.score-badge__icon{font-size:.9rem}.score-badge__score{font-variant-numeric:tabular-nums}.score-badge__label{font-weight:500;opacity:.9;margin-left:4px}.score-badge--green{background:#22c55e26;border-color:#4ade8080;color:#4ade80}.score-badge--yellow{background:#f59e0b26;border-color:#fbbf2480;color:#fbbf24}.score-badge--red{background:#ef444426;border-color:#f8717180;color:#f87171}.score-pill{display:flex;flex-direction:column;gap:10px;padding:14px 18px;border-radius:14px;background:#ffffff0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);margin-top:10px;animation:scoreSlideIn .3s ease-out}@keyframes scoreSlideIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.score-pill--compact{flex-direction:row;align-items:center;padding:8px 14px;gap:12px}.score-pill--green{border-color:#4ade804d;background:#22c55e14}.score-pill--yellow{border-color:#fbbf244d;background:#f59e0b14}.score-pill--red{border-color:#f871714d;background:#ef444414}.score-pill__badge{display:flex;align-items:center;gap:10px}.score-pill__number{font-size:1.6rem;font-weight:700;font-variant-numeric:tabular-nums}.score-pill--green .score-pill__number{color:#4ade80}.score-pill--yellow .score-pill__number{color:#fbbf24}.score-pill--red .score-pill__number{color:#f87171}.score-pill__label{font-size:.95rem;font-weight:500;opacity:.75;color:#e5e7eb}.score-pill__tip{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:10px;background:#ffffff08;font-size:.9rem;line-height:1.5;color:#d4d4d4}.score-pill__tip-icon{font-size:1.1rem;flex-shrink:0}.score-pill__tip-text{flex:1}.score-pill__details{display:flex;flex-wrap:wrap;gap:16px;padding-top:10px;border-top:1px solid rgba(255,255,255,.08)}.score-pill__detail-item{display:flex;gap:6px;align-items:center;font-size:.85rem}.score-pill__detail-label{color:#9ca3af}.score-pill__detail-value{font-weight:600;font-variant-numeric:tabular-nums;color:#e5e7eb}@media (max-width: 640px){.score-pill{padding:12px 14px}.score-pill__number{font-size:1.4rem}.score-pill__details{flex-direction:column;gap:8px}.score-badge{padding:3px 8px;font-size:.75rem}}.chat-bubble-wrapper{display:flex;width:100%;margin:8px 0;animation:slideIn .3s ease-out}.chat-bubble-wrapper.user{justify-content:flex-end;padding-right:16px}.chat-bubble-wrapper.coach{justify-content:flex-start;padding-left:16px}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-bubble{position:relative;max-width:45%;padding:9px 11px;border-radius:12px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 2px 14px #0003;transition:transform .2s ease,box-shadow .2s ease}.chat-bubble:hover{transform:translateY(-2px);box-shadow:0 4px 18px #00000040}.chat-bubble.user{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-bottom-right-radius:6px;box-shadow:0 4px 15px #dc26264d}.chat-bubble.coach{background:linear-gradient(135deg,#38bdf8,#3b82f6);color:#fff;border-bottom-left-radius:6px;border:none;box-shadow:0 4px 15px #38bdf84d}.chat-bubble.live{animation:pulse-bubble 2s ease-in-out infinite}@keyframes pulse-bubble{0%,to{opacity:1}50%{opacity:.85}}.score-badge{position:absolute;top:-12px;right:12px;display:flex;align-items:center;gap:4px;padding:4px 10px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:12px;font-size:.75rem;font-weight:700;color:#0c1118;box-shadow:0 2px 8px #fbbf2466}.score-icon{font-size:12px}.score-value{font-weight:800}.speaker-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7;margin-bottom:6px;font-weight:600}.bubble-text{margin:0;font-size:.75rem;line-height:1.4;white-space:pre-wrap;word-wrap:break-word}.bubble-audio-player{margin-bottom:12px}.chat-bubble.user .bubble-audio-player .inline-audio-player,.chat-bubble.coach .bubble-audio-player .inline-audio-player{background-color:#00000040;border:1px solid rgba(0,0,0,.1)}.live-indicator{display:flex;align-items:center;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.bubble-assessment{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.bubble-assessment .score-badge{position:static}.pulse-dot{width:8px;height:8px;border-radius:50%;background:#ef4444;animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.live-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;color:#ef4444}@media (max-width: 640px){.chat-bubble{max-width:85%;padding:12px 16px}.chat-bubble-wrapper.user{padding-right:8px}.chat-bubble-wrapper.coach{padding-left:8px}.bubble-text{font-size:.95rem}}@media (max-width: 480px){.chat-bubble-wrapper{margin:3px 0}.chat-bubble{max-width:90%;padding:7px 8px;border-radius:11px}.bubble-text{font-size:.57rem;line-height:1.3}.speaker-label{font-size:.4rem;margin-bottom:3px}.score-badge{font-size:.43rem;padding:2px 5px;top:-7px}.bubble-audio-player{margin-bottom:6px}}.audio-visualizer{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px}.audio-visualizer-orb{position:relative;width:88px;height:88px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,#ef4444,#dc2626,#b91c1c);transition:transform .1s ease-out,box-shadow .3s ease,background .4s ease;box-shadow:0 0 17px #ef444466,0 0 33px #dc262633,0 4px 18px #0000004d}.audio-visualizer-orb:hover:not(:disabled){transform:scale(1.05);box-shadow:0 0 22px #ef444480,0 0 44px #dc26264d,0 7px 26px #0006}.audio-visualizer-orb:active:not(:disabled){transform:scale(.95)}.audio-visualizer-orb:focus{outline:none}.audio-visualizer-orb:focus-visible{outline:2px solid #38BDF8;outline-offset:4px}.audio-visualizer-orb.disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#3a3f4b,#2d3139);box-shadow:0 4px 16px #0000004d}.orb-inner{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.25),transparent 60%);pointer-events:none;opacity:0}.orb-glow{position:absolute;border-radius:50%;pointer-events:none;opacity:0;transition:opacity .3s ease}.orb-glow-1{top:-9px;right:-9px;bottom:-9px;left:-9px;background:radial-gradient(circle,rgba(239,68,68,.3),transparent 70%);filter:blur(9px)}.orb-glow-2{top:-18px;right:-18px;bottom:-18px;left:-18px;background:radial-gradient(circle,rgba(220,38,38,.2),transparent 70%);filter:blur(13px)}.orb-glow-3{top:-26px;right:-26px;bottom:-26px;left:-26px;background:radial-gradient(circle,rgba(185,28,28,.15),transparent 70%);filter:blur(18px)}.orb-glow-4{top:-35px;right:-35px;bottom:-35px;left:-35px;background:radial-gradient(circle,rgba(26,26,46,.1),transparent 70%);filter:blur(22px)}.audio-visualizer-orb.active .orb-glow{opacity:1}.orb-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#ffffffe6}.orb-icon svg{width:31px;height:31px}.icon-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.orb-state-label{font-size:.85rem;font-weight:500;color:#94a3b8;letter-spacing:.02em}.audio-visualizer-orb.state-idle{background:linear-gradient(135deg,#ef4444,#dc2626,#b91c1c)}.audio-visualizer-orb.hint-pulse{animation:hint-pulse 2s ease-in-out infinite}@keyframes hint-pulse{0%,to{box-shadow:0 0 30px #ef444466,0 0 60px #dc262633,0 8px 32px #0000004d}50%{box-shadow:0 0 50px #ef4444b3,0 0 100px #ef444480,0 12px 48px #ef444466;transform:scale(1.05)}}.audio-visualizer-orb.state-connecting{background:linear-gradient(135deg,#fbbf24,#f59e0b,#d97706);animation:pulse-glow-yellow 2s ease-in-out infinite}.audio-visualizer-orb.state-connecting .orb-glow-1{background:radial-gradient(circle,rgba(251,191,36,.4),transparent 70%)}.audio-visualizer-orb.state-connecting .orb-glow-2{background:radial-gradient(circle,rgba(245,158,11,.3),transparent 70%)}@keyframes pulse-glow-yellow{0%,to{box-shadow:0 0 30px #fbbf2466,0 0 60px #f59e0b4d,0 8px 32px #0000004d}50%{box-shadow:0 0 50px #fbbf2499,0 0 100px #f59e0b66,0 12px 48px #0006}}.audio-visualizer-orb.state-listening{background:linear-gradient(135deg,#5eead4,#22d3d3 40%,#14b8a6,#0d9488);animation:pulse-glow-cyan 1.5s ease-in-out infinite}.audio-visualizer-orb.state-listening .orb-glow-1{background:radial-gradient(circle,rgba(34,211,211,.5),transparent 70%)}.audio-visualizer-orb.state-listening .orb-glow-2{background:radial-gradient(circle,rgba(20,184,166,.4),transparent 70%)}@keyframes pulse-glow-cyan{0%,to{box-shadow:0 0 40px #22d3d380,0 0 80px #22d3d34d,0 0 120px #22d3d326,0 8px 32px #0000004d}50%{box-shadow:0 0 60px #22d3d399,0 0 100px #22d3d366,0 0 140px #22d3d333,0 12px 48px #0006}}.audio-visualizer-orb.state-thinking{background:linear-gradient(135deg,#a78bfa,#8b5cf6,#7c3aed);animation:pulse-glow-purple 2s ease-in-out infinite}.audio-visualizer-orb.state-thinking .orb-glow-1{background:radial-gradient(circle,rgba(167,139,250,.4),transparent 70%)}.audio-visualizer-orb.state-thinking .orb-glow-2{background:radial-gradient(circle,rgba(139,92,246,.3),transparent 70%)}@keyframes pulse-glow-purple{0%,to{box-shadow:0 0 30px #a78bfa66,0 0 60px #8b5cf64d,0 8px 32px #0000004d}50%{box-shadow:0 0 50px #a78bfa99,0 0 100px #8b5cf666,0 12px 48px #0006}}.audio-visualizer-orb.state-speaking{background:linear-gradient(135deg,#34d399,#10b981,#059669);animation:pulse-glow-green 1.5s ease-in-out infinite}.audio-visualizer-orb.state-speaking .orb-glow-1{background:radial-gradient(circle,rgba(52,211,153,.4),transparent 70%)}.audio-visualizer-orb.state-speaking .orb-glow-2{background:radial-gradient(circle,rgba(16,185,129,.3),transparent 70%)}@keyframes pulse-glow-green{0%,to{box-shadow:0 0 30px #34d39966,0 0 60px #10b9814d,0 8px 32px #0000004d}50%{box-shadow:0 0 50px #34d39999,0 0 100px #10b98166,0 12px 48px #0006}}.thinking-indicator{position:absolute;bottom:-40px;display:flex;gap:8px}.thinking-indicator .dot{width:10px;height:10px;border-radius:50%;background:#a78bfa;animation:bounce 1.4s ease-in-out infinite}.thinking-indicator .dot:nth-child(2){animation-delay:.2s}.thinking-indicator .dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-12px)}}@media (max-width: 640px){.audio-visualizer-orb{width:55px;height:55px}.orb-icon svg{width:22px;height:22px}.orb-glow-1{top:-5px;right:-5px;bottom:-5px;left:-5px}.orb-glow-2{top:-10px;right:-10px;bottom:-10px;left:-10px}.orb-glow-3{top:-15px;right:-15px;bottom:-15px;left:-15px}.orb-glow-4{top:-20px;right:-20px;bottom:-20px;left:-20px}}@media (max-width: 480px){.audio-visualizer-orb{width:50px;height:50px}.orb-icon svg{width:20px;height:20px}.orb-glow-1{top:-4px;right:-4px;bottom:-4px;left:-4px}.orb-glow-2{top:-8px;right:-8px;bottom:-8px;left:-8px}.orb-glow-3{top:-11px;right:-11px;bottom:-11px;left:-11px}.orb-glow-4{top:-15px;right:-15px;bottom:-15px;left:-15px}.orb-state-label{font-size:.65rem}}@media (max-width: 375px){.audio-visualizer-orb{width:44px;height:44px}.orb-icon svg{width:18px;height:18px}.orb-glow-1{top:-3px;right:-3px;bottom:-3px;left:-3px}.orb-glow-2{top:-6px;right:-6px;bottom:-6px;left:-6px}.orb-glow-3{top:-10px;right:-10px;bottom:-10px;left:-10px}.orb-glow-4{top:-13px;right:-13px;bottom:-13px;left:-13px}.orb-state-label{font-size:.6rem}}.text-input-container{display:flex;flex-direction:column;flex:1;min-width:0;position:relative}.input-wrapper{position:relative;display:flex;align-items:flex-end;gap:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:12px 16px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .2s ease}.input-wrapper.focused{border-color:#38bdf880;background:#ffffff14;box-shadow:0 0 24px #38bdf833}.text-input{flex:1;background:transparent;border:none;outline:none;color:#f5f7fa;font-size:1.1rem;font-family:inherit;resize:none;min-height:24px;max-height:80px;height:24px;line-height:1.5;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent;transition:height .1s ease}.text-input::placeholder{color:#6b7280}.text-input::-webkit-scrollbar{width:6px}.text-input::-webkit-scrollbar-track{background:transparent}.text-input::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.text-input:disabled{opacity:.5;cursor:not-allowed}.run-button{flex-shrink:0;width:44px;height:44px;border-radius:8px;border:none;background:#4a90e2;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.run-button:hover:not(:disabled){background:#3a7bc8;transform:scale(1.05)}.run-button:active:not(:disabled){transform:scale(.95)}.run-button:disabled{opacity:.5;cursor:not-allowed}.char-counter{font-size:.875rem;color:#9ca3af;text-align:right;margin-top:8px;padding-right:4px}.char-counter.limit-exceeded{color:#ef4444;font-weight:500}@media (max-width: 640px){.text-input-container{flex:1}.input-wrapper{padding:10px 14px}.text-input{font-size:1rem;max-height:60px}.run-button{width:40px;height:40px}.char-counter{font-size:.8rem}}@media (max-width: 767px) and (min-width: 481px){.text-input-container{width:100%}.input-wrapper{padding:12px 16px}.text-input{font-size:1rem}}@media (max-width: 480px){.text-input-container{width:100%}.input-wrapper{padding:8px 11px;border-radius:18px}.text-input{font-size:.71rem;min-height:18px;max-height:45px;height:18px}.text-input::placeholder{font-size:.68rem}.char-counter{font-size:.56rem;margin-top:4px}.run-button{width:24px;height:24px;min-width:24px;border-radius:6px}.run-button svg{width:10px;height:10px}}@media (max-width: 375px){.input-wrapper{padding:6px 9px}.text-input{font-size:.65rem}.run-button{width:22px;height:22px;min-width:22px}}.input-wrapper.disabled{opacity:.7;cursor:not-allowed}.text-input-disabled-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;border-radius:12px;z-index:5;pointer-events:none}.text-input-disabled-overlay span{color:#f59e0b;font-size:.9rem;font-weight:500;text-align:center;padding:0 16px}@media (max-width: 480px){.text-input-disabled-overlay{border-radius:18px}.text-input-disabled-overlay span{font-size:.75rem;padding:0 12px}}.ai-coaching-button-wrapper{position:relative}.ai-coaching-button{display:flex;align-items:center;gap:6px;padding:9px 16px;border:1px solid rgba(59,130,246,.8);border-radius:999px;background:linear-gradient(135deg,#3b82f659,#2563eb59);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#93c5fd;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 0 14px #3b82f680,0 2px 10px #3b82f666;animation:neon-glow 3s ease-in-out infinite}@keyframes neon-glow{0%,to{box-shadow:0 0 30px #3b82f699,0 0 60px #3b82f666,0 4px 20px #3b82f680}50%{box-shadow:0 0 50px #3b82f6e6,0 0 100px #3b82f6b3,0 4px 32px #3b82f6cc}}.ai-coaching-button:hover:not(.disabled){background:linear-gradient(135deg,#3b82f680,#2563eb80);border-color:#3b82f6;color:#bfdbfe;transform:scale(1.05);box-shadow:0 0 60px #3b82f6e6,0 0 120px #3b82f6b3,0 6px 32px #3b82f6cc}.ai-coaching-button:active:not(.disabled){transform:scale(.98)}.ai-coaching-button.disabled{opacity:.4;cursor:not-allowed;animation:none}.button-label{font-size:1rem;font-weight:600}.ai-coaching-dropdown{position:absolute;bottom:calc(100% + 7px);left:0;min-width:176px;max-height:275px;overflow-y:auto;background:#1e1e1ef2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:11px;padding:7px;box-shadow:0 -7px 26px #0006;z-index:1000;animation:dropdownSlideUp .2s ease-out}@keyframes dropdownSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:7px 11px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:4px}.dropdown-title{font-size:.83rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:gold}.dropdown-item{display:flex;align-items:center;gap:9px;width:100%;padding:9px;border:none;border-radius:7px;background:transparent;color:#f5f7fa;font-size:.88rem;text-align:left;cursor:pointer;transition:all .15s ease}.dropdown-item:hover{background:#38bdf826;color:#f84e38}.dropdown-item.selected{background:#38bdf833;color:#f84e38}.mode-icon{font-size:1.38rem;flex-shrink:0;display:flex;align-items:center;justify-content:center}.mode-icon img{width:2rem;height:2rem;object-fit:contain}.mode-label{flex:1;font-weight:600;font-size:.88rem}.check-icon{font-size:1rem;color:#10b981;font-weight:700}.dropdown-footer{padding:7px 11px;border-top:1px solid rgba(255,255,255,.1);margin-top:4px}.footer-hint{font-size:.77rem;color:gold;font-style:italic}@media (max-width: 1023px) and (min-width: 768px){.ai-coaching-button{padding:16px 28px;font-size:1.4rem}.button-label{font-size:1.2rem}}@media (max-width: 767px) and (min-width: 481px){.ai-coaching-button{padding:14px 24px;font-size:1.3rem}.button-label{font-size:1.1rem}.ai-coaching-dropdown{min-width:200px}}@media (max-width: 480px){.ai-coaching-button{padding:9px 13px;width:100%;justify-content:center;font-size:.88rem;box-shadow:0 0 12px #3b82f666,0 2px 8px #3b82f64d}.button-label{font-size:.8rem}.ai-coaching-dropdown{min-width:calc(100vw - 32px);max-width:calc(100vw - 32px);left:50%;transform:translate(-50%)}.dropdown-header{padding:10px 14px}.dropdown-title{font-size:.9rem}.dropdown-item{padding:14px 12px}.mode-icon{font-size:1.5rem}.mode-icon img{width:2rem;height:2rem}.mode-label{font-size:1rem}.footer-hint{font-size:.85rem}}@media (max-width: 375px){.ai-coaching-button{padding:8px 10px;font-size:.75rem}.button-label{font-size:.7rem}.dropdown-item{padding:8px;gap:6px}.mode-icon{font-size:1rem}.mode-label{font-size:.75rem}}.mode-info{display:flex;flex-direction:column;align-items:flex-start;flex:1}.mode-description{font-size:.75rem;color:#9ca3af;margin-top:2px}.dropdown-item.coming-soon{opacity:.5;cursor:not-allowed}.dropdown-item.coming-soon:hover{background:transparent;color:#f5f7fa}.coming-soon-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;background:#fbbf2433;color:#fbbf24;padding:2px 6px;border-radius:4px}.inline-recorder.recording{box-sizing:border-box}.inline-recorder .recorder-btn{background-color:#fff;color:#dc2626;cursor:pointer}.inline-recorder .recorder-btn.recording{background-color:#dc2626;color:#fff;cursor:pointer;animation:pulse-record 1.5s ease-in-out infinite}.inline-recorder .recorder-btn:hover:not(:disabled){background-color:#f0f0f0;transform:scale(1.05);cursor:pointer}.inline-recorder .recorder-btn.recording:hover:not(:disabled){background-color:#b91c1c;cursor:pointer}@keyframes pulse-record{0%,to{box-shadow:0 0 #dc262666}50%{box-shadow:0 0 0 8px #dc262600}}.inline-recorder .recorder-fill{background-color:#ef4444;transition:width .1s linear}.inline-recorder .recorder-thumb{background-color:#fff;opacity:1!important}.recording-indicator-dot{width:10px;height:10px;border-radius:50%;background-color:#505050;transition:background-color .2s}.recording-indicator-dot.active{background-color:#ef4444;animation:blink-dot 1s ease-in-out infinite}@keyframes blink-dot{0%,to{opacity:1}50%{opacity:.4}}.recorder-error{position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 12px;background-color:#dc2626;color:#fff;border-radius:6px;font-size:12px;white-space:nowrap;margin-bottom:8px;box-shadow:0 2px 8px #0000004d}@media (max-width: 640px){.inline-recorder .audio-time.duration{display:none}}.efc-container{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;margin-top:16px}.efc-header{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1);color:#9ca3af;font-size:.9rem}.efc-card{padding:20px}.efc-pronunciation-section{position:relative;margin-bottom:20px;padding-right:80px}.efc-section-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;margin-bottom:8px}.efc-target-text{font-size:1.1rem;font-weight:600;color:#f5f7fa;line-height:1.5;margin:0}.efc-score-badge{position:absolute;top:16px;right:0;padding:8px 16px;border-radius:20px;font-size:1rem;font-weight:700}.efc-score-badge--excellent{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.efc-score-badge--good{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a2e}.efc-score-badge--fair{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff}.efc-score-badge--needs-work{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef444466}.efc-estimates-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.efc-estimate-card{background:#ffffff0d;border-radius:8px;padding:12px}.efc-estimate-header{display:block;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:gold;font-weight:600;margin-bottom:8px}.efc-ielts-scores{display:flex;justify-content:space-around}.efc-ielts-item{text-align:center}.efc-ielts-label{display:block;font-size:.8rem;color:#9ca3af;margin-bottom:4px}.efc-ielts-value{font-size:1.5rem;font-weight:700;color:#60a5fa}.efc-cefr-display{text-align:center}.efc-cefr-level{display:block;font-size:1.5rem;font-weight:700;color:#818cf8}.efc-cefr-desc{display:block;font-size:.8rem;color:#9ca3af}.efc-audio-section{margin:16px 0}.efc-audio-player{width:100%;height:40px;border-radius:20px;background:#ef444433}.efc-audio-player::-webkit-media-controls-panel{background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:20px}.efc-audio-tip{margin:6px 0 0;font-size:.75rem;color:#ffffff80;text-align:center}.efc-word-breakdown-section{margin:16px 0}.efc-word-breakdown{display:flex;flex-wrap:wrap;gap:6px;padding:12px;background:#0003;border-radius:8px}.efc-word{padding:4px 8px;border-radius:4px;font-size:.95rem;font-weight:500}.efc-word--correct{background:#22c55e80;color:gold;border:1px solid rgba(34,197,94,.8)}.efc-word--warning{background:#fbbf2480;color:gold;border:1px solid rgba(251,191,36,.8)}.efc-word--error{background:#ef444480;color:gold;border:1px solid rgba(239,68,68,.8)}.efc-word--omission{background:#9b59b680;color:gold;text-decoration:line-through;border:1px solid rgba(155,89,182,.8)}.efc-word--insertion{background:#3498db80;color:gold;font-style:italic;border:1px solid rgba(52,152,219,.8)}.efc-word--mispronunciation{background:#e74c3c80;color:gold;border:1px solid rgba(231,76,60,.8)}.efc-feedback-section{margin:16px 0;padding:12px;background:#ffffff08;border-radius:8px}.efc-feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.efc-feedback-label{font-size:1rem;font-weight:600;color:#f5f7fa}.efc-mode-toggle{padding:4px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#d4d6da;font-size:.8rem;cursor:pointer;transition:all .2s ease}.efc-mode-toggle:hover:not(:disabled){background:#ffffff26;color:#f5f7fa}.efc-mode-toggle:disabled{opacity:.5;cursor:not-allowed}.efc-feedback-text{margin:0;color:#ece90f;font-size:1rem;line-height:1.5}.efc-recognized-section{margin-top:16px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.efc-recognized-label{display:block;font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;color:#bcbec4;margin-bottom:4px}.efc-recognized-text{margin:0;color:#9ca3af;font-size:1rem;padding:8px 12px;background:#0003;border-radius:6px}@media (max-width: 640px){.efc-estimates-row{grid-template-columns:1fr}.efc-pronunciation-section{padding-right:0;padding-bottom:50px}.efc-score-badge{position:absolute;top:auto;bottom:0;right:50%;transform:translate(50%)}.efc-ielts-value,.efc-cefr-level{font-size:1.25rem}}.pd-session{display:flex;flex-direction:column;height:100%;min-height:500px;padding:0}.pd-session__header{text-align:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1)}.pd-session__header .pd-header-title{margin:0 0 8px;font-size:2.25rem;font-weight:600;color:var(--tyf-yellow-bright, #fcd34d);text-align:center}.pd-session__header .pd-module-name{margin:0 0 4px;font-size:1.7rem;font-weight:600;color:var(--tyf-text-primary, #f5f7fa);text-align:center}.pd-subtitle{color:#a78bfa;font-size:.9rem;text-align:center}.pd-progress-bar{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.pd-progress-fill{height:100%;background:linear-gradient(90deg,#4a90e2,#357abd);transition:width .3s ease}.pd-prompt-section{flex:1;overflow-y:auto;padding:24px}.pd-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;margin-bottom:16px}.pd-reference-card .pd-lead{margin:16px 0 12px;color:var(--tyf-text-secondary, #9ca3af);font-size:1.06875rem}.pd-reference-card .pd-target-sentence{font-size:1.875rem;font-weight:600;color:var(--tyf-yellow-bright, #fcd34d);margin:0;line-height:1.4;text-align:center}.pd-reference-card .pd-block{margin-top:16px}.pd-reference-audio-wrapper{background:linear-gradient(135deg,#3b82f633,#2563eb33);border:2px solid rgba(59,130,246,.4);border-radius:12px;padding:14px 18px;margin:12px 0}.pd-reference-audio-wrapper .pd-audio-label{display:block;font-size:.75rem;font-weight:700;color:#ffffffb3;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;text-align:center}.pd-reference-audio-wrapper .pd-audio-player{width:100%;height:40px;border-radius:8px}.pd-reference-audio-wrapper audio::-webkit-media-controls-panel{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;padding:0 10px}.pd-reference-audio-wrapper audio::-webkit-media-controls-play-button{background-color:#fff;border-radius:50%}.pd-reference-audio-wrapper audio::-webkit-media-controls-current-time-display,.pd-reference-audio-wrapper audio::-webkit-media-controls-time-remaining-display{color:#fff;font-weight:500}.pd-reference-audio-wrapper audio::-webkit-media-controls-timeline{background-color:#ffffff4d;border-radius:4px}.pd-reference-audio-wrapper audio::-webkit-media-controls-volume-slider{background-color:#ffffff4d}.pd-user-audio-wrapper{background:linear-gradient(135deg,#ef444433,#dc262633);border:2px solid rgba(239,68,68,.4);border-radius:12px;padding:14px 18px;margin:16px 0}.pd-user-audio-wrapper .pd-audio-label{display:block;font-size:.75rem;font-weight:700;color:#ffffffb3;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;text-align:center}.pd-user-audio-wrapper .pd-audio-player,.pd-user-audio-wrapper .pd-user-playback{width:100%;height:40px;border-radius:8px}.pd-user-audio-wrapper audio::-webkit-media-controls-panel{background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:8px;padding:0 10px}.pd-user-audio-wrapper audio::-webkit-media-controls-play-button{background-color:#fff;border-radius:50%}.pd-user-audio-wrapper audio::-webkit-media-controls-current-time-display,.pd-user-audio-wrapper audio::-webkit-media-controls-time-remaining-display{color:#fff;font-weight:500}.pd-user-audio-wrapper audio::-webkit-media-controls-timeline{background-color:#ffffff4d;border-radius:4px}.pd-user-audio-wrapper audio::-webkit-media-controls-volume-slider{background-color:#ffffff4d}.pd-attempt-card{background:#ffffff08}.pd-attempt-instruction{margin:0 0 16px;font-size:1rem;color:#9ca3af;text-align:center}.pd-card .pd-block-title{font-size:1.2rem;font-weight:600;color:var(--tyf-text-primary, #f5f7fa);margin:0 0 16px;text-align:left}.pd-recording-controls{display:flex;flex-direction:row;gap:12px;justify-content:flex-start;margin:16px 0;width:100%}.pd-recording-controls button{flex:1;max-width:200px}.pd-btn{padding:12px 24px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s ease}.pd-btn:disabled{opacity:.4;cursor:not-allowed}.pd-btn--primary{background:#4a90e2;color:#fff;flex:1}.pd-btn--primary:hover:not(:disabled){background:#357abd;transform:translateY(-1px)}.pd-btn--secondary{background:#ffffff1a;color:#9ca3af;border:1px solid rgba(255,255,255,.2);flex:1}.pd-btn--secondary:hover:not(:disabled){background:#ffffff26;color:#f5f7fa}.pd-btn--ghost{background:transparent;color:var(--tyf-text-primary, #f5f7fa);padding:8px 16px;font-weight:500}.pd-btn--ghost:hover:not(:disabled){color:#fff;background:#ffffff1a}.pd-feedback-card{background:#3b82f61a;border-color:#3b82f64d}.pd-feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pd-feedback-title{margin:0;font-size:1.1rem;font-weight:600;color:#60a5fa}.pd-toggle-pill{background:var(--tyf-audio-reference-bg, linear-gradient(135deg, #4da9ff 0%, #007cc3 100%));border:none;color:var(--tyf-yellow-bright, #fcd34d);font-size:.9rem;font-weight:600;padding:8px 20px;border-radius:var(--tyf-radius-pill, 50px);cursor:pointer;transition:all var(--tyf-transition-fast, .15s ease);box-shadow:0 2px 8px #4da9ff4d}.pd-toggle-pill:hover{background:linear-gradient(135deg,#5bb3ff,#0088d9);transform:translateY(-1px);box-shadow:0 4px 12px #4da9ff66}.pd-feedback-toggle.pd-active{background:#3b82f6;border-color:#3b82f6;color:#fff}.pd-feedback-text{margin:0;color:#d1d5db;font-size:.95rem;line-height:1.6}.pd-session__footer{padding:20px 24px;border-top:1px solid rgba(255,255,255,.1);background:#0003;margin-top:auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.pd-session__footer .pd-nav{display:flex;gap:12px}.pd-session__footer .pd-menu{text-align:center;margin-left:auto}.pd-loading-state,.pd-error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;padding:24px;color:#9ca3af}.pd-loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#4a90e2;border-radius:50%;animation:pd-spin 1s linear infinite}@keyframes pd-spin{to{transform:rotate(360deg)}}.pd-error-state{color:#f87171}@media (max-width: 640px){.pd-session__header h2{font-size:1.1rem}.pd-reference-card .pd-target-sentence{font-size:1.2rem}.pd-prompt-section,.pd-card{padding:16px}.pd-recording-controls{flex-direction:column}.pd-recording-controls button{max-width:none}.pd-btn{width:100%}.pd-session__footer .pd-nav{flex-direction:column}.pd-feedback-header{flex-direction:column;gap:12px;align-items:flex-start}}.pd-reference-audio{margin:1rem 0;display:flex;justify-content:center;width:100%;background:linear-gradient(135deg,#4da9ff,#007cc3);padding:6px;border-radius:50px;box-shadow:0 4px 12px #007cc34d}.pd-user-audio{margin-top:1.5rem;display:flex;justify-content:center;width:100%;background:linear-gradient(135deg,#ff6b6b,#ff8e53);padding:6px;border-radius:50px;box-shadow:0 4px 12px #ff6b6b4d}.pd-reference-audio .inline-audio-player,.pd-user-audio .inline-audio-player{background-color:#00000040!important;border:1px solid rgba(0,0,0,.1);max-width:none!important;width:100%}.pd-session .pd-btn,.pd-session .pd-recording-controls button{min-height:48px}.pd-session__footer .pd-btn{min-height:44px}.pd-enhanced-feedback-wrapper{margin-top:20px}.pd-enhanced-feedback-wrapper .pd-step-label{font-size:1.1rem;font-weight:600;color:var(--tyf-text-secondary, #9ca3af);margin-bottom:12px;text-align:center}.pd-enhanced-feedback-wrapper .efc-container{margin-top:0}.pd-enhanced-feedback-wrapper .efc-card{background:#ffffff08}.pd-enhanced-feedback-wrapper+.pd-card.pd-processing-card{margin-top:16px}.pd-exit-pill{background:linear-gradient(135deg,#ef4444,#dc2626);border:2px solid #f87171;color:#fff;font-weight:700;font-size:1rem;padding:12px 32px;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;box-shadow:0 4px 12px #ef444466;min-width:120px}.pd-exit-pill:hover{background:linear-gradient(135deg,#f87171,#ef4444);transform:translateY(-2px);box-shadow:0 6px 16px #ef444480}.pd-exit-pill:active{transform:translateY(0);box-shadow:0 2px 8px #ef444466}.pd-store-rect{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:1px solid rgba(59,130,246,.4);color:#fff;font-weight:600;font-size:.95rem;padding:12px 24px;border-radius:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;box-shadow:0 4px 12px #3b82f64d;min-width:120px}.pd-store-rect:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f680}.pd-store-rect:active{transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.practice-complete .complete-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.practice-complete .complete-hero-text{font-size:1.5rem;font-weight:600;color:#94a3b8;text-align:center;margin:0;line-height:1.4}.practice-complete .complete-stats-card{background:#0006;border:2px solid #3b82f6;border-radius:12px;padding:16px 24px;margin:20px auto;max-width:320px;box-shadow:0 0 15px #3b82f64d,0 0 30px #3b82f61a;position:relative}.practice-complete .stats-card-label{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#0f172a;color:#94a3b8;font-size:.7rem;font-weight:600;letter-spacing:.1em;padding:2px 12px;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.practice-complete .stats-card-content{display:flex;flex-direction:column;gap:12px;padding-top:8px}.practice-complete .stat-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.practice-complete .stat-label{color:#94a3b8;font-size:.9rem}.practice-complete .stat-value{color:#f5f5f4;font-size:1rem;font-weight:600}@media (max-width: 480px){.complete-progress{margin:1rem 0}.complete-hero-text{font-size:1.5rem;padding:0 1rem}.complete-stats-card{margin:1rem .5rem;padding:1rem}.stat-label{font-size:.85rem}.stat-value{font-size:1.1rem}.complete-actions{padding:0 1rem;gap:.75rem}.pd-exit-pill{font-size:.9rem;padding:10px 28px}.pd-store-rect{font-size:.9rem;padding:10px 24px}}.vp-store-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10100;padding:16px}.vp-store-container{background:#1c1917;border-radius:16px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;border:1px solid #44403c;box-shadow:0 25px 50px -12px #000000e6;overflow:hidden}.vp-store-header{padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #44403c;background:#292524;flex-shrink:0}.vp-header-left h2{color:#f59e0b;font-size:1.5rem;font-weight:700;margin:0;letter-spacing:-.02em}.vp-subtitle{color:#a8a29e;font-size:.85rem;display:block;margin-top:2px}.vp-header-right{display:flex;align-items:center;gap:12px}.vp-balance-chip{background:#0f172a;border:1px solid #3b82f6;border-radius:20px;padding:6px 14px;display:flex;align-items:center;gap:6px;box-shadow:0 0 15px #3b82f633}.vp-balance-icon{font-size:1rem}.vp-balance-value{color:#fbbf24;font-weight:700;font-size:1.1rem}.vp-balance-label{color:#94a3b8;font-size:.75rem;font-weight:600}.vp-error-banner{background:#7f1d1d;color:#fecaca;padding:10px 16px;font-size:.9rem;border-bottom:1px solid #991b1b}.vp-store-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.vp-store-item{background:#292524;border-radius:12px;border:1px solid #44403c;display:flex;flex-direction:row;align-items:center;padding:10px;gap:12px;overflow:hidden;transition:transform .2s,border-color .2s}.vp-store-item:hover{transform:translateY(-2px);border-color:#57534e}.vp-store-item.equipped{border-color:#22c55e;background:#1a2e1a}.vp-item-icon{width:48px;height:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:2rem;border-radius:8px;background:#ffffff0d}.vp-item-details{flex:1;padding:0;display:flex;flex-direction:column;gap:4px}.vp-item-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px;gap:8px}.vp-item-top h3{margin:0;color:#f5f5f4;font-size:.9rem;font-weight:600;line-height:1.2;word-break:break-word}.vp-tags{display:flex;gap:4px;flex-wrap:wrap}.vp-tag{font-size:.65rem;padding:2px 6px;border-radius:4px;font-weight:600;text-transform:uppercase}.tag-free{background:#166534;color:#bbf7d0;border:1px solid #22c55e}.tag-premium,.tag-status{background:#451a03;color:#fed7aa;border:1px solid #78350f}.tag-themed{background:#1e3a5f;color:#93c5fd;border:1px solid #3b82f6}.tag-trending{background:#4c0519;color:#f472b6;border:1px solid #be185d}.tag-rare{background:#3b0764;color:#d8b4fe;border:1px solid #7c3aed}.vp-description{margin:0;color:#a8a29e;font-size:.8rem;line-height:1.3}.vp-placeholder-text{color:#78716c;font-size:.75rem;font-style:italic;margin:4px 0 0}.equipped-badge-inline{display:inline-block;background:#166534;color:#bbf7d0;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;border:1px solid #22c55e;margin-top:4px}.vp-item-action{flex-shrink:0;padding:0;min-width:120px}.vp-btn-buy{width:100%;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;color:#1c1917;font-weight:700;font-size:.9rem;padding:10px 16px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:filter .2s}.vp-btn-buy:hover:not(.disabled){filter:brightness(1.1)}.vp-btn-buy.disabled{background:#44403c;color:#78716c;cursor:not-allowed;filter:none}.vp-btn-equip{width:100%;background:#44403c;border:1px solid #57534e;color:#e7e5e4;font-weight:600;font-size:.9rem;padding:10px 16px;border-radius:8px;cursor:pointer;transition:background .2s}.vp-btn-equip:hover:not(.active):not(:disabled){background:#57534e}.vp-btn-equip.active{background:#166534;border-color:#22c55e;color:#bbf7d0;cursor:default}.vp-btn-equip:disabled{cursor:default}.vp-store-footer{padding:16px 20px;border-top:1px solid #44403c;background:#292524;display:flex;flex-direction:column;align-items:center;gap:12px;flex-shrink:0}.vp-exit-btn{background:linear-gradient(135deg,#ef4444,#dc2626);border:2px solid #f87171;color:#fff;font-weight:700;font-size:1rem;padding:12px 32px;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;box-shadow:0 4px 12px #ef444466;min-width:140px}.vp-exit-btn:hover{background:linear-gradient(135deg,#f87171,#ef4444);transform:translateY(-2px);box-shadow:0 6px 16px #ef444480}.vp-exit-btn:active{transform:translateY(0);box-shadow:0 2px 8px #ef444466}.vp-footer-hint{color:#78716c;font-size:.8rem}@media (max-width: 480px){.vp-store-container{max-height:85vh;border-radius:12px}.vp-store-header{flex-direction:column;padding:12px 16px;gap:8px;align-items:flex-start}.vp-header-right{width:100%;justify-content:space-between}.vp-header-left h2{font-size:1.25rem}.vp-subtitle{font-size:.75rem}.vp-balance-chip{padding:4px 10px}.vp-balance-value{font-size:.95rem}.vp-balance-label{font-size:.7rem}.vp-store-list{padding:12px;gap:10px}.vp-item-icon{width:36px;height:36px;font-size:1.5rem;border-radius:6px}.vp-store-item{padding:8px;gap:10px;flex-direction:column;align-items:stretch}.vp-item-top h3{font-size:.85rem}.vp-description{font-size:.75rem;line-height:1.2}.vp-tag{font-size:.6rem;padding:2px 5px}.vp-item-action{min-width:100px}.vp-btn-buy,.vp-btn-equip{font-size:.85rem;padding:8px 12px}.vp-store-footer{padding:12px 16px;gap:10px}.vp-exit-btn{font-size:.9rem;padding:10px 28px;min-width:120px}.vp-footer-hint{font-size:.75rem}}.tutor-orb-debrief-bottom-right{position:fixed;bottom:2rem;right:2rem;z-index:50}.tutor-orb-debrief-bottom-center{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:50}.tutor-orb-overlay-bottom-right{position:fixed;bottom:80px;right:20px;z-index:100;display:flex;flex-direction:column;align-items:center;pointer-events:auto}@media (max-width: 640px){.tutor-orb-debrief-bottom-right,.tutor-orb-debrief-bottom-center{bottom:1rem;scale:.9}}@media (max-width: 480px){.tutor-orb-overlay-bottom-right{transform:scale(.5);transform-origin:bottom right;bottom:55px;right:10px}}:root{--tyf-blue-primary: #4A90E2;--tyf-blue-dark: #357ABD;--tyf-blue-light: #6BA3E8;--tyf-red-accent: #FF0000;--tyf-red-muted: #E53935;--exam-prep-accent: #FCD34D;--exam-prep-weakness: #F59E0B}.exam-prep-container,.ielts-container{display:flex;flex-direction:column;height:100%;padding:20px;background:linear-gradient(135deg,#0f172a,#1a365d);color:#f1f5f9}.cue-card{background:#fff;color:#1e293b;padding:24px;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:20px;text-align:left}.cue-card h3{color:#334155;font-size:1.25rem;margin-bottom:16px;font-weight:700}.cue-card ul{padding-left:20px;line-height:1.6}.scratchpad-area{width:100%;height:120px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#f1f5f9;padding:12px;resize:none;font-family:inherit;font-size:.95rem;margin-bottom:16px}.scratchpad-area:focus{outline:none;border-color:var(--tyf-blue-primary)}.timer-large{font-size:3.5rem;font-weight:800;font-variant-numeric:tabular-nums;margin:20px 0;text-align:center}.timer-prep{color:var(--tyf-blue-primary)}.timer-record{color:var(--tyf-red-muted)}.scorecard-header{text-align:center;margin-bottom:30px}.band-score-hero{font-size:4.5rem;font-weight:800;color:var(--tyf-blue-primary);line-height:1}.band-score-hero.range-display{font-size:3rem}.cefr-level,.cefr-level-subtle{font-size:.7rem;color:#64748b;margin-top:4px;opacity:.7}.score-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin:2rem 0}.score-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.score-item.weakness{border:1px solid rgba(231,76,60,.3);background:#e74c3c1a}.score-label{font-size:.875rem;color:#95a5a6;text-transform:uppercase;letter-spacing:.5px}.score-value{font-weight:700;font-size:1.1rem}.score-value.range{font-size:1rem;color:#f1c40f}@media (max-width: 640px){.score-grid{grid-template-columns:1fr;gap:1rem}}.btn.primary-tyf{background:linear-gradient(135deg,var(--tyf-blue-primary) 0%,var(--tyf-blue-dark) 100%);color:#fff;padding:12px 24px;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn.primary-tyf:hover{background:linear-gradient(135deg,var(--tyf-blue-dark) 0%,#2563EB 100%)}.btn.ghost-tyf{background:transparent;color:var(--tyf-blue-light);border:1px solid rgba(74,144,226,.3);padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn.ghost-tyf:hover{background:#4a90e21a}.btn.primary-teal{background:linear-gradient(135deg,var(--tyf-blue-primary) 0%,var(--tyf-blue-dark) 100%);color:#fff;padding:12px 24px;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn.primary-teal:hover{background:linear-gradient(135deg,var(--tyf-blue-dark) 0%,#2563EB 100%)}.btn.ghost-teal{background:transparent;color:var(--tyf-blue-light);border:1px solid rgba(74,144,226,.3);padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn.ghost-teal:hover{background:#4a90e21a}.recording-pulse{width:60px;height:60px;border-radius:50%;background:var(--tyf-red-muted);margin:0 auto;animation:pulse 1.5s infinite;display:flex;align-items:center;justify-content:center}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}.ep-btn{padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;flex:1;text-decoration:none;font-family:inherit}.ep-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.ep-btn:focus{outline:none;box-shadow:0 0 0 3px #fff3}.ep-btn-primary{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef44444d}.ep-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}.ep-btn-primary:active:not(:disabled){transform:translateY(0)}.ep-btn-skip{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.ep-btn-skip:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.ep-btn-skip:active:not(:disabled){transform:translateY(0)}.ep-btn-retry{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.ep-btn-retry:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.ep-btn-retry:active:not(:disabled){transform:translateY(0)}.ep-btn-tryagain{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;box-shadow:0 4px 12px #fbbf244d}.ep-btn-tryagain:hover:not(:disabled){background:linear-gradient(135deg,#f59e0b,#d97706);transform:translateY(-2px);box-shadow:0 6px 16px #fbbf2466}.ep-btn-tryagain:active:not(:disabled){transform:translateY(0)}.ep-btn-complete{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 4px 12px #22c55e4d}.ep-btn-complete:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);transform:translateY(-2px);box-shadow:0 6px 16px #22c55e66}.ep-btn-complete:active:not(:disabled){transform:translateY(0)}.ep-btn-secondary{background:transparent;color:#9ca3af;border:2px solid #4b5563}.ep-btn-secondary:hover:not(:disabled){background:#4b556333;border-color:#6b7280;color:#d1d5db;transform:translateY(-1px)}.ep-btn-secondary:active:not(:disabled){transform:translateY(0)}.ep-btn-stop{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 14px #ef444466}.ep-btn-stop:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 6px 20px #ef444480}.ep-btn-stop:active:not(:disabled){transform:translateY(0)}.ep-btn-accept{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef44444d;width:100%}.ep-btn-accept:hover:not(:disabled){background:linear-gradient(135deg,#f87171,#ef4444);transform:translateY(-2px);box-shadow:0 8px 20px #ef444466}.ep-btn-accept:active:not(:disabled){transform:translateY(0)}.ep-btn-group{display:flex;gap:1rem;margin-top:1rem}.ep-btn-group--vertical{flex-direction:column}.ep-btn-group--center{justify-content:center}@media (max-width: 480px){.ep-btn{padding:.75rem 1rem;font-size:.9375rem;min-height:44px}.ep-btn-group{flex-direction:column}.ep-btn-group .ep-btn{width:100%}}@keyframes orb-float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes orb-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes inner-smoke-rotate{0%{transform:rotate(0) scale(1);opacity:.7}25%{transform:rotate(90deg) scale(1.15);opacity:.5}50%{transform:rotate(180deg) scale(.95);opacity:.8}75%{transform:rotate(270deg) scale(1.1);opacity:.6}to{transform:rotate(360deg) scale(1);opacity:.7}}@keyframes aura-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.15)}}.tutor-orb-container{animation:orb-float 6s ease-in-out infinite;display:flex;flex-direction:column;align-items:center;gap:8px}.tutor-orb-core{animation:orb-breathe 4s ease-in-out infinite}.tutor-smoke-effect{animation:inner-smoke-rotate 20s linear infinite;transform-origin:center}.tutor-aura{animation:aura-pulse 3s ease-in-out infinite}.tutor-orb-chat-btn{background:linear-gradient(135deg,#8b5cf6cc,#6366f1cc);border:1px solid rgba(255,255,255,.2);color:#fff;padding:6px 14px;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tutor-orb-chat-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666;background:linear-gradient(135deg,#8b5cf6,#6366f1)}.tutor-orb-chat-btn:active{transform:translateY(0)}.tutor-orb-hint{font-size:10px;color:#ffffff80;margin-top:4px;text-align:center}@media (max-width: 480px){.tutor-orb-chat-btn{padding:5px 12px;font-size:11px}.tutor-orb-hint{font-size:9px}}.tutor-orb-help-text{position:absolute;top:-30px;left:50%;transform:translate(-50%);font-size:13px;color:#fcd34d;white-space:nowrap;pointer-events:none;animation:tutor-fade-pulse 2s ease-in-out infinite;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.8);font-weight:600;z-index:10}@keyframes tutor-fade-pulse{0%,to{opacity:.8}50%{opacity:1}}.tutor-orb-practice-overlay,.tutor-orb-phonics-overlay,.tutor-orb-drama-overlay{position:fixed;bottom:100px;right:30px;z-index:1000}.orb-glass-container{position:relative;width:100%;height:100%;border-radius:50%;overflow:hidden;box-shadow:inset 0 0 20px #fff3,inset 0 0 5px #ffffff80;transform-style:preserve-3d}.orb-smoke-layer{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background-size:cover;background-position:center;opacity:.9;mask-image:radial-gradient(circle,black 30%,transparent 65%);-webkit-mask-image:radial-gradient(circle,black 30%,transparent 65%);animation:inner-smoke-rotate 25s linear infinite}.orb-shine-overlay{position:absolute;top:10%;left:15%;width:35%;height:20%;border-radius:50%;background:radial-gradient(ellipse at center,#ffffffb3,#fff0 70%);filter:blur(2px);z-index:5;pointer-events:none}.orb-vignette{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;box-shadow:inset 0 0 20px #0009;z-index:4;pointer-events:none}@keyframes aura-pulse-speaking{0%{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:.3}to{transform:scale(1);opacity:.6}}@keyframes glass-flicker{0%,to{opacity:1}50%{opacity:.8}}.micro-drill{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;max-width:600px;margin:0 auto}.drill-instruction{font-size:1rem;color:#a0a0a0;text-align:center}.target-phrase{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%}.target-phrase .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:#7f8c8d}.target-phrase .phrase{font-size:1.5rem;font-weight:600;color:#f1c40f;text-align:center;line-height:1.4;padding:1rem 1.5rem;background:#f1c40f1a;border-radius:8px;border:1px dashed rgba(241,196,15,.3)}.recording-controls{display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:200px;justify-content:center}.error-message{color:#e74c3c;font-size:.875rem;padding:.75rem 1rem;background:#e74c3c1a;border-radius:8px;border:1px solid rgba(231,76,60,.3)}.micro-drill-orb-wrapper{display:flex;align-items:center;justify-content:center;margin:1rem 0}.micro-drill-orb-wrapper .audio-visualizer-orb{width:120px;height:120px}.micro-drill-orb-wrapper .orb-icon svg{width:40px;height:40px}.micro-drill-orb-wrapper .orb-state-label{display:none}.hint{color:#7f8c8d;font-size:.875rem;text-align:center;margin:0}.result-display{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;border-radius:12px;width:100%}.result-display.success{background:#2ecc711a;border:2px solid #2ecc71}.result-display.warning{background:#f1c40f1a;border:2px solid #f1c40f}.result-display.error{background:#e74c3c1a;border:2px solid #e74c3c}.score-circle{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.score-value{font-size:3.5rem;font-weight:700;line-height:1}.result-display.success .score-value{color:#2ecc71}.result-display.warning .score-value{color:#f1c40f}.result-display.error .score-value{color:#e74c3c}.score-label{font-size:1.5rem;color:#95a5a6}.feedback-text{color:#bdc3c7;font-size:.9375rem;text-align:center;margin:0}.word-breakdown{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:.5rem}.word-breakdown .word{padding:.25rem .5rem;border-radius:4px;font-size:1rem}.word-breakdown .word.correct{background:#2ecc7133;color:#2ecc71}.word-breakdown .word.warning{background:#f1c40f33;color:#f1c40f}.word-breakdown .word.error,.word-breakdown .word.mispronunciation{background:#e74c3c33;color:#e74c3c;text-decoration:underline wavy #e74c3c}.word-breakdown .word.omission{background:#9b59b633;color:#9b59b6;text-decoration:line-through}.word-breakdown .word.insertion{background:#3498db33;color:#3498db;font-style:italic}.sam-speaking-overlay{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:#2ecc7114;border:1px solid rgba(46,204,113,.25);border-radius:12px;width:100%;animation:samFadeIn .3s ease-out}@keyframes samFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sam-speaking-pulse{width:48px;height:48px;border-radius:50%;background:radial-gradient(circle,#2ecc71 30%,transparent 70%);animation:samPulse 1.2s ease-in-out infinite}@keyframes samPulse{0%,to{transform:scale(.8);opacity:.6}50%{transform:scale(1.2);opacity:1}}.sam-speaking-text{color:#2ecc71;font-size:1.1rem;font-weight:600;margin:0}.sam-speaking-hint{color:#7f8c8d;font-size:.85rem;margin:0}.attempt-counter{text-align:center;font-size:.85rem;color:#95a5a6;font-weight:500;letter-spacing:.3px;margin-bottom:.25rem}@media (max-width: 480px){.micro-drill{padding:1.5rem}.target-phrase .phrase{font-size:1.25rem;padding:.75rem 1rem}.record-button{width:80px;height:80px;font-size:2rem}.score-value{font-size:2.5rem}}.remediation-drill{display:flex;flex-direction:column;gap:2rem;padding:2rem;max-width:900px;margin:0 auto}.drill-header{text-align:center}.drill-header-content{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:.5rem}.drill-title{font-size:2rem;font-weight:700;margin:0 0 .5rem;color:var(--tyf-text-accent)}.drill-description{font-size:1.8rem;color:#7f8c8d;margin:0 0 1.5rem}.drill-progress{max-width:500px;margin:0 auto}.progress-bar{height:8px;background:#ecf0f1;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s ease}.progress-text{font-size:.875rem;color:#95a5a6}.drill-content{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.exercise-card{background:#1e293bcc;border:2px solid var(--tyf-blue-primary);border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a}.exercise-number{font-size:.875rem;font-weight:600;color:#fff;background:var(--tyf-blue-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;padding:.5rem 1rem;border-radius:6px;display:inline-block}.exercise-text{font-size:1.25rem;line-height:1.6;color:var(--tyf-text-accent);margin:0 0 2rem;padding:1.5rem;background:#64748b33;border-radius:8px;border-left:4px solid var(--tyf-blue-primary)}.exercise-actions{display:flex;gap:1rem;margin-top:1.5rem}.tips-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;padding:1.5rem;height:fit-content}.tips-title{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:var(--tyf-text-accent)}.tips-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.tips-list li{padding-left:1.5rem;position:relative;line-height:1.5;font-size:1.40625rem;color:var(--tyf-text-accent)}.tips-list li:before{content:"→";position:absolute;left:0;font-weight:700}.drill-footer{text-align:center;padding-top:1rem;border-top:1px solid #ecf0f1}@media (max-width: 768px){.remediation-drill{padding:1rem}.drill-title{font-size:1.5rem}.drill-description{font-size:1rem}.drill-content{grid-template-columns:1fr;gap:1.5rem}.exercise-card{padding:1.5rem}.exercise-text{font-size:1.125rem;padding:1rem}.exercise-actions{flex-direction:column}.tips-card{order:-1}}.corrections-section{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #e94560;border-radius:12px;padding:1.5rem;margin-bottom:1rem}.corrections-title{color:#f1c40f;font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.corrections-subtitle{color:#a0a0a0;font-size:1.35rem;margin:0 0 1.5rem}.corrections-list{display:flex;flex-direction:column;gap:1rem}.correction-card{background:#ffffff0d;border-radius:8px;padding:1rem;border-left:3px solid #e94560}.correction-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.correction-original,.correction-improved{flex:1;min-width:150px}.correction-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:#7f8c8d;margin-bottom:.25rem}.correction-text{display:block;font-size:1.5rem;line-height:1.4}.correction-text.strikethrough{color:#e74c3c;text-decoration:line-through;opacity:.8}.correction-text.highlight{color:#2ecc71;font-weight:600;background:#2ecc711a;padding:.25rem .5rem;border-radius:4px}.correction-arrow{color:#3498db;font-size:1.5rem;font-weight:700;flex-shrink:0}.correction-reason{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);font-size:1.2rem;color:#95a5a6;font-style:italic}.corrections-more{text-align:center;color:#3498db;font-size:.875rem;margin-top:1rem;cursor:pointer}.corrections-more:hover{color:#2980b9;text-decoration:underline}@media (max-width: 768px){.correction-content{flex-direction:column;align-items:stretch}.correction-arrow{transform:rotate(90deg);text-align:center;padding:.5rem 0}.correction-original,.correction-improved{min-width:100%}}.remediation-complete{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem;max-width:600px;margin:0 auto;text-align:center}.remediation-complete-hero{display:flex;flex-direction:column;align-items:center;gap:.75rem}.remediation-complete-icon{font-size:4rem;line-height:1;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.remediation-complete-title{font-size:2.5rem;font-weight:700;color:var(--tyf-text-accent, #e2e8f0);margin:0}.remediation-complete-subtitle{font-size:1.1rem;color:#94a3b8;margin:0}.remediation-complete-stats{background:#1e293bcc;border:1px solid rgba(59,130,246,.3);border-radius:12px;padding:1.5rem;width:100%;max-width:400px;box-shadow:0 0 15px #3b82f61a}.remediation-stats-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:#64748b;display:block;margin-bottom:1rem}.remediation-stats-content{display:flex;flex-direction:column;gap:.75rem}.remediation-stat-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(100,116,139,.2)}.remediation-stat-row:last-child{border-bottom:none}.remediation-stat-name{font-size:.95rem;color:#94a3b8}.remediation-stat-value{font-size:1rem;font-weight:600;color:var(--tyf-text-accent, #e2e8f0)}.remediation-complete-message{background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:10px;padding:1.25rem;width:100%;max-width:400px}.remediation-complete-message p{margin:0;font-size:.95rem;line-height:1.6;color:#a7f3d0}.remediation-complete-message strong{color:#34d399}@media (max-width: 640px){.remediation-complete{padding:1.5rem 1rem;gap:1.5rem}.remediation-complete-title{font-size:2rem}.remediation-complete-icon{font-size:3rem}.remediation-complete-stats,.remediation-complete-message{max-width:100%}}.remediation-stat-highlight{background:#f1c40f26;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;border:1px solid rgba(241,196,15,.3)}.remediation-stat-breakdown{display:flex;flex-direction:column;gap:.5rem;padding:1rem 0;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);margin:1rem 0}.remediation-breakdown-row{display:flex;justify-content:space-between;font-size:.875rem;color:#95a5a6}.remediation-breakdown-row span:first-child{font-weight:500}.remediation-breakdown-row span:last-child{color:#ecf0f1;font-weight:600;font-size:1rem}.exam-prep-session-container,.ielts-session-container{width:100%;min-height:600px;padding:1rem}.connection-status{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem;color:#7f8c8d}.connection-status .spinner{width:50px;height:50px;border:4px solid #ecf0f1;border-top-color:#14b8a6;border-radius:50%;animation:spin 1s linear infinite}.connection-status p{font-size:1rem;margin:0}@media (max-width: 768px){.exam-prep-session-container,.ielts-session-container{padding:.5rem}}.tutor-orb-exam-overlay{position:fixed;bottom:80px;right:20px;z-index:100;display:flex;flex-direction:column;align-items:center;pointer-events:auto}@media (max-width: 480px){.tutor-orb-exam-overlay{display:flex!important;flex-direction:column!important;align-items:center!important;transform:scale(.5)!important;transform-origin:bottom right!important;bottom:55px;right:10px}}.analyzing-inline-card{background:linear-gradient(135deg,#0f2027,#1a3a4a,#0d3b4f);border-radius:16px;border:1px solid rgba(20,184,166,.25);padding:0;overflow:hidden;min-height:400px;display:flex;flex-direction:column}.analyzing-sticky-header{display:flex;flex-direction:column;gap:.25rem;padding:1.25rem 1.5rem;background:#14b8a614;border-bottom:1px solid rgba(20,184,166,.15)}.analyzing-topic-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:#14b8a6;font-weight:600}.analyzing-topic-name{font-size:1.15rem;color:#e2e8f0;font-weight:500;line-height:1.4}.analyzing-inline-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:1.5rem}.analyzing-inline-spinner{position:relative;width:80px;height:80px}.analyzing-inline-spinner .spinner-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:3px solid rgba(20,184,166,.15);border-top-color:#14b8a6;border-radius:50%;animation:analyzingSpin 1s linear infinite}.analyzing-inline-spinner .spinner-ring.inner{top:12px;left:12px;width:calc(100% - 24px);height:calc(100% - 24px);border-color:#14b8a61a;border-top-color:#14b8a680;animation-direction:reverse;animation-duration:1.5s}@keyframes analyzingSpin{to{transform:rotate(360deg)}}.analyzing-inline-steps{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:360px}.analyzing-inline-step{display:flex;align-items:center;gap:.75rem;padding:.6rem .8rem;border-radius:8px;font-size:.9rem;color:#64748b;background:#ffffff08;transition:all .4s ease}.analyzing-inline-step.active{color:#e2e8f0;background:#14b8a61a;border-left:3px solid #14b8a6}.analyzing-inline-step .step-icon{font-size:1.2rem;flex-shrink:0}.analyzing-inline-timer{font-size:1rem;font-weight:600;color:#14b8a6;margin:0}.analyzing-inline-note{font-size:.8rem;color:#64748b;font-style:italic;margin:0}@media (max-width: 480px){.analyzing-inline-card{min-height:350px}.analyzing-topic-name{font-size:1rem}.analyzing-inline-content{padding:1.5rem 1rem}}.analyzing-screen{display:flex;align-items:center;justify-content:center;min-height:500px;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.analyzing-content{text-align:center;max-width:600px}.spinner-container{position:relative;width:100px;height:100px;margin:0 auto 2rem}.spinner{position:absolute;top:0;left:0;width:100%;height:100%;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.spinner-inner{position:absolute;top:15px;left:15px;width:70px;height:70px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff9;border-radius:50%;animation:spin 1.5s linear infinite reverse}.analyzing-title{font-size:2rem;font-weight:700;margin:0 0 2rem;letter-spacing:-.5px}.analyzing-steps{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;text-align:left}.analyzing-step{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.step-icon{font-size:2rem;flex-shrink:0}.step-text{display:flex;flex-direction:column;gap:.25rem}.step-text strong{font-size:1rem;font-weight:600}.step-text span{font-size:.875rem;opacity:.9}.analyzing-timer{font-size:1.125rem;font-weight:600;margin-bottom:1rem;opacity:.9}.analyzing-note{font-size:.875rem;opacity:.8;margin:0;font-style:italic}@media (max-width: 768px){.analyzing-screen{padding:1rem;min-height:400px}.analyzing-title{font-size:1.5rem}.analyzing-steps{gap:1rem}.analyzing-step{padding:.75rem}.step-icon{font-size:1.5rem}.step-text strong{font-size:.875rem}.step-text span{font-size:.75rem}}.exam-prep-debug-panel,.ielts-debug-panel{margin-top:20px;background:#9b59b614;border:2px dashed rgba(155,89,182,.3);border-radius:12px;max-width:480px;margin-left:auto;margin-right:auto}.debug-panel-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#9b59b626;border-bottom:1px solid rgba(155,89,182,.2);border-radius:10px 10px 0 0}.debug-panel-header h4{margin:0;font-size:.9rem;color:#9b59b6}.debug-close-btn{background:none;border:none;color:#9b59b6;font-size:1.25rem;cursor:pointer;padding:0 6px;line-height:1}.debug-panel-content{padding:14px}.debug-section{margin-bottom:14px}.debug-label{display:block;font-size:.8rem;color:#9ca3af;margin-bottom:6px;font-weight:600}.preset-buttons{display:flex;gap:6px}.preset-btn{flex:1;padding:6px 8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#f5f7fa;font-size:.75rem;cursor:pointer;transition:all .15s ease}.preset-btn:hover{background:#ffffff1a}.preset-btn.active{background:#9b59b640;border-color:#9b59b6;color:#bb8fce}.debug-slider{width:100%;margin-top:4px}.debug-actions{display:flex;gap:6px;margin-top:14px}.debug-action-btn{flex:1;padding:8px 10px;border:none;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease}.debug-action-btn.primary{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.debug-action-btn.secondary{background:#9b59b633;color:#9b59b6}.debug-action-btn.tertiary{background:#f1c40f33;color:#f1c40f}.debug-hint{margin:10px 0 0;font-size:.7rem;color:#f59e0b;text-align:center}.disclaimer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .3s ease-out}.disclaimer-modal{background:linear-gradient(180deg,#1e293b,#0f172a);border:1px solid rgba(74,144,226,.3);border-radius:16px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #4a90e21a,0 0 60px #4a90e226;animation:slideUp .4s ease-out}.disclaimer-header{display:flex;flex-direction:column;align-items:center;padding:1.5rem 2rem 1rem;border-bottom:1px solid rgba(74,144,226,.2)}.disclaimer-icon{width:56px;height:56px;background:linear-gradient(135deg,#4a90e2,#357abd);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem;color:#fff}.disclaimer-title{font-size:1.5625rem;font-weight:600;color:gold;margin:0;text-align:center}.disclaimer-body{padding:1.5rem 2rem}.disclaimer-intro{color:#94a3b8;font-size:1.1875rem;line-height:1.6;margin:0 0 1.25rem;text-align:center}.disclaimer-intro strong{color:#4a90e2}.disclaimer-section{background:#4a90e214;border:1px solid rgba(74,144,226,.15);border-radius:12px;padding:1rem 1.25rem;margin-bottom:1rem}.disclaimer-section.warning{background:#e5393514;border-color:#e5393533}.disclaimer-section h3{font-size:1.0625rem;font-weight:600;color:#f8f408;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.disclaimer-section ul{list-style:none;margin:0;padding:0}.disclaimer-section li{display:flex;align-items:center;gap:.75rem;color:#cbd5e1;font-size:1.125rem;line-height:1.5;margin-bottom:.5rem}.disclaimer-section li:last-child{margin-bottom:0}.disclaimer-section li strong{color:#fc1606}.check-icon{color:#4ade80;font-weight:700;flex-shrink:0;margin-top:2px}.x-icon{color:#e53935;font-weight:700;flex-shrink:0;margin-top:2px}.disclaimer-footer-text{color:#f7f6ee;font-size:1.2rem;line-height:1.6;margin:1rem 0 0;text-align:center}.disclaimer-footer-text strong{color:#f73606}.disclaimer-footer{padding:1.25rem 2rem 1.5rem;border-top:1px solid rgba(195,208,224,.548);display:flex;flex-direction:column;align-items:center;gap:1rem}.disclaimer-legal{font-size:1.09375rem;color:#94a3b8;margin:0;text-align:center;letter-spacing:.02em}.disclaimer-modal::-webkit-scrollbar{width:6px}.disclaimer-modal::-webkit-scrollbar-track{background:#0003;border-radius:3px}.disclaimer-modal::-webkit-scrollbar-thumb{background:#4a90e266;border-radius:3px}.disclaimer-modal::-webkit-scrollbar-thumb:hover{background:#4a90e299}@media (max-width: 480px){.disclaimer-modal{max-height:95vh;border-radius:12px}.disclaimer-header,.disclaimer-body,.disclaimer-footer{padding-left:1.25rem;padding-right:1.25rem}.disclaimer-icon{width:48px;height:48px}.disclaimer-icon svg{width:24px;height:24px}.disclaimer-title{font-size:1.375rem}.disclaimer-section{padding:.875rem 1rem}.disclaimer-section li{font-size:1.0625rem}}.dev-debug-panel{position:fixed;bottom:20px;right:20px;width:320px;max-width:90vw;background:linear-gradient(145deg,#1e1e2dfa,#141423fa);border:2px solid rgba(255,200,50,.6);border-radius:12px;box-shadow:0 8px 32px #0006,0 0 20px #ffc83233;z-index:10000;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}.dev-debug-panel__header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(90deg,#ffc83233,#ff96321a);border-bottom:1px solid rgba(255,200,50,.3)}.dev-debug-panel__header h3{margin:0;font-size:14px;font-weight:600;color:#ffc832;letter-spacing:.5px}.dev-debug-panel__close{background:transparent;border:none;color:#fff9;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.dev-debug-panel__close:hover{background:#ff646433;color:#ff6b6b}.dev-debug-panel__content{padding:16px;display:flex;flex-direction:column;gap:14px}.dev-debug-panel__type-badge{display:inline-block;padding:6px 12px;background:#64b4ff26;border:1px solid rgba(100,180,255,.4);border-radius:20px;font-size:12px;font-weight:500;color:#64b4ff;text-align:center}.dev-debug-panel__field{display:flex;flex-direction:column;gap:6px}.dev-debug-panel__field label{font-size:12px;font-weight:500;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.dev-debug-panel__field select,.dev-debug-panel__field input[type=number]{padding:8px 12px;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:14px;outline:none;transition:border-color .2s}.dev-debug-panel__field select:focus,.dev-debug-panel__field input[type=number]:focus{border-color:#ffc83299}.dev-debug-panel__field select option{background:#1a1a2e;color:#fff}.dev-debug-panel__field input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:#ffffff1a;border-radius:3px;outline:none}.dev-debug-panel__field input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#ffc832,#ff9f1a);cursor:pointer;border:2px solid #fff;box-shadow:0 2px 6px #0000004d}.dev-debug-panel__field input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#ffc832,#ff9f1a);cursor:pointer;border:2px solid #fff;box-shadow:0 2px 6px #0000004d}.dev-debug-panel__presets{display:flex;flex-direction:column;gap:8px}.dev-debug-panel__presets label{font-size:12px;font-weight:500;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.dev-debug-panel__preset-btns{display:flex;gap:8px}.dev-debug-panel__preset-btns button{flex:1;padding:8px 12px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ffffffd9;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s}.dev-debug-panel__preset-btns button:hover{background:#ffc83226;border-color:#ffc83266;color:#ffc832}.dev-debug-panel__custom{display:flex;flex-direction:column;gap:12px;padding:12px;background:#0003;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.dev-debug-panel__field-row{display:flex;gap:12px}.dev-debug-panel__field-row .dev-debug-panel__field{flex:1}.dev-debug-panel__field-row input[type=number]{width:100%;text-align:center}.dev-debug-panel__skip-btn{padding:12px 20px;background:linear-gradient(135deg,#4caf50,#2e7d32);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4caf504d}.dev-debug-panel__skip-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4caf5066}.dev-debug-panel__skip-btn:active{transform:translateY(0)}.dev-debug-panel__info{padding:10px 12px;background:#0003;border-radius:6px;border-left:3px solid rgba(100,180,255,.5)}.dev-debug-panel__info p{margin:0;font-size:11px;color:#ffffff80;font-family:Fira Code,Monaco,monospace}.dev-debug-panel__info p+p{margin-top:4px}.dev-debug-toggle{position:fixed;bottom:20px;right:20px;padding:10px 16px;background:linear-gradient(135deg,#ffc832e6,#ff9632e6);border:none;border-radius:24px;color:#1a1a2e;font-size:12px;font-weight:600;cursor:pointer;z-index:9999;box-shadow:0 4px 16px #ffc83266;transition:all .2s}.dev-debug-toggle:hover{transform:scale(1.05);box-shadow:0 6px 20px #ffc83280}@media (max-width: 480px){.dev-debug-panel{bottom:10px;right:10px;left:10px;width:auto}.dev-debug-panel__preset-btns{flex-wrap:wrap}.dev-debug-panel__preset-btns button{flex:1 1 45%}}.practice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center}.practice-overlay__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.practice-overlay__container{position:relative;width:95%;max-width:1000px;max-height:90vh;min-height:600px;background:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}.practice-overlay__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);background:#0003;min-height:70px}.practice-overlay__header h2{margin:0;font-size:2.2rem;font-weight:600;color:var(--tyf-yellow-bright, #fcd34d);flex:1;text-align:center}.back-button{background:#3b82f6;border:none;color:#fff;font-size:1.2rem;font-weight:600;cursor:pointer;padding:12px 20px;border-radius:8px;transition:all .15s ease;min-width:100px;text-align:center}.back-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.close-button{background:none;border:none;color:#9ca3af;font-size:1.5rem;cursor:pointer;padding:8px 12px;border-radius:6px;line-height:1;transition:all .15s ease;min-width:44px;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#ffffff1a;color:#f5f7fa}.practice-overlay__content{flex:1;overflow-y:auto;padding:0}.overlay-section{padding:32px}.overlay-section h3{margin:0 0 12px;font-size:1.75rem;font-weight:600;color:#f5f7fa;text-align:center}.centered-section{text-align:center}.header-title-yellow{color:#f39c12!important;text-transform:uppercase}.section-subtitle{margin:0 0 28px;color:#9ca3af;font-size:1rem;text-align:center}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.selection-grid.two-column{grid-template-columns:repeat(2,1fr);gap:20px;max-width:500px;margin:0 auto}.selection-grid.levels-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:600px;margin:0 auto}.selection-card{display:flex;flex-direction:column;align-items:center;padding:28px 20px;background:#3b82f61f;border:2px solid rgba(59,130,246,.3);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center;min-height:150px}.selection-card.level-card{min-height:180px;padding:32px 24px}.selection-card:hover:not(.disabled){background:#3b82f633;border-color:#3b82f699;transform:translateY(-4px);box-shadow:0 10px 25px -5px #3b82f64d}.selection-card.disabled{opacity:.5;cursor:not-allowed}.level-card.coming-soon{opacity:.5;cursor:not-allowed!important;pointer-events:auto;position:relative;overflow:visible}.level-card.coming-soon:hover{transform:none!important;box-shadow:none!important;background:#ffffff0d!important;border-color:#ffffff1a!important}.coming-soon-badge{position:absolute;top:12px;right:12px;display:inline-block;padding:6px 14px;background:linear-gradient(135deg,#fbbf2433,#f59e0b33);border:1.5px solid rgba(251,191,36,.5);border-radius:20px;font-size:.7rem;font-weight:700;color:#fbbf24;text-transform:uppercase;letter-spacing:.8px;box-shadow:0 0 12px #fbbf244d;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 12px #fbbf244d;border-color:#fbbf2480}50%{box-shadow:0 0 20px #fbbf2480;border-color:#fbbf24b3}}@media (max-width: 480px){.coming-soon-badge{top:8px;right:8px;padding:4px 10px;font-size:.65rem}}.card-title{font-size:2rem;font-weight:700;color:gold;margin-bottom:8px}.card-subtitle{font-size:1.2rem;color:#9ca3af}.module-list{display:flex;flex-direction:column;gap:14px;max-width:700px;margin:0 auto}.module-card{display:flex;flex-direction:column;align-items:center;width:100%;padding:18px 24px;background:#e74c3c;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center;color:#fff}.module-card:hover{background:#c0392b;transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c66}.module-number{font-size:1rem;font-weight:700;color:#faea09da;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.module-title{font-size:1.15rem;font-weight:600;color:#fff;margin-bottom:4px}.module-prompts{font-size:.9rem;color:#fffc}.overlay-loading,.overlay-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:#9ca3af}.overlay-loading .loading-spinner,.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.overlay-error p{margin:0 0 16px;color:#f87171}.overlay-error button{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .15s ease}.overlay-error button:hover{background:#2563eb;transform:translateY(-1px)}.ielts-status{display:flex;align-items:center;justify-content:center;gap:20px;margin:16px 0;padding:12px;background:#0003;border-radius:8px}.status-indicator{font-size:.9rem;font-weight:500}.status-indicator.connected{color:#22c55e}.status-indicator.disconnected{color:#ef4444}.ielts-state{color:#9ca3af;font-size:.85rem}.ielts-error{background:#ef444426;border:1px solid rgba(239,68,68,.4);border-radius:8px;padding:16px;margin:16px 0;text-align:center}.ielts-error p{color:#fca5a5;margin:0 0 12px}.ielts-error button{background:#ef444433;border:1px solid rgba(239,68,68,.4);color:#fca5a5;padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .15s ease}.ielts-error button:hover{background:#ef44444d}.cue-card{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:12px;padding:20px;margin:20px 0;text-align:left}.cue-card h4{color:#fbbf24;margin:0 0 12px;font-size:1.1rem}.cue-card ul{margin:0;padding-left:20px;color:#f5f7fa}.cue-card li{margin-bottom:8px;line-height:1.4}.countdown{display:flex;flex-direction:column;align-items:center;margin:24px 0}.countdown-number{font-size:4rem;font-weight:700;color:#3b82f6;line-height:1}.countdown-label{color:#9ca3af;font-size:.9rem;margin-top:8px}.ielts-controls{margin-top:24px}.ielts-instruction{color:#9ca3af;font-size:1rem;text-align:center;padding:16px;background:#ffffff0d;border-radius:8px}.ielts-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s ease}.stop-button{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;color:#fff}.stop-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 8px 20px #ef44444d}.try-again-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;margin-top:16px}.try-again-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px)}.ielts-processing,.ielts-connecting{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px}.ielts-processing p,.ielts-connecting p{color:#9ca3af}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.ielts-results{text-align:center}.ielts-results h4{color:#f5f7fa;margin:0 0 16px}.band-score{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.band-number{font-size:4rem;font-weight:700;color:#3b82f6;line-height:1}.band-label{color:#9ca3af;font-size:.9rem;margin-top:4px}.score-breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.score-item{display:flex;flex-direction:column;gap:8px;padding:12px 16px;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:8px}.score-label{color:#9ca3af;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.score-value{color:#f5f7fa;font-weight:700;font-size:1.1rem}.ielts-start-container{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.ielts-button.start-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:1.25rem;font-weight:600;padding:1rem 2.5rem;border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 14px #3b82f666}.ielts-button.start-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f680}.ielts-button.start-button:active{transform:translateY(0)}@media (max-width: 768px){.selection-grid.two-column{grid-template-columns:1fr;max-width:100%}.score-breakdown{grid-template-columns:1fr}.ielts-status{flex-direction:column;gap:8px}}@media (max-width: 640px){.practice-overlay__container{width:95%;max-height:90vh;min-height:500px}.practice-overlay__header{padding:12px 16px;min-height:60px}.practice-overlay__header h2{font-size:1.1rem}.back-button{min-width:60px;padding:8px 12px;font-size:.85rem}.close-button{padding:6px;font-size:1.1rem}.overlay-section{padding:20px 16px}.overlay-section h3{font-size:1.25rem;margin-bottom:16px}.selection-grid.levels-grid{grid-template-columns:1fr}.centered-section{min-height:300px}.selection-grid,.selection-grid.two-column{grid-template-columns:1fr}.selection-card{min-height:130px;padding:20px 16px}.card-title{font-size:1.1rem}.card-subtitle{font-size:.85rem}.module-card{padding:14px 16px}.module-title{font-size:1rem}.countdown-number,.band-number{font-size:3rem}.ielts-button{padding:12px 20px;font-size:.95rem}}.ielts-recording-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;width:100%}.recording-timer{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px}.recording-indicator{color:#ef4444;font-weight:600;font-size:.875rem;animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.5}}.recording-time{font-size:2rem;font-weight:700;font-variant-numeric:tabular-nums;color:#f1f5f9}.recording-pulse{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#ef4444,#dc2626);display:flex;align-items:center;justify-content:center;animation:pulse 1.5s ease-in-out infinite;box-shadow:0 0 #ef444466}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #ef444466}50%{transform:scale(1.05);box-shadow:0 0 0 15px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.recording-icon{font-size:2rem}.ielts-button.stop-button{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:1.125rem;font-weight:600;padding:.875rem 2rem;border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 14px #ef444466}.ielts-button.stop-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ef444480}.ielts-button.stop-button:active{transform:translateY(0)}.selection-grid.three-column{grid-template-columns:repeat(3,1fr);gap:16px;max-width:700px;margin:0 auto}.ielts-part-card{display:flex;flex-direction:column;align-items:center;padding:24px 16px;min-height:160px;position:relative}.ielts-part-card.active{background:#2ecc711f;border-color:#2ecc7166}.ielts-part-card.active:hover{background:#2ecc7133;border-color:#2ecc71b3;transform:translateY(-4px);box-shadow:0 10px 25px -5px #2ecc714d}.ielts-part-card.disabled{opacity:.5;cursor:not-allowed;background:#7f8c8d14;border-color:#7f8c8d33;pointer-events:none}.part-number{font-size:.8rem;font-weight:700;color:#ffffff80;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}.ielts-part-card .card-title{font-size:1.4rem;font-weight:700;color:gold;margin-bottom:4px;text-align:center}.ielts-part-card .card-subtitle{font-size:.9rem;color:#9ca3af;margin-bottom:12px}.coming-soon-badge{display:inline-block;padding:4px 10px;background:#e74c3c26;border:1px solid rgba(231,76,60,.3);border-radius:20px;font-size:.7rem;font-weight:600;color:#e74c3c;text-transform:uppercase;letter-spacing:.5px}.available-badge{display:inline-block;padding:4px 10px;background:#2ecc7126;border:1px solid rgba(46,204,113,.3);border-radius:20px;font-size:.7rem;font-weight:600;color:#2ecc71;text-transform:uppercase;letter-spacing:.5px}.debug-toggle-container{margin-top:32px;padding-top:20px;border-top:1px dashed rgba(155,89,182,.3)}.debug-toggle-btn{background:#9b59b626;border:1px solid rgba(155,89,182,.3);color:#9b59b6;padding:8px 16px;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .15s ease}.debug-toggle-btn:hover{background:#9b59b640;border-color:#9b59b680}@media (max-width: 640px){.selection-grid.three-column{grid-template-columns:1fr;gap:12px}.ielts-part-card{padding:20px 16px;min-height:120px}.ielts-part-card .card-title{font-size:1.2rem}}.ielts-orb-wrapper{display:flex;align-items:center;justify-content:center;margin:1rem 0}.ielts-orb-wrapper .audio-visualizer-orb{width:120px;height:120px}.ielts-orb-wrapper .orb-icon svg{width:40px;height:40px}.ielts-orb-wrapper .orb-state-label{display:none}.ielts-end-practice-btn{background:transparent;border:1px solid rgba(156,163,175,.4);color:#9ca3af;padding:8px 16px;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .15s ease;margin-top:1rem}.ielts-end-practice-btn:hover{background:#9ca3af26;border-color:#9ca3af99;color:#d1d5db}.selection-grid.centered-single-column{display:flex;justify-content:center;max-width:400px;margin:0 auto}.selection-grid.centered-single-column .selection-card{width:100%;padding:32px 24px}.selection-card.large-card .card-title{font-size:2.4rem}.selection-card.large-card .card-subtitle{font-size:1.4rem}.tutor-orb-practice-overlay{position:fixed;bottom:100px;right:24px;z-index:10001;pointer-events:auto;cursor:pointer;animation:tutorOrbFadeIn .5s ease-out}@media (max-width: 480px){.tutor-orb-practice-overlay{bottom:80px;right:12px;transform:scale(.5)}}.tutor-orb-practice-overlay.tutor-connecting{opacity:.6;animation:tutorConnecting 1.5s ease-in-out infinite}@keyframes tutorConnecting{0%,to{opacity:.6}50%{opacity:.9}}.tutor-orb-practice-overlay.tutor-connected{opacity:1}@media (max-width: 480px){.practice-overlay .tutor-orb-help-text{font-size:1.5rem!important;font-weight:600;color:#22d3ee;text-shadow:0 0 8px rgba(34,211,238,.6);margin-top:8px;text-align:center}}@media (max-width: 375px){.practice-overlay .tutor-orb-help-text{font-size:.9rem!important}}.practice-vp-hud{display:flex;align-items:center;gap:6px;background:#0006;border:1px solid rgba(251,191,36,.4);border-radius:16px;padding:4px 12px;margin-right:8px}.practice-vp-hud .vp-icon{font-size:.9rem}.practice-vp-hud .vp-value{color:#fbbf24;font-weight:700;font-size:.95rem;font-variant-numeric:tabular-nums}@media (max-width: 640px){.practice-vp-hud{padding:3px 8px;gap:4px}.practice-vp-hud .vp-icon{font-size:.8rem}.practice-vp-hud .vp-value{font-size:.85rem}}.profile-picture-upload{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px;border:2px dashed var(--border-color, #444);border-radius:12px;background-color:var(--surface-color, #1a1a1a);max-width:400px;margin:0 auto;transition:border-color .2s ease}.profile-picture-upload:hover{border-color:var(--primary-color, #4A90E2)}.profile-preview-container{position:relative;display:inline-block}.profile-preview-image{width:180px;height:180px;border-radius:50%;overflow:hidden;border:3px solid var(--primary-color, #4A90E2);box-shadow:0 4px 12px #4a90e24d}.profile-preview-image img{width:100%;height:100%;object-fit:cover}.profile-clear-btn{position:absolute;top:0;right:0;width:28px;height:28px;border-radius:50%;border:none;background:var(--error-color, #E53935);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease}.profile-clear-btn:hover{transform:scale(1.1);background:#c62828}.profile-upload-instructions{text-align:center;color:var(--secondary-text-color, #aaa)}.profile-upload-icon{font-size:48px;margin-bottom:8px}.profile-upload-title{margin:0 0 4px;font-size:1rem;font-weight:600;color:var(--text-color, #fff)}.profile-upload-subtitle{margin:0;font-size:.85rem;color:var(--secondary-text-color, #888)}.profile-file-input{display:none}.profile-upload-btn{padding:12px 28px;border-radius:8px;border:none;background:var(--primary-color, #4A90E2);color:#fff;font-weight:600;cursor:pointer;font-size:1rem;min-width:160px;transition:background .2s ease,transform .1s ease}.profile-upload-btn:hover:not(:disabled){background:var(--primary-hover, #357ABD);transform:translateY(-1px)}.profile-upload-btn:disabled{background:var(--disabled-color, #555);cursor:not-allowed}.profile-upload-btn.uploading{background:var(--processing-color, #666);cursor:wait}.profile-upload-progress{width:100%;max-width:200px;height:8px;background:var(--track-color, #333);border-radius:4px;overflow:hidden;position:relative}.profile-upload-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-color, #4A90E2),var(--success-color, #43A047));border-radius:4px;transition:width .3s ease}.profile-upload-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.7rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.profile-upload-error{padding:12px 16px;border-radius:8px;background:#e5393526;color:var(--error-color, #E53935);font-size:.9rem;text-align:center;width:100%;border:1px solid rgba(229,57,53,.3)}@media (max-width: 480px){.profile-picture-upload{padding:16px;max-width:100%}.profile-preview-image{width:140px;height:140px}.profile-upload-btn{width:100%;padding:14px 20px}}.drama-breakthrough-snapshot{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 24px;max-width:600px;margin:0 auto;background:linear-gradient(180deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006}.snapshot-header{text-align:center}.snapshot-title{margin:0 0 8px;font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,gold,orange);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.snapshot-subtitle{margin:0;font-size:1rem;color:#8892b0}.snapshot-video-container{position:relative;width:100%;max-width:340px;aspect-ratio:9 / 16;margin:0 auto;background:#0a0a0a;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000080}.snapshot-video{width:100%;height:100%;object-fit:contain;background:#000}.snapshot-play-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0006;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.snapshot-play-overlay:hover{background:#00000080}.snapshot-play-icon{font-size:64px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5));transition:transform .2s ease}.snapshot-play-overlay:hover .snapshot-play-icon{transform:scale(1.1)}.snapshot-loading{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#0a0a0a;color:#8892b0}.snapshot-spinner{width:48px;height:48px;border:4px solid rgba(255,215,0,.2);border-top-color:gold;border-radius:50%;animation:snapshot-spin 1s linear infinite}@keyframes snapshot-spin{to{transform:rotate(360deg)}}.snapshot-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#0a0a0a;color:#e53935;text-align:center;padding:20px}.snapshot-error-icon{font-size:48px}.snapshot-retry-btn{margin-top:8px;padding:8px 24px;border-radius:6px;border:1px solid #4A90E2;background:transparent;color:#4a90e2;cursor:pointer;transition:all .2s ease}.snapshot-retry-btn:hover{background:#4a90e2;color:#fff}.snapshot-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;width:100%}.snapshot-btn{padding:12px 24px;border-radius:8px;border:none;font-weight:600;font-size:1rem;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;min-width:140px;justify-content:center}.snapshot-btn:disabled{opacity:.5;cursor:not-allowed}.snapshot-btn-download{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff}.snapshot-btn-download:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #4a90e266}.snapshot-btn-share{background:linear-gradient(135deg,#e53935,#c62828);color:#fff}.snapshot-btn-share:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #e5393566}.snapshot-btn-continue{background:linear-gradient(135deg,gold,orange);color:#1a1a2e}.snapshot-btn-continue:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ffd70066}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:snapshot-spin .8s linear infinite}.snapshot-download-error{padding:12px 20px;border-radius:8px;background:#e5393526;color:#e53935;font-size:.9rem;text-align:center;border:1px solid rgba(229,57,53,.3)}.snapshot-celebration{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#ffd70033,#ffa50033);border:1px solid rgba(255,215,0,.3);border-radius:100px;animation:celebration-pulse 2s ease-in-out infinite}.celebration-emoji{font-size:24px}.celebration-text{font-weight:600;color:gold;font-size:1rem}@keyframes celebration-pulse{0%,to{transform:scale(1);box-shadow:0 0 #ffd7004d}50%{transform:scale(1.02);box-shadow:0 0 20px 5px #ffd70033}}@media (max-width: 480px){.drama-breakthrough-snapshot{padding:20px 16px;gap:20px}.snapshot-title{font-size:1.5rem}.snapshot-actions{flex-direction:column;gap:10px}.snapshot-btn{width:100%;padding:14px 20px}.snapshot-play-icon{font-size:48px}}.micro-drama-complete{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#0d1117,#1a1a2e,#16213e);color:#e6e6e6}.mdc-congrats{display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px;max-width:500px;animation:mdc-fade-in .5s ease-out}@keyframes mdc-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mdc-congrats-emoji{font-size:72px;animation:mdc-bounce 1s ease-in-out}@keyframes mdc-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.mdc-title{margin:0;font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,gold,orange,tomato);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mdc-story-info{margin:0;font-size:1.1rem;color:#8892b0}.mdc-stats{display:flex;gap:32px;margin:16px 0}.mdc-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.mdc-stat-value{font-size:2rem;font-weight:700;color:#4a90e2}.mdc-stat-label{font-size:.85rem;color:#8892b0;text-transform:uppercase;letter-spacing:.5px}.mdc-snapshot-promo{padding:20px 24px;background:linear-gradient(135deg,#4a90e226,#ffd7001a);border:1px solid rgba(74,144,226,.3);border-radius:12px;text-align:center;margin:8px 0}.mdc-promo-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,gold,orange);color:#1a1a2e;font-size:.75rem;font-weight:700;border-radius:100px;margin-bottom:8px}.mdc-snapshot-promo h3{margin:0 0 8px;font-size:1.2rem;color:#fff}.mdc-snapshot-promo p{margin:0;font-size:.9rem;color:#aaa;line-height:1.5}.mdc-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:300px}.mdc-quota-notice{background:#ff980026;border:1px solid rgba(255,152,0,.4);border-radius:8px;padding:12px 16px;text-align:center;width:100%}.mdc-quota-icon{font-size:1.5rem}.mdc-quota-notice p{margin:4px 0;font-size:.9rem;color:#ffb74d}.mdc-quota-detail{font-size:.8rem!important;opacity:.8}.mdc-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.mdc-btn{padding:14px 28px;border-radius:8px;border:none;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.mdc-btn-primary{background:linear-gradient(135deg,#e53935,#c62828);color:#fff}.mdc-btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #e5393566}.mdc-btn-secondary{background:transparent;border:1px solid #555;color:#aaa}.mdc-btn-secondary:hover{border-color:#777;color:#fff}.mdc-exit-btn{margin-top:16px;padding:8px 16px;background:transparent;border:none;color:#666;font-size:.9rem;cursor:pointer;transition:color .2s ease}.mdc-exit-btn:hover{color:#999}.mdc-upload{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:450px;width:100%;animation:mdc-fade-in .3s ease-out}.mdc-back-btn{align-self:flex-start;padding:8px 16px;background:transparent;border:none;color:#888;font-size:.9rem;cursor:pointer;transition:color .2s ease}.mdc-back-btn:hover{color:#fff}.mdc-upload-title{margin:0;font-size:1.5rem;color:#fff}.mdc-upload-desc{margin:0;font-size:.95rem;color:#aaa;text-align:center;line-height:1.5}.mdc-privacy-note{margin:16px 0 0;font-size:.8rem;color:#666;text-align:center}.mdc-generating{display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center;max-width:400px}.mdc-generating-animation{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center}.mdc-film-reel{font-size:64px;animation:mdc-spin-slow 3s linear infinite}@keyframes mdc-spin-slow{to{transform:rotate(360deg)}}.mdc-sparkles{position:absolute;font-size:32px;animation:mdc-pulse 1.5s ease-in-out infinite}@keyframes mdc-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.mdc-generating-title{margin:0;font-size:1.5rem;color:#fff}.mdc-generating-desc{margin:0;font-size:.95rem;color:#aaa;line-height:1.5}.mdc-progress-container{width:100%;max-width:280px}.mdc-progress-bar{height:8px;background:#333;border-radius:4px;overflow:hidden;margin-bottom:8px}.mdc-progress-fill{height:100%;background:linear-gradient(90deg,#4a90e2,#43a047,gold);border-radius:4px;transition:width .5s ease}.mdc-progress-text{font-size:.9rem;color:#888}.mdc-task-id{margin:0;font-size:.75rem;color:#555;font-family:monospace}.mdc-error{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;max-width:400px;animation:mdc-fade-in .3s ease-out}.mdc-error-icon{font-size:64px}.mdc-error-title{margin:0;font-size:1.5rem;color:#e53935}.mdc-error-message{margin:0;font-size:.95rem;color:#aaa;padding:12px 20px;background:#e539351a;border-radius:8px;border:1px solid rgba(229,57,53,.2)}.mdc-error-actions{display:flex;gap:12px;margin-top:8px}@media (max-width: 480px){.micro-drama-complete{padding:16px}.mdc-title{font-size:2rem}.mdc-congrats-emoji{font-size:56px}.mdc-stats{gap:24px}.mdc-stat-value{font-size:1.75rem}.mdc-snapshot-promo{padding:16px 20px}.mdc-actions{max-width:100%}.mdc-btn{padding:16px 24px}.mdc-error-actions{flex-direction:column;width:100%}}.md-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center}.md-overlay__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.md-overlay__container{position:relative;width:90%;max-width:800px;max-height:90vh;background:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}.md-overlay__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1);background:#0003}.md-overlay__header h2{margin:0;font-size:2.2rem;font-weight:600;color:#fcd34d;flex:1;text-align:match-parent}.md-back-button{background:linear-gradient(135deg,#4da9ff,#007cc3);border:none;color:#fcd34d;font-size:1rem;font-weight:600;cursor:pointer;padding:10px 20px;border-radius:50px;transition:all .15s ease;box-shadow:0 2px 8px #4da9ff4d}.md-back-button:hover{background:linear-gradient(135deg,#5bb3ff,#0088d9);transform:translateY(-1px);box-shadow:0 4px 12px #4da9ff66}.md-close-button{background:none;border:none;color:#9ca3af;font-size:1.25rem;cursor:pointer;padding:8px;border-radius:6px;line-height:1;transition:all .15s ease}.md-close-button:hover{background:#ffffff1a;color:#f5f7fa}.md-overlay__content{flex:1;overflow-y:auto;padding:24px}.md-language-section{text-align:center}.md-language-section h3{margin:0 0 8px;font-size:1.5rem;font-weight:600;color:#f5f7fa;text-align:center}.md-select-language-header{font-size:1.8rem;font-weight:700;color:gold;margin:0 0 8px;text-align:center}.md-select-language-subtitle{font-size:.95rem;color:#9ca3af;margin:0 0 24px;text-align:center}.md-language-grid{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.md-language-card{display:flex;flex-direction:column;align-items:center;padding:20px 40px;background:#3b82f626;border:2px solid rgba(59,130,246,.4);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center;min-width:200px}.md-language-card:hover{background:#3b82f640;border-color:#3b82f699;transform:translateY(-2px)}.md-language-card__title{font-size:1.5rem;font-weight:700;color:gold;margin-bottom:4px}.md-language-card__subtitle{font-size:1rem;color:#9ca3af}.md-modules-section{text-align:center}.md-modules-section h3{margin:0 0 8px;font-size:1.2rem;font-weight:600;color:#f5f7fa;text-align:center}.md-section-subtitle{margin:0 0 24px;color:#9ca3af;font-size:.9rem;text-align:center}.md-modules-grid{display:flex;flex-direction:column;align-items:center;max-width:500px;margin:0 auto;gap:12px}.md-module-card{width:100%;padding:16px 24px;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:12px;box-shadow:0 4px 12px #ef44444d;cursor:pointer;transition:all .2s ease;text-align:center}.md-module-card:hover{background:linear-gradient(135deg,#f87171,#ef4444);box-shadow:0 6px 16px #ef444466;transform:translateY(-2px)}.md-module-card__number{font-size:.9rem;font-weight:600;color:#f3ef06cc;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.md-module-card__title{font-size:.9rem;font-weight:700;color:#fff;margin-bottom:4px}.md-module-card__scenes{font-size:.85rem;color:#ffffffb3}.md-levels-section{text-align:center}.md-levels-section h3{margin:0 0 24px;font-size:1.5rem;font-weight:600;color:#f5f7fa;text-align:center}.md-levels-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:500px;margin:0 auto}.md-level-card{display:flex;flex-direction:column;align-items:center;padding:32px 24px;background:#3b82f61f;border:2px solid rgba(59,130,246,.3);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center;min-height:140px}.md-level-card:hover{background:#3b82f633;border-color:#3b82f699;transform:translateY(-4px);box-shadow:0 10px 25px -5px #3b82f64d}.md-level-card__title{font-size:1.5rem;font-weight:700;color:gold;margin-bottom:8px}.md-level-card__subtitle{font-size:1rem;color:#9ca3af}.md-stories-section{text-align:center}.md-stories-section h3{margin:0 0 24px;font-size:1.5rem;font-weight:600;color:#f5f7fa;text-align:center}.md-stories-grid{display:flex;flex-direction:column;gap:16px;max-width:500px;margin:0 auto}.md-story-card{display:flex;flex-direction:column;align-items:center;padding:24px;background:#3b82f61f;border:2px solid rgba(59,130,246,.3);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center}.md-story-card:hover{background:#3b82f633;border-color:#3b82f699;transform:translateY(-4px);box-shadow:0 10px 25px -5px #3b82f64d}.md-story-card__title{font-size:1.4rem;font-weight:700;color:gold;margin-bottom:4px}.md-story-card__subtitle{font-size:.95rem;color:#9ca3af;margin-bottom:8px}.md-story-card__count{font-size:.85rem;color:#60a5fa;font-weight:500}.md-language-card--disabled{opacity:.5;cursor:not-allowed;background:#6464641a;border-color:#6464644d}.md-language-card--disabled:hover{transform:none;box-shadow:none;background:#6464641a;border-color:#6464644d}.md-session{display:flex;flex-direction:column;gap:20px}.md-session__header{text-align:center;margin-bottom:8px}.md-session__header h3{margin:0 0 4px;font-size:1.25rem;font-weight:600;color:#f5f7fa}.md-session__progress{color:#a78bfa;font-size:.9rem;margin:0}.md-step-label{font-size:1.2rem;color:#fcd34d;font-weight:600;margin:0 0 12px}.md-video-container{background:#000;border-radius:12px;padding:0;overflow:hidden}.md-video{width:100%;max-height:300px;border-radius:8px;background:#000;display:block}.md-recording-container{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px}.md-target-text-box{background:#0003;border-radius:8px;padding:16px;margin-bottom:16px}.md-target-sentence{margin:0 0 8px;font-size:1rem;color:#f5f7fa;line-height:1.6}.md-target-sentence:last-child{margin-bottom:0}.md-recording-controls{display:flex;flex-direction:row;gap:12px;margin:0;width:100%}.md-recording-controls .tyf-btn-record,.md-recording-controls .tyf-btn-stop{flex:1;max-width:200px}.md-user-audio{margin-top:12px}.md-analyzing-indicator{text-align:center;padding:16px;color:#a78bfa;font-size:.95rem;animation:md-pulse 1.5s infinite}@keyframes md-pulse{0%,to{opacity:1}50%{opacity:.5}}.md-feedback-container{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px}.md-feedback-card{background:#0003;border-radius:8px;padding:16px}.md-feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.md-feedback-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af}.md-feedback-score{background:#ef4444;color:#fff;padding:4px 12px;border-radius:20px;font-size:.9rem;font-weight:600}.md-feedback-text{font-size:1.1rem;color:#f5f7fa;margin:0 0 12px;line-height:1.5}.md-feedback-tip{font-style:italic;color:#fbbf24;font-size:.9rem;margin:12px 0}.md-feedback-recognized{font-size:.85rem;color:#9ca3af;margin:0}.md-recognized-label{font-weight:600}.md-session-navigation{display:flex;flex-direction:column;align-items:center;gap:12px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.md-nav-row{display:flex;gap:12px;width:100%}.md-nav-btn{flex:1;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#9ca3af}.md-nav-btn:hover:not(:disabled){background:#ffffff26;color:#f5f7fa}.md-nav-btn:disabled{opacity:.5;cursor:not-allowed}.md-nav-btn--primary{background:#ef4444;border-color:#ef4444;color:#fff}.md-nav-btn--primary:hover:not(:disabled){background:#dc2626}.md-back-to-modules-btn{padding:8px 20px;background:#3b82f633;border:1px solid rgba(59,130,246,.4);border-radius:8px;color:#60a5fa;font-size:.9rem;cursor:pointer;transition:all .2s ease}.md-back-to-modules-btn:hover{background:#3b82f64d}.md-save-hint{color:#ef4444;font-size:1.2rem;font-weight:600;margin:0}.md-loading,.md-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:#9ca3af}.md-error button{margin-top:16px;padding:8px 24px;background:#a855f733;border:1px solid rgba(168,85,247,.5);border-radius:8px;color:#a855f7;cursor:pointer}@media (max-width: 640px){.md-overlay__container{width:95%;max-height:95vh}.md-overlay__header{margin-top:30px;padding:12px 16px}.md-overlay__header h2{font-size:1.1rem}.md-back-button{padding:8px 14px;font-size:.85rem}.md-language-grid{flex-direction:column}.md-levels-grid{grid-template-columns:1fr}.md-level-card{min-height:100px;padding:24px 20px}.md-level-card__title{font-size:1.25rem}.md-recording-controls{flex-direction:column}.md-recording-controls .tyf-btn-record,.md-recording-controls .tyf-btn-stop{max-width:none}.md-nav-row{flex-direction:column}}.tutor-orb-drama-overlay{position:fixed;bottom:100px;right:24px;z-index:10001;pointer-events:auto;cursor:pointer;animation:tutorOrbFadeInDrama .5s ease-out}@keyframes tutorOrbFadeInDrama{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.tutor-orb-drama-overlay{bottom:80px;right:12px;transform:scale(.5)}}.tutor-orb-drama-overlay.tutor-connecting{opacity:.6;animation:tutorConnectingDrama 1.5s ease-in-out infinite}@keyframes tutorConnectingDrama{0%,to{opacity:.6}50%{opacity:.9}}.tutor-orb-drama-overlay.tutor-connected{opacity:1}@media (max-width: 480px){.md-overlay .tutor-orb-help-text{font-size:1.5rem!important;font-weight:600;color:#60a5fa;text-shadow:0 0 8px rgba(96,165,250,.6);margin-top:8px;text-align:center}}@media (max-width: 375px){.md-overlay .tutor-orb-help-text{font-size:.9rem!important}}.pb-orb{position:relative;width:100%;aspect-ratio:1 / 1;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;overflow:visible;box-sizing:border-box;border:none;background:transparent;background-color:transparent!important;transition:transform .2s cubic-bezier(.34,1.56,.64,1),filter .2s ease}.pb-orb__texture{position:absolute;top:2px;right:2px;bottom:2px;left:2px;width:calc(100% - 4px);height:calc(100% - 4px);object-fit:contain;z-index:0;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));transition:filter .2s ease}.pb-orb:hover:not(.pb-orb--disabled) .pb-orb__texture{filter:drop-shadow(0 4px 8px rgba(0,0,0,.5)) brightness(1.1)}.pb-orb--selected .pb-orb__texture{filter:drop-shadow(0 0 12px rgba(255,215,0,.8)) drop-shadow(0 0 24px rgba(255,215,0,.4)) brightness(1.15)}.pb-orb--vowel,.pb-orb--plosive,.pb-orb--fricative,.pb-orb--nasal,.pb-orb--approximant{background:transparent!important}.pb-orb:hover:not(.pb-orb--disabled){transform:scale(1.08);filter:drop-shadow(0 4px 8px rgba(0,0,0,.4)) drop-shadow(0 0 12px rgba(251,191,36,.3))}.pb-orb--idle{opacity:1}.pb-orb--selected{transform:scale(1.12);z-index:10;filter:drop-shadow(0 0 12px rgba(251,191,36,.8)) drop-shadow(0 0 24px rgba(251,191,36,.5));animation:pb-orb-pulse-glow 1.5s ease-in-out infinite}.pb-orb--matched{animation:pb-orb-matched .5s ease-out forwards;pointer-events:none}.pb-orb--dropping{animation:pb-orb-drop .4s cubic-bezier(.5,0,.75,0) forwards}.pb-orb--removed{opacity:0;pointer-events:none;transform:scale(0)}.pb-orb--disabled{opacity:.5;cursor:not-allowed;filter:grayscale(50%)}.pb-orb--disabled:hover{transform:none;filter:grayscale(50%)}.pb-orb__phoneme{font-size:clamp(1.35rem,5.25vw,1.95rem);font-weight:700;color:#fff;text-shadow:0 0 8px rgba(0,0,0,.9),2px 2px 4px rgba(0,0,0,.8),-1px -1px 2px rgba(0,0,0,.6),0 0 16px rgba(0,0,0,.4);z-index:2;pointer-events:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-text-stroke:.5px rgba(0,0,0,.3)}.pb-orb__shine{position:absolute;top:10%;left:15%;right:15%;height:30%;background:linear-gradient(180deg,#fff6,#fff0);border-radius:50%;pointer-events:none;z-index:1}.pb-orb__glow{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;background:radial-gradient(circle,rgba(251,191,36,.3) 0%,rgba(251,191,36,.1) 50%,transparent 70%);pointer-events:none;z-index:0;animation:pb-orb-glow-pulse 1.5s ease-in-out infinite}.pb-orb__ripple{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.6) 0%,rgba(255,255,255,.3) 40%,transparent 70%);pointer-events:none;animation:pb-orb-ripple-expand .6s ease-out}@keyframes pb-orb-pulse-glow{0%,to{box-shadow:0 0 24px #fbbf24cc,0 0 48px #fbbf2480,0 6px 20px #0009}50%{box-shadow:0 0 32px #fbbf24,0 0 64px #fbbf24b3,0 6px 20px #0009}}@keyframes pb-orb-glow-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@keyframes pb-orb-ripple-expand{0%{transform:scale(0);opacity:1}to{transform:scale(2);opacity:0}}@keyframes pb-orb-matched{0%{transform:scale(1);opacity:1}30%{transform:scale(1.3);opacity:1}to{transform:scale(.5);opacity:0}}@keyframes pb-orb-drop{0%{transform:translateY(-100%) scale(.9);opacity:.7}to{transform:translateY(0) scale(1);opacity:1}}.pb-orb:focus-visible{outline:3px solid #fbbf24;outline-offset:4px}@media (prefers-reduced-motion: reduce){.pb-orb,.pb-orb__glow,.pb-orb__ripple{animation:none!important;transition:none!important}.pb-orb--selected{animation:none}}@media (max-width: 768px){.pb-orb{min-width:44px;min-height:44px}.pb-orb__phoneme{font-size:clamp(.8rem,3vw,1.1rem)}}@media (max-width: 480px){.pb-orb{border-width:2px}.pb-orb__phoneme{font-size:clamp(.7rem,2.5vw,.95rem)}.pb-orb--selected{box-shadow:0 0 16px #fbbf24b3,0 0 32px #fbbf2466,0 4px 16px #00000080}}.pb-orb,.pb-orb__glow,.pb-orb__ripple{will-change:transform;transform:translateZ(0);backface-visibility:hidden}.pb-orb:not(:hover):not(.pb-orb--selected){will-change:auto}@keyframes pb-orb-drop-in{0%{transform:translateY(-100px) scale(.5);opacity:0}60%{transform:translateY(10px) scale(1.1);opacity:1}80%{transform:translateY(-5px) scale(.95)}to{transform:translateY(0) scale(1)}}@keyframes pb-orb-match-glow{0%{box-shadow:0 0 #fffc}50%{box-shadow:0 0 20px 10px #fff6}to{box-shadow:0 0 #fff0}}@keyframes pb-orb-selected-pulse{0%,to{transform:scale(1.12);filter:brightness(1)}50%{transform:scale(1.18);filter:brightness(1.2)}}.pb-orb--new{animation:pb-orb-drop-in .4s cubic-bezier(.34,1.56,.64,1) forwards}.pb-orb--match-highlight{animation:pb-orb-match-glow .3s ease-out}.pb-orb--selected-active{animation:pb-orb-selected-pulse .6s ease-in-out infinite;z-index:10}.pb-orb--combo-2x{filter:saturate(1.3) brightness(1.1)}.pb-orb--combo-3x{filter:saturate(1.5) brightness(1.2);box-shadow:0 0 15px currentColor}.pb-orb--combo-4x{filter:saturate(1.8) brightness(1.3);box-shadow:0 0 20px currentColor,0 0 30px #ffd70080}.pb-orb-icon-wrapper{width:90%;height:90%;z-index:1;position:absolute;top:5%;right:5%;bottom:5%;left:5%;display:flex;align-items:center;justify-content:center}.pb-orb-text{position:absolute;z-index:2;color:#fff;font-weight:700;font-size:1.2rem;text-shadow:0 2px 4px rgba(0,0,0,.8);pointer-events:none}.pb-orb-glow{position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border-radius:50%;border:2px solid #FFD700;box-shadow:0 0 15px gold,inset 0 0 10px gold;animation:lunarEchoGlow 1.5s infinite alternate;z-index:0;pointer-events:none}@keyframes lunarEchoGlow{0%{opacity:.6;transform:scale(1)}to{opacity:1;transform:scale(1.05)}}.pb-block{position:relative;width:100%;height:100%;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;overflow:hidden;border:3px solid rgba(255,255,255,.3);box-shadow:0 4px 16px #0006,inset 0 2px 8px #fff3,inset 0 -2px 8px #0006;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease,border-color .3s ease}.pb-block:hover:not(.pb-block--disabled):not(.pb-block--shattered){transform:scale(1.05)}.pb-block:active:not(.pb-block--disabled):not(.pb-block--shattered){transform:scale(.98)}.pb-block--limestone{background:linear-gradient(135deg,#cbd5e1,#94a3b8,#64748b);border-color:#47556999;color:#1e293b}.pb-block--limestone:hover:not(.pb-block--disabled){box-shadow:0 6px 20px #64748b80,inset 0 2px 8px #ffffff4d}.pb-block--gold{background:linear-gradient(135deg,#fde047,#ca8a04,#a16207);border-color:#854d0e99;color:#422006}.pb-block--gold:hover:not(.pb-block--disabled){box-shadow:0 6px 20px #ca8a0480,0 0 16px #fde0474d,inset 0 2px 8px #ffffff4d}.pb-block--ruby{background:linear-gradient(135deg,#fca5a5,#b91c1c,#7f1d1d);border-color:#7f1d1d99;color:#fef2f2}.pb-block--ruby:hover:not(.pb-block--disabled){box-shadow:0 6px 20px #b91c1c80,0 0 16px #fca5a54d,inset 0 2px 8px #ffffff4d}.pb-block--diamond{background:linear-gradient(135deg,#e0f2fe,#bae6fd 30%,#7dd3fc 70%,#38bdf8);border-color:#0284c799;color:#0c4a6e}.pb-block--diamond:hover:not(.pb-block--disabled){box-shadow:0 6px 20px #38bdf880,0 0 24px #bae6fd66,inset 0 2px 8px #ffffff80}.pb-block--locked{opacity:1;animation:pb-block-idle 2.5s ease-in-out infinite}@keyframes pb-block-idle{0%,to{transform:scale(1)}50%{transform:scale(1.015)}}.pb-block--charging{border-color:#fbbf24!important;animation:pb-block-charging .8s ease-in-out infinite}@keyframes pb-block-charging{0%,to{box-shadow:0 0 20px #fbbf2499,0 0 40px #fbbf244d,inset 0 0 15px #fbbf2433;transform:scale(1)}50%{box-shadow:0 0 30px #fbbf24cc,0 0 60px #fbbf2480,inset 0 0 20px #fbbf244d;transform:scale(1.03)}}.pb-block--processing{opacity:.85;pointer-events:none;border-color:#fbbf24!important}.pb-block--processing:before{content:"";position:absolute;top:50%;left:50%;width:28px;height:28px;margin:-14px 0 0 -14px;border:3px solid transparent;border-top-color:#fbbf24;border-right-color:#fbbf24;border-radius:50%;animation:pb-processing-spinner .8s linear infinite;z-index:10}@keyframes pb-processing-spinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pb-block--processing .pb-block__content{opacity:.5}.pb-block--cracked{border-color:#ef4444!important;animation:pb-block-shake .5s ease-out}@keyframes pb-block-shake{0%,to{transform:translate(0) rotate(0)}20%{transform:translate(-4px) rotate(-1deg)}40%{transform:translate(4px) rotate(1deg)}60%{transform:translate(-3px) rotate(-.5deg)}80%{transform:translate(3px) rotate(.5deg)}}.pb-block--shattered{animation:pb-block-shatter .5s ease-out forwards;pointer-events:none}@keyframes pb-block-shatter{0%{transform:scale(1);opacity:1}30%{transform:scale(1.15);opacity:.9}to{transform:scale(.6);opacity:0}}.pb-block--selected{outline:3px solid #fcd34d;outline-offset:2px;transform:scale(1.05);z-index:10}.pb-block--disabled{opacity:.5;cursor:not-allowed;filter:grayscale(40%)}.pb-block--disabled:hover{transform:none}.pb-block--retried{border-left:3px solid rgba(255,165,0,.5)}.pb-block__texture{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.1) 50%,transparent 60%),linear-gradient(-45deg,transparent 40%,rgba(0,0,0,.1) 50%,transparent 60%);background-size:200% 200%;pointer-events:none;border-radius:inherit}.pb-block__magma{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:12px;background:radial-gradient(circle,rgba(251,191,36,.4) 0%,rgba(245,158,11,.2) 50%,transparent 70%);opacity:0;pointer-events:none;transition:opacity .3s ease}.pb-block--charging .pb-block__magma{opacity:.8;animation:pb-magma-pulse 1.2s ease-in-out infinite}@keyframes pb-magma-pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:1}}.pb-block__cracks{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cpath d='M50 0 L45 30 L20 35 L40 50 L25 70 L50 60 L55 100' stroke='%23333' stroke-width='2' fill='none' opacity='0.6'/%3E%3Cpath d='M50 0 L55 25 L75 30 L60 45 L80 65 L55 55 L45 100' stroke='%23333' stroke-width='1.5' fill='none' opacity='0.4'/%3E%3C/svg%3E");background-size:cover;opacity:0;pointer-events:none;border-radius:inherit;transition:opacity .3s ease}.pb-block--cracked .pb-block__cracks{opacity:.7}.pb-block__content{z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-align:center;padding:4px}.pb-block__icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.pb-block__status-emoji{font-size:1.25rem;line-height:1}.pb-block__mineral-svg{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.pb-block__word{font-weight:800;font-size:clamp(1.05rem,3.75vw,1.425rem);text-transform:capitalize;text-shadow:0 1px 2px rgba(0,0,0,.4);letter-spacing:.5px;display:flex;flex-direction:column;align-items:center;gap:0;line-height:1.1}.pb-block__word[style*="0.9em"]{letter-spacing:.3px}.pb-block__word[style*="0.8em"]{letter-spacing:.2px}.pb-block__word[style*="0.7em"]{letter-spacing:.1px;line-height:1.05}.pb-block__romanized{font-size:.55rem;opacity:.85;font-style:italic}.pb-block__badge{position:absolute;top:3px;right:3px;font-size:.45rem;font-weight:700;padding:2px 4px;border-radius:4px;background:#00000080;color:#fff;box-shadow:0 1px 3px #0000004d;z-index:6}.pb-block__instruction{position:absolute;bottom:-22px;left:50%;transform:translate(-50%);font-size:.55rem;font-weight:600;white-space:nowrap;opacity:0;transition:opacity .2s ease;text-shadow:0 1px 2px rgba(0,0,0,.5);color:#fcd34d}.pb-block:hover .pb-block__instruction,.pb-block:focus .pb-block__instruction{opacity:1}.pb-block__attempts{position:absolute;bottom:3px;left:3px;display:flex;gap:2px;z-index:6}.pb-block__drill-mark{font-size:.5rem;color:#fbbf24;text-shadow:0 1px 2px rgba(0,0,0,.5)}.pb-block:focus-visible{outline:3px solid #fbbf24;outline-offset:4px}@media (prefers-reduced-motion: reduce){.pb-block,.pb-block__magma,.pb-block__texture{animation:none!important;transition:none!important}}@media (max-width: 480px){.pb-block{border-width:2px;border-radius:6px}.pb-block__icon{font-size:1rem}.pb-block__word{font-size:.65rem}.pb-block__romanized{font-size:.5rem}.pb-block__badge{font-size:.4rem;padding:1px 3px}.pb-block__instruction{display:none}}.pb-block,.pb-block__magma{will-change:transform;transform:translateZ(0);backface-visibility:hidden}.pb-block:not(:hover):not(.pb-block--charging){will-change:auto}@keyframes pb-block-critical{0%{transform:scale(1);filter:drop-shadow(0 0 8px #FFD700) brightness(1.1)}25%{transform:scale(1.02) rotate(.5deg);filter:drop-shadow(0 0 15px #FFD700) brightness(1.3)}50%{transform:scale(1.04);filter:drop-shadow(0 0 20px #FFD700) drop-shadow(0 0 30px #FF5722) brightness(1.4)}75%{transform:scale(1.02) rotate(-.5deg);filter:drop-shadow(0 0 15px #FFD700) brightness(1.3)}to{transform:scale(1);filter:drop-shadow(0 0 8px #FFD700) brightness(1.1)}}@keyframes pb-block-crack-spread{0%{clip-path:circle(0% at 50% 50%);opacity:0}30%{clip-path:circle(30% at 50% 50%);opacity:.5}to{clip-path:circle(100% at 50% 50%);opacity:1}}@keyframes pb-sparkle-burst{0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:0}50%{transform:translate(-50%,-50%) scale(1.2) rotate(180deg);opacity:1}to{transform:translate(-50%,-50%) scale(0) rotate(360deg);opacity:0}}@keyframes pb-block-shatter-enhanced{0%{transform:scale(1);opacity:1}30%{transform:scale(1.15);opacity:.9;filter:brightness(2) saturate(1.5)}to{transform:scale(0);opacity:0;filter:brightness(3) saturate(0)}}.pb-block--charging .pb-block__cracks{opacity:.7;filter:drop-shadow(0 0 3px #FF5722)}.pb-block--processing .pb-block__cracks{opacity:1;filter:url(#magma-displacement) drop-shadow(0 0 5px #FFD700);background-color:#d32f2f99}.pb-block--cracked .pb-block__cracks{animation:pb-block-crack-spread .4s ease-out forwards;filter:drop-shadow(0 0 2px rgba(0,0,0,.8))}.pb-block--shattered.pb-block--with-effects{animation:pb-block-shatter-enhanced .3s ease-out forwards}.pb-block__sparkle{position:absolute;top:50%;left:50%;width:60px;height:60px;transform:translate(-50%,-50%);pointer-events:none;opacity:0;z-index:15}.pb-block--shattered .pb-block__sparkle{animation:pb-sparkle-burst .4s ease-out forwards}.pb-block__sparkle:before,.pb-block__sparkle:after{content:"⭐";position:absolute;font-size:20px}.pb-block__sparkle:before{top:0;left:50%;transform:translate(-50%)}.pb-block__sparkle:after{bottom:0;right:0}.pb-block__spinner{position:absolute;top:50%;left:50%;width:30px;height:30px;margin:-15px 0 0 -15px;border:3px solid rgba(255,215,0,.3);border-top-color:gold;border-radius:50%;animation:pb-processing-spinner .8s linear infinite;z-index:10}.pb-block:not(.pb-block--processing) .pb-block__spinner{display:none}.pb-block--shake{animation:pb-block-shake-gentle .3s ease-out}@keyframes pb-block-shake-gentle{0%,to{transform:translate(0)}20%{transform:translate(-3px) rotate(-1deg)}40%{transform:translate(3px) rotate(1deg)}60%{transform:translate(-2px) rotate(-.5deg)}80%{transform:translate(2px) rotate(.5deg)}}.pb-grid-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:15px;box-sizing:border-box;overflow:visible}.pb-shell--overlay .pb-grid-container{padding:10px}.pb-shell:not(.pb-shell--overlay) .pb-grid-frame{max-width:945px}.pb-grid-frame{position:relative;width:100%;max-width:min(90vw,500px);aspect-ratio:1 / 1;background:linear-gradient(135deg,#8b4513,peru,#daa520 30%,gold,#daa520 70%,peru,#8b4513);border-radius:12px;padding:10px;border:4px solid;border-image:linear-gradient(135deg,#b8860b,gold,#fffacd,gold,#b8860b) 1;box-shadow:inset 0 0 20px #00000080,0 0 30px #ffd7004d,0 0 60px #ffd70026,0 15px 40px #00000080,0 5px 15px #0000004d;box-sizing:border-box;overflow:hidden}.pb-grid-frame:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border:2px solid rgba(255,215,0,.4);border-radius:8px;pointer-events:none}.pb-grid{position:relative;display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr);width:100%;height:100%;gap:4px;background:transparent;border-radius:8px;padding:4px;box-sizing:border-box;box-shadow:inset 0 2px #ffd7001a;overflow:hidden}.pb-grid:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/assets/lattice-pattern.svg);background-size:20px 20px;background-repeat:repeat;opacity:.08;pointer-events:none;z-index:0;border-radius:8px}.pb-grid-cell{min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;position:relative;background:transparent;border:1px solid rgba(255,215,0,.25);border-radius:4px;box-sizing:border-box;overflow:visible;z-index:1}.pb-grid-cell:hover{border-color:#ffd70080;box-shadow:inset 0 0 8px #ffd70026}.pb-corner{position:absolute;width:56px;height:56px;background-image:url(/assets/corner-ornament.svg);background-size:contain;background-repeat:no-repeat;z-index:2;pointer-events:none;opacity:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.pb-corner-tl{top:0;left:0}.pb-corner-tr{top:0;right:0;transform:scaleX(-1)}.pb-corner-bl{bottom:0;left:0;transform:scaleY(-1)}.pb-corner-br{bottom:0;right:0;transform:scale(-1)}.pb-grid-debug{display:flex;gap:12px;padding:8px 16px;background:#000c;border:1px solid rgba(251,191,36,.3);border-radius:8px;font-size:.875rem;color:#fbbf24;font-family:Courier New,monospace}.pb-debug-label{font-weight:600}@media (max-width: 480px){.pb-grid-container{padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.pb-grid-frame{padding:0;max-width:min(95vw,350px);margin:0 auto}.pb-grid{gap:3px;padding:3px}.pb-corner{width:32px;height:32px}}@media (max-width: 360px){.pb-grid-frame{padding:6px;max-width:min(98vw,320px)}.pb-grid{gap:2px;padding:2px}.pb-corner{width:28px;height:28px}}.speak-prompt-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#1a0a0ad9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease-out;border-radius:16px}.speak-prompt-modal{background:linear-gradient(180deg,#7f1d1d,#991b1b,#450a0a);border:3px solid #fbbf24;border-radius:20px;padding:24px;max-width:360px;width:90%;text-align:center;box-shadow:0 8px 32px #00000080,0 0 48px #fbbf244d;animation:slideUp .3s ease-out}.speak-prompt-header{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}.speak-prompt-icon{font-size:2rem}.speak-prompt-header h2{margin:0;font-size:1.5rem;color:#fbbf24;text-shadow:0 2px 4px rgba(0,0,0,.3)}.speak-prompt-word-container{background:#0000004d;border:1px solid rgba(251,191,36,.3);border-radius:12px;padding:16px;margin-bottom:16px}.speak-prompt-word{font-size:2.5rem;font-weight:700;color:#fff;text-transform:capitalize;margin-bottom:4px;text-shadow:0 2px 8px rgba(0,0,0,.4)}.speak-prompt-romanized{font-size:1.25rem;color:#fca5a5;font-style:italic;margin-bottom:8px}.speak-prompt-phoneme{font-size:.875rem;color:#fca5a5}.speak-prompt-phoneme strong{color:#fbbf24;font-size:1rem}.speak-prompt-retry{background:#fbbf2426;border:1px solid rgba(251,191,36,.5);border-radius:8px;padding:8px 12px;font-size:.875rem;color:#fbbf24;margin-bottom:16px}.speak-prompt-mic-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px 24px;font-size:1.25rem;font-weight:700;color:#450a0a;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:12px;cursor:pointer;margin-bottom:16px;transition:transform .2s,box-shadow .2s}.speak-prompt-mic-btn:hover:not(:disabled){transform:scale(1.03);box-shadow:0 4px 20px #fbbf2480}.speak-prompt-mic-btn:disabled{opacity:.6;cursor:not-allowed}.speak-prompt-mic-btn.loading{background:linear-gradient(135deg,#fca5a5,#ef4444);color:#450a0a}.speak-prompt-mic-btn.ready{animation:pulse-gold 1.5s ease-in-out infinite}@keyframes pulse-gold{0%,to{box-shadow:0 0 #fbbf2466}50%{box-shadow:0 0 0 10px #fbbf2400}}.speak-prompt-mic-btn.recording{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff;box-shadow:0 0 15px #ef444480;animation:pulse-red 1.5s ease-in-out infinite;cursor:wait;border:2px solid #fecaca}@keyframes pulse-red{0%,to{box-shadow:0 0 #ef444499;transform:scale(1)}50%{box-shadow:0 0 0 12px #ef444400;transform:scale(1.02)}}.mic-icon{font-size:1.5rem}.speak-prompt-instructions{font-size:.875rem;color:#fca5a5;line-height:1.5;margin-bottom:16px}.speak-prompt-instructions strong{color:#fbbf24}.speak-prompt-cancel{background:transparent;border:1px solid rgba(251,191,36,.3);color:#fca5a5;padding:8px 16px;font-size:.875rem;border-radius:8px;cursor:pointer;transition:background .2s,color .2s}.speak-prompt-cancel:hover{background:#fbbf241a;color:#fbbf24}.speak-prompt-keyboard-hint{margin-top:16px;font-size:.75rem;color:#fca5a599}.speak-prompt-keyboard-hint kbd{background:#fbbf2433;border:1px solid rgba(251,191,36,.3);border-radius:4px;padding:2px 6px;font-family:inherit;color:#fbbf24}@media (max-width: 480px){.speak-prompt-modal{padding:20px}.speak-prompt-word{font-size:2rem}.speak-prompt-romanized{font-size:1rem}.speak-prompt-mic-btn{padding:14px 20px;font-size:1.1rem}.speak-prompt-keyboard-hint{display:none}}.pb-modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem;border-radius:16px}.pb-modal-content{width:100%;max-width:360px;background:linear-gradient(180deg,#1e1b4b,#0f172a);border:2px solid #fbbf24;border-radius:1rem;padding:2rem;text-align:center;box-shadow:0 0 40px #fbbf244d}.pb-modal-title{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:#fbbf24;letter-spacing:.1em;text-shadow:0 2px 8px rgba(251,191,36,.5)}.pb-modal-subtitle{margin:0 0 1.5rem;font-size:.875rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.2em}.pb-stars-container{display:flex;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.pb-star{font-size:2.5rem;filter:grayscale(100%);opacity:.3;transition:all .3s ease}.pb-star--earned{filter:grayscale(0%);opacity:1;text-shadow:0 0 20px rgba(251,191,36,.8)}.pb-score-display{background:#0006;padding:.75rem 1.5rem;border-radius:9999px;margin-bottom:1rem;border:1px solid rgba(255,255,255,.1)}.pb-score-label{display:block;font-size:.625rem;color:#94a3b8;margin-bottom:.25rem;letter-spacing:.1em}.pb-score-value{font-size:1.5rem;font-weight:700}.pb-score-value--high{color:#22c55e}.pb-score-value--mid{color:#fbbf24}.pb-score-value--low{color:#f87171}.pb-stats{margin-bottom:1.5rem;font-size:.875rem;color:#94a3b8}.pb-modal-actions{display:flex;flex-direction:column;gap:.75rem}.pb-btn-row{display:flex;gap:.75rem}.pb-btn{flex:1;padding:.875rem 1.5rem;font-size:.875rem;font-weight:600;border:none;border-radius:.75rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.pb-btn:hover{transform:scale(1.02)}.pb-btn--primary{background:linear-gradient(135deg,#fbbf24,#d97706);color:#1e1b4b;box-shadow:0 4px 16px #fbbf2466}.pb-btn--secondary{background:#ffffff1a;color:#e2e8f0;border:1px solid rgba(255,255,255,.2)}.pb-btn--secondary:hover{background:#ffffff26}.pb-btn--store{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:1px solid rgba(59,130,246,.4);box-shadow:0 4px 12px #3b82f64d}.pb-btn--store:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 4px 16px #3b82f680}.pb-edge-decor{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;overflow:hidden}.pb-decor-branch{position:absolute;width:120px;height:120px}.pb-decor-branch--tl{top:-10px;left:-10px;transform:rotate(0)}.pb-decor-branch--tr{top:-10px;right:-10px;transform:scaleX(-1)}.pb-blossom{position:absolute;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffb7c5,#ff69b4,#db7093);box-shadow:0 0 10px #ffb6c199,inset 0 -2px 4px #0000001a;animation:blossom-float 4s ease-in-out infinite}.pb-blossom--1{width:16px;height:16px;top:20px;left:30px;animation-delay:0s}.pb-blossom--2{width:12px;height:12px;top:40px;left:50px;animation-delay:.5s}.pb-blossom--3{width:14px;height:14px;top:30px;left:70px;animation-delay:1s}@keyframes blossom-float{0%,to{transform:translateY(0) rotate(0);opacity:.9}50%{transform:translateY(3px) rotate(5deg);opacity:1}}.pb-lantern-glow{position:absolute;width:80px;height:200px;top:10%;background:radial-gradient(ellipse at center top,rgba(255,100,50,.3) 0%,rgba(255,150,50,.15) 40%,transparent 70%);animation:lantern-flicker 3s ease-in-out infinite}.pb-lantern-glow--left{left:-40px;animation-delay:0s}.pb-lantern-glow--right{right:-40px;animation-delay:1.5s}@keyframes lantern-flicker{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.pb-floor-glow{position:absolute;bottom:0;left:10%;right:10%;height:60px;background:linear-gradient(to top,rgba(255,200,100,.1) 0%,transparent 100%)}.pb-edge-decor--reduced .pb-blossom,.pb-edge-decor--reduced .pb-lantern-glow{animation:none!important}@media (prefers-reduced-motion: reduce){.pb-blossom,.pb-lantern-glow{animation:none!important}}@media (max-width: 480px){.pb-decor-branch{width:80px;height:80px}.pb-blossom--1{width:12px;height:12px}.pb-blossom--2{width:9px;height:9px}.pb-blossom--3{width:10px;height:10px}.pb-lantern-glow{width:50px;height:120px}}.pb-shell{display:flex;flex-direction:column;min-height:100vh;max-height:100vh;background-color:#450a0a;background-image:url(/assets/phonics_bomb_tet_bg.jpg);background-size:cover;background-position:center top;background-repeat:no-repeat;background-attachment:fixed;color:#fef2f2;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden;position:relative}.pb-shell:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at center,transparent 30%,rgba(0,0,0,.4) 70%,rgba(0,0,0,.7) 100%);pointer-events:none;z-index:0}.pb-shell>*{position:relative;z-index:1}.pb-shell--overlay{min-height:auto;max-height:none;height:100%;background:transparent}.pb-shell--overlay:before{display:none}.pb-shell--loading{justify-content:center;align-items:center}.pb-loading-spinner{text-align:center;animation:pb-pulse 2s ease-in-out infinite}.pb-loading-spinner .pb-lantern-icon{font-size:4rem;animation:pb-swing 1.5s ease-in-out infinite}.pb-loading-spinner p{margin-top:1rem;font-size:1.25rem;color:gold}.pb-shell--error{justify-content:center;align-items:center;gap:1rem}.pb-error-message{color:#ef4444;font-size:1.25rem;margin-bottom:1rem}.pb-retry-button,.pb-back-button{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,opacity .2s}.pb-retry-button{background:gold;color:#1a0a0a;font-weight:600}.pb-back-button{background:transparent;color:#fca5a5;border:1px solid #fca5a5}.pb-retry-button:hover,.pb-back-button:hover{transform:scale(1.05)}.pb-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#1a0a0af2;border-bottom:2px solid #FFD700}.pb-back-button-header{background:transparent;border:none;color:#fca5a5;font-size:.875rem;cursor:pointer;padding:.5rem;transition:color .2s}.pb-back-button-header:hover{color:gold}.pb-title{font-size:1.5rem;font-weight:700;color:gold;text-shadow:0 2px 4px rgba(0,0,0,.3);margin:0;display:flex;align-items:center;gap:.5rem}.pb-title .pb-lantern{font-size:1.25rem;animation:pb-swing 3s ease-in-out infinite}.pb-header-controls{min-width:60px;display:flex;justify-content:flex-end}.pb-pause-button{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem;transition:transform .2s}.pb-pause-button:hover{transform:scale(1.1)}.pb-hud{display:flex;justify-content:space-around;padding:.5rem 1rem;background:#2d1515cc;border-bottom:1px solid rgba(255,215,0,.3)}.pb-hud-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.pb-hud-label{font-size:.9375rem;text-transform:uppercase;letter-spacing:.5px;color:#fca5a5}.pb-hud-value{font-size:1.3125rem;font-weight:600;color:gold}.pb-hud-item--lives .pb-hud-value{font-size:1.125rem}.pb-hud--compact{padding:.5rem 1rem;gap:1.5rem;flex-wrap:nowrap;justify-content:center}.pb-hud--compact .pb-hud-item{flex-direction:row;align-items:center;gap:.5rem}.pb-hud-pause{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:background .2s}.pb-hud-pause:hover{background:#ffd70033}.pb-main{flex:1;display:flex;justify-content:center;align-items:center;padding:1rem;overflow:hidden}.pb-placeholder{background:#2d1515e6;border:2px solid #FFD700;border-radius:12px;padding:2rem;text-align:center;min-width:300px;max-width:400px;box-shadow:0 4px 20px #00000080}.pb-grid-loading{text-align:center;color:gold}.pb-grid-preview{padding:1.5rem;border:2px dashed rgba(255,215,0,.4);border-radius:8px;margin-bottom:1rem}.pb-grid-preview p{margin:0;font-size:1.125rem}.pb-grid-hint{font-size:.75rem!important;color:#fca5a5;margin-top:.5rem!important}.pb-phase-indicator{font-size:.75rem;color:#fca5a5;margin:1rem 0}.pb-phase-indicator code{background:#0000004d;padding:.25rem .5rem;border-radius:4px;font-family:Fira Code,Consolas,monospace}.pb-start-button{padding:1rem 2.5rem;font-size:1.25rem;font-weight:700;color:#1a0a0a;background:linear-gradient(135deg,gold,#b8860b);border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s;text-transform:uppercase;letter-spacing:1px}.pb-start-button:hover{transform:scale(1.05);box-shadow:0 6px 20px #ffd70080}.pb-start-button:active{transform:scale(.98)}.pb-playing-indicator{padding:1rem}.pb-playing-indicator p{margin:.5rem 0}.pb-playing-hint{font-size:.75rem!important;color:#fca5a5}.pb-pause-overlay{padding:1rem}.pb-pause-overlay h2{margin:0 0 1.5rem;font-size:1.5rem;color:gold}.pb-resume-button,.pb-quit-button{display:block;width:100%;padding:.75rem 1.5rem;margin:.5rem 0;font-size:1rem;border:none;border-radius:8px;cursor:pointer;transition:transform .2s}.pb-resume-button{background:#22c55e;color:#fff;font-weight:600}.pb-quit-button{background:transparent;color:#fca5a5;border:1px solid #fca5a5}.pb-resume-button:hover,.pb-quit-button:hover{transform:scale(1.02)}.pb-footer{padding:.75rem 1rem;background:#1a0a0af2;border-top:2px solid #FFD700}.pb-vibe-panel{display:flex;align-items:center;gap:.75rem;background:#2d1515cc;padding:.75rem 1rem;border-radius:12px;border:1px solid rgba(255,215,0,.2)}.pb-vibe-avatar{font-size:2rem;flex-shrink:0}.pb-vibe-content{flex:1}.pb-vibe-message{margin:0;font-size:1.3125rem;color:#fef2f2;line-height:1.4}@keyframes pb-pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes pb-swing{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}@keyframes pb-fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pb-scorePop{0%{transform:scale(1)}30%{transform:scale(1.3);color:#22c55e}to{transform:scale(1)}}.pb-score-pop{animation:pb-scorePop .4s ease-out}.pb-hud-item--score .pb-hud-value{font-size:1rem;font-weight:700;min-width:60px;text-align:center}.pb-hud-item--multiplier .pb-hud-value{color:#ff6b6b;font-weight:700}@media (max-width: 480px){.pb-header{padding:.5rem}.pb-title{font-size:1.25rem}.pb-title .pb-lantern{display:none}.pb-placeholder{min-width:auto;width:100%;padding:1.5rem}.pb-hud{padding:.5rem}.pb-hud-label{font-size:.5rem}.pb-hud-value{font-size:.75rem}.pb-vibe-panel{padding:.5rem .75rem}.pb-vibe-avatar{font-size:1.5rem}.pb-vibe-message{font-size:.8125rem}}@keyframes pb-combo-flash{0%{transform:scale(1);color:inherit}30%{transform:scale(1.5);color:gold;text-shadow:0 0 10px #FFD700,0 0 20px #FF5722}to{transform:scale(1);color:inherit}}@keyframes pb-screen-shake{0%,to{transform:translate(0)}10%{transform:translate(-3px) rotate(-.5deg)}20%{transform:translate(3px) rotate(.5deg)}30%{transform:translate(-3px) rotate(-.5deg)}40%{transform:translate(3px) rotate(.5deg)}50%{transform:translate(-2px)}60%{transform:translate(2px)}70%{transform:translate(-1px)}80%{transform:translate(1px)}90%{transform:translate(0)}}@keyframes pb-combo-popup{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}30%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:0;transform:translate(-50%,-60%) scale(1)}}.pb-stats__mult--active{animation:pb-combo-flash .4s ease-out}.pb-shell--shake{animation:pb-screen-shake .3s ease-out}.pb-combo-streak{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;font-weight:700;color:gold;text-shadow:0 0 10px #FFD700,0 0 20px #FF5722,2px 2px 0 #D32F2F;pointer-events:none;opacity:0;z-index:2000}.pb-combo-streak--show{animation:pb-combo-popup .6s ease-out forwards}.pb-hud-item--multiplier .pb-hud-value[data-active=true]{color:gold;text-shadow:0 0 8px #FFD700;animation:pb-combo-flash .4s ease-out}@media (max-width: 768px){.pb-hud--compact{padding:.4rem .75rem;gap:1rem}.pb-hud--compact .pb-hud-label{font-size:.75rem}.pb-hud--compact .pb-hud-value,.pb-shell--overlay .pb-vibe-message{font-size:1rem}}@media (max-width: 480px){.pb-hud--compact{padding:.3rem .5rem;gap:.75rem}.pb-hud--compact .pb-hud-label{font-size:.65rem}.pb-hud--compact .pb-hud-value,.pb-shell--overlay .pb-vibe-message{font-size:.9rem}.pb-hud-pause{font-size:1.25rem;padding:.2rem .4rem}}.pb-atmosphere{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.pb-atmosphere-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,215,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,215,0,.05) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(circle at center,black 40%,transparent 90%);mask-image:radial-gradient(circle at center,black 40%,transparent 90%)}.pb-atmosphere-particles{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at top,rgba(255,192,203,.1) 0%,transparent 50%)}.pb-header-echo{position:relative;z-index:10;display:flex;justify-content:center;align-items:center;padding:10px 0;gap:15px}.pb-title-echo{font-size:1.75rem;font-weight:900;color:gold;text-transform:uppercase;letter-spacing:2px;text-shadow:0 0 10px rgba(255,215,0,.5);margin:0;text-align:center;flex:1;display:flex;justify-content:center;align-items:center;gap:8px}.pb-header-decoration{display:flex;align-items:center;justify-content:center}.pb-header-spacer{min-width:80px}.pb-hud-echo{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:0 20px;margin-bottom:10px}.pb-stat-multi{font-size:1.5rem;font-weight:700;color:gold;text-shadow:0 0 10px rgba(255,215,0,.8),0 2px 4px rgba(0,0,0,.6),0 0 20px rgba(255,165,0,.4);width:60px;flex-shrink:0}.pb-multi-x{font-family:Courier New,monospace}.pb-stat-score-pill{position:relative;width:140px;height:40px;display:flex;align-items:center;justify-content:center;margin-left:75px}.pb-pill-bg{position:absolute;top:0;right:0;bottom:0;left:0}.pb-score-val{position:relative;z-index:2;font-family:Courier New,monospace;font-weight:700;color:gold;font-size:1.1rem}.pb-stat-lives-echo{display:flex;gap:8px;min-width:150px;justify-content:flex-end}.pb-life-ingot{width:42px;height:26px;display:flex;align-items:center;justify-content:center}.pb-life-ingot-img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));transition:opacity .3s ease,filter .3s ease}.pb-life-ingot-img--dimmed{opacity:.3;filter:grayscale(100%) drop-shadow(0 1px 2px rgba(0,0,0,.2))}.pb-grid-wrapper{position:relative;z-index:5;flex:1;display:flex;justify-content:center;align-items:center;padding:1rem;max-width:625px;margin:0 auto;width:100%}.pb-footer-echo{position:relative;z-index:10;margin-top:auto;margin-bottom:12px;height:112px;width:95%;max-width:450px;align-self:center;display:flex;align-items:center;justify-content:center}.pb-scroll-bg{position:absolute;top:0;right:0;bottom:0;left:0;filter:drop-shadow(0 4px 10px rgba(0,0,0,.6))}.pb-footer-content{position:relative;z-index:2;text-align:center;padding-top:25px;padding-bottom:10px;width:85%}.pb-quote{color:#fdf5e6;font-family:Inter,-apple-system,sans-serif;font-style:normal;font-size:1.125rem;margin:0;font-weight:500;line-height:1.4;text-shadow:0 1px 2px rgba(0,0,0,.5)}.pb-exit-btn-echo{position:absolute;left:10px;top:50%;transform:translateY(-50%);background:#00000080;border:2px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;padding:6px 12px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;z-index:10}.pb-exit-btn-echo:hover{background:#ef4444b3;border-color:#ef4444}@media (max-width: 480px){.pb-title-echo{font-size:1.25rem;letter-spacing:1px}.pb-header-echo{padding:8px 0}.pb-header-decoration{font-size:1.1rem}.pb-exit-btn-echo{font-size:.75rem;padding:4px 10px}}.pb-stat-level{display:flex;align-items:center;justify-content:center}.pb-level-badge{background:linear-gradient(135deg,#0009,#0006);border:2px solid rgba(251,191,36,.6);border-radius:8px;padding:4px 10px;font-size:.9rem;font-weight:700;color:#fbbf24;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap}.pb-exit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.pb-exit-modal{background:linear-gradient(135deg,#1c1917,#292524);border:3px solid #ca8a04;border-radius:16px;padding:24px 32px;max-width:320px;text-align:center;box-shadow:0 8px 32px #00000080,0 0 20px #ca8a044d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pb-exit-modal-title{color:#fbbf24;font-size:1.5rem;font-weight:700;margin:0 0 12px}.pb-exit-modal-text{color:#fef3c7;font-size:1rem;margin:0 0 20px;line-height:1.4}.pb-exit-modal-buttons{display:flex;gap:12px;justify-content:center}.pb-exit-modal-btn{padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid}.pb-exit-modal-btn--cancel{background:transparent;border-color:#22c55e;color:#22c55e}.pb-exit-modal-btn--cancel:hover{background:#22c55e33}.pb-exit-modal-btn--confirm{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff}.pb-exit-modal-btn--confirm:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466}.pb-reset-btn{background:#0000004d;border:1px solid rgba(255,215,0,.4);border-radius:20px;padding:6px 12px;display:flex;align-items:center;justify-content:center;gap:6px;color:gold;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-left:8px;flex-shrink:0}.pb-reset-btn:hover{background:#ffd70033;border-color:gold;box-shadow:0 0 10px #ffd7004d}.pb-reset-btn:active{transform:scale(.95)}.pb-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;background:#000000d9;display:flex;justify-content:center;align-items:center;padding:1rem;animation:pb-overlay-fadeIn .2s ease-out}@keyframes pb-overlay-fadeIn{0%{opacity:0}to{opacity:1}}.pb-overlay__container{width:100%;max-width:1000px;max-height:95vh;background-color:#450a0a;background-image:url(/assets/phonics_bomb_tet_bg.jpg);background-size:cover;background-position:center;border:3px solid #ca8a04;border-radius:16px;box-shadow:0 0 30px #fbbf244d,0 25px 50px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:pb-overlay-slideUp .3s ease-out}@keyframes pb-overlay-slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.pb-overlay__header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#1a0a0af2;border-bottom:2px solid #FFD700;flex-shrink:0}.pb-overlay__back-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;min-width:80px}.pb-overlay__back-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #3b82f666}.pb-overlay__back-btn:active{transform:scale(.98)}.pb-overlay__title{font-size:1.5rem;font-weight:700;color:gold;text-shadow:0 2px 4px rgba(0,0,0,.3);margin:0;text-align:center;flex:1}.pb-overlay__header-spacer{min-width:80px}.pb-overlay__reset-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;min-width:80px}.pb-overlay__reset-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #3b82f666}.pb-overlay__reset-btn:active{transform:scale(.98)}.pb-overlay__body{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#ca8a04 rgba(26,10,10,.5)}.pb-overlay__body::-webkit-scrollbar{width:8px}.pb-overlay__body::-webkit-scrollbar-track{background:#1a0a0a80}.pb-overlay__body::-webkit-scrollbar-thumb{background:#ca8a04;border-radius:4px}.pb-overlay__body::-webkit-scrollbar-thumb:hover{background:#fbbf24}@media (max-width: 768px){.pb-overlay{padding:0;align-items:stretch}.pb-overlay__container{max-width:100%;max-height:100vh;border-radius:0;border-left:none;border-right:none}.pb-overlay__header{padding:.5rem .75rem}.pb-overlay__title{font-size:1.25rem}.pb-overlay__back-btn{padding:.4rem .75rem;font-size:.9rem;min-width:70px}}@media (max-width: 480px){.pb-overlay__title{font-size:1.1rem}.pb-overlay__back-btn{padding:.35rem .6rem;font-size:.85rem;min-width:60px}.pb-overlay__header-spacer{min-width:60px}}.pb-overlay--closing{animation:pb-overlay-fadeOut .2s ease-in forwards}.pb-overlay--closing .pb-overlay__container{animation:pb-overlay-slideDown .2s ease-in forwards}@keyframes pb-overlay-fadeOut{to{opacity:0}}@keyframes pb-overlay-slideDown{to{opacity:0;transform:translateY(20px) scale(.98)}}.tutor-orb-phonics-overlay{position:fixed;bottom:120px;right:24px;z-index:1001;pointer-events:auto;cursor:pointer;animation:tutorOrbFadeInPhonics .5s ease-out}@keyframes tutorOrbFadeInPhonics{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tutor-orb-phonics-overlay.tutor-connecting{opacity:.6;animation:tutorConnectingPhonics 1.5s ease-in-out infinite}@keyframes tutorConnectingPhonics{0%,to{opacity:.6}50%{opacity:.9}}.tutor-orb-phonics-overlay.tutor-connected{opacity:1}@media (max-width: 480px){.tutor-orb-phonics-overlay{position:fixed!important;bottom:55px!important;right:12px!important;z-index:1045!important;transform:scale(.5)!important;transform-origin:bottom right!important;display:flex!important;flex-direction:column-reverse!important;align-items:center!important}.tutor-orb-phonics-overlay .tutor-orb-help-text{font-size:1rem!important;font-weight:600!important;color:#a78bfa!important;text-shadow:0 0 8px rgba(167,139,250,.6)!important;text-align:center!important;white-space:nowrap!important;margin-bottom:250px!important;display:block!important;pointer-events:none!important;transform:scale(1);transform-origin:bottom center}}@media (max-width: 375px){.tutor-orb-phonics-overlay{bottom:55px!important;right:8px!important}.tutor-orb-phonics-overlay .tutor-orb-help-text{font-size:1rem!important}}.permission-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:1000;background:#0000;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0);transition:all .3s ease;pointer-events:none}.permission-overlay--visible{background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:all}.permission-card{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid rgba(59,130,246,.3);border-radius:20px;padding:32px;max-width:420px;width:90%;text-align:center;box-shadow:0 20px 50px #00000080,0 0 40px #3b82f626;opacity:0;transform:scale(.95) translateY(20px);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.permission-card--visible{opacity:1;transform:scale(1) translateY(0)}.permission-card__icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;margin:0 auto 20px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;box-shadow:0 8px 24px #3b82f659}.permission-card__icon-emoji{font-size:2.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.permission-card__title{font-size:1.6rem;font-weight:700;margin:0 0 12px;background:linear-gradient(135deg,#38bdf8,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.permission-card__description{font-size:1rem;line-height:1.6;color:#94a3b8;margin:0 0 24px}.permission-card__features{list-style:none;padding:0;margin:0 0 28px;text-align:left}.permission-card__features li{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:.95rem;color:#e5e7eb;border-bottom:1px solid rgba(255,255,255,.05)}.permission-card__features li:last-child{border-bottom:none}.permission-card__feature-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#4ade8026;border-radius:50%;color:#4ade80;font-size:.8rem;font-weight:700;flex-shrink:0}.permission-card__actions{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.permission-card__btn{width:100%;padding:14px 24px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;font-family:inherit}.permission-card__btn--primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 16px #3b82f659}.permission-card__btn--primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f673;transform:translateY(-2px)}.permission-card__btn--primary:active{transform:translateY(0)}.permission-card__btn--secondary{background:#ffffff0d;color:#94a3b8;border:1px solid rgba(255,255,255,.1)}.permission-card__btn--secondary:hover{background:#ffffff14;border-color:#fff3;color:#e5e7eb}.permission-card__note{text-align:center;font-size:.8rem;color:#64748b;margin:0}@media (max-width: 640px){.permission-card{padding:24px 20px;margin:16px}.permission-card__icon{width:60px;height:60px}.permission-card__icon-emoji{font-size:2rem}.permission-card__title{font-size:1.4rem}.permission-card__description{font-size:.9rem}.permission-card__btn{padding:12px 20px}}.score-bubble{display:flex;justify-content:flex-start;padding:12px 16px;animation:scoreFadeIn .35s cubic-bezier(.4,0,.2,1);animation-fill-mode:backwards;animation-delay:50ms}@keyframes scoreFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.score-bubble__content{background:#1e2332f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:7px 8px;max-width:340px;width:100%;box-shadow:0 2px 12px #0000004d}.score-bubble__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0;gap:12px}.score-bubble__word{font-size:.9rem;font-weight:700;color:#e2e610;margin:1;line-height:1.3;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.score-bubble__pill{font-size:.8rem;font-weight:700;padding:5px 11px;border-radius:999px;font-variant-numeric:tabular-nums;flex-shrink:0}.score-bubble__pill--green{background:#22c55e33;color:#4ade80;border:1px solid rgba(74,222,128,.4)}.score-bubble__pill--yellow{background:#f59e0b33;color:#fbbf24;border:1px solid rgba(251,191,36,.4)}.score-bubble__pill--red{background:#ef444433;color:#f87171;border:1px solid rgba(248,113,113,.4)}.score-bubble__pill--gray{background:#6b728033;color:#9ca3af;border:1px solid rgba(156,163,175,.4);font-size:.8rem;white-space:nowrap}.score-bubble--pending .score-bubble__content{background:#1e2332d9;border:1px solid rgba(99,102,241,.3)}.score-bubble__pill--pending{background:#6366f133;color:#a5b4fc;border:1px solid rgba(165,180,252,.4);font-size:.85rem;white-space:nowrap;display:flex;align-items:center;gap:6px;animation:pendingPulse 1.5s ease-in-out infinite}.score-bubble__spinner{width:12px;height:12px;border:2px solid rgba(165,180,252,.3);border-top-color:#a5b4fc;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pendingPulse{0%,to{opacity:1}50%{opacity:.7}}.score-bubble__pending-content{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:10px}.score-bubble__pending-bar{height:12px;background:linear-gradient(90deg,#6366f126,#6366f14d,#6366f126);background-size:200% 100%;border-radius:6px;animation:shimmer 1.5s ease-in-out infinite}.score-bubble__pending-bar--short{width:60%}.score-bubble__pending-bar--medium{width:80%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.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}.score-bubble--error .score-bubble__content{background:#1e2332d9;border:1px solid rgba(156,163,175,.2)}.score-bubble__error-message{font-size:.9rem;color:#9ca3af;line-height:1.5;margin:12px 0 0;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.score-bubble--fallback .score-bubble__content{background:linear-gradient(135deg,#4a5568f2,#2d3748f2);border:1px solid rgba(113,128,150,.3)}.score-bubble__pill--fallback{background:#6366f126;color:#a5b4fc;border:1px solid rgba(165,180,252,.3);font-size:.85rem;white-space:nowrap;display:flex;align-items:center;gap:6px}.score-bubble__fallback-icon{font-size:1em;line-height:1}.score-bubble__fallback-message{font-size:.95rem;color:#e2e8f0;line-height:1.5;margin:12px 0 0;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.score-bubble__scores{display:flex;justify-content:space-around;margin:16px 0;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)}.score-item{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;padding:0 8px}.score-item:not(:last-child){border-right:1px solid rgba(255,255,255,.1)}.score-item__label{font-size:.53rem;font-weight:600;letter-spacing:.05em;color:#9ca3af;text-transform:uppercase;margin-bottom:3px}.score-item__value{font-size:.83rem;font-weight:700;color:#f3f4f6;font-variant-numeric:tabular-nums}.score-bubble__tip{font-size:.68rem;font-style:italic;color:#d1d5db;line-height:1.5;margin:0}@media (max-width: 480px){.score-bubble{padding:3px 4px}.score-bubble__content{padding:5px 6px;max-width:100%;border-radius:6px}.score-bubble__header{gap:4px}.score-bubble__word{font-size:.5rem;max-width:150px}.score-bubble__pill{font-size:.38rem;padding:2px 4px}.score-bubble__tip{font-size:.38rem;line-height:1.3}.score-bubble__scores{margin:5px 0;padding:4px 0}.score-item{padding:0 2px}.score-item__label{font-size:.28rem}.score-item__value{font-size:.43rem}}.score-bubble{animation:scoreFadeIn .4s cubic-bezier(.4,0,.2,1);animation-delay:50ms;animation-fill-mode:backwards;margin-bottom:12px}@keyframes scoreFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.score-bubble-pending{animation:pendingFadeIn .3s ease-out;animation-fill-mode:backwards;margin-bottom:12px}@keyframes pendingFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mode-indicator{position:fixed;top:26px;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;justify-content:center;gap:9px;padding:12px 30px;border-radius:999px;min-width:165px;font-family:Inter,system-ui,sans-serif;font-size:18px;font-weight:800;letter-spacing:1.5px;animation:slideDownFade .4s cubic-bezier(.175,.885,.32,1.275) forwards;transition:all .3s ease}.mode-indicator--chat{background:linear-gradient(180deg,#450a0a,#2b0505);color:#fff;border:3px solid transparent;background-clip:padding-box,border-box;background-origin:padding-box,border-box;background-image:linear-gradient(#450a0a,#2b0505),linear-gradient(90deg,#ef4444,#dc2626,#ef4444);text-transform:uppercase;text-shadow:0 0 15px rgba(255,255,255,.6);animation:slideDownFade .4s ease-out forwards;box-shadow:0 0 20px #ef444499,0 0 30px #b91c1c59,inset 0 0 10px #00000080}.mode-indicator--scoring{background:linear-gradient(180deg,#2e1065,#1e0a45);color:#fff;border:3px solid transparent;background-clip:padding-box,border-box;background-origin:padding-box,border-box;background-image:linear-gradient(#2e1065,#1e0a45),linear-gradient(90deg,#00f2ff,#a855f7,#00f2ff);text-transform:uppercase;text-shadow:0 0 15px rgba(255,255,255,.6);animation:slideDownFade .4s ease-out forwards;box-shadow:0 0 20px #06b6d499,0 0 30px #a855f759,inset 0 0 10px #00000080}.mode-indicator__icon{font-size:21px}.mode-indicator__label{font-size:15px;white-space:nowrap}@keyframes slideDownFade{0%{opacity:0;transform:translate(-50%,-40px)}to{opacity:1;transform:translate(-50%)}}@media (max-width: 480px){.mode-indicator{top:10px;padding:5px 13px;min-width:112px;font-size:14px}.mode-indicator__label{font-size:11px}.mode-indicator__icon{font-size:13px}}.new-chat-button{position:relative;z-index:99;margin:0;display:flex;align-items:center;justify-content:center;gap:5px;padding:13px 24px;border-radius:999px;border:2px solid rgba(234,179,8,.8);background:linear-gradient(135deg,#eab30859,#ca8a0459);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fef08a;font-size:.87rem;font-weight:700;white-space:nowrap;cursor:pointer;transition:all .3s ease;box-shadow:0 0 20px #eab30880,0 0 40px #eab3084d,0 3px 14px #eab30866;animation:neon-glow-yellow 3s ease-in-out infinite}@keyframes neon-glow-yellow{0%,to{box-shadow:0 0 30px #eab30899,0 0 60px #eab30866,0 4px 20px #eab30880}50%{box-shadow:0 0 50px #eab308e6,0 0 100px #eab308b3,0 4px 32px #eab308cc}}.new-chat-button:hover:not(:disabled){background:linear-gradient(135deg,#eab30880,#ca8a0480);border-color:#eab308;color:#fff;transform:scale(1.05);box-shadow:0 0 60px #eab308e6,0 0 120px #eab308b3,0 6px 32px #eab308cc}.new-chat-button:active:not(:disabled){transform:scale(.98)}.new-chat-button:disabled{opacity:.4;cursor:not-allowed;animation:none}.new-chat-button__icon{display:none}@media (max-width: 480px){.new-chat-button{padding:7px 11px;font-size:.7rem;border-radius:20px}.new-chat-button__text{display:inline}}.new-chat-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.new-chat-confirm-dialog{background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;max-width:360px;width:calc(100% - 32px);text-align:center}.new-chat-confirm-dialog__title{margin:0 0 12px;font-size:18px;font-weight:600;color:#f1f5f9}.new-chat-confirm-dialog__message{margin:0 0 24px;font-size:14px;color:#94a3b8;line-height:1.5}.new-chat-confirm-dialog__actions{display:flex;gap:12px;justify-content:center}.new-chat-confirm-dialog__button{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.new-chat-confirm-dialog__button--cancel{background:transparent;border:1px solid rgba(255,255,255,.3);color:#94a3b8}.new-chat-confirm-dialog__button--cancel:hover{background:#ffffff1a}.new-chat-confirm-dialog__button--confirm{background:#dc2626;border:none;color:#fff}.new-chat-confirm-dialog__button--confirm:hover{background:#b91c1c}.mode-selection-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeIn .3s ease-out}.mode-selection-modal{background:linear-gradient(145deg,#1e293b,#0f172a);border:1px solid rgba(59,130,246,.2);border-radius:16px;padding:32px;max-width:670px;width:95%;max-height:95vh;overflow-y:auto;display:flex;flex-direction:column;gap:21px;box-shadow:0 17px 40px #0009;animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1) forwards}.mode-selection-modal__title{margin:0;font-size:1.67rem;font-weight:800;color:#ffe100;text-align:center;text-shadow:0 0 13px rgba(255,225,0,.3)}.mode-selection-modal__options{display:grid;grid-template-columns:1fr 1fr;gap:21px;width:100%;padding-bottom:5px}.mode-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:#ffffff08;border:2px solid transparent;border-radius:13px;padding:21px 16px;cursor:pointer;transition:all .2s ease;position:relative}.mode-card:hover{transform:translateY(-5px);background:#ffffff12}.mode-badge-wrapper{height:60px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;width:100%}.neon-badge{padding:8px 21px;border-radius:999px;font-size:1rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;background:#0006;box-shadow:inset 0 0 13px #00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap}.neon-badge.chat{color:#fff;border:3px solid #ef4444;box-shadow:0 0 15px #ef444480,inset 0 0 10px #ef444433;text-shadow:0 0 10px rgba(239,68,68,.8)}.neon-badge.scoring{color:#fff;position:relative;background-clip:padding-box;border:3px solid transparent;background-color:#0006;background:linear-gradient(#1e1e1e,#1e1e1e) padding-box,linear-gradient(to right,#3b82f6,#8b5cf6,#ec4899) border-box;box-shadow:0 0 20px #8b5cf666}.neon-badge.scoring span{text-shadow:0 0 10px rgba(139,92,246,.8)}.mode-card--chat:hover .neon-badge.chat{box-shadow:0 0 25px #ef4444cc,inset 0 0 15px #ef44444d;transform:scale(1.05);transition:all .2s ease}.mode-card--scoring:hover .neon-badge.scoring{box-shadow:0 0 30px #8b5cf6b3;transform:scale(1.05);transition:all .2s ease}.mode-card--chat:hover{border-color:#ef4444;box-shadow:0 10px 30px #ef444426}.mode-card--scoring:hover{border-color:#8b5cf6;box-shadow:0 10px 30px #8b5cf626}.mode-card__title{margin:0 0 8px;font-size:1.2rem;font-weight:700;color:#fff}.mode-card__description{margin:0 0 16px;font-size:.73rem;color:#cbd5e1;line-height:1.5;min-height:33px}.mode-card__features{list-style:none;padding:0;margin:0;width:100%;text-align:left}.mode-card__features li{font-size:.7rem;color:#94a3b8;padding:5px 0;display:flex;align-items:center;gap:8px;border-top:1px solid rgba(255,255,255,.05)}.check-icon{color:#10b981;font-weight:700;font-size:1.2rem}.mode-selection-modal__countdown{width:100%;text-align:center;margin-top:10px}.mode-selection-modal__countdown-text{margin:0 0 12px;font-size:1rem;color:#94a3b8}.mode-selection-modal__countdown-text strong{color:#fca5a5;font-size:1.1rem}.mode-selection-modal__progress-bar{height:6px;width:100%;background:#ffffff1a;border-radius:3px;overflow:hidden}.mode-selection-modal__progress-fill{height:100%;background:linear-gradient(90deg,#dc2626,#f87171);transition:width 1s linear}.voice-toggle{display:flex;align-items:center;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);width:100%}.voice-toggle__label{font-size:.85rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.voice-toggle__buttons{display:flex;gap:8px;background:#0000004d;padding:4px;border-radius:8px}.voice-toggle__btn{padding:8px 20px;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:transparent;border:2px solid transparent;color:#64748b}.voice-toggle__btn:hover:not(.voice-toggle__btn--active){color:#94a3b8;background:#ffffff0d}.voice-toggle__btn--active{color:#fff;border:2px solid #ef4444;background:#ef44441a;box-shadow:0 0 15px #ef444466,0 0 30px #ef444433,inset 0 0 10px #ef44441a}.voice-toggle__btn--active:hover{box-shadow:0 0 20px #ef444499,0 0 40px #ef44444d,inset 0 0 15px #ef444426}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.mode-selection-modal__options{grid-template-columns:1fr}.mode-selection-modal{padding:24px}.voice-toggle{flex-direction:column;align-items:flex-start;gap:8px}}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal{background:linear-gradient(180deg,#1a1a2e,#16213e);border-radius:16px;padding:2rem;width:100%;max-width:400px;position:relative;box-shadow:0 20px 40px #0006,0 0 0 1px #ffffff1a;animation:modal-appear .2s ease-out}@keyframes modal-appear{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.auth-modal__close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#888;font-size:1.5rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.auth-modal__close:hover{background:#ffffff1a;color:#fff}.auth-modal__title{color:#fff;font-size:1.5rem;font-weight:600;margin:0 0 .5rem;text-align:center}.auth-modal__subtitle{color:#888;font-size:.9rem;margin:0 0 1.5rem;text-align:center}.auth-notice{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);color:#ffc107;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.5rem}.auth-field label{color:#aaa;font-size:.85rem;font-weight:500}.auth-field input{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:.75rem 1rem;color:#fff;font-size:1rem;transition:all .2s}.auth-field input::placeholder{color:#666}.auth-field input:focus{outline:none;border-color:var(--color-primary, #6366f1);box-shadow:0 0 0 3px #6366f133}.auth-field input:disabled{opacity:.5;cursor:not-allowed}.auth-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.auth-button:disabled{opacity:.5;cursor:not-allowed}.auth-button--primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;margin-top:.5rem}.auth-button--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.auth-button--google{background:#fff;color:#333;border:1px solid #ddd}.auth-button--google:hover:not(:disabled){background:#f8f8f8;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.google-icon{width:20px;height:20px}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.auth-divider span{color:#666;font-size:.85rem}.auth-switch{text-align:center;color:#888;font-size:.9rem;margin:1.5rem 0 0}.auth-link{background:none;border:none;color:var(--color-primary, #6366f1);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.auth-link:hover{color:#818cf8}.auth-success{text-align:center}.auth-success__icon{font-size:3rem;margin-bottom:1rem}.auth-success__message{color:#aaa;line-height:1.6;margin-bottom:1.5rem}.auth-success__message strong{color:#fff}@media (max-width: 480px){.auth-modal{padding:1.5rem;margin:1rem}.auth-modal__title{font-size:1.25rem}}.input-plus-menu-wrapper{position:relative;display:flex;align-items:center}.tyf-gemini-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;flex-shrink:0;overflow:hidden;background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#f5f7fa;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);outline:none;box-shadow:none;padding:0}.tyf-gemini-btn:hover:not(.disabled){background:#ffffff26;border-color:#ffffff4d;transform:scale(1.05);box-shadow:0 4px 12px #0003}.tyf-gemini-btn.active{background:#ffffff1f;border-color:#ffffff40}.tyf-gemini-btn:active:not(.disabled){transform:scale(.95)}.tyf-gemini-btn.disabled{opacity:.3;cursor:not-allowed}.input-plus-menu{position:absolute;bottom:calc(100% + 8px);left:0;min-width:280px;max-height:400px;overflow-y:auto;background:#1e1e1efa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:8px;box-shadow:0 -8px 32px #00000080;z-index:1000;animation:menuSlideUp .2s ease-out}@keyframes menuSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.input-plus-menu__header{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:4px}.input-plus-menu__title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af}.input-plus-menu__item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:8px;background:transparent;transition:all .15s ease}.input-plus-menu__item:not(.disabled):hover{background:#ffffff0d}.input-plus-menu__item.disabled{opacity:.5;cursor:not-allowed}.menu-item-content{display:flex;align-items:center;gap:12px}.menu-item-icon{font-size:1.25rem;flex-shrink:0}.menu-item-label{font-size:.95rem;font-weight:500;color:#f5f7fa}.toggle-switch{position:relative;width:44px;height:24px;border-radius:12px;border:none;background:#ffffff1a;cursor:pointer;transition:background .2s ease}.toggle-switch.active{background:linear-gradient(135deg,#3b82f6,#2563eb)}.toggle-switch__slider{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s ease;box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-switch__slider{transform:translate(20px)}.coming-soon-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;background:#fbbf2433;color:#fbbf24;padding:2px 8px;border-radius:4px}.input-plus-menu__footer{padding:8px 12px;border-top:1px solid rgba(255,255,255,.1);margin-top:4px}.menu-footer-hint{font-size:.75rem;color:#9ca3af;font-style:italic}.settings-label{display:none!important}@media (max-width: 480px){.input-wrapper .input-plus-menu-wrapper{display:none!important}.mobile-settings-wrapper .input-plus-menu-wrapper{position:relative;top:auto;left:auto;z-index:auto}.tyf-gemini-btn{width:auto;height:36px;border-radius:18px;padding:0 12px 0 8px;gap:6px;overflow:visible;background:transparent;border:1px solid rgba(255,255,255,.3)}.settings-label{display:inline;font-size:.85rem;font-weight:500;color:#f5f7fa;white-space:nowrap}.input-plus-menu{position:absolute;top:calc(100% + 8px);left:0;bottom:auto;min-width:280px;max-width:320px;box-shadow:0 8px 32px #00000080;animation:menuSlideDown .2s ease-out}@keyframes menuSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.menu-item-label{font-size:.85rem}}.voice-select{padding:6px 10px;min-width:140px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#f5f7fa;font-size:.85rem;font-family:inherit;cursor:pointer;outline:none;transition:all .2s ease}.voice-select:hover{background:#ffffff14;border-color:#ffffff4d}.voice-select:focus{background:#ffffff1a;border-color:#14b8a6;box-shadow:0 0 0 2px #14b8a633}.voice-select option{background:#1e1f20;color:#f5f7fa;padding:8px}@media (max-width: 480px){.voice-select{min-width:120px;font-size:.8rem;padding:5px 8px}.footer-buttons-row .input-plus-menu{bottom:calc(100% + 8px);top:auto;left:0;right:auto;max-height:60vh}.footer-buttons-row .tyf-gemini-btn{width:32px;height:32px;padding:0}.footer-buttons-row .settings-label{display:none!important}}.live-coach-container{width:100vw;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;margin:0;padding:20px 32px;padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom));padding-left:max(32px,env(safe-area-inset-left));padding-right:max(32px,env(safe-area-inset-right));display:flex;flex-direction:column;gap:20px;overflow:hidden;background:#000;border-radius:0;box-shadow:none;font-family:Inter,system-ui,-apple-system,sans-serif;color:#f5f7fa}.live-coach-minimal-header{position:relative;display:flex;justify-content:space-between;align-items:center;padding:12px 0 16px;margin:0 auto;max-width:800px;width:100%;border-bottom:1px solid rgba(255,255,255,.05)}@media (max-width: 480px){.live-coach-minimal-header{max-width:100%;padding:12px 16px 16px}}.live-coach-back-button{background:#3b82f6;border:none;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;padding:9px 15px;border-radius:8px;transition:all .15s ease;min-width:75px;text-align:center}.live-coach-back-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.header-new-chat-wrapper{display:flex;align-items:center;justify-content:flex-end}.header-tyf-logo{position:absolute;left:-98px;top:-15px;width:188px;height:90px;z-index:10;display:flex;align-items:center;pointer-events:none}.header-auth-section{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:1;margin-left:auto}.auth-buttons{display:flex;gap:8px}.auth-login-button{background:transparent;border:1px solid rgba(255,255,255,.3);color:#f5f7fa;font-size:.85rem;font-weight:500;cursor:pointer;padding:8px 16px;border-radius:8px;transition:all .15s ease}.auth-login-button:hover{background:#ffffff1a;border-color:#ffffff80}.auth-signup-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;padding:8px 16px;border-radius:8px;transition:all .15s ease;box-shadow:0 2px 8px #3b82f64d}.auth-signup-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.auth-user-info{display:flex;align-items:center;gap:12px}.auth-username{color:#9ca3af;font-size:.85rem;font-weight:500}.auth-signout-button{background:transparent;border:1px solid rgba(239,68,68,.4);color:#fca5a5;font-size:.8rem;font-weight:500;cursor:pointer;padding:6px 12px;border-radius:6px;transition:all .15s ease}.auth-signout-button:hover{background:#ef444426;border-color:#ef444499}@media (max-width: 480px){.header-tyf-logo{left:10px;top:5px;width:50px;height:50px}}.connection-orb{width:22px;height:22px;border-radius:50%;border:none;cursor:pointer;background:radial-gradient(circle at 30% 30%,#ffffffe6,#ef4444 20%,#991b1b 80%,#450a0a);box-shadow:0 0 7px #ef4444b3,inset 0 -2px 4px #0006;border:1px solid rgba(239,68,68,.5);transition:all .3s ease}.connection-orb.connected{background:radial-gradient(circle at 30% 30%,#ffffffe6,#10b981 20%,#047857 80%,#064e3b);box-shadow:0 0 7px #10b981b3,inset 0 -2px 4px #0006;border:1px solid rgba(16,185,129,.5)}.connection-orb:not(.connected){animation:sharpPulse 2s infinite}@keyframes sharpPulse{0%{box-shadow:0 0 12px #ef4444b3}50%{box-shadow:0 0 20px #ef4444e6}to{box-shadow:0 0 12px #ef4444b3}}.header-connection-status{display:flex;align-items:flex-start;gap:6px}.header-connection-column{display:flex;flex-direction:column;align-items:center;gap:5px;margin-top:6px}.connection-status-text{font-size:.94rem;font-weight:600;color:#ef4444;text-transform:capitalize;margin-top:7px}.connection-status-text.connected{color:#10b981}.live-coach-header{display:flex;align-items:center;justify-content:space-between;gap:40px;padding-bottom:12px;margin:0 auto;max-width:800px;width:100%;border-bottom:1px solid rgba(255,255,255,.1)}.title-block h1{margin:0;font-size:3rem;font-weight:700;background:linear-gradient(135deg,#38bdf8,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.title-block .subtitle{margin:4px 0 0;color:#9ca3af;font-size:.95rem}.connection-status{padding:12px 32px;margin-right:0;border-radius:999px;font-size:1.5rem;font-weight:700;color:#fff;white-space:nowrap;transition:background-color .3s ease}.error-banner{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:10px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-icon{font-size:20px}.error-text{flex:1;color:#fca5a5;font-size:.9rem}.error-close{background:none;border:none;color:#fca5a5;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .2s ease}.error-close:hover{background:#ef444433}.chat-window{flex:1;padding:16px;margin:0 auto;max-width:800px;width:100%;border-radius:12px;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;display:flex;flex-direction:column;gap:12px;background:#1e1f20;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent;position:relative}.header-left-section{display:flex;align-items:center;gap:8px}.footer-text-input-wrapper{flex:1;max-width:1000px}.footer-buttons-row{display:flex;flex-direction:row;gap:12px;align-items:center}.footer-buttons-row .input-plus-menu-wrapper{flex-shrink:0}.chat-window::-webkit-scrollbar{width:8px}.chat-window::-webkit-scrollbar-track{background:transparent}.chat-window::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.chat-window::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.welcome-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px 24px;background:transparent;border-radius:0;border:none;animation:fadeIn .6s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.welcome-logo{width:90%;height:auto}.welcome-prompt h3{margin:0 0 clamp(10px,2vw,16px) 0;font-size:clamp(1.1rem,4vw,1.25rem);font-weight:700;color:#fff200}.welcome-tagline{margin:0 0 clamp(8px,1.5vw,12px) 0;font-size:clamp(.9rem,3vw,1.1rem);color:#9ca3af;line-height:1.4}.welcome-prompt p{margin:0 0 clamp(8px,1.5vw,12px) 0;color:#d1d5db;font-size:clamp(.85rem,2.5vw,1rem);line-height:1.4}.welcome-prompt .hint{color:#9ca3af;font-size:clamp(.75rem,2vw,.86rem);font-style:italic;margin-bottom:clamp(12px,2vw,20px)}.welcome-prompt kbd{display:inline-block;padding:2px 8px;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.85rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#f5f7fa}.live-coach-footer{display:flex;flex-direction:column;align-items:center;gap:13px;padding:13px 18px 26px;border-top:1px solid rgba(255,255,255,.1)}.footer-mic-section{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;gap:7px}.coach-speaking-pill{display:flex;align-items:center;gap:8px;background:#eab30826;border:1px solid rgba(234,179,8,.4);color:#fbbf24;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500;animation:pill-blink 1.5s ease-in-out infinite}.coach-speaking-dot{width:8px;height:8px;border-radius:50%;background:#fbbf24;animation:dot-pulse 1s ease-in-out infinite}@keyframes pill-blink{0%,to{opacity:1;box-shadow:0 0 8px #eab3084d}50%{opacity:.7;box-shadow:0 0 16px #eab30880}}@keyframes dot-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.footer-input-row{display:flex;align-items:center;justify-content:flex-start;gap:20px;width:100%;max-width:880px;position:relative}.ai-coaching-button-wrapper{flex-shrink:0}.live-coach-chat-input{flex:1;height:auto;padding:11px 22px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#f5f7fa;font-family:Inter,sans-serif;font-size:1rem;font-weight:500;outline:none;transition:all .3s ease;box-shadow:inset 0 1px 2px #0003}.live-coach-chat-input::placeholder{color:#fff6}.live-coach-chat-input:focus{background:#ffffff1a;border-color:#fff9;box-shadow:0 0 20px #ffffff4d,0 0 40px #ffffff1a,inset 0 0 10px #ffffff0d;transform:translateY(-1px)}.action-buttons{display:flex;gap:12px;width:100%;max-width:400px}.exit-button{flex:1;padding:14px 24px;border-radius:10px;border:none;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #dc26264d}.exit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #dc262666}.exit-button:active:not(:disabled){transform:translateY(0)}.exit-button:disabled{background:#dc262666;cursor:not-allowed;box-shadow:none}.mic-button{width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,#ef4444,#dc2626);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 0 10px #ef444480,0 0 20px #ef44444d;animation:micPulse 2s ease-in-out infinite}@keyframes micPulse{0%,to{box-shadow:0 0 20px #ef444480,0 0 40px #ef44444d,0 0 60px #ef44441a;transform:scale(1)}50%{box-shadow:0 0 30px #ef4444b3,0 0 50px #ef444480,0 0 80px #ef444433;transform:scale(1.05)}}.mic-button:hover:not(:disabled){box-shadow:0 0 30px #ef4444b3,0 0 60px #ef444480,0 0 90px #ef44444d;transform:scale(1.05)}.mic-button.active{background:linear-gradient(135deg,#f87171,#ef4444);animation:micPulseRecording .8s ease-in-out infinite}@keyframes micPulseRecording{0%,to{transform:scale(1);box-shadow:0 0 30px #ef4444b3,0 0 60px #ef444480,0 0 90px #ef44444d}50%{transform:scale(1.08);box-shadow:0 0 40px #f87171cc,0 0 80px #f8717199,0 0 120px #f8717166}}.mic-button.connecting{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 0 20px #f59e0b80,0 0 40px #f59e0b4d;cursor:wait;animation:micPulseConnecting 1s ease-in-out infinite}@keyframes micPulseConnecting{0%,to{opacity:1}50%{opacity:.6}}.mic-button:disabled{opacity:.5;cursor:not-allowed;animation:none}@media (max-width: 1023px) and (min-width: 768px){.live-coach-container{padding:16px 24px;gap:16px}.welcome-prompt{padding:16px 20px}.welcome-features{gap:16px}.footer-input-row{gap:12px}}@media (max-width: 767px) and (min-width: 481px){.live-coach-container{padding:12px 16px;gap:12px}.live-coach-minimal-header{padding:0 0 10px}.connection-status-text{font-size:1.1rem}.welcome-prompt{padding:12px 16px}.welcome-features{flex-direction:column;gap:10px}.welcome-feature-item{justify-content:center}.live-coach-footer{padding:16px 12px 40px;gap:16px}.footer-input-row{flex-wrap:wrap;gap:10px}.footer-input-row>div:first-child{min-width:100px}}@media (max-width: 480px){.live-coach-container{padding:8px 12px;padding-top:max(8px,env(safe-area-inset-top));padding-bottom:max(8px,env(safe-area-inset-bottom));gap:8px}.live-coach-minimal-header{padding:0 0 8px}.header-connection-column{margin-top:15px}.connection-status-text{font-size:.8rem;margin-top:18px}.connection-orb{width:28px;height:28px}.welcome-prompt{padding:8px 12px}.welcome-prompt .hint kbd{display:none}.welcome-features{flex-direction:column;gap:8px}.welcome-feature-item{padding:8px 12px;font-size:.875rem;justify-content:center}.welcome-feature-icon{width:24px;height:24px}.chat-window{padding:8px;border-radius:8px}.live-coach-footer{position:sticky;bottom:0;background:#000;padding:5px 4px 10px;padding-bottom:max(10px,env(safe-area-inset-bottom));gap:5px;border-top:1px solid rgba(255,255,255,.1);z-index:10}.footer-mic-section{gap:3px}.footer-input-row{flex-direction:column;gap:8px;align-items:stretch}.footer-input-row>div:first-child{display:none!important}.footer-text-input-wrapper{width:100%;max-width:100%}.footer-buttons-row{display:flex;flex-direction:row;gap:10px;width:100%;align-items:center}.footer-buttons-row .input-plus-menu-wrapper{flex-shrink:0;width:32px}.footer-buttons-row .input-plus-menu-wrapper .button-label{display:none!important}.footer-buttons-row .ai-coaching-button-wrapper{flex:1;min-width:140px}.ai-coaching-button-wrapper{width:100%}.live-coach-chat-input{padding:4px 8px;font-size:.55rem}.coach-speaking-pill{padding:3px 6px;font-size:9px}.mic-button{width:25px;height:25px}}@media (max-width: 375px){.live-coach-container{padding:4px 6px;gap:4px}.connection-status-text{font-size:.7rem}.welcome-prompt{padding:4px 6px}.welcome-feature-item{font-size:.7rem;padding:4px 8px}.live-coach-footer{padding:4px 4px 8px;gap:4px}.live-coach-chat-input{padding:5px 10px;font-size:.65rem}.mic-button{width:22px;height:22px}}.audio-play-button{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#9ca3af;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-left:8px}.audio-play-button:hover:not(:disabled){background:#fff3;border-color:#fff6;color:#f5f7fa;transform:scale(1.05)}.audio-play-button:active:not(:disabled){transform:scale(.95)}.audio-play-button.playing{background:#38bdf833;border-color:#38bdf866;color:#38bdf8}.audio-play-button:disabled{opacity:.4;cursor:not-allowed}.bubble-content{display:flex;align-items:flex-start;gap:8px}.bubble-text-wrapper{flex:1;min-width:0}.tutor-orb-livecoach-overlay{position:fixed;bottom:100px;right:calc(50% - 376px);z-index:45;pointer-events:auto;cursor:pointer;animation:tutorOrbFadeIn .5s ease-out}@keyframes tutorOrbFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tutor-orb-livecoach-overlay:hover{transform:scale(1.05);transition:transform .2s ease}@media (max-width: 480px){.tutor-orb-livecoach-overlay{bottom:70px;right:12px;transform:scale(.5)}.tutor-orb-livecoach-overlay:hover{transform:scale(.525)}}@media (max-width: 375px){.tutor-orb-livecoach-overlay{bottom:60px;right:8px}}.connection-button-orb{position:relative;width:60px;height:60px;border-radius:50%;border:none;background:transparent;cursor:pointer;transition:all .3s ease;overflow:visible;padding:0}.connection-button-orb:hover:not(:disabled){transform:scale(1.03)}.connection-button-orb:active:not(:disabled){transform:scale(.95)}.connection-button-orb:disabled{opacity:.6;cursor:not-allowed}.connection-button-orb .orb-glow{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;pointer-events:none;opacity:0;transition:opacity .3s ease}.connection-button-orb .orb-glow-1{background:radial-gradient(circle,currentColor 0%,transparent 60%);filter:blur(4px)}.connection-button-orb .orb-glow-2{top:-8px;right:-8px;bottom:-8px;left:-8px;background:radial-gradient(circle,currentColor 0%,transparent 60%);filter:blur(8px)}.connection-button-orb .orb-inner{position:relative;width:100%;height:100%;border-radius:50%;background:#141419e6;border:2px solid currentColor;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.connection-button-orb .orb-status-dot{width:20px;height:20px;border-radius:50%;background:currentColor;box-shadow:0 0 16px currentColor;transition:all .3s ease}.connection-button-orb.connected{color:#10b981}.connection-button-orb.connected .orb-glow{opacity:.7}.connection-button-orb.connected .orb-inner{background:#10b98126}.connection-button-orb.connected .orb-status-dot{animation:pulse-green 2s ease-in-out infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 16px #10b981,0 0 32px #10b98180;transform:scale(1)}50%{box-shadow:0 0 24px #10b981,0 0 48px #10b981b3;transform:scale(1.1)}}.connection-button-orb.disconnected{color:#ef4444}.connection-button-orb.disconnected .orb-glow{opacity:.5}.connection-button-orb.disconnected .orb-inner{background:#ef444426}.connection-button-orb.disconnected .orb-status-dot{animation:pulse-red 2s ease-in-out infinite}@keyframes pulse-red{0%,to{box-shadow:0 0 16px #ef4444;opacity:1}50%{box-shadow:0 0 24px #ef4444;opacity:.7}}.connection-button-orb.connecting{color:#f59e0b}.connection-button-orb.connecting .orb-glow{opacity:.6}.connection-button-orb.connecting .orb-inner{background:#f59e0b26}.connection-button-orb.connecting .orb-status-dot{animation:pulse-orange 1s ease-in-out infinite}@keyframes pulse-orange{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.connection-button-orb.failed{color:#dc2626}.connection-button-orb.failed .orb-glow{opacity:.5}.connection-button-orb.failed .orb-inner{background:#dc262626}.connection-button-orb.failed .orb-status-dot{animation:pulse-failed 3s ease-in-out infinite}@keyframes pulse-failed{0%,to{box-shadow:0 0 16px #dc2626;opacity:1}50%{box-shadow:0 0 8px #dc2626;opacity:.5}}@media (max-width: 640px){.connection-button-orb{width:50px;height:50px}.connection-button-orb .orb-status-dot{width:16px;height:16px}}.landing-page{background:#0a0a0a;color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden;overflow-y:auto;height:100vh;position:fixed;top:0;left:0;right:0;bottom:0;z-index:10}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#0a0a0ad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(100,149,237,.15)}.landing-nav__logo{height:36px}.landing-nav__right{display:flex;gap:.75rem;align-items:center}.landing-nav__btn{padding:.5rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.landing-nav__btn--login{background:transparent;color:#d1d5db;border:1px solid rgba(100,149,237,.3)}.landing-nav__btn--login:hover{color:#fff;border-color:#6495ed99}.landing-nav__btn--signup{background:linear-gradient(135deg,#6495ed,#4169e1);color:#fff}.landing-nav__btn--signup:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6495ed66}.hero-section{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6rem 2rem 2rem;position:relative;background:radial-gradient(circle at center,#1a1a2e,#0a0a0a)}.welcome-logo-wrapper{width:clamp(180px,45vw,300px);height:clamp(180px,45vw,300px);margin-bottom:clamp(12px,3vw,24px);border-radius:50%;background:transparent;box-shadow:none;display:flex;align-items:center;justify-content:center;overflow:visible;filter:drop-shadow(0 0 30px rgba(0,100,255,.6));transition:width .3s ease,height .3s ease,margin-bottom .3s ease}.welcome-features{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(10px,3vw,24px);margin-top:clamp(10px,2vw,14px)}.welcome-feature-item{display:flex;align-items:center;gap:clamp(6px,1vw,10px);font-size:clamp(.8rem,2vw,.875rem);color:#9ca3af}.welcome-feature-icon{width:24px;height:24px;color:#ff0;flex-shrink:0}.hero-headline{font-size:3rem;font-weight:700;color:gold;text-align:center;margin-bottom:1rem;line-height:1.2}.hero-subhead{font-size:1.125rem;color:#fff;text-align:center;max-width:600px;margin-bottom:2.5rem;line-height:1.6}.hero-mic-button{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#e53935,#c62828);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;margin-bottom:1rem;box-shadow:0 4px 12px #e5393566}.hero-mic-button:hover{transform:scale(1.1);box-shadow:0 8px 24px #e5393599}.hero-mic-button .mic-icon{fill:#fff;width:24px;height:24px}.hero-tap-text{font-size:.875rem;color:#9ca3af;text-align:center;margin-bottom:.5rem}.hero-shortcuts{font-size:.875rem;color:#9ca3af;text-align:center}.hero-shortcuts kbd{background:#ffffff1a;padding:.25rem .5rem;border-radius:4px;font-family:monospace;font-size:.75rem;border:1px solid rgba(255,255,255,.2);margin:0 .25rem}.section-header--yellow{color:gold!important}.squad-card__image--full{width:100%;height:auto;border-radius:12px;object-fit:contain!important;max-height:none}.footer-logo-container{display:flex;justify-content:center;margin-bottom:2rem;width:100%}.footer-logo--large{height:72px;width:auto}.demo-section{padding:6rem 2rem;max-width:1200px;margin:0 auto}.demo-header{text-align:center;margin-bottom:4rem}.demo-header h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.demo-header p{font-size:1.125rem;color:#d1d5db;max-width:700px;margin:0 auto}.demo-grid{display:grid;grid-template-columns:1fr;gap:3rem}@media (min-width: 1024px){.demo-grid{grid-template-columns:1fr 1fr}}.demo-card{background:#1e1e3280;border:1px solid rgba(100,149,237,.2);border-radius:16px;padding:2rem;transition:transform .3s ease}.demo-card:hover{transform:translateY(-8px);border-color:#6495ed80}.demo-screenshot{width:100%;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 8px 24px #0006;object-fit:contain;background:#0d0d1a;max-height:450px}.demo-card h3{font-size:1.5rem;margin-bottom:1rem;color:#6495ed}.demo-card p{color:#d1d5db;line-height:1.6}.proof-section{padding:6rem 2rem;background:#0a0a0acc}.proof-header{text-align:center;margin-bottom:4rem}.proof-header h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.proof-header p{font-size:1.125rem;color:#d1d5db}.proof-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:1200px;margin:0 auto}@media (min-width: 768px){.proof-grid{grid-template-columns:1fr 1fr}}.proof-card{position:relative;overflow:hidden;border-radius:16px;cursor:pointer;transition:transform .3s ease}.proof-card:hover{transform:scale(1.05)}.proof-image{width:100%;height:400px;display:block;object-fit:contain;object-position:center;background:#0d0d1a}.proof-overlay{position:absolute;bottom:0;left:0;width:100%;padding:2rem;background:linear-gradient(transparent,#000000e6)}.proof-overlay h4{font-size:1.5rem;margin-bottom:.5rem;color:#6495ed}.proof-overlay p{color:#d1d5db;line-height:1.4}.squad-section{padding:6rem 2rem;max-width:1400px;margin:0 auto}.squad-header{text-align:center;margin-bottom:4rem}.squad-header h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.squad-header p{font-size:1.125rem;color:#d1d5db}.squad-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width: 768px){.squad-grid{grid-template-columns:1fr 1fr}}@media (min-width: 1024px){.squad-grid{grid-template-columns:repeat(4,1fr)}}.squad-card{background:#1e1e3280;border:2px solid;border-radius:16px;padding:2rem;text-align:center;transition:all .3s ease}.squad-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px #00000080}.squad-card--cyan{border-color:#00ffff4d}.squad-card--cyan:hover{border-color:#0ff9;box-shadow:0 12px 32px #00ffff4d}.squad-card--purple{border-color:#9333ea4d}.squad-card--purple:hover{border-color:#9333ea99;box-shadow:0 12px 32px #9333ea4d}.squad-card--blue{border-color:#6495ed4d}.squad-card--blue:hover{border-color:#6495ed99;box-shadow:0 12px 32px #6495ed4d}.squad-card--green{border-color:#22c55e4d}.squad-card--green:hover{border-color:#22c55e99;box-shadow:0 12px 32px #22c55e4d}.squad-orb{width:150px;height:150px;border-radius:50%;margin:0 auto 1.5rem;box-shadow:0 8px 24px #0006}.squad-card h3{font-size:1.75rem;margin-bottom:.5rem}.squad-card h4{font-size:1rem;color:#9ca3af;margin-bottom:1rem;text-transform:uppercase;letter-spacing:1px}.squad-card p{color:#d1d5db;line-height:1.6;font-size:.9375rem}.footer-section{background:#0a0a0a;border-top:1px solid rgba(100,149,237,.2);padding:4rem 2rem 2rem}.footer-content{display:flex;flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto 2rem}@media (min-width: 768px){.footer-content{flex-direction:row;justify-content:space-between;align-items:center}}.footer-left{display:flex;flex-direction:column;align-items:center;gap:.5rem}@media (min-width: 768px){.footer-left{align-items:flex-start}}.footer-logo{height:48px}.footer-tagline{color:#9ca3af;font-size:.875rem}.footer-center{display:flex;flex-direction:column;gap:1rem;align-items:center}@media (min-width: 768px){.footer-center{flex-direction:row;gap:2rem}}.footer-link{color:#6495ed;text-decoration:none;font-weight:500;transition:color .3s ease}.footer-link:hover{color:#fff}.footer-seo{max-width:800px;margin:2rem auto 0;padding-top:2rem;border-top:1px solid rgba(100,149,237,.1);text-align:center;color:#6b7280;font-size:.75rem;line-height:1.6}.footer-copyright{margin-top:1rem;color:#4b5563}.waitlist-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.waitlist-modal{background:#141423f2;border:1px solid rgba(100,149,237,.3);border-radius:24px;padding:3rem;max-width:500px;width:100%;position:relative;box-shadow:0 20px 60px #000c}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#9ca3af;font-size:2rem;cursor:pointer;transition:color .3s ease}.modal-close:hover{color:#fff}.modal-header{text-align:center;margin-bottom:2rem}.modal-header .lock-icon{font-size:3rem;margin-bottom:1rem}.modal-header h2{font-size:2rem;margin-bottom:.5rem}.modal-header p{color:#d1d5db}.waitlist-form{display:flex;flex-direction:column;gap:1rem}.waitlist-input{padding:1rem;background:#1e1e3280;border:1px solid rgba(100,149,237,.3);border-radius:12px;color:#fff;font-size:1rem;transition:border-color .3s ease}.waitlist-input:focus{outline:none;border-color:#6495ed99}.waitlist-input:disabled{opacity:.5;cursor:not-allowed}.waitlist-submit-btn{padding:1rem 2rem;background:linear-gradient(135deg,#6495ed,#4169e1);color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s ease}.waitlist-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #6495ed66}.waitlist-submit-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{color:#ef4444;font-size:.875rem;text-align:center}.modal-fine-print{text-align:center;color:#9ca3af;font-size:.75rem;margin-top:1rem}.modal-success{text-align:center}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff;margin:0 auto 2rem;animation:successPop .5s ease-out}@keyframes successPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.modal-success h2{font-size:2rem;margin-bottom:1rem}.modal-success p{color:#d1d5db;line-height:1.6}@media (max-width: 768px){.hero-section{padding-top:5rem}.hero-headline{font-size:2rem}.hero-orb{width:150px;height:150px}.hero-mic-button{width:70px;height:70px}.demo-header h2,.proof-header h2,.squad-header h2{font-size:2rem}.waitlist-modal{padding:2rem}.landing-nav{padding:.75rem 1rem}.landing-nav__logo{height:28px}.landing-nav__btn{padding:.4rem .75rem;font-size:.8rem}}.dev-mode-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#d32f2f,#c62828);color:#fff;box-shadow:0 2px 8px #0000004d;animation:slideDown .3s ease-out}.dev-mode-banner__content{display:flex;align-items:center;justify-content:center;padding:12px 20px;max-width:1200px;margin:0 auto;gap:12px}.dev-mode-banner__icon{font-size:24px;animation:pulse 2s ease-in-out infinite}.dev-mode-banner__message{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;letter-spacing:.3px}.dev-mode-banner__message strong{font-weight:700;font-size:15px}.dev-mode-banner__env{display:inline-block;padding:2px 8px;background:#fff3;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.dev-mode-banner__dismiss{margin-left:auto;background:none;border:none;color:#fff;font-size:28px;line-height:1;cursor:pointer;padding:0 8px;opacity:.8;transition:opacity .2s ease,transform .2s ease}.dev-mode-banner__dismiss:hover{opacity:1;transform:scale(1.1)}.dev-mode-banner__dismiss:active{transform:scale(.95)}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@media (max-width: 640px){.dev-mode-banner__content{padding:10px 16px;gap:8px}.dev-mode-banner__icon{font-size:20px}.dev-mode-banner__message{font-size:13px;flex-direction:column;align-items:flex-start;gap:4px}.dev-mode-banner__env{font-size:11px;padding:1px 6px}.dev-mode-banner__dismiss{font-size:24px}}@media (prefers-reduced-motion: reduce){.dev-mode-banner,.dev-mode-banner__icon{animation:none}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;width:100vw;height:100vh;overflow:hidden;background-color:#0d1117}html{margin:0;padding:0;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.App{width:100%;max-width:none;margin:0;padding:0;text-align:center;min-height:100vh;background:#f5f7fa}.main-menu{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.menu-container{max-width:1200px;width:100%;text-align:center}.menu-container h1{font-size:48px;color:#fff;margin-bottom:12px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.menu-subtitle{font-size:20px;color:#ffffffe6;margin-bottom:48px}.menu-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;padding:0 20px}.menu-card{background:#fff;border-radius:16px;padding:40px 32px;text-decoration:none;color:inherit;transition:all .3s ease;box-shadow:0 4px 12px #00000026;cursor:pointer}.menu-card:hover{transform:translateY(-8px);box-shadow:0 8px 24px #0003}.menu-icon{font-size:64px;margin-bottom:20px}.menu-card h2{font-size:28px;color:#2c3e50;margin-bottom:12px}.menu-card p{font-size:16px;color:#7f8c8d;line-height:1.6}@media (max-width: 768px){.menu-container h1{font-size:36px}.menu-subtitle{font-size:18px}.menu-cards{grid-template-columns:1fr;gap:16px}.menu-card{padding:32px 24px}.menu-icon{font-size:48px}.menu-card h2{font-size:24px}}.game-shell{--game-red: #ef4444;--game-red-dark: #991b1b;--game-gold: #FFD700;--game-gold-dark: #B8860B;--game-bg-primary: #1a0a0a;--game-bg-secondary: #2d1515;--game-bg-gradient: linear-gradient( 135deg, var(--game-bg-primary) 0%, var(--game-bg-secondary) 50%, var(--game-red-dark) 100% );--game-panel-bg: rgba(45, 21, 21, .9);--game-header-bg: rgba(26, 10, 10, .95);--game-footer-bg: rgba(26, 10, 10, .95);--game-text-primary: #fef2f2;--game-text-secondary: #fca5a5;--game-text-muted: #f87171;--orb-vowel: #3B82F6;--orb-plosive: #FFD700;--orb-fricative: #22C55E;--orb-nasal: #EF4444;--orb-approximant: #8B5CF6;--orb-frozen: #7C3AED;--game-shadow: 0 4px 20px rgba(0, 0, 0, .5);--game-glow-gold: 0 0 20px rgba(255, 215, 0, .4);--game-glow-red: 0 0 20px rgba(239, 68, 68, .4);--game-glow-success: 0 0 20px rgba(34, 197, 94, .4);--game-success: #22C55E;--game-error: #EF4444;--game-warning: #F59E0B;--game-info: #3B82F6;--game-transition-fast: .15s ease-out;--game-transition-normal: .25s ease-out;--game-transition-slow: .4s ease-out}.password-reminder-toast{position:fixed;bottom:2rem;right:2rem;background:#6495edf2;color:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 8px 24px #0000004d;display:flex;align-items:center;gap:1rem;max-width:400px;animation:toastSlideIn .3s ease-out;z-index:999}.password-reminder-toast p{margin:0;font-size:.875rem;line-height:1.4;color:#fff}.password-reminder-toast button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;opacity:.7;transition:opacity .3s;padding:0;min-width:24px}.password-reminder-toast button:hover{opacity:1}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;padding:0}
