@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--color-bg: #0a0a0a;--color-surface: #1a1a1a;--color-surface-2: #262626;--color-surface-3: #0f0f0f;--color-border: #333;--color-border-strong: #444;--color-text: #e5e5e5;--color-text-dim: #999;--color-text-muted: #666;--color-accent: #39d353;--color-accent-dim: #2ecc71;--color-accent-deep: #229954;--color-accent-soft: rgba(57, 211, 83, .15);--color-accent-glow: rgba(57, 211, 83, .3);--color-accent-tint: rgba(57, 211, 83, .08);--color-warning: #ffc857;--color-warning-strong: #f39c12;--color-warning-orange: #ff9500;--color-danger: #ff5f5f;--color-danger-strong: #c0392b;--color-info: #5b9aff;--color-provisional: #ffc857;--color-on-accent: #fff;--font-mono: "JetBrains Mono", "Monaco", "Courier New", ui-monospace, monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 999px;--shadow-soft: 0 4px 12px rgba(0, 0, 0, .3);--shadow-glow: 0 0 0 3px var(--color-accent-soft);--shadow-press: inset 0 2px 8px rgba(0, 0, 0, .5);--t-fast: .12s ease;--t-base: .2s cubic-bezier(.4, 0, .2, 1)}body{font-family:var(--font-mono);background:var(--color-bg);min-height:100vh;display:flex;justify-content:center;align-items:center;color:var(--color-text);padding:20px}#root{width:100%;max-width:1280px;height:calc(100vh - 40px)}button{cursor:pointer;border:1px solid transparent;border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:var(--font-mono);transition:background var(--t-base),border-color var(--t-base),transform var(--t-fast),box-shadow var(--t-base);background:var(--color-surface-2);color:var(--color-text);padding:10px 16px}button:hover{background:var(--color-border);border-color:var(--color-accent);box-shadow:0 4px 12px var(--color-accent-soft)}button:active{transform:translateY(0);background:var(--color-surface)}button:disabled{opacity:.4;cursor:not-allowed;transform:none;border-color:transparent;box-shadow:none}button:disabled:hover{background:var(--color-surface-2);border-color:transparent;box-shadow:none}input{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 16px;font-size:14px;font-family:var(--font-mono);outline:none;transition:border-color var(--t-base),background var(--t-base),box-shadow var(--t-base);background:var(--color-surface);color:var(--color-text)}input:focus{border-color:var(--color-accent);background:var(--color-surface-2);box-shadow:var(--shadow-glow)}@media(max-width:768px){body{padding:10px}#root{height:calc(100vh - 20px)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:1px solid transparent;border-radius:var(--radius-md);font-family:var(--font-mono);font-weight:600;letter-spacing:.02em;transition:background var(--t-base),border-color var(--t-base),color var(--t-base),box-shadow var(--t-base),transform var(--t-fast);text-decoration:none;user-select:none;white-space:nowrap}.btn:focus-visible{outline:none;box-shadow:var(--shadow-glow)}.btn:disabled,.btn[aria-disabled=true]{opacity:.45;cursor:not-allowed;pointer-events:none}.btn--sm{font-size:12px;padding:6px 12px}.btn--md{font-size:14px;padding:10px 18px}.btn--lg{font-size:15px;padding:13px 22px}.btn--block{width:100%}.btn--primary{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent)}.btn--primary:hover{background:var(--color-accent-dim);border-color:var(--color-accent-dim);box-shadow:0 4px 14px var(--color-accent-glow);transform:translateY(-1px)}.btn--primary:active{transform:translateY(0);background:var(--color-accent-deep);border-color:var(--color-accent-deep)}.btn--ghost{background:transparent;color:var(--color-text);border-color:var(--color-border-strong)}.btn--ghost:hover{background:var(--color-surface-2);border-color:var(--color-accent);color:var(--color-accent)}.btn--ghost:active{background:var(--color-surface)}.btn--danger{background:transparent;color:var(--color-danger);border-color:var(--color-danger)}.btn--danger:hover{background:#ff5f5f1a;color:var(--color-danger);border-color:var(--color-danger);box-shadow:0 4px 14px #ff5f5f33}.btn--danger:active{background:#ff5f5f2e}.btn--subtle{background:transparent;color:var(--color-text-dim);border-color:transparent}.btn--subtle:hover{background:var(--color-surface-2);color:var(--color-text)}.btn__icon{display:inline-flex;align-items:center;font-size:1em;line-height:1}.username-form-container{display:flex;justify-content:center;align-items:center;min-height:100vh}.username-card{background:var(--color-surface);border:1px solid var(--color-border);padding:40px;border-radius:16px;box-shadow:0 20px 60px #0009;text-align:center;max-width:400px;width:100%;backdrop-filter:blur(10px)}.login-logo{width:auto;height:165px;margin:0 auto 20px;filter:drop-shadow(0 0 20px rgba(57,211,83,.5));transition:filter .3s ease}.login-logo:hover{filter:drop-shadow(0 0 30px rgba(57,211,83,.7))}@media(max-width:768px){.login-logo{height:140px}}@media(max-width:480px){.login-logo{height:110px}.username-card{padding:30px 20px}}.username-card h1{font-size:2.5rem;margin-bottom:10px;color:var(--color-accent);font-family:Monaco,monospace}.subtitle{color:var(--color-text-dim);margin-bottom:30px;font-size:14px;font-family:Monaco,monospace}.username-card form{display:flex;flex-direction:column;gap:15px}.username-card input{width:100%}.online-users-badge{display:inline-flex;align-items:center;gap:6px;background:#39d3531a;border:1px solid rgba(57,211,83,.3);padding:6px 12px;border-radius:20px;font-size:12px;color:var(--color-accent);font-weight:600;margin-bottom:20px;font-family:Monaco,monospace}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.version-badge{margin-top:20px;padding:6px 12px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:8px;font-size:10px;color:var(--color-text-muted);font-family:Monaco,monospace;font-weight:600}.mode-selector-page{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-surface-3) 100%)}.mode-content{max-width:900px;margin:0 auto;padding:50px 20px;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.mode-header{text-align:center;margin-bottom:60px;animation:fadeInDown .6s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.welcome-badge{display:inline-block;padding:6px 16px;background:var(--color-accent-soft);border:1px solid var(--color-accent-glow);border-radius:var(--radius-pill);color:var(--color-accent);font-size:12px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}.mode-header h1{color:var(--color-accent);font-size:42px;margin-bottom:16px;font-weight:700;text-shadow:0 2px 10px rgba(57,211,83,.3)}.mode-subtitle{color:var(--color-text-dim);font-size:18px;margin-bottom:24px}.mode-header p{color:var(--color-text-dim);font-size:17px;margin-bottom:20px;line-height:1.6;font-family:var(--font-mono)}.online-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 20px;background:#39d35326;border:2px solid rgba(57,211,83,.4);border-radius:24px;color:var(--color-accent);font-size:15px;font-weight:600;box-shadow:0 4px 16px #39d35333;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 4px 16px #39d35333}50%{transform:scale(1.02);box-shadow:0 6px 20px #39d3534d}}.online-dot{width:10px;height:10px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 10px var(--color-accent);animation:blink 2s ease-in-out infinite}.mode-cards{display:flex;gap:30px;width:100%;max-width:800px;flex-wrap:wrap;justify-content:center}.mode-card{flex:1;min-width:320px;max-width:380px;background:linear-gradient(145deg,var(--color-surface-2),var(--color-surface));border:3px solid var(--color-border);border-radius:24px;padding:42px 32px;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);text-align:center;position:relative;overflow:hidden}.mode-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.03) 100%);opacity:0;transition:opacity .4s ease}.mode-card:hover:before{opacity:1}.mode-card:hover{transform:translateY(-8px);box-shadow:0 16px 40px #0009}.chat-card{border-color:var(--color-accent)}.chat-card:hover{border-color:var(--color-accent-dim);box-shadow:0 16px 40px var(--color-accent-glow);background:linear-gradient(145deg,var(--color-surface-2),var(--color-surface))}.practice-card{border-color:var(--color-border-strong)}.practice-card:hover{border-color:var(--color-accent);box-shadow:0 16px 40px #00000080;background:linear-gradient(145deg,var(--color-surface-2),var(--color-surface))}.card-icon{font-size:64px;margin-bottom:24px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.mode-card h2{color:var(--color-text);font-size:28px;margin-bottom:14px;font-weight:700}.mode-card p{color:var(--color-text-dim);font-size:15px;line-height:1.7;margin-bottom:20px}.card-badge{display:inline-block;padding:6px 14px;background:var(--color-surface-2);border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);color:var(--color-text-dim);font-size:12px;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.5px}.card-badge.primary{background:var(--color-accent-soft);border-color:var(--color-accent-glow);color:var(--color-accent)}@media(max-width:768px){.mode-content{padding:32px 16px}.mode-header{margin-bottom:40px}.mode-header h1{font-size:32px}.mode-header p{font-size:15px}.welcome-badge{font-size:11px;padding:5px 12px}.online-badge{font-size:13px;padding:8px 16px}.mode-cards{flex-direction:column;gap:24px}.mode-card{min-width:100%;padding:36px 28px}.card-icon{font-size:56px}.mode-card h2{font-size:24px}.mode-card p{font-size:14px}}.morse-key-container{display:flex;justify-content:center;align-items:center;padding:8px;flex-shrink:0;min-height:160px}.morse-key{width:140px;height:140px;border-radius:50%;background:linear-gradient(145deg,var(--color-accent),var(--color-accent-dim));border:5px solid var(--color-accent-deep);box-shadow:0 6px 16px #0006,inset 0 -4px 8px #00000040;cursor:pointer;transition:transform .15s cubic-bezier(.4,0,.2,1),box-shadow var(--t-base),background var(--t-base);display:flex;flex-direction:column;justify-content:center;align-items:center;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative;overflow:hidden}.morse-key:not(.disabled):hover{transform:scale(1.04);box-shadow:0 10px 25px #00000073,0 0 22px var(--color-accent-glow),inset 0 -4px 8px #00000040}.morse-key:not(.disabled):active,.morse-key.pressed{transform:scale(.92);box-shadow:0 4px 12px #00000080,0 0 24px var(--color-accent-glow),inset 0 8px 16px #00000080;background:linear-gradient(145deg,var(--color-accent-dim),var(--color-accent-deep))}.morse-key.pressed{animation:intensePulse .3s ease-out}@keyframes intensePulse{0%{box-shadow:0 4px 12px #00000080,inset 0 8px 16px #00000080}40%{box-shadow:0 0 24px var(--color-accent-glow),0 0 36px var(--color-accent-soft),inset 0 8px 16px #00000080}to{box-shadow:0 4px 12px #00000080,inset 0 8px 16px #00000080}}.morse-key.disabled{background:linear-gradient(145deg,var(--color-border-strong),var(--color-border));border-color:var(--color-border-strong);cursor:not-allowed;opacity:.5;box-shadow:0 4px 12px #0006}.morse-key-content{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;z-index:10}.morse-key-label{font-size:16px;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:1px}.morse-key-hint{font-size:10px;color:#ffffffe6;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.press-progress{position:absolute;bottom:0;left:50%;transform:translate(-50%);height:8px;background:linear-gradient(90deg,#f1c40f,var(--color-warning-strong),var(--color-warning-strong));border-radius:4px;transition:width .05s linear;box-shadow:0 0 16px #f39c12cc,inset 0 -2px 4px #0000004d;z-index:5}.ripple{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.5) 0%,var(--color-accent-soft) 35%,transparent 70%);width:100%;height:100%;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);animation:rippleEffect .8s cubic-bezier(0,0,.2,1);pointer-events:none;z-index:1}@keyframes rippleEffect{0%{transform:translate(-50%,-50%) scale(0);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}.timing-feedback{position:absolute;top:-120px;left:50%;transform:translate(-50%);background:linear-gradient(145deg,var(--color-surface),var(--color-surface-2));border:2px solid var(--color-accent);border-radius:var(--radius-md);padding:12px 16px;min-width:200px;box-shadow:0 4px 12px #0006,0 0 20px var(--color-accent-glow);animation:feedbackSlideIn .3s ease-out;z-index:100}@keyframes feedbackSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.timing-feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.timing-feedback-signal{font-size:28px;font-weight:700;color:var(--color-on-accent)}.timing-feedback-accuracy{font-size:24px;font-weight:700}.timing-feedback-details{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:12px}.timing-feedback-label{color:#ffffffb3;text-align:right}.timing-feedback-value{color:var(--color-on-accent);font-weight:700}.adaptive-stats{position:absolute;top:-50px;left:50%;transform:translate(-50%);background:#000000b3;border:2px solid rgba(139,195,74,.5);border-radius:8px;padding:6px 12px;display:flex;gap:8px;align-items:center;font-size:12px;white-space:nowrap}.adaptive-stats-label{color:#fffc}.adaptive-stats-value{color:var(--color-accent);font-weight:700}.timing-targets{position:absolute;bottom:-60px;left:50%;transform:translate(-50%);display:flex;gap:20px;background:#0009;border:2px solid rgba(255,255,255,.2);border-radius:12px;padding:8px 16px}.timing-target{display:flex;flex-direction:column;align-items:center;gap:4px}.timing-target-symbol{font-size:24px;font-weight:700;color:var(--color-on-accent)}.timing-target-value{font-size:11px;color:#ffffffb3;font-weight:600}.settings-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:settings-fade .18s ease;backdrop-filter:blur(4px);padding:20px}@keyframes settings-fade{0%{opacity:0}to{opacity:1}}.settings-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:86vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 10px 40px #0009;animation:settings-slide .22s cubic-bezier(.4,0,.2,1)}@keyframes settings-slide{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--color-surface-2);border-bottom:1px solid var(--color-border);color:var(--color-accent);flex-shrink:0}.settings-header h3{margin:0;font-size:14px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em}.settings-close-btn{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-dim);font-size:14px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background var(--t-base),border-color var(--t-base),color var(--t-base)}.settings-close-btn:hover{background:var(--color-surface-2);border-color:var(--color-accent);color:var(--color-accent)}.settings-tabs{display:flex;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:4px 4px 0;gap:2px;flex-shrink:0;overflow-x:auto;scrollbar-width:none}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-dim);font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:color var(--t-base),border-color var(--t-base),background var(--t-base);white-space:nowrap;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.settings-tab:hover:not(.settings-tab--active){color:var(--color-text);background:var(--color-surface-2)}.settings-tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.settings-tab__icon{font-size:13px}.settings-tab__label{letter-spacing:.04em}.settings-content{padding:16px 18px 22px;overflow-y:auto;flex:1;background:var(--color-surface)}.settings-content::-webkit-scrollbar{width:8px}.settings-content::-webkit-scrollbar-track{background:var(--color-surface)}.settings-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.settings-content::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}.settings-section{display:flex;flex-direction:column;gap:10px}.settings-section__header{margin-top:12px}.settings-section__header:first-child{margin-top:0}.settings-section__header h4{margin:0 0 4px;font-size:12px;font-weight:700;font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-dim)}.settings-section__header p{margin:0 0 6px;font-size:12px;color:var(--color-text-dim);line-height:1.5;font-family:var(--font-mono)}.settings-section__header--sub{margin-top:18px;padding-top:14px;border-top:1px solid var(--color-border)}.settings-meta{font-size:11px;color:var(--color-text-dim);font-family:var(--font-mono)}.tolerance-grid{display:grid;grid-template-columns:1fr;gap:8px}@media(min-width:540px){.tolerance-grid{grid-template-columns:repeat(3,1fr)}}.tolerance-card{text-align:left;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px;cursor:pointer;transition:border-color var(--t-base),background var(--t-base),transform var(--t-fast);font-family:var(--font-mono);display:flex;flex-direction:column;gap:4px;min-width:0}.tolerance-card:hover{border-color:var(--color-accent);background:var(--color-surface);transform:translateY(-1px)}.tolerance-card--selected{border-color:var(--color-accent);background:var(--color-accent-tint)}.tolerance-card__row{display:flex;justify-content:space-between;align-items:center;gap:6px}.tolerance-card__label{font-size:13px;font-weight:700;color:var(--color-text)}.tolerance-card--selected .tolerance-card__label{color:var(--color-accent)}.tolerance-card__rec{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-warning);background:#ffc8571f;border:1px solid rgba(255,200,87,.35);padding:1px 6px;border-radius:var(--radius-pill);white-space:nowrap}.tolerance-card__gap{font-size:11px;color:var(--color-accent);font-weight:600}.tolerance-card__desc{font-size:10px;color:var(--color-text-dim);line-height:1.4;word-break:break-word}.toggle-row{display:flex;align-items:flex-start;gap:12px;padding:8px 10px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--t-base),background var(--t-base)}.toggle-row:hover{border-color:var(--color-border-strong)}.toggle-row input{position:absolute;opacity:0;pointer-events:none}.toggle-row__visual{display:inline-block;position:relative;width:34px;height:20px;background:var(--color-surface-3);border:1px solid var(--color-border-strong);border-radius:999px;flex-shrink:0;margin-top:2px;transition:background var(--t-base),border-color var(--t-base)}.toggle-row__thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--color-text-dim);border-radius:50%;transition:left var(--t-base),background var(--t-base)}.toggle-row input:checked+.toggle-row__visual{background:var(--color-accent-soft);border-color:var(--color-accent)}.toggle-row input:checked+.toggle-row__visual .toggle-row__thumb{left:16px;background:var(--color-accent)}.toggle-row__text{display:flex;flex-direction:column;gap:2px;min-width:0}.toggle-row__label{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--color-text)}.toggle-row__hint{font-family:var(--font-mono);font-size:11px;color:var(--color-text-dim);line-height:1.4}.slider-row{display:flex;flex-direction:column;gap:4px;padding:8px 10px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md)}.slider-row__head{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.slider-row__label{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--color-text)}.slider-row__value{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--color-accent);white-space:nowrap}.slider-row__hint{font-family:var(--font-mono);font-size:11px;color:var(--color-text-dim);line-height:1.4}.slider-row__input{width:100%;height:6px;background:var(--color-surface-3);border-radius:3px;appearance:none;-webkit-appearance:none;outline:none;margin:4px 0 2px}.slider-row__input::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-accent);cursor:pointer;margin-top:-5px;border:none}.slider-row__input::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-accent);cursor:pointer;border:none}.slider-row__input::-webkit-slider-runnable-track{height:6px;background:var(--color-surface-3);border-radius:3px}.slider-row__input::-moz-range-track{height:6px;background:var(--color-surface-3);border-radius:3px}.shortcut-grid{display:grid;grid-template-columns:1fr;gap:6px}@media(min-width:540px){.shortcut-grid{grid-template-columns:1fr 1fr}}.shortcut-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 10px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);min-width:0}.shortcut-keys{display:inline-flex;align-items:center;gap:4px;flex-shrink:0}.shortcut-key{display:inline-block;padding:2px 7px;background:var(--color-surface-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--color-accent);box-shadow:0 1px 0 var(--color-bg);white-space:nowrap}.shortcut-sep{font-family:var(--font-mono);font-size:11px;color:var(--color-text-muted)}.shortcut-desc{font-family:var(--font-mono);font-size:12px;color:var(--color-text);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.help-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.help-list li{font-family:var(--font-mono);font-size:12px;color:var(--color-text);line-height:1.6;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);position:relative;padding:8px 12px 8px 28px}.help-list li:before{content:"→";position:absolute;left:12px;top:8px;color:var(--color-accent);font-weight:700}.help-list strong{color:var(--color-accent)}@media(max-width:480px){.settings-overlay{padding:0;align-items:stretch}.settings-panel{max-width:100%;max-height:100vh;border-radius:0}.settings-tab{padding:10px;font-size:11px}.settings-tab__label{letter-spacing:.02em}.settings-content{padding:14px 14px 22px}.toggle-row,.slider-row,.tolerance-card,.help-list li{padding:8px 10px}.shortcut-row{flex-direction:column;align-items:flex-start;gap:4px}.shortcut-desc{text-align:left;white-space:normal}}.helper-toggle{position:fixed;bottom:20px;left:20px;z-index:999;display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--color-surface-2);border:1px solid var(--color-border-strong);color:var(--color-accent);border-radius:var(--radius-pill);font-size:13px;font-weight:600;font-family:var(--font-mono);cursor:pointer;box-shadow:0 4px 12px #0006;transition:background var(--t-base),border-color var(--t-base),transform var(--t-fast),box-shadow var(--t-base)}.helper-toggle:hover{transform:translateY(-2px);background:var(--color-surface);border-color:var(--color-accent);box-shadow:0 6px 16px var(--color-accent-soft)}.helper-icon{font-size:16px}iframe[src*=buymeacoffee]{transform:scale(.7);transform-origin:bottom right}.helper-backdrop{position:fixed;inset:0;background:#00000073;backdrop-filter:blur(2px);z-index:1000;animation:helper-fade-in .2s ease}@keyframes helper-fade-in{0%{opacity:0}to{opacity:1}}.helper-drawer{position:fixed;top:0;right:0;height:100vh;width:min(440px,92vw);background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:-10px 0 40px #0009;display:flex;flex-direction:column;z-index:1001;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);pointer-events:none}.helper-drawer--open{transform:translate(0);pointer-events:auto}.helper-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--color-surface-2);border-bottom:1px solid var(--color-border);color:var(--color-accent);flex-shrink:0}.helper-header h3{margin:0;font-size:14px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em}.close-btn{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-dim);font-size:16px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background var(--t-base),border-color var(--t-base),color var(--t-base)}.close-btn:hover{background:var(--color-surface-2);border-color:var(--color-accent);color:var(--color-accent)}.helper-content{padding:16px;overflow-y:auto;flex:1;background:var(--color-surface);display:flex;flex-direction:column;gap:12px}.timing-info{background:var(--color-surface-3);border:1px solid var(--color-border);padding:10px 12px;border-radius:var(--radius-md);font-size:12px;line-height:1.7;font-family:var(--font-mono)}.timing-info strong{color:var(--color-accent);font-size:12px;display:block;margin-bottom:4px}.timing-info p{margin:2px 0;color:var(--color-text-dim)}.morse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px}.morse-item{display:flex;flex-direction:column;align-items:center;padding:8px 6px;background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:background var(--t-base),border-color var(--t-base),transform var(--t-fast)}.morse-item:hover{background:var(--color-surface-2);border-color:var(--color-accent);transform:translateY(-1px)}.morse-letter{font-size:16px;font-weight:700;color:var(--color-accent);margin-bottom:2px;font-family:var(--font-mono)}.morse-code{font-family:var(--font-mono);font-size:12px;color:var(--color-text-dim);letter-spacing:1.5px}.helper-content::-webkit-scrollbar{width:8px}.helper-content::-webkit-scrollbar-track{background:var(--color-surface)}.helper-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.helper-content::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}@media(max-width:768px){.helper-toggle{bottom:12px;left:12px;padding:7px 12px;font-size:11px}.helper-icon{font-size:14px}.helper-text{font-size:11px}.helper-drawer{width:100vw}iframe[src*=buymeacoffee]{transform:scale(.55);transform-origin:bottom right}.morse-grid{grid-template-columns:repeat(auto-fill,minmax(58px,1fr));gap:6px}.morse-item{padding:6px 4px}.morse-letter{font-size:15px}.morse-code{font-size:11px}}@media(max-width:480px){.helper-toggle{padding:5px 10px;font-size:10px}.helper-icon{font-size:12px}.helper-text{font-size:10px}iframe[src*=buymeacoffee]{transform:scale(.45);transform-origin:bottom right}}.player-card{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:13px;color:var(--color-text);min-width:0;max-width:100%;transition:border-color var(--t-base),background var(--t-base)}.player-card--you{border-color:var(--color-accent);background:linear-gradient(180deg,var(--color-accent-tint),var(--color-surface))}.player-card--partner{border-color:var(--color-info);background:linear-gradient(180deg,rgba(91,154,255,.08),var(--color-surface))}.player-card--disconnected{opacity:.55;border-color:var(--color-border);background:var(--color-surface)}.player-card__role{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);flex-shrink:0}.player-card--you .player-card__role{color:var(--color-accent)}.player-card--partner .player-card__role{color:var(--color-info)}.player-card__name{font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:18ch}.player-card__name--placeholder{color:var(--color-text-muted);font-style:italic;font-weight:400}.player-card__meta{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.player-card__chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-pill);background:var(--color-surface-2);border:1px solid var(--color-border);font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--color-accent);white-space:nowrap}.player-card__typing{display:inline-flex;gap:2px}.player-card__typing span{width:4px;height:4px;border-radius:50%;background:var(--color-accent);animation:pc-typing 1s infinite ease-in-out}.player-card__typing span:nth-child(2){animation-delay:.15s}.player-card__typing span:nth-child(3){animation-delay:.3s}@keyframes pc-typing{0%,60%,to{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}@media(max-width:768px){.player-card{padding:5px 10px;font-size:12px}.player-card__name{max-width:12ch}}.skip-playback-btn{background:#39d35326;border:1px solid rgba(57,211,83,.5);color:var(--color-accent);font-family:Monaco,monospace;font-size:11px;padding:3px 10px;margin-left:8px;border-radius:12px;cursor:pointer;transition:all .15s}.skip-playback-btn:hover{background:#39d3534d;transform:translateY(-1px)}.transcript{margin:0;background:var(--color-surface-3);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:0 2px 8px #0000004d;overflow:hidden;display:flex;flex-direction:column;flex:1;min-height:0}.transcript-header{background:linear-gradient(180deg,var(--color-surface-2) 0%,var(--color-surface) 100%);border-bottom:1px solid var(--color-border);padding:8px 12px;display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}.transcript-header>.player-card{flex:0 1 auto;min-width:0}.transcript-header-actions{display:inline-flex;gap:6px;flex:1 1 auto;justify-content:center;min-width:0}.transcript-icon-btn{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-dim);font-size:13px;width:28px;height:28px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--t-base),border-color var(--t-base),color var(--t-base),transform var(--t-fast);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:0}.transcript-icon-btn:hover{background:var(--color-surface-2);border-color:var(--color-accent);color:var(--color-accent)}.transcript-icon-btn:active{transform:scale(.95)}.chat-container{padding:12px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:6px;min-height:0;background:var(--color-surface-3)}.chat-message{display:flex;width:100%;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.own-message{justify-content:flex-end}.chat-message.partner-message{justify-content:flex-start}.message-bubble{max-width:70%;display:flex;flex-direction:column;border-radius:10px;padding:8px 12px;word-break:break-word}.own-message .message-bubble{background:linear-gradient(135deg,#39d35326,#39d3531a);border:1px solid rgba(57,211,83,.3);border-bottom-right-radius:3px}.partner-message .message-bubble{background:var(--color-surface);border:1px solid var(--color-border);border-bottom-left-radius:3px}.message-content{font-family:Courier New,monospace;font-size:14px;letter-spacing:1.5px;line-height:1.3;margin-bottom:4px}.own-message .message-content{color:var(--color-accent)}.partner-message .message-content{color:var(--color-text)}.message-translation{margin-top:4px;padding:6px 10px;border-radius:6px;font-size:11px;font-family:Monaco,Courier New,monospace;font-style:normal;letter-spacing:normal;line-height:1.3;background:#5b9aff1a;color:var(--color-info);border:1px solid rgba(91,154,255,.3)}.message-meta{display:flex;align-items:center;gap:4px;font-size:9px;margin-top:3px}.own-message .message-meta{justify-content:flex-end}.partner-message .message-meta{justify-content:flex-start}.message-wpm{background:var(--color-accent);color:var(--color-bg);padding:2px 5px;border-radius:6px;font-weight:700;font-size:8px;font-family:Monaco,monospace}.message-time{color:var(--color-text-muted);font-size:9px;font-family:Monaco,monospace}.typing-indicator-message .message-bubble{background:var(--color-surface);border:1px solid var(--color-border);padding:8px 12px;display:flex;align-items:center;gap:8px}.typing-indicator{display:flex;gap:3px}.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--color-info);animation:typingDot 1.4s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-5px);opacity:1}}.typing-text{font-size:11px;color:var(--color-text-dim);font-style:italic;font-family:Monaco,monospace}.live-wpm{color:var(--color-warning-orange);font-weight:700;font-style:normal}.chat-container::-webkit-scrollbar{width:8px}.chat-container::-webkit-scrollbar-track{background:var(--color-surface-3);border-radius:10px}.chat-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:10px}.chat-container::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}@media(max-width:900px){.transcript{margin:0;min-height:280px}.message-bubble{max-width:88%}.message-content{font-size:14px;letter-spacing:1.5px}.message-translation{font-size:12px}}@media(max-width:520px){.transcript-header{gap:6px}.transcript-header>.player-card{flex:1 1 calc(50% - 4px);font-size:12px}.transcript-header-actions{flex:1 1 100%;justify-content:flex-end;order:3}}.morse-controls{display:flex;flex-direction:column;gap:10px;padding:0;background:transparent;border:none;font-family:var(--font-mono);color:var(--color-text)}.mc-live-row{background:#00000059;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px;min-height:60px}.mc-symbols-line{font-size:22px;letter-spacing:2px;line-height:1.3;word-break:break-all;color:var(--color-accent)}.mc-committed-symbols{opacity:1}.mc-in-progress-symbols{opacity:.55;font-style:italic;margin-left:2px;text-shadow:0 0 6px rgba(57,211,83,.4)}.mc-text-line{margin-top:6px;font-size:16px;letter-spacing:1px;color:var(--color-text);display:flex;flex-wrap:wrap;align-items:center;gap:4px}.mc-committed-text{font-weight:600}.mc-provisional-letter{color:var(--color-warning);opacity:.75;font-weight:500}.mc-did-you-mean{display:inline-flex;align-items:center;gap:6px;margin-left:6px;font-size:13px}.mc-question{color:var(--color-danger);font-weight:700;font-size:18px}.mc-dym-label{color:var(--color-text-dim);font-size:12px}.mc-dym-chip{background:#5b9aff26;border:1px solid rgba(91,154,255,.5);color:var(--color-info);padding:3px 10px;border-radius:12px;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;transition:all .15s}.mc-dym-chip:hover{background:#5b9aff4d;transform:translateY(-1px)}.mc-dym-or{color:var(--color-text-dim);font-size:16px}.mc-suggestions{display:flex;gap:8px;flex-wrap:wrap;min-height:36px}.mc-suggestion-chip{flex:1 1 auto;min-width:80px;padding:8px 14px;background:linear-gradient(135deg,#39d35326,#39d35314);border:1px solid rgba(57,211,83,.4);color:var(--color-accent);border-radius:8px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;letter-spacing:1px;transition:all .15s}.mc-suggestion-chip:hover{background:linear-gradient(135deg,#39d3534d,#39d35326);transform:translateY(-1px);box-shadow:0 4px 12px #39d35340}.mc-suggestion-chip:active{transform:translateY(0)}.mc-timeline{display:flex;flex-direction:column;gap:4px}.mc-timeline-track{display:flex;height:14px;border-radius:7px;overflow:hidden;background:#00000080;border:1px solid var(--color-border)}.mc-zone{position:relative;flex:1 1 0;border-right:1px solid rgba(0,0,0,.5);overflow:hidden}.mc-zone:last-child{border-right:none}.mc-zone-letter{background:#39d35326;flex:2}.mc-zone-letter .mc-zone-fill{background:linear-gradient(90deg,rgba(57,211,83,.7),var(--color-accent))}.mc-zone-word{background:#ffc85726;flex:1.5}.mc-zone-word .mc-zone-fill{background:linear-gradient(90deg,rgba(255,200,87,.7),var(--color-warning))}.mc-zone-send{background:#ff5f5f26;flex:1.5;transition:opacity .4s}.mc-zone-send.hidden{opacity:.25}.mc-zone-send.visible{opacity:1}.mc-zone-send .mc-zone-fill{background:linear-gradient(90deg,rgba(255,95,95,.7),var(--color-danger))}.mc-zone-fill{height:100%;width:0%;transition:none}.mc-zone-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:9px;font-weight:600;letter-spacing:1px;color:#ffffffa6;text-transform:uppercase;pointer-events:none;text-shadow:0 0 3px rgba(0,0,0,.8)}.mc-timeline-meta{font-size:10px;color:var(--color-text-dim);display:flex;justify-content:space-between;font-family:Monaco,monospace}.mc-timeline-thresholds{opacity:.6}.mc-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.mc-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:10px 8px;min-height:56px;background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:1px;transition:background var(--t-base),border-color var(--t-base),color var(--t-base),transform var(--t-fast),box-shadow var(--t-base);user-select:none;-webkit-tap-highlight-color:transparent}.mc-btn:hover:not(:disabled){background:var(--color-surface-2);border-color:var(--color-accent);color:var(--color-accent)}.mc-btn:active:not(:disabled){background:var(--color-surface);transform:translateY(0);box-shadow:inset 0 2px 4px #0006}.mc-btn:disabled{opacity:.4;cursor:not-allowed}.mc-btn-icon{font-size:18px;line-height:1}.mc-btn-label{font-size:10px;text-transform:uppercase;letter-spacing:1px}.mc-btn-undo:hover:not(:disabled){border-color:var(--color-danger);color:var(--color-danger)}.mc-btn-letter:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.mc-btn-space:hover:not(:disabled){border-color:var(--color-warning);color:var(--color-warning)}.mc-btn-send{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg)}.mc-btn-send:hover:not(:disabled){background:var(--color-accent-dim);border-color:var(--color-accent-dim);color:var(--color-bg);box-shadow:0 4px 14px var(--color-accent-glow);transform:translateY(-1px)}.mc-btn-send:active:not(:disabled){background:var(--color-accent-deep);border-color:var(--color-accent-deep);transform:translateY(0)}.mc-btn-send:disabled{background:var(--color-surface-2);border-color:var(--color-border-strong);color:var(--color-text-dim)}.mc-keyboard-hint{font-size:10px;color:var(--color-text-dim);text-align:center;letter-spacing:.5px;padding:4px 0}@media(max-width:600px){.mc-symbols-line{font-size:18px}.mc-text-line{font-size:14px}.mc-btn{min-height:52px;padding:8px 6px}.mc-btn-icon{font-size:16px}.mc-btn-label{font-size:9px}.mc-keyboard-hint{display:none}}.seg-switch{display:inline-flex;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:3px;gap:2px;font-family:var(--font-mono)}.seg-switch__option{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 14px;background:transparent;border:none;color:var(--color-text-dim);font-size:12px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--t-base),color var(--t-base);white-space:nowrap}.seg-switch__option:hover:not(.seg-switch__option--active){background:var(--color-surface-2);color:var(--color-text)}.seg-switch__option--active{background:var(--color-accent-soft);color:var(--color-accent);box-shadow:inset 0 0 0 1px var(--color-accent)}.seg-switch__option:disabled{opacity:.4;cursor:not-allowed}.seg-switch__icon{display:inline-flex;font-size:13px}@media(max-width:600px){.seg-switch__option{padding:5px 9px;font-size:11px}}.stat-pill{display:inline-flex;align-items:baseline;gap:6px;padding:5px 11px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-pill);font-family:var(--font-mono);font-size:12px;color:var(--color-text-dim);line-height:1.2;white-space:nowrap;transition:border-color var(--t-base),background var(--t-base),color var(--t-base)}.stat-pill__icon{font-size:13px;line-height:1;align-self:center;color:var(--color-text-dim)}.stat-pill__value{font-weight:700;color:var(--color-text);font-size:13px}.stat-pill__label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.stat-pill--accent .stat-pill__value,.stat-pill--accent .stat-pill__icon{color:var(--color-accent)}.stat-pill--warn .stat-pill__value,.stat-pill--warn .stat-pill__icon{color:var(--color-warning)}.stat-pill--clickable{cursor:pointer;border-color:var(--color-border)}.stat-pill--clickable:hover{border-color:var(--color-accent);background:var(--color-surface-2)}.stat-pill--clickable:focus-visible{outline:none;box-shadow:var(--shadow-glow)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}@media(max-width:768px){html,body{overflow-y:auto;overflow-x:hidden}#root{overflow:visible}}.app-container{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:0 20px 60px #0009;overflow:hidden;height:100%;display:flex;flex-direction:column;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.99)}to{opacity:1;transform:scale(1)}}.status-bar{background:linear-gradient(180deg,var(--color-surface-2) 0%,var(--color-surface) 100%);border-bottom:1px solid var(--color-border);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;flex-wrap:nowrap;min-height:56px}.status-bar__center{display:flex;align-items:center;justify-content:center;gap:12px;flex:1;min-width:0;flex-wrap:wrap;font-family:var(--font-mono);font-size:12px;color:var(--color-text-dim)}.status-bar__right{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.status-bar__text{color:var(--color-text);opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.status-bar__icon-btn{position:relative;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-accent);font-size:14px;width:32px;height:32px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--t-base),border-color var(--t-base),transform var(--t-fast);display:inline-flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.status-bar__icon-btn:hover{background:var(--color-surface-2);border-color:var(--color-accent)}.status-bar__icon-btn:active{transform:scale(.95)}.online-count-indicator{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--color-info);font-weight:600;font-family:var(--font-mono);white-space:nowrap}.online-dot-small{width:6px;height:6px;border-radius:50%;background:var(--color-info);box-shadow:0 0 6px var(--color-info);animation:blink 2s ease-in-out infinite}.connection-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-dim);white-space:nowrap}.connection-dot{width:8px;height:8px;border-radius:50%;animation:blink 2s ease-in-out infinite}.connection-dot.connected{background:var(--color-accent);box-shadow:0 0 8px var(--color-accent)}.connection-dot.disconnected{background:var(--color-danger);box-shadow:0 0 8px var(--color-danger)}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.both-typing-badge{background:var(--color-warning-orange);color:var(--color-on-accent);padding:3px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;font-family:var(--font-mono);animation:pulse 1s ease-in-out infinite;white-space:nowrap}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.main-app-content{flex:1;display:grid;grid-template-columns:minmax(360px,1fr) minmax(320px,1.1fr);gap:12px;padding:12px;overflow:hidden;min-height:0}.left-col{display:flex;flex-direction:column;gap:10px;min-width:0;min-height:0;overflow:auto}.right-col{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}@media(max-width:900px){.main-app-content{grid-template-columns:1fr;gap:10px;padding:10px}.left-col{overflow:visible}.right-col{min-height:280px}}.input-panel{background:linear-gradient(180deg,var(--color-surface-2) 0%,var(--color-surface) 100%);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:12px;display:flex;flex-direction:column;gap:10px;min-width:0}.stats-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;padding:4px 0}.timing-guide{display:flex;justify-content:center;align-items:center;gap:16px;padding:8px 16px;background:var(--color-surface-3);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);flex-shrink:0}.timing-item{display:flex;flex-direction:column;align-items:center;gap:2px}.timing-icon{font-size:14px}.timing-label{font-size:11px;font-weight:700;font-family:var(--font-mono);color:var(--color-accent)}.timing-desc{font-size:9px;color:var(--color-text-dim);font-family:var(--font-mono)}.timing-divider{font-size:18px;color:var(--color-border);font-weight:300}.input-mode-toggle{display:flex;justify-content:center;align-items:center;padding:6px 16px}.mode-toggle{width:140px;height:36px;background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);position:relative;cursor:pointer;transition:background var(--t-base),border-color var(--t-base);padding:0;overflow:hidden}.mode-toggle.active{background:var(--color-accent-soft);border-color:var(--color-accent)}.toggle-slider{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.toggle-option{font-size:12px;font-weight:600;color:var(--color-text-dim);font-family:var(--font-mono);letter-spacing:.04em}.mode-toggle.active .toggle-option{color:var(--color-accent)}.main-content{flex:1;padding:40px 20px;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center}.main-content h2{color:var(--color-text);margin-bottom:16px;font-size:24px;font-weight:600;font-family:var(--font-mono)}.waiting-hint{color:var(--color-text-dim);font-size:14px;margin-top:6px}.waiting-actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap;justify-content:center}.two-circle-container{display:flex;justify-content:center;align-items:center;gap:30px;padding:12px;flex-shrink:0;min-height:170px}.circle-button{width:140px;height:140px;border-radius:50%;border:5px solid var(--color-accent-deep);cursor:pointer;transition:transform .15s cubic-bezier(.4,0,.2,1),box-shadow var(--t-base),background var(--t-base);display:flex;flex-direction:column;justify-content:center;align-items:center;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative;overflow:hidden;background:linear-gradient(145deg,var(--color-accent),var(--color-accent-dim));box-shadow:0 6px 16px #0006,inset 0 -4px 8px #0003}.dot-button,.dash-button{background:linear-gradient(145deg,var(--color-accent),var(--color-accent-dim));border-color:var(--color-accent-deep)}.circle-button:not(:disabled):hover{transform:scale(1.04);box-shadow:0 8px 22px #00000073,0 0 18px var(--color-accent-glow),inset 0 -4px 8px #0003}.circle-button:not(:disabled):active,.circle-button.button-pressed{transform:scale(.92);box-shadow:0 4px 12px #00000080,inset 0 8px 16px #0006;animation:buttonPulse .3s ease-out}@keyframes buttonPulse{0%{box-shadow:0 4px 12px #00000080,inset 0 8px 16px #0006}50%{box-shadow:0 0 25px var(--color-accent-glow),0 0 35px var(--color-accent-soft),inset 0 8px 16px #0006}to{box-shadow:0 4px 12px #00000080,inset 0 8px 16px #0006}}.circle-button:disabled{background:linear-gradient(145deg,var(--color-border-strong),var(--color-border));border-color:var(--color-border-strong);cursor:not-allowed;opacity:.5}.circle-label{font-size:12px;font-weight:700;color:var(--color-on-accent);text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:1.5px;margin-bottom:6px;font-family:var(--font-mono)}.circle-symbol{font-size:36px;font-weight:700;color:var(--color-on-accent);text-shadow:3px 3px 6px rgba(0,0,0,.5);font-family:var(--font-mono)}.live-translation{background:linear-gradient(145deg,var(--color-surface-3),var(--color-surface));border:1px solid var(--color-accent);border-radius:var(--radius-md);padding:10px 14px;margin:0;box-shadow:0 3px 10px #0006,0 0 16px var(--color-accent-soft);animation:slideIn .3s ease-out;min-height:80px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.morse-symbols{font-size:18px;font-weight:700;color:var(--color-accent);font-family:var(--font-mono);margin-bottom:8px;letter-spacing:1.5px;word-break:break-all;line-height:1.4}.translated-text{font-size:14px;color:var(--color-text);font-weight:600;font-family:var(--font-mono);padding-top:8px;border-top:1px solid var(--color-border)}.keyboard-hint{text-align:center;padding:6px 10px;background:var(--color-accent-soft);border:1px solid var(--color-accent-glow);color:var(--color-accent);font-size:10px;font-weight:600;font-family:var(--font-mono);margin:0;border-radius:var(--radius-sm);flex-shrink:0}.settings-hint-badge{position:absolute;bottom:100%;right:-8px;background:var(--color-warning-strong);color:var(--color-on-accent);font-size:10px;padding:4px 8px;border-radius:var(--radius-sm);font-weight:700;font-family:var(--font-mono);white-space:nowrap;animation:bounce-badge 1s ease-in-out infinite,fadeInBadge .3s ease;box-shadow:0 2px 8px #f39c1266;margin-bottom:6px}.settings-hint-badge:after{content:"";position:absolute;top:100%;right:14px;border:6px solid transparent;border-top-color:var(--color-warning-strong)}@keyframes bounce-badge{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes fadeInBadge{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.app-container{border-radius:0;min-height:100vh;height:auto}.status-bar{flex-wrap:wrap;gap:8px;padding:8px 10px;min-height:0}.status-bar__center{order:3;width:100%;justify-content:center;gap:8px;font-size:11px}.online-count-indicator,.connection-status{font-size:11px}.main-app-content{padding:8px;gap:8px}.input-panel{padding:10px;gap:8px}.two-circle-container{gap:14px;padding:8px;min-height:120px}.circle-button{width:94px;height:94px;border-width:3px}.circle-label{font-size:10px;margin-bottom:3px}.circle-symbol{font-size:26px}.live-translation{margin:0;padding:8px 10px}.morse-symbols{font-size:15px;margin-bottom:6px}.translated-text{font-size:12px;padding-top:6px}.keyboard-hint{display:none}}@media(max-width:480px){.main-content h2{font-size:18px;margin-bottom:12px}.waiting-hint{font-size:12px}.two-circle-container{gap:10px;padding:6px;min-height:100px}.circle-button{width:85px;height:85px;border-width:3px}.circle-label{font-size:9px}.circle-symbol{font-size:22px}}.practice-mode-page{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;background:var(--color-surface)}.practice-content{max-width:900px;margin:0 auto;padding:30px 20px;min-height:100%}.practice-header{text-align:center;margin-bottom:40px}.practice-header h1{color:var(--color-accent);font-size:36px;margin-bottom:12px;font-weight:700}.practice-header p{color:var(--color-text-dim);font-size:16px;margin-bottom:24px}.back-btn{padding:10px 20px;background:var(--color-surface-2);border:2px solid var(--color-border);border-radius:10px;color:var(--color-accent);font-size:14px;cursor:pointer;transition:all .3s ease}.back-btn:hover{background:var(--color-border);border-color:var(--color-accent);transform:translateY(-2px)}.sandbox-card-container{max-width:700px;margin:0 auto 30px}.sandbox-card{width:100%;background:linear-gradient(145deg,#2a2a2a,#1e1e1e);border:3px solid var(--color-accent);border-radius:20px;padding:32px;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:24px;position:relative;overflow:hidden}.sandbox-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(57,211,83,.1) 0%,transparent 100%);opacity:0;transition:opacity .4s ease}.sandbox-card:hover:before{opacity:1}.sandbox-card:hover{transform:translateY(-6px);border-color:var(--color-accent-dim);box-shadow:0 12px 32px #39d35366}.sandbox-icon{font-size:64px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.sandbox-content{flex:1;text-align:left}.sandbox-content h2{color:var(--color-accent);font-size:26px;margin-bottom:10px;font-weight:700}.sandbox-content p{color:#bbb;font-size:15px;line-height:1.6;margin-bottom:12px}.sandbox-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dim));border-radius:12px;color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #39d3534d}.section-divider{text-align:center;margin:40px auto;position:relative;max-width:600px}.section-divider:before,.section-divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:linear-gradient(to right,transparent,var(--color-border),transparent)}.section-divider:before{left:0}.section-divider:after{right:0}.section-divider span{background:var(--color-surface);padding:0 20px;color:var(--color-text-muted);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.tutorial-section-title{text-align:center;color:var(--color-text-dim);font-size:18px;margin-bottom:24px;font-weight:600}.tutorial-list{display:flex;flex-direction:column;gap:16px;max-width:700px;margin:0 auto}.tutorial-card{background:linear-gradient(145deg,var(--color-surface-2),var(--color-surface));border:2px solid var(--color-border);border-radius:16px;padding:24px;cursor:pointer;transition:all .3s ease;text-align:left;position:relative}.tutorial-card:hover{border-color:#3498db;transform:translate(8px);box-shadow:0 8px 20px #3498db33}.tutorial-number{position:absolute;top:16px;right:16px;background:#3498db;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.tutorial-card h3{color:var(--color-text);font-size:20px;margin-bottom:8px;font-weight:600}.tutorial-card p{color:var(--color-text-dim);font-size:14px;margin-bottom:12px;line-height:1.5}.tutorial-target{color:var(--color-text-muted);font-size:13px;font-family:Monaco,monospace}.target-text{color:var(--color-accent);font-weight:600}.practice-interface{max-width:700px;margin:0 auto;padding:20px}.practice-interface-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;position:relative}.back-btn-small{padding:8px 16px;background:var(--color-surface-2);border:2px solid var(--color-border);border-radius:8px;color:var(--color-accent);font-size:13px;cursor:pointer;transition:all .3s ease;white-space:nowrap}.back-btn-small:hover{background:var(--color-border);border-color:var(--color-accent)}.practice-interface-header h2{color:var(--color-text);font-size:22px;font-weight:600;flex:1}.settings-btn-practice{background:var(--color-surface-2);border:2px solid var(--color-border);color:var(--color-accent);font-size:18px;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;padding:0}.settings-btn-practice:hover{background:var(--color-border);border-color:var(--color-accent);transform:rotate(90deg) scale(1.1);box-shadow:0 4px 12px #39d3534d}.target-display{background:linear-gradient(145deg,var(--color-surface-3),var(--color-surface));border:2px solid #3498db;border-radius:16px;padding:24px;margin-bottom:20px;text-align:center;box-shadow:0 4px 16px #3498db33}.target-display h3{color:#3498db;font-size:16px;margin-bottom:12px;font-weight:600}.target-text-large{font-size:28px;color:var(--color-accent);font-weight:700;margin-bottom:12px;font-family:Monaco,monospace}.target-morse{font-size:20px;color:var(--color-text);font-family:Monaco,monospace;margin-bottom:16px;letter-spacing:2px}.hint-text{color:var(--color-text-dim);font-size:13px;font-style:italic;line-height:1.5}.input-mode-toggle{display:flex;justify-content:center;align-items:center;margin-bottom:16px}.mode-toggle{width:160px;height:38px;background:linear-gradient(145deg,#2c2c2c,var(--color-surface));border:2px solid var(--color-border-strong);border-radius:19px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;overflow:hidden}.mode-toggle.active{background:linear-gradient(145deg,var(--color-accent),var(--color-accent-dim));border-color:var(--color-accent-dim)}.toggle-slider{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.toggle-option{font-size:13px;font-weight:700;color:var(--color-on-accent);text-shadow:1px 1px 2px rgba(0,0,0,.5);font-family:Monaco,monospace;letter-spacing:.5px}.mode-toggle:not(.active) .toggle-option{color:var(--color-text-dim)}.two-circle-container{display:flex;justify-content:center;align-items:center;gap:30px;padding:15px;flex-shrink:0;min-height:170px}.circle-button{width:140px;height:140px;border-radius:50%;border:5px solid;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;justify-content:center;align-items:center;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative;overflow:hidden;box-shadow:0 6px 16px #0000004d}.dot-button{background:linear-gradient(145deg,var(--color-accent-dim),var(--color-accent-dim));border-color:var(--color-accent-deep)}.dash-button{background:linear-gradient(145deg,#3498db,#2980b9);border-color:#21618c}.circle-button:not(:disabled):hover{transform:scale(1.05)}.circle-button:not(:disabled):active,.circle-button.button-pressed{transform:scale(.92);box-shadow:0 5px 15px #0006,inset 0 8px 16px #0006}.circle-label{font-size:12px;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:1.5px;margin-bottom:6px}.circle-symbol{font-size:36px;font-weight:700;color:#fff;text-shadow:3px 3px 6px rgba(0,0,0,.5)}.live-translation{background:linear-gradient(145deg,var(--color-surface-3),var(--color-surface));border:2px solid var(--color-accent);border-radius:10px;padding:16px;margin:16px 0;box-shadow:0 3px 10px #0006,0 0 16px #39d35333;min-height:80px}.morse-symbols{font-size:20px;font-weight:700;color:var(--color-accent);font-family:Monaco,Courier New,monospace;margin-bottom:8px;letter-spacing:1.5px;word-break:break-all;line-height:1.4}.translated-text{font-size:16px;color:var(--color-text);font-weight:600;font-family:Monaco,Courier New,monospace;padding-top:8px;border-top:1px solid var(--color-border)}.practice-actions{display:flex;gap:12px;justify-content:center;margin:20px 0}.action-btn{padding:12px 24px;border:2px solid var(--color-border);border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.check-btn{background:linear-gradient(145deg,var(--color-accent-dim),var(--color-accent-dim));color:#fff;border-color:var(--color-accent-deep)}.check-btn:hover{background:linear-gradient(145deg,var(--color-accent-dim),var(--color-accent-deep));transform:translateY(-2px);box-shadow:0 6px 16px #2ecc7166}.reset-btn{background:var(--color-surface-2);color:var(--color-text);border-color:var(--color-border-strong)}.reset-btn:hover{background:var(--color-border);border-color:#555;transform:translateY(-2px)}.result-display{background:linear-gradient(145deg,var(--color-surface-2),var(--color-surface));border:3px solid;border-radius:16px;padding:32px;margin-top:24px;text-align:center;animation:slideIn .4s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.result-display.correct{border-color:var(--color-accent-dim);box-shadow:0 8px 24px #2ecc714d}.result-display.incorrect{border-color:var(--color-warning-strong);box-shadow:0 8px 24px #f39c124d}.result-icon{font-size:56px;margin-bottom:16px}.result-display h3{color:var(--color-text);font-size:28px;margin-bottom:12px;font-weight:700}.result-display p{color:var(--color-text-dim);font-size:16px;margin-bottom:20px}.comparison{background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:10px;padding:16px;margin:20px 0;text-align:left}.comparison-row{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}.comparison-row:last-child{margin-bottom:0}.comparison-label{color:var(--color-text-muted);font-size:13px;font-weight:600;min-width:100px;font-family:Monaco,monospace}.comparison-value{color:var(--color-text);font-size:14px;font-family:Monaco,monospace;flex:1;word-break:break-all}.next-btn,.retry-btn{padding:12px 28px;border:2px solid;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px}.next-btn{background:linear-gradient(145deg,#3498db,#2980b9);color:#fff;border-color:#21618c}.next-btn:hover{background:linear-gradient(145deg,#2980b9,#21618c);transform:translateY(-2px);box-shadow:0 6px 16px #3498db66}.retry-btn{background:linear-gradient(145deg,var(--color-warning-strong),var(--color-warning-strong));color:#fff;border-color:#d35400}.retry-btn:hover{background:linear-gradient(145deg,var(--color-warning-strong),#d35400);transform:translateY(-2px);box-shadow:0 6px 16px #f39c1266}.keyboard-hint{text-align:center;padding:8px 12px;background:#39d3531a;border:1px solid rgba(57,211,83,.3);color:var(--color-accent);font-size:11px;font-weight:600;font-family:Monaco,monospace;margin:12px 0;border-radius:8px}@media(max-width:768px){.practice-content,.practice-interface{padding:20px 12px}.practice-header h1{font-size:28px}.sandbox-card{flex-direction:column;text-align:center;padding:28px 24px}.sandbox-icon{font-size:56px}.sandbox-content{text-align:center}.sandbox-content h2{font-size:22px}.sandbox-content p{font-size:14px}.tutorial-card{padding:20px}.tutorial-card h3{font-size:18px}.target-text-large{font-size:24px}.target-morse{font-size:16px}.mode-toggle{width:140px;height:34px}.toggle-option{font-size:11px}.keyboard-hint{display:none}.two-circle-container{gap:20px;padding:10px;min-height:140px}.circle-button{width:110px;height:110px;border-width:4px}.circle-symbol{font-size:30px}.practice-actions{flex-direction:column}.action-btn{width:100%}.result-display{padding:24px 16px}.result-icon{font-size:48px}.result-display h3{font-size:24px}.settings-btn-practice{width:36px;height:36px;font-size:16px}}.tutorial-target-panel{background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:18px 18px 22px;display:flex;flex-direction:column;gap:10px;flex:1;min-height:0;overflow:auto}.tutorial-target-panel__header{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.tutorial-target-panel__icon{font-size:18px}.tutorial-target-panel__heading{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-dim)}.tutorial-target-panel__text{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--color-accent);letter-spacing:.06em;word-break:break-word;margin-top:4px}.tutorial-target-panel__morse{font-family:var(--font-mono);font-size:16px;letter-spacing:.12em;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px;word-break:break-word}.tutorial-target-panel__hint{font-family:var(--font-mono);font-size:12px;color:var(--color-text-dim);line-height:1.5;padding:8px 10px;background:var(--color-accent-tint);border:1px dashed var(--color-accent-glow);border-radius:var(--radius-sm)}.tutorial-target-panel .result-display{margin-top:10px}.control-panel{display:flex;justify-content:center;gap:10px;padding:8px 4px;flex-wrap:wrap}.control-panel__btn{min-width:140px}.btn-icon{font-size:16px;line-height:1}@media(max-width:768px){.control-panel{padding:6px 4px;gap:8px}.control-panel__btn{min-width:110px}.btn-icon{font-size:14px}}@media(max-width:480px){.control-panel{gap:6px}.control-panel__btn{min-width:100px;flex:1}}.coachmark-overlay{position:fixed;inset:0;z-index:9999;background:#000000bf;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;animation:fade-in .25s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.coachmark-card{background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-surface-3) 100%);border:1px solid var(--color-accent);border-radius:16px;padding:28px 24px 22px;max-width:480px;width:100%;box-shadow:0 30px 60px #000000b3,0 0 30px #39d35333;font-family:Monaco,Menlo,monospace;color:var(--color-text);position:relative;animation:slide-up .3s ease}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.coachmark-step-indicator{display:flex;gap:6px;margin-bottom:18px;justify-content:center}.coachmark-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:all .2s}.coachmark-dot.done{background:#39d35380}.coachmark-dot.active{background:var(--color-accent);width:24px;border-radius:4px;box-shadow:0 0 8px #39d35380}.coachmark-title{font-size:20px;font-weight:600;color:var(--color-accent);margin:0 0 12px;letter-spacing:.5px}.coachmark-body{font-size:14px;line-height:1.6;color:#d0d0d0;margin:0 0 24px}.coachmark-actions{display:flex;gap:12px;align-items:center;justify-content:space-between}.coachmark-skip{background:transparent;border:none;color:var(--color-text-dim);font-family:inherit;font-size:13px;cursor:pointer;padding:8px 4px}.coachmark-skip:hover{color:#ccc}.coachmark-next{background:linear-gradient(135deg,var(--color-accent) 0%,#2eb045 100%);color:var(--color-bg);border:none;font-family:inherit;font-size:13px;font-weight:700;letter-spacing:.5px;padding:10px 20px;border-radius:8px;cursor:pointer;transition:all .15s}.coachmark-next:hover{transform:translateY(-1px);box-shadow:0 6px 16px #39d35366}.coachmark-step-counter{position:absolute;bottom:8px;right:12px;font-size:10px;color:#555;letter-spacing:1px}@media(max-width:600px){.coachmark-card{padding:22px 18px 18px}.coachmark-title{font-size:17px}.coachmark-body{font-size:13px}}.page-container{position:fixed;inset:0;background:#0a0a0a;padding:80px 20px 40px;overflow-y:auto;overflow-x:hidden}.page-content{max-width:900px;margin:0 auto;background:#1a1a1a;border-radius:16px;border:1px solid #333;box-shadow:0 20px 60px #0009,0 0 30px #39d3531a;padding:50px;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.page-title{font-size:48px;color:#39d353;margin-bottom:30px;font-weight:700;font-family:Monaco,Courier New,monospace;text-shadow:0 0 20px rgba(57,211,83,.5);border-bottom:2px solid #333;padding-bottom:20px}.page-intro{color:#5b9aff;font-size:14px;margin-bottom:30px;font-family:Monaco,Courier New,monospace}.page-section{margin-bottom:40px}.page-section h2{font-size:32px;color:#5b9aff;margin-bottom:16px;margin-top:30px;font-weight:600;font-family:Monaco,Courier New,monospace}.page-section h3{font-size:24px;color:#667eea;margin-bottom:12px;margin-top:20px;font-weight:600;font-family:Monaco,Courier New,monospace}.page-section p{font-size:16px;line-height:1.8;color:#e5e5e5;margin-bottom:16px;font-family:Segoe UI,Monaco,Courier New,monospace,sans-serif}.page-section strong{color:#39d353;font-weight:600}.page-section em{color:#5b9aff;font-style:italic}.feature-list{list-style:none;padding-left:0;margin:16px 0}.feature-list li{font-size:16px;line-height:1.8;color:#e5e5e5;margin-bottom:12px;padding-left:30px;position:relative;font-family:Segoe UI,Monaco,Courier New,monospace,sans-serif}.feature-list li:before{content:"▸";position:absolute;left:0;color:#39d353;font-weight:700;font-size:20px}.feature-list li strong{color:#39d353;font-weight:600}@media(max-width:768px){.page-container{padding:60px 10px 20px}.page-content{padding:30px 20px;border-radius:8px}.page-title{font-size:32px;margin-bottom:20px}.page-section h2{font-size:24px}.page-section h3{font-size:20px}.page-section p,.feature-list li{font-size:15px}}@media(max-width:480px){.page-content{padding:20px 15px}.page-title{font-size:28px}.page-section h2{font-size:22px}.page-section h3{font-size:18px}}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#0a0a0a;color:#0f0}.loading-spinner{width:50px;height:50px;border:4px solid #111;border-top:4px solid #00ff00;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-login{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a1a);padding:20px}.login-container{background:#111;border:2px solid #00ff00;border-radius:10px;padding:40px;max-width:400px;width:100%;box-shadow:0 0 30px #0f03}.login-container h1{color:#0f0;text-align:center;margin-bottom:10px;font-family:Monaco,monospace}.login-subtitle{color:#888;text-align:center;margin-bottom:30px;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#0f0;font-weight:700;font-size:14px}.form-group input{background:#1a1a1a;border:1px solid #00ff00;border-radius:5px;padding:12px;color:#fff;font-size:16px;font-family:Monaco,monospace}.form-group input:focus{outline:none;border-color:#0f0;box-shadow:0 0 10px #00ff004d}.login-btn{background:#0f0;color:#000;border:none;border-radius:5px;padding:14px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s}.login-btn:hover{background:#0d0;box-shadow:0 0 15px #00ff0080}.login-error{background:#ff00001a;border:1px solid #ff0000;border-radius:5px;padding:10px;color:#f66;font-size:14px}.attempts-warning{margin-top:8px;color:#fa0;font-weight:700}.login-footer{margin-top:30px;text-align:center;font-size:12px;color:#888}.login-footer .warning{color:#fa0;font-weight:700;margin-top:5px}.admin-dashboard{height:100vh;display:flex;flex-direction:column;background:#0a0a0a;color:#fff;font-family:Monaco,monospace;overflow:hidden}.admin-header{flex-shrink:0;background:#111;border-bottom:2px solid #00ff00;padding:20px 30px;display:flex;justify-content:space-between;align-items:center}.header-left h1{color:#0f0;margin:0 0 5px;font-size:24px}.header-left p{color:#888;margin:0;font-size:14px}.header-right{display:flex;align-items:center;gap:20px}.username{color:#0f0;font-size:14px}.logout-btn{background:#f33;color:#fff;border:none;border-radius:5px;padding:8px 16px;cursor:pointer;transition:all .2s}.logout-btn:hover{background:red;box-shadow:0 0 10px #ff00004d}.admin-tabs{flex-shrink:0;background:#1a1a1a;border-bottom:1px solid #333;display:flex;padding:0 20px;overflow-x:auto}.admin-tabs .tab{background:transparent;border:none;color:#888;padding:15px 25px;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent;font-size:14px;white-space:nowrap}.admin-tabs .tab:hover{color:#0f0;background:#00ff000d}.admin-tabs .tab.active{color:#0f0;border-bottom-color:#0f0;background:#00ff001a}.admin-content{flex:1;overflow-y:auto;padding:30px;max-width:1400px;margin:0 auto;width:100%}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#111;border:1px solid #00ff00;border-radius:8px;padding:20px;text-align:center;transition:all .2s}.stat-card:hover{border-color:#0f0;box-shadow:0 0 15px #0f03;transform:translateY(-2px)}.stat-card h3,.stat-card h4{color:#888;font-size:14px;margin:0 0 10px;text-transform:uppercase;letter-spacing:1px}.stat-value{color:#0f0;font-size:32px;font-weight:700}.data-table{width:100%;background:#111;border:1px solid #333;border-radius:8px;overflow:hidden;border-collapse:collapse}.data-table thead{background:#1a1a1a;border-bottom:2px solid #00ff00}.data-table th{color:#0f0;text-align:left;padding:15px;font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:1px}.data-table td{color:#ccc;padding:12px 15px;border-bottom:1px solid #222}.data-table tbody tr:hover{background:#00ff000d}.data-table tbody tr:last-child td{border-bottom:none}.data-table code{background:#1a1a1a;border:1px solid #333;border-radius:3px;padding:2px 6px;color:#0f0;font-size:12px}.data-table em{color:#888;font-style:italic}.no-data{text-align:center!important;color:#666!important;font-style:italic;padding:30px!important}.status-chatting{background:#0f0;color:#000;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase}.status-waiting{background:#fa0;color:#000;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase}.filters{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.filters input{background:#111;border:1px solid #333;border-radius:5px;padding:10px 15px;color:#fff;flex:1;min-width:200px}.filters input:focus{outline:none;border-color:#0f0}.filters button{background:#0f0;color:#000;border:none;border-radius:5px;padding:10px 20px;cursor:pointer;font-weight:700;transition:all .2s}.filters button:hover{background:#0d0;box-shadow:0 0 10px #00ff004d}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:30px;padding:20px}.pagination button{background:#111;border:1px solid #00ff00;color:#0f0;padding:10px 20px;border-radius:5px;cursor:pointer;transition:all .2s}.pagination button:hover:not(:disabled){background:#0f0;color:#000}.pagination button:disabled{opacity:.3;cursor:not-allowed}.pagination span{color:#888}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.tab-header h2{color:#0f0;margin:0}.refresh-btn{background:#111;border:1px solid #00ff00;color:#0f0;padding:8px 16px;border-radius:5px;cursor:pointer;transition:all .2s}.refresh-btn:hover{background:#0f0;color:#000}.messages-table .morse-code{font-family:Monaco,monospace;color:#0f0;font-size:13px}.messages-table .translated-text{color:#fff;font-weight:700}.usernames-list{color:#0f0;font-size:13px}.settings-section{background:#111;border:1px solid #333;border-radius:8px;padding:25px;margin-bottom:20px}.settings-section h3{color:#0f0;margin:0 0 15px}.settings-section p{color:#ccc;line-height:1.6;margin-bottom:10px}.settings-section pre{background:#0a0a0a;border:1px solid #333;border-radius:5px;padding:15px;color:#0f0;overflow-x:auto;margin:10px 0}.settings-section code{background:#0a0a0a;border:1px solid #333;border-radius:3px;padding:3px 8px;color:#0f0}.cleanup-controls{display:flex;align-items:center;gap:15px;margin-top:15px}.cleanup-controls label{color:#fff;display:flex;align-items:center;gap:10px}.cleanup-controls input{background:#0a0a0a;border:1px solid #333;border-radius:5px;padding:8px 12px;color:#fff;width:80px;text-align:center}.delete-btn{background:#f33;color:#fff;border:none;border-radius:5px;padding:10px 20px;cursor:pointer;font-weight:700;transition:all .2s}.delete-btn:hover{background:red;box-shadow:0 0 10px #ff00004d}.loading{text-align:center;padding:50px;color:#888;font-style:italic}@media(max-width:768px){.admin-header{flex-direction:column;gap:15px;text-align:center}.header-right{flex-direction:column}.admin-tabs{padding:0 10px}.admin-tabs .tab{padding:12px 15px;font-size:12px}.admin-content{padding:15px}.stat-cards{grid-template-columns:1fr}.data-table{font-size:12px}.data-table th,.data-table td{padding:8px}.filters{flex-direction:column}.filters input{min-width:100%}.pagination{flex-direction:column;gap:10px}.cleanup-controls{flex-direction:column;align-items:stretch}}.hamburger-button{position:fixed;top:16px;right:16px;z-index:1001;background:linear-gradient(145deg,#2c2c2c,var(--color-surface));border:2px solid var(--color-accent);color:var(--color-accent);font-size:24px;width:44px;height:44px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0006,0 0 20px #39d35333;font-family:Monaco,monospace}.hamburger-button:hover{background:linear-gradient(145deg,var(--color-accent),var(--color-accent-dim));color:var(--color-bg);transform:scale(1.05);box-shadow:0 6px 16px #00000080,0 0 30px #39d35366}.hamburger-button:active{transform:scale(.95)}.menu-overlay{position:fixed;inset:0;background:#000000b3;z-index:999;animation:fadeIn .3s ease}.hamburger-menu{position:fixed;top:0;right:-320px;width:300px;height:100vh;background:linear-gradient(180deg,var(--color-surface) 0%,var(--color-surface-3) 100%);border-left:2px solid var(--color-accent);box-shadow:-5px 0 30px #000c,0 0 40px #39d35333;z-index:1000;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow-y:auto}.hamburger-menu.open{right:0}.menu-header{padding:20px;border-bottom:2px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--color-surface-2) 0%,var(--color-surface) 100%)}.menu-header h3{color:var(--color-accent);font-size:20px;font-weight:600;font-family:Monaco,monospace;margin:0;text-shadow:0 0 10px rgba(57,211,83,.5)}.menu-close{background:transparent;border:2px solid var(--color-border);color:var(--color-accent);font-size:20px;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0}.menu-close:hover{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent);transform:rotate(90deg)}.menu-list{list-style:none;padding:0;margin:20px 0;flex:1}.menu-list li{margin:0}.menu-link{display:flex;align-items:center;gap:12px;padding:16px 20px;color:var(--color-text);text-decoration:none;font-size:16px;font-weight:600;font-family:Monaco,monospace;transition:all .2s ease;border-left:3px solid transparent;position:relative}.menu-link:hover{background:#39d3531a;border-left-color:var(--color-accent);color:var(--color-accent)}.menu-link.active{background:#39d35326;border-left-color:var(--color-accent);color:var(--color-accent)}.menu-link.active:after{content:"▸";position:absolute;right:20px;font-size:18px;color:var(--color-accent);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:translate(0)}50%{opacity:.6;transform:translate(5px)}}.menu-icon{font-size:20px;display:inline-block;width:24px;text-align:center}.menu-footer{padding:20px;border-top:2px solid var(--color-border);text-align:center;background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-surface-3) 100%)}.menu-footer p{color:var(--color-info);font-size:14px;font-weight:600;font-family:Monaco,monospace;margin:5px 0}.menu-version{color:#667eea!important;font-size:12px!important;opacity:.7}@media(max-width:480px){.hamburger-menu{width:280px;right:-300px}.hamburger-button{top:12px;right:12px;width:40px;height:40px;font-size:22px}.menu-header h3{font-size:18px}.menu-link{font-size:15px;padding:14px 18px}}.hamburger-menu::-webkit-scrollbar{width:6px}.hamburger-menu::-webkit-scrollbar-track{background:var(--color-bg)}.hamburger-menu::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:3px}.hamburger-menu::-webkit-scrollbar-thumb:hover{background:var(--color-accent-dim)}.landing-overlay{position:fixed;inset:0;background:var(--color-bg);z-index:10000;display:flex;align-items:center;justify-content:center;padding:15px;overflow-y:auto;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.landing-content{max-width:750px;width:100%;background:linear-gradient(180deg,var(--color-surface) 0%,var(--color-surface-3) 100%);border-radius:16px;border:2px solid var(--color-accent);box-shadow:0 30px 80px #000c,0 0 50px #39d3534d;padding:30px 35px;text-align:center;animation:slideUp .6s cubic-bezier(.4,0,.2,1);max-height:95vh;overflow-y:auto;margin:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-header{margin-bottom:20px}.landing-title{font-size:36px;color:var(--color-accent);font-weight:700;font-family:Monaco,Courier New,monospace;margin-bottom:10px;text-shadow:0 0 25px rgba(57,211,83,.6);line-height:1.2}.morse-animation{display:flex;justify-content:center;gap:8px;margin-top:10px}.morse-dot,.morse-dash{font-size:22px;color:var(--color-accent);animation:morseBlink 1.5s ease-in-out infinite}.morse-dot:nth-child(1){animation-delay:0s}.morse-dash:nth-child(2){animation-delay:.3s}.morse-dot:nth-child(3){animation-delay:.6s}@keyframes morseBlink{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.2);text-shadow:0 0 20px rgba(57,211,83,.8)}}.landing-tagline{font-size:16px;color:var(--color-info);line-height:1.5;margin-bottom:22px;font-family:Monaco,Courier New,monospace}.landing-features{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:22px}.feature-item{background:#39d3530d;border:1px solid var(--color-border);border-radius:10px;padding:16px 10px;transition:all .3s ease}.feature-item:hover{background:#39d3531a;border-color:var(--color-accent);transform:translateY(-3px);box-shadow:0 8px 25px #39d35333}.feature-icon{font-size:32px;display:block;margin-bottom:8px}.feature-item h3{font-size:15px;color:var(--color-accent);margin-bottom:6px;font-weight:600;font-family:Monaco,monospace}.feature-item p{font-size:13px;color:var(--color-text);line-height:1.4;font-family:Segoe UI,sans-serif;margin:0}.landing-about{background:#5b9aff0d;border:1px solid var(--color-border);border-radius:10px;padding:18px;margin-bottom:22px;text-align:left}.landing-about h2{font-size:20px;color:var(--color-info);margin-bottom:8px;font-weight:600;font-family:Monaco,monospace}.landing-about p{font-size:14px;color:var(--color-text);line-height:1.6;margin:0;font-family:Segoe UI,sans-serif}.landing-actions{text-align:center}.enter-chat-btn{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dim));color:var(--color-bg);border:none;padding:14px 40px;font-size:18px;font-weight:700;font-family:Monaco,monospace;border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #39d35366;display:inline-flex;align-items:center;gap:10px;margin-bottom:12px}.enter-chat-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px #39d35399;background:linear-gradient(135deg,var(--color-accent-dim),var(--color-accent-dim))}.enter-chat-btn:active{transform:translateY(-1px)}.btn-icon{font-size:20px;animation:slideRight 1.5s ease-in-out infinite}@keyframes slideRight{0%,to{transform:translate(0)}50%{transform:translate(4px)}}.landing-note{font-size:12px;color:#667eea;font-family:Monaco,monospace;margin:0}.landing-content::-webkit-scrollbar{width:6px}.landing-content::-webkit-scrollbar-track{background:var(--color-bg)}.landing-content::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:3px}.landing-content::-webkit-scrollbar-thumb:hover{background:var(--color-accent-dim)}@media(max-width:1080px){.landing-content{padding:25px 28px;max-height:90vh}.landing-title{font-size:30px}.morse-dot,.morse-dash{font-size:20px}.landing-tagline{font-size:15px;margin-bottom:18px}.landing-features{gap:10px;margin-bottom:18px}.feature-item{padding:14px 8px}.feature-icon{font-size:28px}.feature-item h3{font-size:14px}.feature-item p{font-size:12px}.landing-about{padding:15px}.landing-about h2{font-size:18px}.landing-about p{font-size:13px}.enter-chat-btn{padding:12px 32px;font-size:16px}}@media(max-width:768px){.landing-overlay{padding:10px}.landing-content{padding:22px 20px;border-radius:12px;max-height:92vh}.landing-title{font-size:26px}.morse-dot,.morse-dash{font-size:18px}.landing-tagline{font-size:14px;margin-bottom:16px}.landing-features{grid-template-columns:1fr;gap:10px;margin-bottom:16px}.feature-item{padding:14px 16px}.feature-icon{font-size:30px}.feature-item h3{font-size:15px}.feature-item p{font-size:13px}.landing-about{padding:14px;margin-bottom:16px}.landing-about h2{font-size:17px}.landing-about p{font-size:13px}.enter-chat-btn{width:100%;padding:12px 28px;font-size:16px}.landing-note{font-size:11px}}@media(max-width:480px){.landing-content{padding:18px 16px}.landing-title{font-size:22px}.morse-dot,.morse-dash{font-size:16px}.landing-tagline{font-size:13px}.feature-icon{font-size:26px}.feature-item h3{font-size:14px}.feature-item p{font-size:12px}.landing-about h2{font-size:16px}.landing-about p{font-size:12px}.enter-chat-btn{padding:11px 24px;font-size:15px}.landing-note{font-size:10px}}
