/* QA: Album Thumbnails
 * - Album opens quickly and shows thumbnails within 1–2s on normal broadband.
 * - Clicking a thumb loads the large image, not the original.
 * - Network tab shows thumbs are small files (tens of KB), not MB.
 * - Existing albums without thumbUrl still work (fallback to original but warn once).
 */
:root {
    --brand-color-rgb: 59, 130, 246; /* Corresponds to #3B82F6, used for tinting */
    --gv-primary: #005f6b;
    --gv-secondary: #008C9E;
    --gv-accent: #ffffff;
    --gv-heading-text: #ffffff;
    --gv-body-text: #dbeafe;
    --gv-chat-bg: rgba(255,255,255,0.15);
    --gv-ava-bubble-bg: rgba(255, 255, 255, 0.16);
    --gv-chat-text: #ffffff;
    --gv-button-bg: #005f6b;
    --gv-button-text: #ffffff;
    --gv-font-family: 'Poppins', sans-serif;
    --gv-hover-bg: var(--gv-button-text);
    --gv-hover-text: var(--gv-button-bg);
    --gv-hover-border: var(--gv-button-text);
    --gv-chat-opacity: 1;
}

/* --- RESET --- */
* { box-sizing: border-box; }
body { margin: 0; padding: 0; font-family: var(--gv-font-family); overflow: hidden; height: 100vh; background: #000; }

body.gv-hover-solid {
    --gv-hover-bg: var(--gv-secondary);
    --gv-hover-text: var(--gv-button-text);
    --gv-hover-border: rgba(255,255,255,0.34);
}

/* --- 1. TOUR LAYER --- */
#tour-view { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; }
iframe { width: 100%; height: 100%; border: none; }

/* --- 1A. LOADER --- */
.gv-loader {
    position: fixed;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background:
        radial-gradient(120% 85% at 50% -10%, rgba(var(--brand-color-rgb), 0.24), transparent 58%),
        radial-gradient(90% 70% at 50% 100%, rgba(0, 95, 107, 0.18), transparent 62%),
        linear-gradient(180deg, #05080f 0%, #070c17 48%, #04070d 100%);
    z-index: 14000;
    opacity: 1;
    transition: opacity 0.45s ease;
}

.gv-loader.hidden {
    opacity: 0;
    pointer-events: none;
}

.gv-loader-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.gv-loader-mark {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background: linear-gradient(135deg, #006f7d 0%, #00a0b7 100%);
    color: #fff;
    font-weight: 700;
    font-size: 16px;
    letter-spacing: 1px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255,255,255,0.26);
    box-shadow: 0 12px 28px rgba(0,0,0,0.34);
}

.gv-loader-name {
    color: var(--gv-heading-text);
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.gv-loader-spinner {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.22);
    border-top-color: rgba(255,255,255,0.94);
    border-right-color: rgba(0, 159, 182, 0.78);
    animation: gv-spin 0.9s linear infinite;
}

.gv-loader-text {
    font-size: 13px;
    color: var(--gv-body-text);
    letter-spacing: 0.3px;
}

@keyframes gv-spin {
    to { transform: rotate(360deg); }
}

/* --- 2. PREMIUM TOP BAR (REFACTORED) --- */
.premium-top-bar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
    z-index: 10;
    
    background: rgba(var(--brand-color-rgb), 0.08);
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    border-bottom: 1px solid rgba(var(--brand-color-rgb), 0.2);
    box-shadow: 0 4px 30px rgba(0,0,0,0.1);
}

.top-bar-left { display: flex; align-items: center; gap: 20px; z-index: 2; }
.top-bar-logo { height: 60px; object-fit: contain; filter: none; }
.divider { width: 1px; height: 32px; background: rgba(var(--brand-color-rgb), 0.3); }

.top-bar-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: min(56vw, 680px);
    display: flex;
    justify-content: center;
    pointer-events: none;
    z-index: 1;
}
.room-title-container { position: relative; width: 100%; height: 28px; overflow: hidden; text-align: center; }
.room-title-text {
    display: block; color: var(--gv-heading-text); font-size: 20px; font-weight: 600;
    text-shadow: 0 1px 3px rgba(0,0,0,0.2);
    transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
    position: absolute; top: 0; left: 50%;
    width: max-content;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transform: translateX(-50%) translateY(0);
}
.room-title-text.upcoming { transform: translateX(-50%) translateY(100%); }
.room-title-container.animating .current { transform: translateX(-50%) translateY(-100%); }
.room-title-container.animating .upcoming { transform: translateX(-50%) translateY(0); }

.top-bar-right { position: relative; display: flex; align-items: center; gap: 8px; margin-left: auto; z-index: 2; }
.menu-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.26);
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    font-size: 16px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 18px rgba(0,0,0,0.2);
    transition: transform 180ms cubic-bezier(0.22, 0.61, 0.36, 1), background-color 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}
.menu-btn i { color: currentColor; }
.menu-btn:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px) scale(1.03);
    box-shadow: 0 10px 20px rgba(0,0,0,0.24);
}
.menu-btn:active {
    transform: translateY(0) scale(0.97);
}
.menu-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px rgba(255,255,255,0.85), 0 0 0 6px rgba(var(--brand-color-rgb), 0.34);
}

.top-bar-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 10px;
    width: 260px;
    background: rgba(8, 14, 24, 0.76);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.16);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.38);
    padding: 8px;
    z-index: 50;
    display: flex;
    flex-direction: column;
    gap: 4px;
    opacity: 0;
    transform: translateY(-10px) scale(0.95);
    pointer-events: none;
    transition: all 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}
.top-bar-dropdown.active { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.dropdown-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px;
    color: var(--gv-body-text);
    text-decoration: none;
    font-size: 13px;
    font-weight: 520;
    border-radius: 10px;
    border: 1px solid transparent;
    background: transparent;
    width: 100%;
    font-family: inherit;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.dropdown-item-main {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}
.dropdown-item:hover {
    background-color: rgba(255,255,255,0.11);
    border-color: rgba(255,255,255,0.24);
    transform: translateX(2px);
}
.dropdown-item.active {
    background: rgba(var(--brand-color-rgb), 0.3);
    border-color: rgba(255,255,255,0.4);
}
.dropdown-item:focus-visible {
    outline: none;
    border-color: rgba(255,255,255,0.55);
    box-shadow: 0 0 0 2px rgba(255,255,255,0.2);
}
.dropdown-item .fa-fw { width: 18px; text-align: center; opacity: 0.86; }
.dropdown-item-arrow {
    font-size: 11px;
    opacity: 0.72;
}

.gv-room-explorer-panel {
    display: none;
    position: fixed;
    left: 16px;
    top: 86px;
    width: min(360px, calc(100vw - 24px));
    max-height: calc(100vh - 108px);
    overflow-y: auto;
    background: rgba(8, 14, 24, 0.82);
    backdrop-filter: blur(22px) saturate(170%);
    -webkit-backdrop-filter: blur(22px) saturate(170%);
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,0.36);
    padding: 12px;
    z-index: 6001;
    font-family: var(--gv-font-family);
    color: var(--gv-body-text);
    gap: 10px;
}

.gv-room-explorer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}
.gv-room-explorer-header strong {
    font-size: 13px;
    letter-spacing: 0.02em;
    font-weight: 640;
    color: var(--gv-heading-text);
}
.gv-room-explorer-close {
    border: 1px solid rgba(255,255,255,0.2);
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    border-radius: 8px;
    padding: 5px 8px;
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.gv-room-explorer-close:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px);
}

.gv-room-explorer-intro {
    font-size: 11px;
    color: var(--gv-body-text);
    line-height: 1.4;
}

.gv-room-explorer-search,
.gv-room-explorer-select {
    width: 100%;
    border: 1px solid rgba(255,255,255,0.24);
    background: rgba(255,255,255,0.08);
    color: var(--gv-body-text);
    border-radius: 10px;
    padding: 9px 10px;
    font-size: 12px;
    font-family: inherit;
}
.gv-room-explorer-search::placeholder {
    color: var(--gv-body-text);
    opacity: 0.62;
}
.gv-room-explorer-search:focus,
.gv-room-explorer-select:focus {
    outline: none;
    border-color: rgba(255,255,255,0.5);
    box-shadow: 0 0 0 2px rgba(255,255,255,0.16);
}
.gv-room-explorer-select option {
    color: #0f172a;
}

.gv-room-explorer-filters {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.gv-room-explorer-featured,
.gv-room-explorer-list,
.gv-room-explorer-featured-list {
    display: grid;
    gap: 8px;
}

.gv-room-explorer-section-label {
    font-size: 11px;
    color: var(--gv-body-text);
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.gv-room-row-wrap {
    display: grid;
    gap: 5px;
}

.gv-room-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    width: 100%;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.08);
    color: var(--gv-body-text);
    border-radius: 12px;
    padding: 10px 11px;
    font-size: 12px;
    text-align: left;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}
.gv-room-row:hover {
    transform: translateY(-1px);
    border-color: rgba(255,255,255,0.42);
    background: rgba(255,255,255,0.14);
    box-shadow: 0 8px 18px rgba(0,0,0,0.22);
}
.gv-room-row:focus-visible {
    outline: none;
    border-color: rgba(255,255,255,0.56);
    box-shadow: 0 0 0 2px rgba(255,255,255,0.2);
}
.gv-room-row.active {
    border-color: rgba(var(--brand-color-rgb), 0.82);
    background: rgba(var(--brand-color-rgb), 0.24);
    box-shadow: 0 10px 20px rgba(0,0,0,0.24), 0 0 0 1px rgba(var(--brand-color-rgb), 0.34) inset;
}

.gv-room-row-label {
    font-weight: 550;
    line-height: 1.35;
}

.gv-room-row-badges {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.gv-room-badge {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    border-radius: 8px;
    padding: 2px 6px;
}
.gv-room-badge.active {
    color: var(--gv-button-text);
    background: var(--gv-button-bg);
    border: 1px solid rgba(255,255,255,0.26);
}
.gv-room-badge.viewed {
    color: #e8f8ff;
    background: rgba(var(--brand-color-rgb), 0.24);
    border: 1px solid rgba(var(--brand-color-rgb), 0.42);
}

.gv-room-summary {
    font-size: 11px;
    color: rgba(255,255,255,0.72);
    line-height: 1.45;
    padding: 0 4px;
}

.gv-room-explorer-empty {
    font-size: 12px;
    color: rgba(255,255,255,0.72);
}


/* --- 3. WELCOME MODAL --- */
#welcome-modal {
    position: fixed;
    inset: 0;
    background:
        radial-gradient(80% 60% at 50% 0%, rgba(var(--brand-color-rgb), 0.22), transparent 70%),
        rgba(2, 5, 11, 0.76);
    backdrop-filter: blur(8px) saturate(140%);
    -webkit-backdrop-filter: blur(8px) saturate(140%);
    z-index: 12000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
    transition: opacity 0.35s ease;
}
#welcome-modal.hidden { opacity: 0; pointer-events: none; }
.modal-glass {
    width: min(760px, calc(100vw - 30px));
    padding: 34px 34px 30px;
    background:
        linear-gradient(160deg, rgba(21, 30, 47, 0.94), rgba(11, 17, 30, 0.95));
    border-radius: 22px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.46), 0 1px 0 rgba(255,255,255,0.18) inset;
    text-align: center;
    color: var(--gv-chat-text);
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.modal-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
}
.modal-brand-logo {
    width: min(230px, 72%);
    height: 42px;
    object-fit: contain;
    filter: none;
    opacity: 0.98;
}
.modal-title {
    font-size: 32px;
    font-weight: 700;
    margin: 6px 0 0;
    color: var(--gv-heading-text);
    line-height: 1.2;
}
.modal-subtitle {
    font-size: 14px;
    opacity: 0.92;
    margin: 0 auto;
    max-width: 92%;
    font-weight: 400;
    line-height: 1.66;
    color: var(--gv-body-text);
}
.modal-choice-grid {
    margin-top: 10px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.choice-panel {
    min-height: 156px;
    padding: 15px 15px 14px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.22);
    cursor: pointer;
    color: var(--gv-chat-text);
    font: inherit;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.choice-panel.guided {
    background: linear-gradient(152deg, rgba(0, 95, 107, 0.3), rgba(0, 95, 107, 0.16));
    border-color: rgba(176, 236, 247, 0.3);
    box-shadow: 0 9px 20px rgba(0, 95, 107, 0.18), inset 0 1px 0 rgba(255,255,255,0.14);
}
.choice-panel.self {
    background: linear-gradient(152deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.06));
    border-color: rgba(255,255,255,0.24);
    box-shadow: 0 8px 18px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.12);
}
.choice-panel:hover {
    transform: translateY(-2px);
    border-color: rgba(255,255,255,0.38);
    box-shadow: 0 12px 22px rgba(0,0,0,0.24), inset 0 1px 0 rgba(255,255,255,0.18);
}
.choice-panel-title-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.choice-panel-title {
    font-size: 18px;
    line-height: 1.28;
    font-weight: 700;
    color: var(--gv-heading-text);
}
.choice-panel-recommended {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 650;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgba(9, 27, 35, 0.94);
    background: rgba(214, 248, 255, 0.86);
    border: 1px solid rgba(255,255,255,0.38);
}
.choice-panel-desc {
    margin: 0;
    font-size: 12px;
    line-height: 1.56;
    font-weight: 430;
    color: var(--gv-body-text);
}

body.gv-loader-active #welcome-modal {
    opacity: 0;
    pointer-events: none;
}

body.gv-startup-gate-active #tour-view,
body.gv-startup-gate-active .premium-top-bar,
body.gv-startup-gate-active .content-dock,
body.gv-startup-gate-active #gv-room-explorer-panel,
body.gv-startup-gate-active .gv-room-content-panel {
    opacity: 0.35;
    filter: blur(1px) saturate(0.68);
    transition: opacity 0.24s ease, filter 0.24s ease;
}

body.gv-startup-gate-active .premium-top-bar,
body.gv-startup-gate-active .content-dock,
body.gv-startup-gate-active #gv-room-explorer-panel,
body.gv-startup-gate-active .gv-room-content-panel {
    pointer-events: none;
}

body.gv-startup-gate-active #ava-card {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(18px) !important;
}

/* --- 4. AVA GLASS CARD (The 3-Stack Container) --- */
#ava-card {
    position: absolute; right: 40px; bottom: 40px;
    width: 360px; height: 70vh; max-height: 650px; min-height: 400px;
    display: flex; flex-direction: column;
    background: transparent;
    color: var(--gv-chat-text);
    backdrop-filter: blur(25px) saturate(180%);
    -webkit-backdrop-filter: blur(25px) saturate(180%);
    border-radius: 30px; border: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
    z-index: 20; padding: 0 25px 20px 25px; 
    opacity: 0; pointer-events: none; transform: translateY(20px);
    transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}
#ava-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: var(--gv-chat-bg);
    opacity: var(--gv-chat-opacity);
    pointer-events: none;
    z-index: 0;
}
#ava-card > .expanded-only,
#ava-card > .minimized-only {
    position: relative;
    z-index: 1;
}
#ava-card.visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
#ava-card.minimized .expanded-only { display: none; }
#ava-card:not(.minimized) .minimized-only { display: none; }

/* === STACK 1: THE HEADER (Fixed Top) === */
.expanded-only { display: flex; flex-direction: column; height: 100%; }
.card-header { text-align: center; margin-top: 35px; margin-bottom: 10px; flex-shrink: 0; padding-right: 0; }
.agent-name { margin: 0; color: var(--gv-heading-text); font-size: 22px; font-weight: 700; text-shadow: 0 2px 4px rgba(0,0,0,0.2); }
.agent-role { font-size: 10px; color: var(--gv-accent); font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; margin-top: 4px; display: block; }
.avatar-wrapper { position: absolute; top: -40px; left: 25px; z-index: 25; transition: all 0.5s; }
.avatar-img {
    width: 80px; height: 80px; border-radius: 50%;
    border: 3px solid rgba(255, 255, 255, 0.9);
    box-shadow: 0 5px 15px rgba(0,0,0,0.2); object-fit: cover; background: var(--gv-primary);
}
.control-bar { position: absolute; top: 10px; right: -8px; display: flex; gap: 8px; z-index: 30; }
.icon-btn {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.26);
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 14px rgba(0,0,0,0.2);
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
    backdrop-filter: blur(4px);
}
.icon-btn i { color: currentColor; }
.icon-btn:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px) scale(1.03);
    box-shadow: 0 8px 16px rgba(0,0,0,0.24);
}
.icon-btn:active { transform: translateY(0) scale(0.97); }

/* === STACK 2: THE SCROLLABLE WINDOW (Middle) === */
#card-body { display: flex; flex-direction: column; flex-grow: 1; min-height: 0; overflow: hidden; position: relative; margin-bottom: 10px; }
#chat-history {
    flex-grow: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 14px;
    padding: 10px 5px; scrollbar-width: none;
    -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 15px, black 95%, transparent 100%);
    mask-image: linear-gradient(to bottom, transparent 0%, black 15px, black 95%, transparent 100%);
}
#chat-history::-webkit-scrollbar { display: none; }

.message .text { padding: 14px 18px; border-radius: 20px; font-size: 14px; line-height: 1.5; box-shadow: 0 4px 10px rgba(0,0,0,0.05); white-space: pre-wrap; overflow-wrap: anywhere; }
.message.ava .text { background: var(--gv-ava-bubble-bg, rgba(255, 255, 255, 0.16)); color: var(--gv-chat-text); border-top-left-radius: 4px; animation: popInLeft 0.6s forwards; }
.message.user { align-self: flex-end; }
.message.user .text { background: var(--gv-visitor-bubble-bg, linear-gradient(135deg, var(--gv-primary) 0%, var(--gv-secondary) 100%)); color: var(--gv-button-text); border-top-right-radius: 4px; animation: popInRight 0.6s forwards; }
@keyframes popInLeft { from { opacity: 0; transform: translateX(-10px); } to { opacity: 1; transform: translateX(0); } }
@keyframes popInRight { from { opacity: 0; transform: translateX(10px); } to { opacity: 1; transform: translateX(0); } }

.ava-chips {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin: 8px 6px 0 6px;
}
.ava-chip-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255,255,255,0.72);
}
.ava-chip-groups {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.ava-chip-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.ava-chip-group-title {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255,255,255,0.64);
}
.ava-chip-group-items {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.ava-chip {
    border: 1px solid rgba(255,255,255,0.28);
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    font-size: 12px;
    padding: 6px 12px;
    border-radius: 999px;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(0,0,0,0.06);
    transition: all 0.2s ease;
}
.ava-chip:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    box-shadow: 0 6px 14px rgba(0,0,0,0.2);
    transform: translateY(-1px);
}
.ava-chip:active { transform: translateY(0); }

.ava-lead-form {
    margin-top: 10px;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.22);
    background: rgba(8, 14, 24, 0.45);
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    min-width: 0;
    max-height: min(52vh, 430px);
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
}
.ava-lead-head {
    display: grid;
    gap: 5px;
}
.ava-lead-head h4 {
    margin: 0;
    font-size: 13px;
    font-weight: 650;
    color: var(--gv-heading-text);
}
.ava-lead-head p {
    margin: 0;
    font-size: 11px;
    color: rgba(255,255,255,0.82);
    line-height: 1.4;
}
.ava-lead-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 8px;
    min-width: 0;
}
.ava-lead-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 11px;
    color: rgba(255,255,255,0.8);
    min-width: 0;
}
.ava-lead-field input {
    border: 1px solid rgba(255,255,255,0.26);
    background: rgba(255,255,255,0.1);
    color: var(--gv-chat-text);
    border-radius: 10px;
    padding: 8px 10px;
    font-size: 12px;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}
.ava-lead-field select,
.ava-lead-field textarea {
    border: 1px solid rgba(255,255,255,0.26);
    background: rgba(255,255,255,0.1);
    color: var(--gv-chat-text);
    border-radius: 10px;
    padding: 8px 10px;
    font-size: 12px;
    font-family: inherit;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}
.ava-lead-field textarea {
    resize: vertical;
    min-height: 72px;
    max-height: 160px;
}
.ava-lead-field input:focus {
    outline: none;
    border-color: var(--gv-hover-border);
    box-shadow: 0 0 0 2px rgba(255,255,255,0.12);
}
.ava-lead-field select:focus,
.ava-lead-field textarea:focus {
    outline: none;
    border-color: var(--gv-hover-border);
    box-shadow: 0 0 0 2px rgba(255,255,255,0.12);
}
.ava-lead-field-full {
    grid-column: 1 / -1;
}
.ava-lead-consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 11px;
    color: rgba(255,255,255,0.84);
    margin-top: 2px;
    padding-top: 2px;
}
.ava-lead-consent input {
    margin-top: 2px;
}
.ava-lead-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
    padding-top: 8px;
    margin-top: 0;
    border-top: 1px solid rgba(255,255,255,0.14);
    background: transparent;
}
.ava-lead-submit {
    border: 1px solid rgba(255,255,255,0.26);
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    border-radius: 10px;
    padding: 8px 14px;
    min-height: 34px;
    min-width: 120px;
    font-size: 12px;
    cursor: pointer;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0,0,0,0.16);
    transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.ava-lead-submit:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px);
}
.ava-lead-submit:disabled {
    opacity: 0.68;
    cursor: progress;
    transform: none;
}
.ava-lead-status {
    font-size: 11px;
    color: rgba(255,255,255,0.8);
    flex: 1 1 160px;
    min-width: 0;
    text-align: right;
}
.ava-lead-form.is-complete .ava-lead-submit {
    display: none;
}

@media (max-width: 540px) {
    .ava-lead-grid {
        grid-template-columns: 1fr;
    }
    .ava-lead-actions {
        align-items: stretch;
    }
    .ava-lead-submit {
        width: 100%;
    }
    .ava-lead-status {
        text-align: left;
    }
}

/* === STACK 3: THE CONTROLS (Fixed Bottom) === */
.input-container { flex-shrink: 0; width: 100%; z-index: 10; margin-top: auto; }
.input-pill {
    background: rgba(8, 14, 24, 0.44); border-radius: 24px; padding: 6px;
    display: flex; align-items: flex-end; box-shadow: 0 8px 20px rgba(0,0,0,0.1);
    border: 1px solid rgba(255,255,255,0.26); width: 100%;
}
.mic-icon {
    width: 40px; height: 40px; background: var(--gv-button-bg); color: var(--gv-button-text); border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.28);
    box-shadow: 0 6px 14px rgba(0,0,0,0.18);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0; cursor: pointer; margin-bottom: 2px;
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}
.mic-icon i { color: currentColor; }
.mic-icon:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px) scale(1.03);
    box-shadow: 0 8px 16px rgba(0,0,0,0.24);
}
.mic-icon:active { transform: translateY(0) scale(0.97); }
#user-input {
    flex: 1; border: none; outline: none; background: transparent;
    padding: 10px 12px; font-size: 14px; color: var(--gv-chat-text); font-weight: 500;
    font-family: var(--gv-font-family); resize: none; max-height: 80px; overflow-y: auto; line-height: 1.4;
}
#user-input::placeholder { color: rgba(255,255,255,0.65); }
#send-btn {
    width: 40px; height: 40px; background: var(--gv-button-bg); color: var(--gv-button-text); border: none; border-radius: 50%;
    cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-bottom: 2px;
}
.powered-by { text-align: center; font-size: 10px; color: rgba(255,255,255,0.5); margin-top: 5px; font-weight: 500; letter-spacing: 0.5px; }

/* --- MINIMIZED STATE --- */
#ava-card.minimized {
    width: auto; height: auto; right: 30px; bottom: 30px;
    border-radius: 24px; padding: 12px 14px;
    background: transparent;
    backdrop-filter: blur(25px) saturate(180%);
    cursor: pointer; min-height: unset;
}
#ava-card.minimized .minimized-only { display: flex; }
.minimized-only { position: relative; align-items: center; gap: 12px; }
.mini-controls-col { display: flex; flex-direction: column; gap: 8px; justify-content: center; padding-left: 2px; }
.mini-btn {
    width: 30px;
    height: 30px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.26);
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 6px 14px rgba(0,0,0,0.18);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}
.mini-btn i {
    color: currentColor;
    font-size: 12px;
    line-height: 1;
}
.mini-btn:hover { background: var(--gv-hover-bg); color: var(--gv-hover-text); border-color: var(--gv-hover-border); transform: translateY(-1px) scale(1.03); box-shadow: 0 8px 16px rgba(0,0,0,0.22); }
.mini-btn:active { transform: translateY(0) scale(0.97); }
.mini-btn.active-mic { background: var(--gv-secondary); color: var(--gv-button-text); border-color: rgba(255,255,255,0.4); }
.mini-avatar {
    width: 60px; height: 60px; border-radius: 50%;
    border: 3px solid rgba(255,255,255,0.9);
    object-fit: cover; box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}
.msg-badge {
    position: absolute; top: -4px; right: -4px;
    min-width: 16px; height: 16px; padding: 0 4px;
    background: rgba(255, 76, 93, 0.96); color: #fff;
    border-radius: 10px; border: 1px solid rgba(255,255,255,0.9);
    box-shadow: 0 6px 14px rgba(0,0,0,0.28);
    font-size: 10px; font-weight: 700; line-height: 1;
    display: flex; align-items: center; justify-content: center;
    transform: scale(0.86) translateY(2px); opacity: 0;
    transition: transform 0.22s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.22s ease;
    z-index: 50; pointer-events: none;
}
.msg-badge.visible { transform: scale(1) translateY(0); opacity: 1; }

/* --- 5. INTERACTIVE OPTIONS (Suggestion Chips) --- */
.options-container { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; justify-content: flex-end; padding-bottom: 5px; }
.option-chip {
    background: rgba(255, 255, 255, 0.15); border: 1px solid rgba(255, 255, 255, 0.4);
    color: var(--gv-button-text); padding: 8px 16px; border-radius: 20px; font-size: 12px;
    font-weight: 500; cursor: pointer; transition: all 0.2s ease;
    backdrop-filter: blur(5px); animation: popInRight 0.5s forwards;
}
.option-chip:hover {
    background: var(--gv-hover-bg); border-color: var(--gv-hover-border); color: var(--gv-hover-text);
    transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}



/* --- Ava Design Classes --- */
body.gv-rounded #ava-card,
body.gv-rounded #ava-card.minimized {
    border-radius: 24px;
}
body.gv-square #ava-card,
body.gv-square #ava-card.minimized {
    border-radius: 12px;
}
body.gv-rounded .input-pill {
    border-radius: 22px;
}
body.gv-square .input-pill {
    border-radius: 10px;
}
body.gv-rounded .ava-chip,
body.gv-rounded .option-chip {
    border-radius: 16px;
}
body.gv-square .ava-chip,
body.gv-square .option-chip {
    border-radius: 8px;
}
body.gv-rounded #send-btn,
body.gv-rounded .mic-icon,
body.gv-rounded .icon-btn {
    border-radius: 14px;
}
body.gv-square #send-btn,
body.gv-square .mic-icon,
body.gv-square .icon-btn {
    border-radius: 8px;
}

body.gv-shadow #ava-card,
body.gv-shadow #ava-card.minimized {
    box-shadow: 0 20px 56px rgba(0, 0, 0, 0.35);
}
body.gv-no-shadow #ava-card,
body.gv-no-shadow #ava-card.minimized {
    box-shadow: none;
}

body.gv-glass #ava-card,
body.gv-glass #ava-card.minimized {
    backdrop-filter: blur(32px) saturate(185%);
    -webkit-backdrop-filter: blur(32px) saturate(185%);
}
body.gv-glass #ava-card::before {
    background: rgba(0, 0, 0, 0.5);
}
body.gv-solid #ava-card,
body.gv-solid #ava-card.minimized {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}
body.gv-solid #ava-card::before {
    background: var(--gv-chat-bg);
    opacity: 1;
}

body.gv-chat-logo-hidden .avatar-wrapper {
    display: none;
}
body.gv-chat-logo-hidden .card-header {
    margin-top: 16px;
}
body.gv-chat-logo-center .avatar-wrapper {
    left: 50%;
    transform: translateX(-50%);
}
body.gv-chat-logo-center .card-header {
    margin-top: 48px;
}

/* -- FIX: Mute Icon Color -- */
.icon-btn.muted, .mini-btn.muted { 
    background: rgba(100, 116, 139, 0.5); /* Neutral gray/slate */
    color: rgba(255, 255, 255, 0.9);
}

@keyframes gv-control-live-pulse {
    0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(255,255,255,0.36), 0 8px 18px rgba(0,0,0,0.24); }
    55% { transform: scale(1.06); box-shadow: 0 0 0 10px rgba(255,255,255,0), 0 0 22px rgba(255,255,255,0.42), 0 10px 20px rgba(0,0,0,0.24); }
    100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(255,255,255,0), 0 8px 18px rgba(0,0,0,0.24); }
}
@keyframes gv-control-live-icon {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.18); }
}
@keyframes gv-mic-live-ring {
    0% { opacity: 0.7; transform: scale(1); }
    100% { opacity: 0; transform: scale(1.14); }
}
.icon-btn.is-speaking,
.mini-btn.is-speaking,
.mic-icon.is-listening,
.mini-btn.is-listening {
    background: rgba(255,255,255,0.94) !important;
    color: var(--gv-button-bg) !important;
    border-color: rgba(255,255,255,0.96) !important;
    animation: gv-control-live-pulse 1.2s cubic-bezier(0.22, 0.61, 0.36, 1) infinite;
}
.icon-btn.is-speaking i,
.mini-btn.is-speaking i,
.mic-icon.is-listening i,
.mini-btn.is-listening i {
    animation: gv-control-live-icon 0.9s ease-in-out infinite;
}
.mic-icon.is-listening,
.mini-btn.is-listening {
    position: relative;
}
.mic-icon.is-listening::after,
.mini-btn.is-listening::after {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: inherit;
    border: 1px solid rgba(255,255,255,0.42);
    animation: gv-mic-live-ring 1.35s ease-out infinite;
    pointer-events: none;
}


@media (max-width: 600px) {
    #ava-card:not(.minimized) { right: 0; left: 0; bottom: 0; width: 100%; border-radius: 24px 24px 0 0; }
}

@media (max-width: 760px) {
    .modal-glass {
        width: min(520px, calc(100vw - 22px));
        padding: 28px 20px 22px;
        gap: 12px;
    }
    .modal-brand-logo {
        width: min(210px, 78%);
        height: 40px;
    }
    .modal-title {
        font-size: 26px;
    }
    .modal-subtitle {
        font-size: 13px;
        max-width: 100%;
    }
    .modal-choice-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .choice-panel {
        min-height: 132px;
        padding: 14px;
    }
    .choice-panel-title {
        font-size: 16px;
    }
    .choice-panel-desc {
        font-size: 11px;
    }
}

/* --- 7. COOKIE BANNER --- */
.cookie-banner {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    max-width: 800px;
    
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 16px 24px;
    
    /* Dark Glass */
    background:
        linear-gradient(145deg, rgba(13, 19, 32, 0.9), rgba(8, 13, 24, 0.88));
    backdrop-filter: blur(14px) saturate(165%);
    -webkit-backdrop-filter: blur(14px) saturate(165%);
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    box-shadow: 0 14px 34px rgba(0,0,0,0.36);
    
    color: var(--gv-body-text);
    z-index: 10000;
    transition: opacity 0.5s, transform 0.5s;
}

.cookie-banner.hidden {
    opacity: 0;
    transform: translateX(-50%) translateY(20px);
    pointer-events: none;
}

body.gv-startup-gate-active .cookie-banner {
    opacity: 0;
    transform: translateX(-50%) translateY(20px);
    pointer-events: none;
    visibility: hidden;
}

.cookie-banner p {
    margin: 0;
    font-size: 13px;
    font-weight: 450;
    line-height: 1.5;
    color: var(--gv-body-text);
}

.cookie-buttons {
    display: flex;
    gap: 12px;
    flex-shrink: 0;
}

.cookie-btn {
    border: 1px solid rgba(255,255,255,0.24);
    padding: 9px 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.cookie-btn:hover {
    transform: translateY(-1px);
}

.cookie-btn.decline {
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.92);
}

.cookie-btn.accept {
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
}

.cookie-btn.accept:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
}

/* --- 8. SLEEP & VOICE-MODE STATES --- */

/* -- FIX: Hide mini controls when in deep sleep -- */
#ava-card.deep-sleep .mic-mini,
#ava-card.deep-sleep .speaker-mini {
    display: none !important;
}

/* Green pulse animation for the avatar border */
@keyframes pulse-green-border {
    0% {
        box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.7);
    }
    70% {
        box-shadow: 0 0 0 8px rgba(74, 222, 128, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(74, 222, 128, 0);
    }
}

/* Apply pulse animation when minimized but NOT sleeping (i.e., Voice Mode) */
#ava-card.minimized.voice-mode .mini-avatar {
    animation: none;
}

/* --- 9. NEW: CONTENT DOCK --- */
.content-dock {
    position: fixed;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 500;

    display: flex;
    gap: 0.75rem;
    padding: 0;

    background: transparent;
    border-radius: 9999px;
    border: 1px solid transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    pointer-events: none;
    transition: background-color 180ms ease, border-color 180ms ease, box-shadow 180ms ease, padding 180ms ease;
}

.content-dock.has-visible-content {
    padding: 0.75rem;
    background: rgba(8, 14, 24, 0.52);
    backdrop-filter: blur(14px) saturate(165%);
    -webkit-backdrop-filter: blur(14px) saturate(165%);
    border-color: rgba(255, 255, 255, 0.18);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.3);
    pointer-events: auto;
}

/* Hide dock when an overlay (album) is open */
body.gv-overlay-open .content-dock {
    opacity: 0;
    pointer-events: none;
    transform: translateX(-50%) translateY(20px);
}

.dock-btn {
    position: relative;
    background: var(--gv-button-bg);
    border: 1px solid rgba(255, 255, 255, 0.34);
    color: var(--gv-button-text);
    width: 46px;
    height: 46px;
    border-radius: 50%;
    cursor: pointer;
    display: none; /* Hidden by default */
    align-items: center;
    justify-content: center;
    font-size: 20px;
    transform: translateY(0) scale(1);
    -webkit-tap-highlight-color: transparent;
    transition: transform 180ms cubic-bezier(0.22, 0.61, 0.36, 1), background-color 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
}
.dock-btn.visible {
    display: flex; /* Shown by JS */
}
.dock-btn i {
    color: currentColor;
    transition: color 160ms ease;
}
.dock-btn:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-2px) scale(1.04);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.24);
}
.dock-btn.active {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(0) scale(1.02);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
}
.dock-btn:active {
    transform: translateY(0) scale(0.98);
}

@keyframes gv-content-unseen-pulse {
    0% { transform: scale(1); opacity: 0.7; box-shadow: 0 0 0 0 rgba(255, 209, 170, 0.52); }
    70% { transform: scale(1.06); opacity: 1; box-shadow: 0 0 0 6px rgba(255, 209, 170, 0); }
    100% { transform: scale(1); opacity: 0.8; box-shadow: 0 0 0 0 rgba(255, 209, 170, 0); }
}

.dock-btn.has-unseen::after {
    content: "";
    position: absolute;
    top: 6px;
    right: 6px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #ffd1aa;
    box-shadow: 0 0 10px rgba(255, 209, 170, 0.75);
}
.dock-btn.has-unseen:not(.active)::after {
    animation: gv-content-unseen-pulse 1.8s ease-in-out infinite;
}

.rise-up-menu {
    position: absolute;
    bottom: 120%; /* Position above the button */
    left: 50%;
    transform: translateX(-50%);
    
    display: none; /* Hidden by default */
    flex-direction: column;
    gap: 8px;
    padding: 8px;

    width: 200px; /* Example width */
    background: var(--gv-chat-bg);
    backdrop-filter: blur(12px) saturate(180%);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.2);
}
.dock-btn.has-menu:hover .rise-up-menu {
    display: flex; /* Show on hover for now */
}
.rise-up-menu:empty {
    display: none !important;
}
.rise-up-item {
    color: var(--gv-chat-text);
    padding: 8px 12px;
    border-radius: 8px;
    text-align: center;
    font-size: 14px;
    transition: background 0.2s;
}
.rise-up-item:hover {
    background: var(--gv-secondary);
}

.gv-room-content-panel {
    display: none;
    position: fixed;
    left: 20px;
    bottom: 108px;
    width: min(380px, calc(100vw - 40px));
    max-height: min(54vh, 460px);
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(8, 14, 24, 0.78);
    backdrop-filter: blur(18px) saturate(170%);
    -webkit-backdrop-filter: blur(18px) saturate(170%);
    box-shadow: 0 16px 36px rgba(0,0,0,0.34);
    color: var(--gv-body-text);
    font-family: var(--gv-font-family);
    z-index: 580;
    overflow: visible;
}

.gv-room-content-inner {
    max-height: inherit;
    overflow: auto;
    padding: 18px 22px 16px;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.32) transparent;
}

.gv-room-content-inner::-webkit-scrollbar {
    width: 8px;
}

.gv-room-content-inner::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.28);
    border-radius: 8px;
}

.gv-room-content-close {
    position: absolute;
    top: -11px;
    right: -11px;
    width: 30px;
    height: 30px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.36);
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 8px 18px rgba(0,0,0,0.32);
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
    z-index: 3;
}

.gv-room-content-close:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px) scale(1.04);
}

.gv-room-content-close:active {
    transform: translateY(0) scale(0.97);
}

/* === ALBUM OVERLAY === */
.gv-album {
    position: fixed;
    inset: 0;
    background: rgba(3, 8, 16, 0.24);
    backdrop-filter: blur(2px);
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding: max(env(safe-area-inset-top), 92px) 16px
             max(env(safe-area-inset-bottom), 92px) 16px;
    box-sizing: border-box;
    z-index: 600;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.22s ease;
}

.gv-album:not(.hidden) {
    opacity: 1;
    pointer-events: auto;
}

.gv-album-sidebar {
    width: min(520px, calc(100vw - 32px));
    max-width: 100%;
    max-height: calc(100vh - 92px - 120px);
    display: flex;
    flex-direction: column;
    background: transparent;
    border: 0;
    box-shadow: none;
    transform: translateX(-20px);
    transition: transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
    opacity: 0.96;
    padding: 0;
    box-sizing: border-box;
    gap: 12px;
}

@keyframes gv-album-sidebar-enter {
    0% {
        transform: translateX(-34px);
        opacity: 0;
    }
    70% { transform: translateX(10px); opacity: 1; }
    100% { transform: translateX(0); opacity: 1; }
}

.gv-album-sidebar-header,
.gv-album-sidebar-viewer,
.gv-album-thumbs,
.gv-album-content-panel {
    background: rgba(8, 14, 24, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 18px;
    backdrop-filter: blur(22px) saturate(170%);
    -webkit-backdrop-filter: blur(22px) saturate(170%);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.36);
}

.gv-album:not(.hidden) .gv-album-sidebar {
    transform: translateX(0);
    animation: gv-album-sidebar-enter 320ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.gv-album-sidebar-header {
    padding: 14px 14px 12px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    color: var(--gv-heading-text);
    min-height: 74px;
}

.gv-album-sidebar-heading {
    min-width: 0;
    display: grid;
    gap: 4px;
}

.gv-album-sidebar-title {
    margin: 0;
    font-size: 20px;
    line-height: 1.18;
    font-weight: 640;
    letter-spacing: 0.01em;
}

.gv-album-sidebar-meta {
    font-size: 11px;
    opacity: 0.88;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.gv-album-close {
    background: var(--gv-button-bg);
    border: 1px solid rgba(255, 255, 255, 0.24);
    color: var(--gv-button-text);
    font-size: 15px;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    cursor: pointer;
    transition: transform 220ms cubic-bezier(0.22, 0.61, 0.36, 1), background-color 220ms cubic-bezier(0.22, 0.61, 0.36, 1), color 220ms cubic-bezier(0.22, 0.61, 0.36, 1), border-color 220ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.gv-album-close:hover {
    transform: translateY(-1px) scale(1.04);
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
}

.gv-album-sidebar-viewer {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 10;
    min-height: 250px;
    border-radius: 18px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gv-album-stage {
    position: relative;
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    isolation: isolate;
    overflow: hidden;
    border-radius: 18px;
    transform: translateZ(0);
    backface-visibility: hidden;
}

.gv-album-image {
    width: 70%;
    height: 84%;
    position: absolute;
    top: 50%;
    left: 50%;
    object-fit: cover;
    border-radius: 14px;
    display: block;
    z-index: 3;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.16);
    opacity: 0;
    transform: translate(-50%, -50%) translateX(0) scale(0.98);
    transition: transform 420ms cubic-bezier(0.16, 1, 0.3, 1), filter 420ms cubic-bezier(0.16, 1, 0.3, 1), opacity 420ms cubic-bezier(0.16, 1, 0.3, 1);
    will-change: transform, opacity;
}

.gv-album-image.current {
    opacity: 1;
    transform: translate(-50%, -50%) translateX(0) scale(1);
    cursor: zoom-in;
}

.gv-album-image.incoming {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 4;
    pointer-events: none;
    opacity: 0;
    transform: translate(-50%, -50%) translateX(0) scale(0.94);
}

.gv-album-stage[data-direction="next"] .gv-album-image.incoming {
    transform: translate(-50%, -50%) translateX(-50px) scale(0.94);
}
.gv-album-stage[data-direction="prev"] .gv-album-image.incoming {
    transform: translate(-50%, -50%) translateX(50px) scale(0.94);
}

.gv-album-stage.is-animating[data-direction="next"] .gv-album-image.current {
    transform: translate(-50%, -50%) translateX(46px) scale(0.96);
    opacity: 0.24;
}
.gv-album-stage.is-animating[data-direction="prev"] .gv-album-image.current {
    transform: translate(-50%, -50%) translateX(-46px) scale(0.96);
    opacity: 0.24;
}

.gv-album-stage.is-animating[data-direction="next"] .gv-album-image.incoming.is-active,
.gv-album-stage.is-animating[data-direction="prev"] .gv-album-image.incoming.is-active {
    transform: translate(-50%, -50%) translateX(0) scale(1);
    opacity: 1;
}

.gv-album-image-peek {
    position: absolute;
    top: 50%;
    width: 52%;
    height: 72%;
    object-fit: cover;
    border-radius: 12px;
    opacity: 0;
    pointer-events: none;
    z-index: 1;
    filter: saturate(0.88) brightness(0.94);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.3);
    transition: opacity 420ms cubic-bezier(0.16, 1, 0.3, 1) 40ms, transform 420ms cubic-bezier(0.16, 1, 0.3, 1) 40ms, filter 420ms cubic-bezier(0.16, 1, 0.3, 1) 40ms;
}

.gv-album-image-peek.prev {
    left: 8%;
    transform: translateY(-50%) scale(0.9);
}

.gv-album-image-peek.next {
    right: 8%;
    transform: translateY(-50%) scale(0.9);
}

.gv-album-stage.is-animating[data-direction="next"] .gv-album-image-peek.next,
.gv-album-stage.is-animating[data-direction="prev"] .gv-album-image-peek.prev {
    opacity: 0.48;
    transform: translateY(-50%) scale(0.88);
}
.gv-album-stage.is-animating[data-direction="prev"] .gv-album-image-peek.next {
    opacity: 0.34;
    transform: translateY(-50%) scale(0.84);
}
.gv-album-stage.is-animating[data-direction="next"] .gv-album-image-peek.prev {
    transform: translateY(-50%) scale(0.84);
    opacity: 0.36;
}

.gv-album-caption {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 10px;
    padding: 7px 10px;
    box-sizing: border-box;
    background: rgba(6, 10, 18, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 10px;
    font-size: 13px;
    color: var(--gv-body-text);
    line-height: 1.35;
    z-index: 3;
}

.gv-album-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: var(--gv-button-bg);
    border: 1px solid rgba(255, 255, 255, 0.24);
    color: var(--gv-button-text);
    font-size: 18px;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    display: inline-flex;
    z-index: 2;
    transition: transform 220ms cubic-bezier(0.22, 0.61, 0.36, 1), background-color 220ms cubic-bezier(0.22, 0.61, 0.36, 1), border-color 220ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.gv-album-nav:hover {
    transform: translateY(calc(-50% - 1px)) scale(1.04);
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
}

.gv-album-nav.prev { left: 12px; }
.gv-album-nav.next { right: 12px; }

.gv-album-counter {
    display: none;
}

.gv-album-thumbs {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 10px 10px;
    align-items: center;
    scrollbar-width: thin;
    min-height: 82px;
    border-radius: 16px;
}

.gv-album-thumb-wrap {
    position: relative;
    display: inline-flex;
    border: none;
    background: transparent;
    padding: 0;
    cursor: pointer;
    transition: transform 220ms cubic-bezier(0.22, 0.61, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 0.61, 0.36, 1), border-color 220ms cubic-bezier(0.22, 0.61, 0.36, 1);
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    flex: 0 0 auto;
    overflow: hidden;
}

.gv-album-thumb {
    width: 84px;
    height: 58px;
    border-radius: 9px;
    display: block;
    object-fit: cover;
    background: rgba(8, 10, 18, 0.45);
}

.gv-album-thumb-wrap:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 255, 255, 0.46);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.28);
}
.gv-album-thumb-wrap:hover .gv-album-thumb {
    filter: saturate(1.05) brightness(1.04);
}

.gv-album-thumb-wrap.active {
    border-color: rgba(255, 255, 255, 0.95);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.22), 0 8px 18px rgba(0, 0, 0, 0.35);
    transform: translateY(-1px);
}

.gv-album-thumb-wrap[data-caption]::after {
    content: attr(data-caption);
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 70px;
    background: var(--gv-chat-bg);
    color: var(--gv-chat-text);
    font-size: 11px;
    padding: 4px 8px;
    border-radius: 8px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.gv-album-thumb-wrap[data-caption]:hover::after {
    opacity: 1;
}

/* Content panel */
.gv-album-content-panel {
    margin-top: 0;
    padding: 24px 30px 26px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 0;
    flex: 1;
}

.gv-album-description {
    margin: 0;
    display: grid;
    gap: 10px;
    color: var(--gv-body-text);
    font-size: 13px;
    line-height: 1.62;
    opacity: 0.9;
    overflow: auto;
}
.gv-album-description-paragraph {
    margin: 0;
    line-height: 1.62;
}

.gv-album-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 9px 16px;
    border-radius: 11px;
    margin-top: auto;
    text-decoration: none;
    font-weight: 600;
    font-size: 13px;
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    border: 1px solid rgba(255, 255, 255, 0.2);
    width: fit-content;
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

.gv-album-cta:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px);
}

@media (max-width: 1024px) {
    .gv-album-sidebar {
        width: min(500px, calc(100vw - 24px));
    }
}

@media (max-width: 980px), (max-height: 820px) {
    .gv-album-thumbs {
        min-height: 68px;
        padding: 8px 8px;
    }
    .gv-album-thumb {
        width: 72px;
        height: 50px;
    }
    .gv-album-content-panel {
        flex: 1 1 auto;
        min-height: 170px;
        padding: 20px 24px 22px;
    }
}

@media (max-width: 820px) {
    .gv-album {
        align-items: flex-end;
        justify-content: flex-start;
        background: rgba(5, 9, 16, 0.42);
        padding: max(env(safe-area-inset-top), 84px)
                 max(env(safe-area-inset-right), 10px)
                 max(env(safe-area-inset-bottom), 84px)
                 max(env(safe-area-inset-left), 10px);
    }
    .gv-album-sidebar {
        width: 100%;
        max-height: calc(100vh - 84px - 84px);
        border: none;
        border-radius: 16px;
        box-shadow: none;
        padding: 0;
        transform: translateY(16px);
        gap: 10px;
    }
    .gv-album:not(.hidden) .gv-album-sidebar {
        transform: translateY(0);
    }
    .gv-album-sidebar-viewer {
        aspect-ratio: 4 / 3;
        min-height: 210px;
    }
    .gv-album-image {
        width: 73%;
        height: 82%;
    }
    .gv-album-image-peek {
        width: 56%;
        height: 70%;
    }
    .gv-album-thumbs {
        min-height: 62px;
        padding: 6px 8px;
    }
    .gv-album-thumb {
        width: 68px;
        height: 46px;
    }
    .gv-album-content-panel {
        padding: 18px 22px 20px;
        flex: 1 1 auto;
        min-height: 160px;
    }
    .gv-album-thumbs::-webkit-scrollbar {
        display: none;
    }
}

/* === CONTENT OVERLAY (VIDEO/DOCS) === */
.gv-content-overlay {
    position: fixed;
    inset: 0;
    background: transparent;
    backdrop-filter: none;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding: max(env(safe-area-inset-top), 92px)
             max(env(safe-area-inset-right), 18px)
             max(env(safe-area-inset-bottom), 92px)
             max(env(safe-area-inset-left), 18px);
    box-sizing: border-box;
    z-index: 610;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.28s ease;
}
.gv-content-overlay:not(.hidden) {
    opacity: 1;
}
.gv-content-overlay.is-expanded {
    justify-content: center;
}
.gv-content-card {
    width: min(560px, calc(100vw - 36px));
    min-height: min(460px, calc(100vh - 220px));
    max-height: calc(100vh - 92px - 120px);
    display: flex;
    flex-direction: column;
    background: rgba(8, 14, 24, 0.78);
    backdrop-filter: blur(22px) saturate(170%);
    -webkit-backdrop-filter: blur(22px) saturate(170%);
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.2);
    box-shadow: 0 18px 42px rgba(0,0,0,0.36);
    overflow: hidden;
    transform: translateX(-16px);
    transition: transform 0.28s cubic-bezier(.22,.61,.36,1);
    pointer-events: auto;
}
.gv-content-overlay:not(.hidden) .gv-content-card {
    transform: translateX(0);
}
.gv-content-overlay.is-expanded .gv-content-card {
    width: min(1120px, calc(100vw - 120px));
    min-height: min(760px, calc(100vh - 220px));
    max-height: calc(100vh - 92px - 92px);
}
.gv-content-header {
    padding: 14px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.18);
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--gv-heading-text);
}
.gv-content-title {
    margin: 0;
    font-size: 17px;
    font-weight: 650;
}
.gv-content-controls {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.gv-content-expand {
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.24);
    color: rgba(255,255,255,0.94);
    font-size: 12px;
    font-weight: 600;
    min-width: 72px;
    height: 32px;
    border-radius: 10px;
    cursor: pointer;
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.gv-content-expand:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px);
}
.gv-content-close {
    background: var(--gv-button-bg);
    border: 1px solid rgba(255,255,255,0.24);
    color: var(--gv-button-text);
    font-size: 15px;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    cursor: pointer;
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.gv-content-close:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px) scale(1.03);
}
.gv-content-body {
    flex: 1;
    padding: 16px 22px 18px;
    overflow: auto;
    color: var(--gv-body-text);
}
.gv-content-body iframe,
.gv-content-body video {
    width: 100%;
    min-height: 280px;
    height: min(46vh, 520px);
    border: 0;
    border-radius: 14px;
    background: rgba(0,0,0,0.46);
}
.gv-content-overlay.is-expanded .gv-content-body iframe,
.gv-content-overlay.is-expanded .gv-content-body video {
    min-height: 420px;
    height: min(64vh, calc(100vh - 240px));
}
.gv-content-rich {
    display: grid;
    gap: 12px;
}
.gv-content-text {
    display: grid;
    gap: 12px;
    color: var(--gv-body-text);
    font-size: 14px;
}
.gv-content-text-paragraph {
    margin: 0;
    line-height: 1.66;
    color: var(--gv-body-text);
}
.gv-room-content-text {
    margin: 0 0 12px 0;
    display: grid;
    gap: 10px;
    font-size: 14px;
    color: var(--gv-body-text);
}
.gv-room-content-text-paragraph {
    margin: 0;
    line-height: 1.6;
    color: var(--gv-body-text);
}
.gv-content-fallback-note {
    font-size: 12px;
    color: var(--gv-body-text);
    margin-top: 4px;
}
.gv-content-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}
.gv-content-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    padding: 8px 12px;
    border-radius: 10px;
    background: var(--gv-button-bg);
    color: var(--gv-button-text);
    border: 1px solid rgba(255,255,255,0.24);
    font-size: 12px;
    font-weight: 600;
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.gv-content-action-btn:hover {
    background: var(--gv-hover-bg);
    color: var(--gv-hover-text);
    border-color: var(--gv-hover-border);
    transform: translateY(-1px);
}
.gv-content-empty {
    border: 1px dashed rgba(255,255,255,0.24);
    border-radius: 12px;
    padding: 14px;
    color: rgba(255,255,255,0.74);
    font-size: 13px;
}
.gv-ui-guide-highlight {
    box-shadow: 0 0 0 2px rgba(255,255,255,0.78), 0 0 0 8px rgba(255,255,255,0.18), 0 0 24px rgba(255,255,255,0.34);
    animation: gv-ui-guide-pulse 1.25s cubic-bezier(0.22, 0.61, 0.36, 1) infinite;
    will-change: box-shadow, transform, opacity;
}
@keyframes gv-ui-guide-pulse {
    0% {
        box-shadow: 0 0 0 2px rgba(255,255,255,0.74), 0 0 0 6px rgba(255,255,255,0.16), 0 0 18px rgba(255,255,255,0.3);
    }
    50% {
        box-shadow: 0 0 0 2px rgba(255,255,255,0.86), 0 0 0 10px rgba(255,255,255,0.22), 0 0 30px rgba(255,255,255,0.4);
    }
    100% {
        box-shadow: 0 0 0 2px rgba(255,255,255,0.74), 0 0 0 6px rgba(255,255,255,0.16), 0 0 18px rgba(255,255,255,0.3);
    }
}
@media (max-width: 900px) {
    .gv-content-overlay {
        align-items: flex-start;
    }
    .gv-content-card {
        width: min(560px, calc(100vw - 24px));
        min-height: min(460px, calc(100vh - 210px));
        max-height: calc(100vh - 110px - 92px);
        border-radius: 18px;
    }
    .gv-content-overlay.is-expanded .gv-content-card {
        width: calc(100vw - 24px);
        min-height: min(680px, calc(100vh - 170px));
        max-height: calc(100vh - 110px - 92px);
    }
    .gv-content-overlay.is-expanded .gv-content-body iframe,
    .gv-content-overlay.is-expanded .gv-content-body video {
        min-height: 320px;
        height: min(52vh, calc(100vh - 260px));
    }
}
