/* ═══════════════════════════════════════════════════════════════
   Sprachassistent — Buddy UI (refactored)
   Layout: Tokens → Layout → Reactor → Components → Animations → Responsive
   ═══════════════════════════════════════════════════════════════ */

/* ──────────────── 1. TOKENS ──────────────── */
:root {
    --jv-bg: #03070a;
    --jv-cyan: #00d4ff;
    --jv-cyan-dim: #0a8fb5;
    --jv-cyan-deep: #003a4a;
    --jv-warn: #ff9500;
    --jv-busy: #ffea00;
    --jv-speak: #00ff41;
    --jv-idle: #ff3d00;

    /* State-Farben für den Reaktor:
       offline → rot, idle (Mic AUS) → dunkelrot, listening → grün,
       thinking → lila, speaking → orange */
    --st-offline:   #ff3d00;
    --st-ready:     #4a0500;
    --st-listening: #00ff41;
    --st-thinking:  #b482ff;
    --st-speaking:  #ff9a1f;

    --gap-xs: 0.3rem;
    --gap-s:  0.6rem;
    --gap-m:  1rem;
    --gap-l:  1.5rem;
    --radius-s: 6px;
    --radius-m: 10px;
    --radius-l: 14px;
    --border-soft: 1px solid rgba(255, 255, 255, 0.08);
    --shadow-card: 0 8px 24px rgba(0, 0, 0, 0.45);
    --tone-bg: rgba(8, 14, 20, 0.85);
    --tone-fg: rgba(220, 240, 255, 0.92);
    --tone-fg-dim: rgba(220, 240, 255, 0.55);

    /* Z-Index-Stack — explizit gestaffelt */
    --z-reactor-core:    2;
    --z-reactor-spark:   3;
    --z-browser-pane:    60;
    --z-settings-panel: 100;
    --z-settings-toggle:105;
    --z-room-toggle:    140;
    --z-onboarding:     150;
    --z-mobile-browser: 200;
}
* { box-sizing: border-box; }

/* ──────────────── 2. LAYOUT ──────────────── */
.va-root {
    font-family: "Orbitron", "Rajdhani", "Consolas", monospace;
    color: var(--jv-cyan);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    width: 100%;
    max-width: 720px;
    margin: 0 auto;
    padding: 1rem;
    user-select: none;
    position: relative;
}

.va-ctxbar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    border-left: 2px solid var(--jv-speak);
    padding: 0.3rem 0.7rem;
    margin-bottom: 0.75rem;
    font-size: 0.65rem;
}
.va-ctx-picker {
    flex: 1;
    background: var(--jv-bg);
    border: 1px solid rgba(0,255,65,0.4);
    color: var(--jv-speak);
    padding: 0.25rem 0.5rem;
    font-family: inherit;
    font-size: 0.7rem;
    text-transform: none;
    letter-spacing: 0.08em;
    cursor: pointer;
    min-height: 32px;
    transition: border-color 0.2s;
}
.va-ctx-picker:focus, .va-ctx-picker:hover { outline: none; border-color: var(--jv-speak); }
.va-ctx-clear {
    background: transparent;
    border: 1px solid rgba(0,255,65,0.4);
    color: var(--jv-speak);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.65rem;
    padding: 0.2rem 0.5rem;
    min-height: 32px;
    transition: all 0.2s;
}
.va-ctx-clear:hover { border-color: var(--jv-idle); color: var(--jv-idle); }
.va-ctx-clear.hidden { display: none; }
.va-hud-mode {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: var(--tone-fg-dim);
    font-family: ui-monospace, monospace;
    font-size: 0.6rem;
    letter-spacing: 0.18em;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    margin-left: auto;
    flex-shrink: 0;
}

.va-status {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0.6rem auto 0.2rem;
    padding: 0.35rem 0.9rem;
    border-radius: 999px;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    font-weight: 600;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: var(--tone-fg);
    transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}
.va-status::before {
    content: "";
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--tone-fg-dim);
    transition: all 0.3s ease;
}

.va-wait-hint {
    margin: 0.3rem auto 0;
    text-align: center;
    font-family: ui-monospace, monospace;
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    color: rgba(255, 200, 130, 0.85);
    animation: va-wait-fade 1.2s ease-in-out infinite alternate;
}
.va-wait-hint.hidden { display: none; }

.va-phases {
    display: flex;
    justify-content: center;
    gap: 0.4rem;
    margin: 0.6rem auto 0;
    padding: 0.5rem 0.7rem;
    background: rgba(5, 10, 14, 0.55);
    border: var(--border-soft);
    border-radius: 999px;
    width: fit-content;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}
.va-phase {
    flex: 0 0 auto;
    padding: 0 0.35rem;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
    opacity: 0.35;
    transition: opacity 0.3s ease;
}
.va-phase.active,
.va-phase.done { opacity: 1; }
.va-phase + .va-phase::before {
    content: "";
    position: absolute;
    top: 7px;
    left: -0.65rem;
    width: 0.9rem;
    height: 1px;
    background: rgba(255,255,255,0.12);
}
.va-phase-dot {
    width: 12px; height: 12px;
    border-radius: 50%;
    background: rgba(180, 130, 255, 0.20);
    border: 1px solid rgba(180, 130, 255, 0.50);
    transition: background 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.va-phase.active .va-phase-dot {
    background: rgba(180, 130, 255, 0.95);
    border-color: rgba(200, 160, 255, 0.9);
    box-shadow: 0 0 0 6px rgba(180, 130, 255, 0.22);
    animation: va-phase-pulse 1.1s ease-in-out infinite;
}
.va-phase.done .va-phase-dot {
    background: rgba(255, 215, 80, 0.92);
    border-color: rgba(255, 215, 80, 0.65);
    box-shadow: 0 0 8px rgba(255, 215, 80, 0.4);
}
.va-phase-label {
    font-family: ui-monospace, monospace;
    font-size: 0.6rem;
    letter-spacing: 0.12em;
    color: rgba(220, 200, 255, 0.7);
}
.va-phase.active .va-phase-label { color: rgba(200, 160, 255, 1); }
.va-phase.done   .va-phase-label { color: rgba(255, 215, 100, 0.95); }

.va-fastmode-badge {
    background: linear-gradient(135deg, rgba(255,154,31,0.25), rgba(180,130,255,0.18));
    border: 1px solid rgba(255,154,31,0.55);
    color: #ffba6e;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.6rem;
    letter-spacing: 0.18em;
    text-shadow: 0 0 6px rgba(255,154,31,0.4);
    flex-shrink: 0;
    animation: va-fastmode-glow 2s ease-in-out infinite;
}
.va-fastmode-badge.hidden { display: none; }

/* ──────────────── 3. REACTOR ──────────────── */
.va-reactor {
    position: relative;
    width: 320px;
    height: 320px;
    margin: 1rem auto;
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: transform 0.3s;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}
.va-reactor:active { transform: scale(0.97); }
.va-reactor.waking { animation: va-reactor-wake 0.9s cubic-bezier(0.34, 1.56, 0.64, 1) 1; }
.va-reactor::before,
.va-reactor::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}
.va-reactor::before {
    inset: 8px;
    border: 1px dashed var(--jv-cyan-dim);
    animation: va-spin 28s linear infinite;
    opacity: 0.7;
}
.va-reactor::after {
    inset: 30px;
    border: 1px solid var(--jv-cyan-dim);
    animation: va-spin 16s linear infinite reverse;
    box-shadow: inset 0 0 30px rgba(0,212,255,0.1);
    opacity: 0.7;
}
.va-spark {
    position: absolute;
    width: 4px; height: 4px;
    border-radius: 50%;
    pointer-events: none;
    z-index: var(--z-reactor-spark);
    animation: va-spark 6s ease-in-out infinite;
}
.va-spark:nth-child(1) { top: 18%; left: 28%; background: var(--jv-cyan);  box-shadow: 0 0 8px var(--jv-cyan);  animation-delay: 0s; }
.va-spark:nth-child(2) { top: 24%; right: 20%; background: var(--jv-speak); box-shadow: 0 0 8px var(--jv-speak); animation-delay: 1.7s; }
.va-spark:nth-child(3) { bottom: 22%; left: 32%; background: var(--jv-busy); box-shadow: 0 0 8px var(--jv-busy); animation-delay: 3.4s; }
.va-spark:nth-child(4) { bottom: 18%; right: 30%; background: var(--jv-cyan); box-shadow: 0 0 8px var(--jv-cyan); animation-delay: 5.1s; }

.va-canvas { position: absolute; inset: 0; filter: drop-shadow(0 0 8px currentColor); }
.va-ring-fast {
    position: absolute;
    inset: -10px;
    border-radius: 50%;
    border: 2px dotted var(--jv-cyan);
    animation: va-spin 8s linear infinite;
    opacity: 0.4;
    pointer-events: none;
}
.va-core {
    width: 150px; height: 150px;
    border-radius: 50%;
    background: radial-gradient(circle at center, var(--jv-cyan-dim) 0%, var(--jv-cyan-deep) 50%, transparent 75%);
    box-shadow:
        0 0 30px rgba(0,212,255,0.4),
        inset 0 0 30px rgba(0,212,255,0.6);
    display: grid;
    place-items: center;
    transition: all 0.3s ease;
    position: relative;
    z-index: var(--z-reactor-core);
    animation: va-core-breath 4s ease-in-out infinite;
}
.va-core-glyph {
    font-size: 3rem;
    color: var(--jv-cyan);
    text-shadow: 0 0 12px var(--jv-cyan), 0 0 24px var(--jv-cyan);
}
.va-pulse {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 2px solid var(--jv-cyan);
    opacity: 0;
    pointer-events: none;
}
.va-bolts {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s;
}
.va-bolt {
    position: absolute;
    top: 50%; left: 50%;
    width: 2px;
    height: 130px;
    transform-origin: top center;
    background: linear-gradient(to bottom, var(--st-thinking), transparent);
    box-shadow: 0 0 12px var(--st-thinking), 0 0 24px var(--st-thinking);
    animation: va-bolt-flicker 0.4s steps(2, end) infinite;
}
.va-bolt:nth-child(1) { transform: translate(-50%, 0) rotate(0deg);   animation-delay: 0s; }
.va-bolt:nth-child(2) { transform: translate(-50%, 0) rotate(72deg);  animation-delay: 0.1s; }
.va-bolt:nth-child(3) { transform: translate(-50%, 0) rotate(144deg); animation-delay: 0.2s; }
.va-bolt:nth-child(4) { transform: translate(-50%, 0) rotate(216deg); animation-delay: 0.3s; }
.va-bolt:nth-child(5) { transform: translate(-50%, 0) rotate(288deg); animation-delay: 0.4s; }

/* State-Reactor */
.va-root[data-state="idle"] .va-core {
    background: radial-gradient(circle at center, var(--st-ready) 0%, #1a0200 50%, transparent 75%);
    box-shadow: 0 0 22px var(--st-ready), inset 0 0 22px rgba(74,5,0,0.7);
    animation: va-idle-sleep 5s ease-in-out infinite;
}
.va-root[data-state="idle"] .va-core-glyph {
    color: #b53a26;
    text-shadow: 0 0 8px var(--st-ready), 0 0 16px var(--st-ready);
    animation: va-glyph-sleep 5s ease-in-out infinite;
}
.va-root[data-state="idle"] .va-pulse {
    border-color: var(--st-ready);
    animation: va-idle-wave 3.5s ease-out infinite;
}
.va-root[data-state="listening"] .va-core {
    background: radial-gradient(circle at center, var(--st-listening) 0%, #003d10 50%, transparent 75%);
    box-shadow: 0 0 60px var(--st-listening), inset 0 0 40px rgba(0,255,65,0.85);
    animation: va-core-breath 0.8s ease-in-out infinite;
}
.va-root[data-state="listening"] .va-core-glyph {
    color: var(--st-listening);
    text-shadow: 0 0 12px var(--st-listening), 0 0 32px var(--st-listening);
}
.va-root[data-state="listening"] .va-pulse {
    border-color: var(--st-listening);
    animation: va-pulse 1.4s ease-out infinite;
}
.va-root[data-state="thinking"] .va-core {
    background: radial-gradient(circle at center, var(--st-thinking) 0%, #2e1a4d 50%, transparent 75%);
    box-shadow: 0 0 55px var(--st-thinking), inset 0 0 35px rgba(180,130,255,0.7);
    animation: va-core-breath 1.2s ease-in-out infinite;
}
.va-root[data-state="thinking"] .va-core-glyph {
    color: var(--st-thinking);
    text-shadow: 0 0 12px var(--st-thinking), 0 0 32px var(--st-thinking);
    animation: va-spin 2s linear infinite;
}
.va-root[data-state="thinking"] .va-pulse {
    border-color: var(--st-thinking);
    animation: va-pulse 1.0s ease-out infinite;
}
.va-root[data-state="thinking"] .va-bolts { opacity: 1; }
.va-root[data-state="speaking"] .va-core {
    background: radial-gradient(circle at center, var(--st-speaking) 0%, #4d2400 50%, transparent 75%);
    box-shadow: 0 0 60px var(--st-speaking), inset 0 0 40px rgba(255,154,31,0.65);
    animation: va-core-breath 0.5s ease-in-out infinite;
}
.va-root[data-state="speaking"] .va-core-glyph {
    color: var(--st-speaking);
    text-shadow: 0 0 12px var(--st-speaking), 0 0 32px var(--st-speaking);
}
.va-root[data-state="speaking"] .va-pulse {
    border-color: var(--st-speaking);
    animation: va-pulse 0.6s ease-out infinite;
}
.va-root[data-state="disconnected"] .va-core {
    background: radial-gradient(circle at center, var(--st-offline) 0%, #5a0000 50%, transparent 75%);
    box-shadow: 0 0 50px var(--st-offline), inset 0 0 40px rgba(255,61,0,0.9);
    animation: va-disconnect-pulse 0.6s ease-in-out infinite;
}
.va-root[data-state="disconnected"] .va-core-glyph {
    color: var(--st-offline);
    text-shadow: 0 0 16px var(--st-offline), 0 0 32px var(--st-offline);
}

/* Status-Pille je State */
.va-root[data-state="idle"]      .va-status::before { background: var(--st-ready);     box-shadow: 0 0 5px var(--st-ready); opacity: 0.85; }
.va-root[data-state="listening"] .va-status::before { background: var(--st-listening); box-shadow: 0 0 10px var(--st-listening); animation: va-dot-blink 0.9s ease-in-out infinite; }
.va-root[data-state="thinking"]  .va-status::before { background: var(--st-thinking);  box-shadow: 0 0 10px var(--st-thinking);  animation: va-dot-blink 1.4s ease-in-out infinite; }
.va-root[data-state="speaking"]  .va-status::before { background: var(--st-speaking);  box-shadow: 0 0 10px var(--st-speaking); }
.va-root[data-state="disconnected"] .va-status::before { background: var(--st-offline); box-shadow: 0 0 10px var(--st-offline); animation: va-dot-blink 0.6s ease-in-out infinite; }
.va-root[data-state="idle"]      .va-status { color: #b53a26;            border-color: rgba(74,5,0,0.55); }
.va-root[data-state="listening"] .va-status { color: var(--st-listening); border-color: rgba(0,255,65,0.45); }
.va-root[data-state="thinking"]  .va-status { color: var(--st-thinking);  border-color: rgba(180,130,255,0.45); }
.va-root[data-state="speaking"]  .va-status { color: var(--st-speaking);  border-color: rgba(255,154,31,0.45); }
.va-root[data-state="disconnected"] .va-status { color: var(--st-offline); border-color: rgba(255,61,0,0.5); animation: va-disconnect-pulse 0.8s ease-in-out infinite; }

/* ──────────────── 4. COMPONENTS ──────────────── */

/* Bubble-Chat */
.va-log {
    background: rgba(5, 10, 14, 0.55);
    border: var(--border-soft);
    border-radius: var(--radius-m);
    padding: var(--gap-s);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
    display: flex;
    flex-direction: column;
    gap: var(--gap-s);
}
.va-log:empty::before {
    content: "Klick den Reaktor oder sag etwas. Ich bin bereit.";
    color: var(--tone-fg-dim);
    font-style: italic;
    font-family: "Consolas", monospace;
    text-align: center;
    padding: 2rem 1rem;
    letter-spacing: 0;
    text-transform: none;
    font-size: 0.85rem;
}
.va-line {
    padding: 0.6rem 0.9rem;
    border-radius: var(--radius-m);
    line-height: 1.55;
    word-break: break-word;
    overflow-wrap: anywhere;
    max-width: 88%;
    margin: 0;
}
.va-user {
    align-self: flex-end;
    background: linear-gradient(135deg, rgba(255,61,0,0.18), rgba(255,61,0,0.08));
    border: 1px solid rgba(255,61,0,0.35);
    color: rgba(255, 220, 200, 0.95);
    border-bottom-right-radius: 4px;
}
.va-assistant {
    align-self: flex-start;
    background: linear-gradient(135deg, rgba(0,212,255,0.12), rgba(0,212,255,0.05));
    border: 1px solid rgba(0,212,255,0.30);
    color: rgba(220, 245, 255, 0.95);
    border-bottom-left-radius: 4px;
}

/* Settings */
.va-settings-toggle {
    position: fixed;
    top: 0.8rem; right: 0.8rem;
    width: 48px; height: 48px;
    background: rgba(5, 10, 14, 0.85);
    border: 1px solid var(--jv-cyan);
    color: var(--jv-cyan);
    border-radius: 50%;
    box-shadow: 0 4px 14px rgba(0,0,0,0.5), 0 0 12px rgba(0,212,255,0.25);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    font-size: 1.3rem;
    cursor: pointer;
    z-index: var(--z-settings-toggle);
    transition: all 0.2s;
}
.va-settings-toggle:hover { background: var(--jv-cyan-deep); box-shadow: 0 0 16px var(--jv-cyan); }
.va-settings {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: min(92vw, 420px);
    padding: 1rem 1rem 4rem;
    background: rgba(5, 10, 14, 0.97);
    border-left: 2px solid var(--jv-cyan);
    box-shadow: var(--shadow-card);
    z-index: var(--z-settings-panel);
    transform: translateX(100%);
    transition: transform 0.28s cubic-bezier(0.32, 0.72, 0, 1);
    overflow-y: auto;
    font-size: 0.7rem;
}
.va-settings:not(.hidden) { transform: translateX(0); }
.va-settings.hidden { display: block; transform: translateX(100%); }
.va-settings::before {
    content: "Einstellungen";
    display: block;
    font-size: 0.75rem;
    letter-spacing: 0.4em;
    color: var(--jv-cyan);
    text-shadow: 0 0 6px var(--jv-cyan);
    text-align: center;
    padding-bottom: 0.8rem;
    margin-bottom: 0.6rem;
    border-bottom: 1px solid rgba(0,212,255,0.2);
}
.va-settings details {
    border-top: 1px solid rgba(0,212,255,0.1);
    padding: 0.7rem 0;
}
.va-settings details:first-child { border-top: none; padding-top: 0; }
.va-settings summary {
    cursor: pointer;
    color: var(--jv-cyan);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    list-style: none;
}
.va-settings summary::-webkit-details-marker { display: none; }
.va-settings summary::before { content: "▸ "; transition: transform 0.2s; display: inline-block; }
.va-settings details[open] > summary::before { content: "▾ "; }
.va-settings details > * + * { margin-top: 0.7rem; }
.va-settings label {
    display: block;
    font-size: 0.65rem;
    color: var(--tone-fg-dim);
    text-transform: none;
    letter-spacing: 0.05em;
}
.va-settings select,
.va-settings input[type="text"],
.va-settings input[type="range"] {
    width: 100%;
    margin-top: 0.3rem;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(0,212,255,0.25);
    color: var(--jv-cyan);
    padding: 0.4rem 0.6rem;
    font-family: ui-monospace, monospace;
    font-size: 0.72rem;
    border-radius: var(--radius-s);
    text-transform: none;
}
.va-settings select:focus,
.va-settings select:hover,
.va-settings input:focus { outline: none; border-color: var(--jv-cyan); }
.va-settings input[type="range"] { padding: 0; height: 4px; -webkit-appearance: none; }
.va-wake-toggle { display: flex; align-items: center; gap: 0.5rem; cursor: pointer; }
.va-wake-toggle input { width: auto; margin: 0; }

.va-hint-text {
    display: block;
    margin: 0.3rem 0 0.5rem;
    font-size: 0.62rem;
    line-height: 1.5;
    color: var(--tone-fg-dim);
    font-family: ui-monospace, "Consolas", monospace;
    text-transform: none;
    letter-spacing: 0.01em;
}
.va-hint-text strong { color: rgba(255, 215, 100, 0.95); font-weight: 600; }
.va-hint-warn {
    color: rgba(255, 200, 130, 0.85);
    border-left: 2px solid rgba(255, 154, 31, 0.4);
    padding-left: 0.5rem;
    margin-top: 0.3rem;
}

.va-save-btn {
    width: 100%;
    margin: 0.5rem 0;
    padding: 0.6rem;
    background: rgba(0,255,65,0.12);
    border: 1px solid var(--jv-speak);
    color: var(--jv-speak);
    border-radius: var(--radius-s);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    transition: background 0.15s ease;
}
.va-save-btn:hover { background: rgba(0,255,65,0.22); }
.va-save-btn.dirty {
    background: rgba(255,234,0,0.15);
    border-color: var(--jv-busy);
    color: var(--jv-busy);
}

/* Voice-Picker */
.va-voice-picker {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    margin-top: 0.4rem;
    max-height: 360px;
    overflow-y: auto;
    padding-right: 0.3rem;
}
.va-voice-group { margin-top: 0.5rem; padding-bottom: 0.2rem; }
.va-voice-group:first-child { margin-top: 0; }
.va-voice-group-label {
    font-family: ui-monospace, monospace;
    font-size: 0.6rem;
    letter-spacing: 0.2em;
    color: var(--tone-fg-dim);
    text-transform: uppercase;
}
.va-voice-card {
    position: relative;
    display: grid;
    grid-template-columns: 36px 1fr auto;
    gap: 0.6rem;
    align-items: center;
    padding: 0.4rem 0.55rem;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.02);
    border-radius: var(--radius-s);
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease;
    font-family: "Consolas", ui-monospace, monospace;
    font-size: 0.78rem;
    text-transform: none;
    letter-spacing: 0.02em;
    color: var(--tone-fg);
}
.va-voice-card:hover { background: rgba(0, 212, 255, 0.06); border-color: rgba(0, 212, 255, 0.25); }
.va-voice-card.selected {
    background: linear-gradient(135deg, rgba(0,212,255,0.18), rgba(0,212,255,0.05));
    border-color: var(--jv-cyan);
    box-shadow: 0 0 12px rgba(0,212,255,0.18);
    color: var(--jv-cyan);
}
.va-voice-card.selected::after { content: "✓"; position: absolute; right: 0.6rem; color: var(--jv-cyan); }
.va-voice-play {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: rgba(0, 212, 255, 0.12);
    border: 1px solid rgba(0, 212, 255, 0.4);
    color: var(--jv-cyan);
    cursor: pointer;
    font-size: 0.7rem;
    display: grid;
    place-items: center;
    padding: 0;
    line-height: 1;
    transition: background 0.15s ease, transform 0.05s ease;
}
.va-voice-play:hover { background: rgba(0, 212, 255, 0.28); }
.va-voice-play:active { transform: scale(0.92); }
.va-voice-play:disabled { opacity: 0.5; cursor: wait; }
.va-voice-name { font-weight: 500; text-transform: capitalize; }
.va-voice-quality {
    font-family: "Orbitron", monospace;
    font-size: 0.55rem;
    letter-spacing: 0.15em;
    padding: 0.1rem 0.4rem;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 4px;
    color: var(--tone-fg-dim);
    margin-right: 1rem;
}
.va-voice-card.selected .va-voice-quality {
    background: rgba(0,212,255,0.18);
    border-color: rgba(0,212,255,0.35);
    color: var(--jv-cyan);
}

/* Fast-Mode-Toggle */
.va-fastmode-block {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    padding: 0.7rem;
    background: linear-gradient(135deg, rgba(255,154,31,0.12), rgba(180,130,255,0.08));
    border: 1px solid rgba(255,154,31,0.35);
    border-radius: var(--radius-s);
    cursor: pointer;
}
.va-fastmode-block input[type="checkbox"] {
    margin-top: 0.2rem;
    width: 18px; height: 18px;
    accent-color: #ff9a1f;
    cursor: pointer;
    flex: 0 0 auto;
}
.va-fastmode-label { display: flex; flex-direction: column; gap: 0.3rem; text-transform: none; letter-spacing: 0; }
.va-fastmode-label strong {
    color: #ff9a1f;
    text-shadow: 0 0 6px rgba(255,154,31,0.4);
    font-family: "Orbitron", monospace;
    letter-spacing: 0.1em;
    font-size: 0.75rem;
}
.va-fastmode-label small {
    color: var(--tone-fg-dim);
    font-size: 0.65rem;
    line-height: 1.5;
    font-family: "Consolas", ui-monospace, monospace;
}

/* EQ */
.va-eq-row {
    display: grid;
    grid-template-columns: 60px 1fr 36px;
    gap: 0.4rem;
    align-items: center;
    margin: 0.3rem 0;
    font-size: 0.62rem;
}
.va-eq-band-label { color: var(--tone-fg-dim); text-transform: uppercase; letter-spacing: 0.18em; }

/* Memory */
.va-memory-block { font-family: "Consolas", monospace; font-size: 0.72rem; }
.va-mem-list {
    max-height: 180px;
    overflow-y: auto;
    background: rgba(0,0,0,0.3);
    padding: 0.5rem;
    border: 1px solid rgba(176,125,255,0.18);
    border-radius: var(--radius-s);
    text-transform: none;
    letter-spacing: 0;
}
.va-mem-item { display: flex; justify-content: space-between; align-items: center; padding: 0.2rem 0; border-bottom: 1px solid rgba(176,125,255,0.1); }
.va-mem-item span { flex: 1; word-break: break-word; padding-right: 0.5rem; }
.va-mem-del {
    background: transparent;
    border: 1px solid rgba(255,61,0,0.4);
    color: var(--jv-idle);
    width: 22px; height: 22px;
    cursor: pointer;
    font-size: 0.7rem;
    line-height: 1;
}
.va-mem-del:hover { background: var(--jv-idle); border-color: var(--jv-idle); color: #000; }
.va-mem-empty { opacity: 0.4; font-style: italic; padding: 0.3rem 0; }
.va-mem-add { display: flex; gap: 0.4rem; margin-top: 0.5rem; }
.va-mem-input {
    flex: 1;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(176,125,255,0.3);
    color: #d8c4ff;
    padding: 0.35rem 0.55rem;
    font-family: inherit;
    font-size: 0.7rem;
    border-radius: var(--radius-s);
    text-transform: none;
}
.va-mem-add-btn {
    width: 32px;
    background: transparent;
    border: 1px solid #b07dff;
    color: #b07dff;
    font-size: 1rem;
    cursor: pointer;
    border-radius: var(--radius-s);
}
.va-mem-add-btn:hover { background: #b07dff; color: #000; }

/* Stats */
.va-stats-pane {
    font-family: "Consolas", monospace;
    text-transform: none;
    letter-spacing: 0;
    font-size: 0.75rem;
    color: var(--jv-cyan);
    background: rgba(0,30,40,0.4);
    padding: 0.6rem;
    border-left: 2px solid var(--jv-busy);
}
.va-stat-row {
    display: flex;
    justify-content: space-between;
    padding: 0.25rem 0;
    border-bottom: 1px solid rgba(0,212,255,0.07);
}
.va-stat-row b { color: var(--jv-busy); text-shadow: 0 0 4px var(--jv-busy); font-weight: 700; }
.va-stats-refresh {
    width: 100%;
    margin-top: 0.4rem;
    padding: 0.5rem;
    background: transparent;
    border: 1px solid var(--jv-busy);
    color: var(--jv-busy);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    text-shadow: 0 0 4px var(--jv-busy);
}
.va-stats-refresh:hover { background: rgba(255,234,0,0.15); box-shadow: 0 0 8px var(--jv-busy); }

/* Health */
.va-health-pane { font-family: ui-monospace, monospace; font-size: 0.72rem; margin-bottom: 0.4rem; }
.va-health-summary {
    padding: 0.4rem 0.5rem;
    margin-bottom: 0.3rem;
    border-radius: 4px;
    font-weight: 600;
    letter-spacing: 0.06em;
}
.va-health-summary.ok   { background: rgba(255, 215, 80, 0.15); color: rgba(255, 215, 100, 1); border: 1px solid rgba(255, 215, 80, 0.5); }
.va-health-summary.warn { background: rgba(255, 165, 50, 0.18); color: rgba(255, 200, 120, 1); border: 1px solid rgba(255, 165, 50, 0.6); }
.va-health-summary.err  { background: rgba(255, 80, 80, 0.18); color: rgba(255, 150, 150, 1); border: 1px solid rgba(255, 80, 80, 0.6); }
.va-health-row {
    display: grid;
    grid-template-columns: 18px 130px 1fr 60px;
    gap: 0.4rem;
    align-items: center;
    padding: 0.25rem 0.5rem;
    border-bottom: 1px solid rgba(180, 130, 255, 0.1);
}
.va-health-row.ok   .va-health-icon { color: rgba(180, 130, 255, 1); }
.va-health-row.warn .va-health-icon { color: rgba(255, 200, 100, 1); }
.va-health-row.err  .va-health-icon { color: rgba(255, 120, 120, 1); }
.va-health-name   { color: rgba(220, 200, 255, 0.9); }
.va-health-detail { color: rgba(180, 200, 220, 0.7); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.va-health-ms     { color: rgba(180, 130, 255, 0.7); text-align: right; font-size: 0.65rem; }
.va-health-refresh {
    width: 100%;
    padding: 0.4rem;
    background: transparent;
    border: 1px solid rgba(180, 130, 255, 0.5);
    color: rgba(200, 160, 255, 1);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
}
.va-health-refresh:hover { background: rgba(180, 130, 255, 0.15); }

/* Test */
.va-test-results {
    margin-top: 0.5rem;
    max-height: 240px;
    overflow-y: auto;
    font-family: ui-monospace, monospace;
    font-size: 0.7rem;
}
.va-test-row {
    display: grid;
    grid-template-columns: 16px 1fr 70px 1fr;
    gap: 0.4rem;
    padding: 0.2rem 0;
    text-transform: none;
    letter-spacing: 0;
    border-bottom: 1px solid rgba(255,255,255,0.04);
}
.va-test-row.ok   { color: var(--jv-speak); }
.va-test-row.fail { color: var(--jv-idle); }
.va-test-id  { color: var(--tone-fg); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.va-test-ms  { color: var(--tone-fg-dim); text-align: right; }
.va-test-msg { color: var(--tone-fg-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.65rem; }
.va-test-note {
    display: inline-block;
    margin-left: 0.4rem;
    padding: 0 0.35rem;
    font-size: 0.55rem;
    letter-spacing: 0.1em;
    background: rgba(255, 154, 31, 0.18);
    border: 1px solid rgba(255, 154, 31, 0.4);
    color: rgba(255, 200, 130, 0.95);
    border-radius: 3px;
    text-transform: uppercase;
}
.va-test-btn {
    width: 100%;
    padding: 0.5rem;
    background: rgba(0,212,255,0.08);
    border: 1px solid var(--jv-cyan);
    color: var(--jv-cyan);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
}
.va-test-btn:hover { background: rgba(0,212,255,0.18); }
.va-test-btn:disabled { opacity: 0.5; cursor: wait; }

/* Inbox */
.va-inbox { margin-top: 0.5rem; padding: 0.5rem 0; }
.va-inbox.hidden { display: none; }
.va-inbox-filter { margin-bottom: 0.5rem; }
.va-inbox-proj {
    width: 100%;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(0,212,255,0.3);
    color: var(--jv-cyan);
    padding: 0.4rem 0.6rem;
    border-radius: var(--radius-s);
    font-family: ui-monospace, monospace;
    font-size: 0.7rem;
    cursor: pointer;
}
.va-inbox-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.5rem;
    align-items: center;
    padding: 0.5rem 0.7rem;
    border-radius: var(--radius-s);
    background: rgba(255,255,255,0.02);
    border: var(--border-soft);
    margin-bottom: 0.3rem;
    cursor: pointer;
    text-decoration: none;
    font-family: ui-monospace, monospace;
    font-size: 0.7rem;
    text-transform: none;
    letter-spacing: 0;
    color: var(--tone-fg);
    transition: background 0.2s ease, border-color 0.2s ease;
}
.va-inbox-item:hover { background: rgba(0, 212, 255, 0.08); border-color: rgba(0, 212, 255, 0.3); color: var(--jv-cyan); }
.va-inbox-item::after { content: "→"; color: var(--tone-fg-dim); font-size: 0.85rem; }
.va-inbox-item span { display: flex; flex-direction: column; gap: 2px; }
.va-inbox-item strong {
    color: var(--jv-cyan);
    font-weight: 600;
    font-family: "Orbitron", monospace;
    font-size: 0.7rem;
    letter-spacing: 0.1em;
}
.va-inbox-when { color: var(--tone-fg-dim); font-size: 0.62rem; }
.va-inbox-more {
    width: 100%;
    margin-top: 0.4rem;
    padding: 0.5rem;
    background: transparent;
    border: 1px dashed rgba(0,212,255,0.4);
    color: var(--jv-cyan);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    border-radius: var(--radius-s);
    transition: background 0.2s ease;
}
.va-inbox-more:hover { background: rgba(0,212,255,0.08); }

/* Action-Buttons (Inbox/History/Export/Logout) */
.va-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.va-actions button,
.va-actions .va-export-btn {
    flex: 1;
    min-width: 130px;
    min-height: 44px;
    background: transparent;
    border: 1px solid var(--jv-cyan-dim);
    color: var(--jv-cyan);
    text-decoration: none;
    text-align: center;
    padding: 0.6rem;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.2s;
}
.va-actions button:hover,
.va-actions .va-export-btn:hover { background: var(--jv-cyan-deep); box-shadow: 0 0 8px var(--jv-cyan); }
.va-logout:hover { color: var(--jv-warn) !important; border-color: var(--jv-warn) !important; box-shadow: 0 0 8px var(--jv-warn) !important; }

/* Bridge-Pane */
.va-bridge-pane {
    margin: var(--gap-s) 0;
    border: 1px solid rgba(0,255,65,0.4);
    border-radius: var(--radius-m);
    background: rgba(0, 14, 8, 0.7);
    box-shadow: 0 0 16px rgba(0,255,65,0.18), inset 0 0 8px rgba(0,255,65,0.04);
    overflow: hidden;
}
.va-bridge-pane.hidden { display: none; }
.va-bridge-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(90deg, rgba(0,255,65,0.18), transparent);
    padding: 0.45rem 0.7rem;
    color: var(--jv-speak);
    font-size: 0.65rem;
    letter-spacing: 0.25em;
    border-bottom: 1px solid rgba(0,255,65,0.25);
}
.va-bridge-header::after {
    content: "live";
    background: rgba(0,255,65,0.18);
    padding: 0.1rem 0.5rem;
    border-radius: 999px;
    font-size: 0.55rem;
    letter-spacing: 0.18em;
    border: 1px solid rgba(0,255,65,0.3);
}
.va-bridge-log {
    max-height: 200px;
    overflow-y: auto;
    padding: 0.5rem 0.7rem;
    font-family: "Consolas", ui-monospace, monospace;
    font-size: 0.72rem;
    line-height: 1.5;
    text-transform: none;
    letter-spacing: 0;
    color: rgba(180, 240, 200, 0.85);
}
.va-bridge-line { padding: 0.15rem 0; word-break: break-word; }
.va-bridge-text   { color: #d8ffe8; }
.va-bridge-tool   { color: var(--jv-cyan); text-shadow: 0 0 4px var(--jv-cyan); }
.va-bridge-result { color: #b8d4ff; opacity: 0.8; }
.va-bridge-system { color: var(--jv-busy); font-style: italic; opacity: 0.8; }

/* Boot-Sequenz */
.va-boot-frame, .va-boot-line, .va-boot-hex {
    font-family: ui-monospace, "Consolas", monospace;
    font-size: 0.72rem;
    letter-spacing: 0;
    text-transform: none;
}
.va-boot-frame { color: var(--jv-cyan); text-shadow: 0 0 6px var(--jv-cyan); animation: va-boot-fade 0.18s ease-out; }
.va-boot-frame.ok { color: var(--jv-speak); text-shadow: 0 0 6px var(--jv-speak); }
.va-boot-line {
    color: rgba(120, 200, 255, 0.85);
    overflow: hidden;
    white-space: nowrap;
    animation: va-boot-type 0.22s ease-out;
}
.va-boot-line.ok { color: var(--jv-speak); text-shadow: 0 0 4px rgba(0,255,65,0.6); }
.va-boot-hex {
    color: var(--jv-cyan-dim);
    letter-spacing: 0.04em;
    opacity: 0.6;
    text-shadow: 0 0 3px var(--jv-cyan-dim);
    animation: va-hex-flicker 0.4s ease-in-out infinite alternate;
}

/* Browser-Pane */
.va-browser-pane {
    position: fixed;
    inset: 4vh 4vw;
    z-index: var(--z-browser-pane);
    background: rgba(8, 12, 18, 0.98);
    border: 1px solid rgba(140, 180, 220, 0.35);
    border-radius: var(--radius-l);
    box-shadow: 0 18px 60px rgba(0, 0, 0, 0.55);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.va-browser-pane.hidden { display: none; }
.va-browser-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.8rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0));
    border-bottom: 1px solid rgba(120, 200, 255, 0.2);
    color: #cfe6ff;
    font-family: ui-monospace, monospace;
    text-transform: lowercase;
    letter-spacing: 0;
    font-size: 0.78rem;
}
.va-browser-url {
    flex: 1;
    background: rgba(0,0,0,0.35);
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    font-size: 0.7rem;
    color: var(--tone-fg);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    border: 1px solid rgba(255,255,255,0.08);
}
.va-browser-newtab,
.va-browser-close {
    background: transparent;
    border: 1px solid rgba(120, 200, 255, 0.3);
    color: #cfe6ff;
    border-radius: 4px;
    padding: 0.2rem 0.55rem;
    cursor: pointer;
    font-size: 0.85rem;
}
.va-browser-newtab:hover,
.va-browser-close:hover { background: rgba(120, 200, 255, 0.15); }
.va-browser-frame { flex: 1; border: 0; background: #0a0e14; width: 100%; }
.va-browser-fallback {
    position: absolute;
    inset: 50% 1rem auto 1rem;
    transform: translateY(-50%);
    background: rgba(20, 32, 44, 0.92);
    border: 1px solid rgba(120, 200, 255, 0.4);
    color: #cfe6ff;
    padding: 0.8rem 1rem;
    border-radius: 8px;
    text-align: center;
    font-size: 0.85rem;
}
.va-browser-fallback.hidden { display: none; }
.va-browser-fallback a { color: #7fc8ff; text-decoration: underline; }

/* Login */
.va-login {
    max-width: 380px;
    margin: 4rem auto 0;
    padding: 2rem 1.5rem;
    background: linear-gradient(180deg, rgba(0,40,60,0.5), rgba(0,20,30,0.3));
    border: 1px solid rgba(0,212,255,0.3);
    border-radius: var(--radius-l);
    text-align: center;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 40px rgba(0,212,255,0.12);
    animation: va-login-fade 0.5s ease-out;
}
.va-login-title {
    font-size: 1.1rem;
    letter-spacing: 0.4em;
    color: var(--jv-cyan);
    text-shadow: 0 0 12px var(--jv-cyan), 0 0 24px var(--jv-cyan);
    margin-bottom: 1.2rem;
    animation: va-title-pulse 3s ease-in-out infinite;
}
.va-login-pin {
    width: 100%;
    padding: 0.9rem 1rem;
    text-align: center;
    font-size: 1.2rem;
    letter-spacing: 0.4em;
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(0,212,255,0.3);
    border-radius: var(--radius-s);
    color: var(--jv-cyan);
    font-family: inherit;
    margin-bottom: 0.8rem;
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.va-login-pin:focus {
    outline: none;
    border-color: var(--jv-cyan);
    box-shadow: 0 0 0 3px rgba(0,212,255,0.18);
}
.va-login-btn {
    width: 100%;
    padding: 0.9rem;
    background: linear-gradient(180deg, rgba(0,212,255,0.18), rgba(0,212,255,0.08));
    border: 1px solid var(--jv-cyan);
    color: var(--jv-cyan);
    border-radius: var(--radius-s);
    font-family: inherit;
    font-size: 0.8rem;
    letter-spacing: 0.3em;
    cursor: pointer;
    text-shadow: 0 0 6px var(--jv-cyan);
    transition: background 0.2s ease, transform 0.05s ease;
}
.va-login-btn:hover { background: rgba(0,212,255,0.3); }
.va-login-btn:active { transform: scale(0.98); }
.va-login-err { color: var(--jv-idle); margin-top: 0.6rem; font-size: 0.75rem; min-height: 1.2em; }
.va-shake { animation: va-shake-anim 0.55s cubic-bezier(.36,.07,.19,.97) both; }

/* Onboarding */
.va-onboarding {
    position: fixed;
    inset: 0;
    background: rgba(3, 7, 10, 0.85);
    z-index: var(--z-onboarding);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    backdrop-filter: blur(6px);
}
.va-onboarding.hidden { display: none; }
.va-onboarding-card {
    background: linear-gradient(180deg, rgba(0,40,60,0.85), rgba(0,20,30,0.7));
    border: 1px solid rgba(0,212,255,0.4);
    border-radius: var(--radius-l);
    padding: 1.5rem;
    max-width: 420px;
    text-align: center;
    box-shadow: 0 24px 70px rgba(0,0,0,0.6), 0 0 40px rgba(0,212,255,0.15);
    color: var(--tone-fg);
    animation: va-login-fade 0.4s ease-out;
}
.va-onboarding-card h3 {
    color: var(--jv-cyan);
    text-shadow: 0 0 10px var(--jv-cyan);
    margin: 0 0 0.8rem;
    letter-spacing: 0.2em;
    font-size: 0.95rem;
}
.va-onboarding-card p {
    line-height: 1.6;
    font-size: 0.8rem;
    color: var(--tone-fg-dim);
    text-transform: none;
    letter-spacing: 0;
    margin: 0.4rem 0;
}
.va-onboarding-step-dots {
    display: flex;
    justify-content: center;
    gap: 0.4rem;
    margin: 1rem 0 0.5rem;
}
.va-onboarding-step-dots span {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: rgba(0,212,255,0.2);
    border: 1px solid rgba(0,212,255,0.4);
}
.va-onboarding-step-dots span.active { background: var(--jv-cyan); box-shadow: 0 0 8px var(--jv-cyan); }
.va-onboarding-actions { display: flex; gap: 0.6rem; margin-top: 1rem; }
.va-onboarding-actions button {
    flex: 1;
    padding: 0.6rem;
    background: transparent;
    border: 1px solid var(--jv-cyan);
    color: var(--jv-cyan);
    border-radius: var(--radius-s);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    transition: background 0.2s ease;
}
.va-onboarding-actions button:hover { background: rgba(0,212,255,0.12); }
.va-onboarding-actions .primary { background: rgba(0,212,255,0.2); text-shadow: 0 0 6px var(--jv-cyan); }

/* PWA-Install-Hint */
.va-install-hint {
    margin-top: 1rem;
    padding: 0.7rem;
    background: rgba(255, 234, 0, 0.12);
    border: 1px solid var(--jv-busy);
    border-left: 3px solid var(--jv-busy);
    color: var(--jv-busy);
    font-size: 0.75rem;
    text-transform: none;
    letter-spacing: 0;
    display: flex; align-items: center; gap: 0.5rem;
    box-shadow: 0 0 12px rgba(255, 234, 0, 0.2);
}
.va-install-hint button {
    background: transparent;
    border: 1px solid var(--jv-busy);
    color: var(--jv-busy);
    padding: 0.2rem 0.6rem;
    cursor: pointer;
    font-family: inherit;
}
.va-install-hint button:hover { background: var(--jv-busy); color: #000; }

/* ──────────────── 5. ANIMATIONS ──────────────── */
@keyframes va-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes va-pulse { 0% { transform: scale(0.6); opacity: 0.8; } 100% { transform: scale(1.5); opacity: 0; } }
@keyframes va-spark {
    0%, 100% { opacity: 0; transform: scale(0.5); }
    8%       { opacity: 1; transform: scale(1.4); }
    20%      { opacity: 0; transform: scale(0.5); }
}
@keyframes va-reactor-wake {
    0%   { transform: scale(0.85); filter: brightness(0.6); }
    40%  { transform: scale(1.15); filter: brightness(2) drop-shadow(0 0 30px currentColor); }
    100% { transform: scale(1); filter: brightness(1); }
}
@keyframes va-core-breath {
    0%, 100% { transform: scale(1);    box-shadow: 0 0 30px rgba(0,212,255,0.4), inset 0 0 30px rgba(0,212,255,0.6); }
    50%      { transform: scale(1.06); box-shadow: 0 0 50px rgba(0,212,255,0.7), inset 0 0 40px rgba(0,212,255,0.9); }
}
@keyframes va-idle-sleep {
    0%, 100% { transform: scale(0.95); box-shadow: 0 0 16px var(--st-ready), inset 0 0 18px rgba(74,5,0,0.5);  opacity: 0.7; }
    50%      { transform: scale(1.05); box-shadow: 0 0 32px var(--st-ready), inset 0 0 26px rgba(74,5,0,0.85); opacity: 1; }
}
@keyframes va-glyph-sleep { 0%, 100% { opacity: 0.6; } 50% { opacity: 1; } }
@keyframes va-idle-wave   { 0% { transform: scale(0.7); opacity: 0.6; } 100% { transform: scale(1.6); opacity: 0; } }
@keyframes va-bolt-flicker {
    0%   { opacity: 0; }
    10%  { opacity: 1; }
    20%  { opacity: 0.2; }
    30%  { opacity: 0.9; }
    100% { opacity: 0.4; }
}
@keyframes va-disconnect-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
@keyframes va-dot-blink {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.3; transform: scale(0.8); }
}
@keyframes va-phase-pulse {
    0%, 100% { transform: scale(1);    box-shadow: 0 0 0 4px rgba(180, 130, 255, 0.25); }
    50%      { transform: scale(1.25); box-shadow: 0 0 0 10px rgba(180, 130, 255, 0); }
}
@keyframes va-fastmode-glow {
    0%, 100% { box-shadow: 0 0 4px rgba(255,154,31,0.3); }
    50%      { box-shadow: 0 0 14px rgba(255,154,31,0.55); }
}
@keyframes va-wait-fade { from { opacity: 0.5; } to { opacity: 1; } }
@keyframes va-boot-fade { from { opacity: 0; transform: translateX(-8px); } to { opacity: 1; transform: translateX(0); } }
@keyframes va-boot-type { from { opacity: 0; transform: translateY(2px); }   to { opacity: 1; transform: translateY(0); } }
@keyframes va-hex-flicker { from { opacity: 0.45; } to { opacity: 0.75; } }
@keyframes va-login-fade  { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes va-title-pulse {
    0%, 100% { text-shadow: 0 0 12px var(--jv-cyan), 0 0 24px var(--jv-cyan); }
    50%      { text-shadow: 0 0 20px var(--jv-cyan), 0 0 40px var(--jv-cyan); }
}
@keyframes va-shake-anim {
    10%, 90% { transform: translateX(-2px); }
    20%, 80% { transform: translateX(4px); }
    30%, 50%, 70% { transform: translateX(-8px); }
    40%, 60% { transform: translateX(8px); }
}

/* ──────────────── 6. RESPONSIVE ──────────────── */
@media (max-width: 640px) {
    .va-root {
        padding: 0.5rem;
        padding-top: max(0.5rem, env(safe-area-inset-top));
        padding-bottom: max(0.5rem, env(safe-area-inset-bottom));
        letter-spacing: 0.08em;
        max-width: 100%;
        overflow-x: hidden;
        min-height: 100vh;
        min-height: 100dvh;
    }
    .va-hud-mode { font-size: 0.65rem; flex-shrink: 0; }
    .va-ctxbar { flex-wrap: nowrap; padding: 0.3rem 0.5rem; padding-right: 64px; }
    .va-ctx-picker { flex: 1 1 auto; min-width: 100px; min-height: 44px; font-size: 16px; }
    .va-ctx-clear { min-height: 44px; padding: 0.3rem 0.6rem; font-size: 0.65rem; flex-shrink: 0; }
    .va-reactor {
        width: min(75vw, 60vh);
        max-width: 320px;
        height: min(75vw, 60vh);
        max-height: 320px;
    }
    .va-line { max-width: 92%; }
    .va-actions { flex-direction: column; gap: 0.4rem; }
    .va-actions button,
    .va-actions .va-export-btn { min-width: 0; min-height: 46px; font-size: 0.8rem; flex: none; width: 100%; }
    .va-settings-toggle { width: 44px; height: 44px; top: 0.4rem; right: 0.4rem; }
    .va-stat-row { font-size: 0.7rem; flex-wrap: wrap; }
    .va-install-hint { font-size: 0.7rem; padding: 0.5rem; flex-wrap: wrap; }
    .va-install-hint button { min-height: 36px; padding: 0.4rem 0.8rem; }
    .va-login { margin: 2rem auto; padding: 1.5rem; max-width: 92vw; }
    .va-login-pin { font-size: 1.4rem; min-height: 56px; }
    .va-test-row { grid-template-columns: 16px 1fr 50px; font-size: 0.65rem; }
    .va-settings {
        width: 100vw;
        border-left: none;
        border-top: 2px solid var(--jv-cyan);
        top: auto;
        right: 0;
        bottom: 0;
        max-height: 85vh;
        transform: translateY(100%);
        border-radius: var(--radius-l) var(--radius-l) 0 0;
    }
    .va-settings:not(.hidden) { transform: translateY(0); }
    .va-settings.hidden { transform: translateY(100%); }
}
@media (max-width: 480px) {
    .va-browser-pane {
        inset: 0 !important;
        border-radius: 0;
        border: none;
        z-index: var(--z-mobile-browser);
    }
    .va-browser-frame { height: calc(100% - 50px); }
}
@media (max-width: 380px) {
    .va-reactor { width: 84vw; height: 84vw; }
    .va-core-glyph { font-size: 2rem; }
    .va-status { font-size: 0.6rem; letter-spacing: 0.1em; }
}
@media (max-width: 640px) and (display-mode: standalone) {
    .va-root { padding-top: env(safe-area-inset-top, 0.5rem); }
}

/* EQ-Test-Button */
.va-eq-test {
    width: 100%;
    margin-top: 0.5rem;
    padding: 0.5rem;
    background: rgba(255, 234, 0, 0.08);
    border: 1px solid var(--jv-busy);
    color: var(--jv-busy);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    border-radius: var(--radius-s);
    text-shadow: 0 0 4px var(--jv-busy);
    transition: background 0.15s ease;
}
.va-eq-test:hover { background: rgba(255, 234, 0, 0.18); }
.va-eq-test:disabled { opacity: 0.5; cursor: wait; }

/* Raum-Toggle-Overlay (10s nach „Wohnzimmer an") */
.va-room-toggle {
    position: fixed;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: var(--z-room-toggle);
    pointer-events: none;
}
.va-room-toggle-card {
    pointer-events: auto;
    background: linear-gradient(180deg, rgba(0,40,60,0.95), rgba(0,20,30,0.92));
    border: 1px solid rgba(255,154,31,0.5);
    border-radius: var(--radius-l);
    padding: 0.8rem;
    min-width: 280px;
    max-width: 92vw;
    box-shadow: 0 24px 70px rgba(0,0,0,0.6), 0 0 30px rgba(255,154,31,0.2);
    color: var(--tone-fg);
    animation: va-login-fade 0.25s ease-out;
}
.va-room-toggle-title {
    text-align: center;
    color: #ffba6e;
    font-family: "Orbitron", monospace;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-shadow: 0 0 6px rgba(255,154,31,0.4);
    margin-bottom: 0.6rem;
}
.va-room-toggle-list {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}
.va-room-device {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 0.6rem;
    padding: 0.45rem 0.6rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-s);
    font-family: ui-monospace, monospace;
    font-size: 0.75rem;
    text-transform: none;
    letter-spacing: 0;
}
.va-room-device.err { border-color: rgba(255,61,0,0.5); }
.va-room-device-name { color: var(--tone-fg); }
.va-room-device-btn {
    background: rgba(0,255,65,0.15);
    border: 1px solid var(--jv-speak);
    color: var(--jv-speak);
    padding: 0.25rem 0.7rem;
    border-radius: 4px;
    font-family: inherit;
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    cursor: pointer;
    min-width: 50px;
}
.va-room-device[data-state="off"] .va-room-device-btn {
    background: rgba(255,61,0,0.12);
    border-color: rgba(255,61,0,0.5);
    color: var(--jv-idle);
}
.va-room-device-btn:hover { filter: brightness(1.2); }
.va-room-device-btn:disabled { opacity: 0.5; cursor: wait; }
.va-room-toggle-bar {
    height: 3px;
    background: linear-gradient(90deg, #ffba6e, var(--jv-cyan));
    margin-top: 0.7rem;
    border-radius: 2px;
    transform-origin: left;
}
@keyframes va-room-bar-shrink {
    from { transform: scaleX(1); }
    to   { transform: scaleX(0); }
}

/* ───── Benutzer-Pane ───── */
.va-users-pane { font-family: ui-monospace, monospace; font-size: 0.7rem; }
.va-users-empty, .va-sched-empty, .va-search-empty {
    opacity: 0.4; font-style: italic; padding: 0.5rem 0; text-align: center;
    text-transform: none; letter-spacing: 0;
}
.va-user-row {
    display: grid;
    grid-template-columns: 1fr auto 24px;
    gap: 0.5rem;
    align-items: center;
    padding: 0.4rem 0.5rem;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: var(--radius-s);
    margin-bottom: 0.3rem;
    text-transform: none; letter-spacing: 0;
}
.va-user-name { color: var(--tone-fg); font-weight: 500; }
.va-user-since { color: var(--tone-fg-dim); font-size: 0.6rem; }
.va-user-del {
    background: transparent;
    border: 1px solid rgba(255,61,0,0.4);
    color: var(--jv-idle);
    width: 22px; height: 22px;
    cursor: pointer;
    font-size: 0.7rem;
    line-height: 1;
    border-radius: 4px;
}
.va-user-del:hover { background: var(--jv-idle); border-color: var(--jv-idle); color: #000; }
.va-users-add, .va-sched-add {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.5rem;
}
.va-users-name, .va-users-pin,
.va-sched-name, .va-sched-when, .va-sched-payload, .va-sched-type {
    flex: 1 1 120px;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(0,212,255,0.25);
    color: var(--jv-cyan);
    padding: 0.4rem 0.55rem;
    font-family: ui-monospace, monospace;
    font-size: 0.7rem;
    border-radius: var(--radius-s);
    text-transform: none;
    letter-spacing: 0;
}
.va-users-add-btn, .va-sched-add-btn {
    background: rgba(0,255,65,0.12);
    border: 1px solid var(--jv-speak);
    color: var(--jv-speak);
    padding: 0.4rem 0.7rem;
    cursor: pointer;
    font-family: inherit;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    border-radius: var(--radius-s);
    flex: 0 0 auto;
}
.va-users-add-btn:hover, .va-sched-add-btn:hover { background: rgba(0,255,65,0.24); }

/* ───── Schedules-Pane ───── */
.va-sched-pane { font-family: ui-monospace, monospace; font-size: 0.7rem; }
.va-sched-row {
    display: grid;
    grid-template-columns: 1fr auto 24px;
    gap: 0.5rem;
    align-items: center;
    padding: 0.5rem 0.6rem;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-s);
    margin-bottom: 0.3rem;
    text-transform: none; letter-spacing: 0;
}
.va-sched-row.disabled { opacity: 0.45; }
.va-sched-info {
    display: flex; flex-direction: column; gap: 2px;
    min-width: 0;
}
.va-sched-info strong { color: var(--jv-cyan); font-weight: 600; font-size: 0.72rem; }
.va-sched-info small { color: var(--tone-fg-dim); font-size: 0.62rem; }
.va-sched-next { color: rgba(255,200,130,0.85) !important; }
.va-sched-toggle {
    display: flex; align-items: center; gap: 0.3rem;
    font-size: 0.6rem; letter-spacing: 0.15em;
    cursor: pointer;
    color: var(--tone-fg-dim);
}
.va-sched-toggle input { accent-color: var(--jv-speak); }
.va-sched-del {
    background: transparent;
    border: 1px solid rgba(255,61,0,0.4);
    color: var(--jv-idle);
    width: 22px; height: 22px;
    cursor: pointer;
    font-size: 0.7rem;
    border-radius: 4px;
}
.va-sched-del:hover { background: var(--jv-idle); color: #000; }
.va-sched-type {
    flex: 0 0 auto;
    min-width: 100px;
    cursor: pointer;
}

/* ───── IP-Whitelist ───── */
.va-wl-pane { font-family: ui-monospace, monospace; font-size: 0.7rem; margin-top: 0.4rem; }
.va-wl-empty { opacity: 0.5; font-style: italic; padding: 0.3rem 0; }
.va-wl-current {
    background: rgba(0,0,0,0.35);
    border: 1px solid rgba(0,212,255,0.2);
    border-radius: var(--radius-s);
    padding: 0.5rem 0.6rem;
    margin-bottom: 0.5rem;
    font-size: 0.72rem;
}
.va-wl-cur-row { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.va-wl-cur-row strong { color: var(--jv-cyan); font-family: ui-monospace, monospace; }
.va-wl-cur-badge { color: var(--tone-fg-dim); font-size: 0.65rem; }
.va-wl-add-current {
    margin-left: auto;
    background: rgba(0,255,65,0.12);
    color: var(--jv-speak);
    border: 1px solid rgba(0,255,65,0.45);
    padding: 0.25rem 0.55rem;
    cursor: pointer;
    font-family: ui-monospace, monospace;
    font-size: 0.65rem;
    border-radius: 4px;
}
.va-wl-add-current:hover { background: rgba(0,255,65,0.24); }
.va-wl-row {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    padding: 0.3rem 0.4rem;
    border-bottom: 1px solid rgba(0,212,255,0.08);
}
.va-wl-ip-cell { color: var(--jv-cyan); font-weight: 600; min-width: 130px; }
.va-wl-label-cell { flex: 1; color: var(--tone-fg-dim); }
.va-wl-del {
    background: transparent;
    color: var(--jv-idle);
    border: 1px solid rgba(255,180,0,0.4);
    padding: 0.2rem 0.5rem;
    cursor: pointer;
    font-size: 0.7rem;
    border-radius: 4px;
}
.va-wl-del:hover { background: var(--jv-idle); color: #000; }
.va-wl-add { display: flex; gap: 0.4rem; margin-top: 0.5rem; flex-wrap: wrap; }
.va-wl-ip, .va-wl-label {
    flex: 1 1 140px;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(0,212,255,0.3);
    color: var(--jv-cyan);
    padding: 0.4rem 0.6rem;
    border-radius: var(--radius-s);
    font-family: ui-monospace, monospace;
    font-size: 0.72rem;
}
.va-wl-add-btn {
    background: rgba(0,255,65,0.12);
    color: var(--jv-speak);
    border: 1px solid rgba(0,255,65,0.45);
    padding: 0.4rem 0.8rem;
    cursor: pointer;
    font-family: ui-monospace, monospace;
    border-radius: var(--radius-s);
}
.va-wl-add-btn:hover { background: rgba(0,255,65,0.24); }

/* ───── Suche ───── */
.va-search-input {
    width: 100%;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(0,212,255,0.3);
    color: var(--jv-cyan);
    padding: 0.5rem 0.7rem;
    border-radius: var(--radius-s);
    font-family: ui-monospace, monospace;
    font-size: 0.78rem;
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: 0.4rem;
}
.va-search-input:focus { outline: none; border-color: var(--jv-cyan); box-shadow: 0 0 0 2px rgba(0,212,255,0.15); }
.va-search-results {
    max-height: 320px;
    overflow-y: auto;
    font-family: ui-monospace, monospace;
    font-size: 0.7rem;
}
.va-search-count {
    color: var(--tone-fg-dim);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.6rem;
    padding: 0.3rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    margin-bottom: 0.3rem;
}
.va-search-row {
    padding: 0.45rem 0.6rem;
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: var(--radius-s);
    margin-bottom: 0.3rem;
    text-transform: none; letter-spacing: 0;
}
.va-search-source {
    display: block;
    color: var(--jv-cyan);
    font-weight: 600;
    font-size: 0.65rem;
    margin-bottom: 0.2rem;
}
.va-search-snippet {
    color: var(--tone-fg);
    font-size: 0.72rem;
    line-height: 1.45;
    word-break: break-word;
}
