:root {
    --ve-navy: #071a3d;
    --ve-blue: #005cbf;
    --ve-bright-blue: #0074ff;
    --ve-purple: #6b3ff2;
    --ve-text: #162033;
    --ve-muted: #5b667a;
    --ve-soft: #f5f8ff;
    --ve-card: rgba(255, 255, 255, 0.92);
    --ve-border: rgba(20, 45, 90, 0.12);
    --ve-shadow: 0 24px 70px rgba(7, 26, 61, 0.14);
}

html {
    font-size: 14px;
    position: relative;
    min-height: 100%;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

body {
    min-height: 100vh;
    margin: 0;
    color: var(--ve-text);
    background: radial-gradient(circle at 12% 12%, rgba(0, 116, 255, 0.14), transparent 34%), radial-gradient(circle at 88% 18%, rgba(107, 63, 242, 0.13), transparent 30%), linear-gradient(135deg, #ffffff 0%, #f5f8ff 48%, #eef4ff 100%);
}

.site-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
}

.site-main {
    flex: 1;
}

    .site-main > .container-fluid {
        max-width: 100%;
        overflow-x: hidden;
    }

.ve-navbar {
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(16px);
}

.ve-brand {
    font-weight: 800;
    letter-spacing: 0.2px;
    color: var(--ve-navy) !important;
}

.nav-logo {
    width: 34px;
    height: auto;
}

/* Main hero shell */

.ve-hero {
    position: relative;
    width: 100%;
    max-width: 1900px;
    margin: 0 auto 2rem auto;
    padding: clamp(1rem, 2.2vw, 2.6rem);
    border: 1px solid var(--ve-border);
    border-radius: clamp(18px, 1.6vw, 32px);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(245, 248, 255, 0.9)), radial-gradient(circle at 78% 20%, rgba(0, 116, 255, 0.12), transparent 36%), radial-gradient(circle at 16% 86%, rgba(107, 63, 242, 0.10), transparent 34%);
    box-shadow: var(--ve-shadow);
    overflow: hidden;
}

    .ve-hero::after {
        content: "";
        position: absolute;
        inset: auto -10% -42% 45%;
        height: 360px;
        background: radial-gradient(circle, rgba(0, 116, 255, 0.13), transparent 60%), radial-gradient(circle at 30% 70%, rgba(107, 63, 242, 0.12), transparent 56%);
        filter: blur(8px);
        pointer-events: none;
    }

.hero-fluid-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(320px, 0.85fr) minmax(620px, 1.15fr);
    gap: clamp(1rem, 2vw, 2.5rem);
    align-items: stretch;
}

.hero-copy-column,
.hero-demo-column {
    min-width: 0;
}

.hero-demo-column {
    container-type: inline-size;
}

.hero-copy {
    position: relative;
    z-index: 1;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(0.25rem, 1vw, 1rem);
}

.hero-logo {
    width: clamp(130px, 14vw, 245px);
    height: auto;
    display: block;
}

.hero-eyebrow {
    margin-bottom: 0.7rem;
    color: var(--ve-bright-blue);
    font-weight: 800;
    font-size: 0.82rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.hero-title {
    max-width: 820px;
    margin-bottom: 1rem;
    color: var(--ve-navy);
    font-size: clamp(2.2rem, 4.2vw, 5.1rem);
    line-height: 0.98;
    font-weight: 900;
    letter-spacing: -0.055em;
}

.hero-subtitle {
    max-width: 760px;
    margin-bottom: 1.6rem;
    color: #344158;
    font-size: clamp(1.05rem, 1.5vw, 1.35rem);
    line-height: 1.65;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    margin-bottom: 0.85rem;
}

.ve-btn-primary,
.ve-btn-secondary {
    border-radius: 999px;
    padding: 0.9rem 1.35rem;
    font-weight: 800;
    box-shadow: 0 12px 30px rgba(0, 92, 191, 0.16);
}

.ve-btn-primary {
    color: #ffffff;
    border: 0;
    background: linear-gradient(135deg, var(--ve-blue), var(--ve-purple));
}

    .ve-btn-primary:hover,
    .ve-btn-primary:focus {
        color: #ffffff;
        transform: translateY(-1px);
    }

.ve-btn-secondary {
    color: var(--ve-navy);
    border: 1px solid rgba(0, 92, 191, 0.22);
    background: rgba(255, 255, 255, 0.82);
}

.hero-note {
    max-width: 620px;
    margin: 0;
    color: var(--ve-muted);
    font-size: 0.95rem;
}















/* Friday rush / multiple Ginos demo */

.hero-logo-rush-row {
    display: flex;
    align-items: center;
    gap: clamp(1rem, 1.4vw, 1.6rem);
    margin-bottom: 1.25rem;
}

    .hero-logo-rush-row .hero-logo {
        flex: 0 0 auto;
    }

.rush-demo-button {
    flex: 1;
    max-width: 385px;
    display: flex;
    align-items: center;
    gap: 0.85rem;
    border: 1px solid rgba(0, 116, 255, 0.24);
    border-radius: 22px;
    padding: 0.95rem 1rem;
    color: #ffffff;
    background: linear-gradient(135deg, #005cbf 0%, #6b3ff2 100%);
    box-shadow: 0 18px 44px rgba(0, 92, 191, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.22);
    text-align: left;
    cursor: pointer;
}

    .rush-demo-button:hover,
    .rush-demo-button:focus {
        transform: translateY(-1px);
        box-shadow: 0 22px 52px rgba(0, 92, 191, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.25);
    }

.rush-demo-icon {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 50%;
    background: radial-gradient(circle at 35% 22%, rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0.13));
    box-shadow: 0 0 24px rgba(255, 255, 255, 0.24), inset 0 0 0 1px rgba(255, 255, 255, 0.28);
    font-size: 1.35rem;
    font-weight: 900;
}

.rush-demo-button strong,
.rush-demo-button em {
    display: block;
}

.rush-demo-button strong {
    font-size: 1.05rem;
    font-weight: 950;
    line-height: 1.15;
}

.rush-demo-button em {
    margin-top: 0.2rem;
    color: rgba(255, 255, 255, 0.86);
    font-size: 0.84rem;
    font-style: normal;
    font-weight: 750;
    line-height: 1.25;
}

.rush-demo-chevron {
    margin-left: auto;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    transition: transform 0.2s ease;
}

.rush-demo-button[aria-expanded="true"] .rush-demo-chevron {
    transform: rotate(90deg);
}

.rush-demo-panel {
    width: min(100%, 760px);
    margin: -0.2rem 0 1.15rem 0;
    border-radius: 28px;
    padding: clamp(1rem, 1.4vw, 1.35rem);
    color: #ffffff;
    background: radial-gradient(circle at 50% 55%, rgba(0, 198, 255, 0.28), transparent 24%), radial-gradient(circle at 50% 50%, rgba(107, 63, 242, 0.22), transparent 38%), linear-gradient(145deg, #06163b 0%, #071f4d 55%, #092e72 100%);
    box-shadow: 0 26px 64px rgba(7, 26, 61, 0.24), inset 0 0 0 1px rgba(255, 255, 255, 0.10);
    animation: rushPanelOpen 0.24s ease-out;
}

    .rush-demo-panel[hidden] {
        display: none;
    }

@keyframes rushPanelOpen {
    from {
        opacity: 0;
        transform: translateY(-8px) scale(0.985);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.rush-demo-panel-header {
    position: relative;
    text-align: center;
    padding: 0.25rem 2rem 0.2rem 2rem;
}

    .rush-demo-panel-header h3 {
        max-width: 620px;
        margin: 0 auto;
        color: #ffffff;
        font-size: clamp(1.35rem, 2.25vw, 2.15rem);
        line-height: 1.12;
        font-weight: 950;
        letter-spacing: -0.045em;
    }

    .rush-demo-panel-header p {
        max-width: 530px;
        margin: 0.6rem auto 0 auto;
        color: rgba(234, 242, 255, 0.82);
        font-size: clamp(0.92rem, 1.2vw, 1.08rem);
        line-height: 1.35;
        font-weight: 750;
    }

.rush-demo-close {
    position: absolute;
    top: 0;
    right: 0;
    width: 32px;
    height: 32px;
    display: grid;
    place-items: center;
    border: 0;
    border-radius: 50%;
    color: rgba(255, 255, 255, 0.82);
    background: rgba(255, 255, 255, 0.12);
    font-size: 1.25rem;
    font-weight: 900;
    line-height: 1;
    cursor: pointer;
}

.rush-demo-caller-map {
    position: relative;
    height: clamp(520px, 34vw, 620px);
    margin-top: 1.05rem;
    border-radius: 24px;
    overflow: hidden;
    background: radial-gradient(circle at 50% 52%, rgba(0, 198, 255, 0.22), transparent 18%), radial-gradient(circle at 50% 50%, rgba(107, 63, 242, 0.18), transparent 36%), linear-gradient(180deg, rgba(2, 10, 33, 0.08), rgba(2, 10, 33, 0.02));
}

    .rush-demo-caller-map::before,
    .rush-demo-caller-map::after {
        content: "";
        position: absolute;
        border-radius: 50%;
        border: 1px solid rgba(80, 178, 255, 0.13);
        pointer-events: none;
    }

    .rush-demo-caller-map::before {
        inset: 19% 23%;
    }

    .rush-demo-caller-map::after {
        inset: 26% 31%;
    }

.rush-gino-main,
.rush-gino-node {
    position: absolute;
    z-index: 3;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: #ffffff;
    background: radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.52), transparent 20%), linear-gradient(145deg, #1185ff 0%, #2d46ff 45%, #7740f2 100%);
    box-shadow: 0 0 0 4px rgba(63, 213, 255, 0.34), 0 0 34px rgba(0, 198, 255, 0.58), inset 0 -12px 22px rgba(25, 0, 140, 0.28);
    font-weight: 950;
}

.rush-gino-main {
    top: 52%;
    left: 50%;
    width: clamp(104px, 8vw, 132px);
    height: clamp(104px, 8vw, 132px);
    transform: translate(-50%, -50%);
    font-size: clamp(1.85rem, 2.7vw, 2.55rem);
}

.rush-gino-node {
    width: clamp(58px, 4.7vw, 76px);
    height: clamp(58px, 4.7vw, 76px);
    font-size: clamp(0.92rem, 1.25vw, 1.15rem);
}

.rush-gino-one {
    top: 30%;
    left: 42%;
}

.rush-gino-two {
    top: 31%;
    right: 29%;
}

.rush-gino-three {
    top: 49%;
    right: 23%;
}

.rush-gino-four {
    bottom: 19%;
    right: 32%;
}

.rush-gino-five {
    bottom: 19%;
    left: 32%;
}

.rush-gino-six {
    top: 49%;
    left: 23%;
}

.rush-gino-seven {
    top: 31%;
    left: 29%;
}

.rush-caller-card {
    position: absolute;
    z-index: 4;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-width: clamp(145px, 13vw, 190px);
    min-height: 66px;
    border-radius: 999px;
    padding: 0.48rem 0.85rem 0.48rem 0.48rem;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.13);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12), 0 14px 30px rgba(0, 0, 0, 0.20);
    backdrop-filter: blur(10px);
}

    .rush-caller-card img {
        width: 54px;
        height: 54px;
        flex: 0 0 auto;
        border-radius: 50%;
        object-fit: cover;
        background: rgba(255, 255, 255, 0.10);
    }

    .rush-caller-card strong {
        display: block;
        font-size: clamp(0.78rem, 1.05vw, 0.98rem);
        line-height: 1.1;
        font-weight: 950;
    }

.rush-caller-number {
    position: absolute;
    top: 0.22rem;
    left: 3.05rem;
    width: 1.25rem;
    height: 1.25rem;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: #ffffff;
    background: #6b3ff2;
    font-size: 0.68rem;
    font-weight: 950;
}

.rush-caller-one {
    top: 6%;
    left: 50%;
    transform: translateX(-50%);
}

.rush-caller-two {
    top: 20%;
    right: 2%;
}

.rush-caller-three {
    top: 47%;
    right: 0;
}

.rush-caller-four {
    bottom: 5%;
    right: 12%;
}

.rush-caller-five {
    bottom: 5%;
    left: 12%;
}

.rush-caller-six {
    top: 47%;
    left: 0;
}

.rush-caller-seven {
    top: 20%;
    left: 2%;
}

@media (max-width: 768px) {
    .hero-logo-rush-row {
        align-items: stretch;
        flex-direction: column;
    }

    .rush-demo-button,
    .rush-demo-panel {
        max-width: 100%;
    }

    .rush-demo-caller-map {
        height: 520px;
    }

    .rush-caller-card {
        min-width: 136px;
    }
}

/* Demo area */

.demo-shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(300px, 1fr) minmax(260px, 0.75fr);
    gap: clamp(0.8rem, 1.15vw, 1.25rem);
    height: 100%;
}

.gino-stage,
.control-board,
.feature-card,
.content-section {
    border: 1px solid var(--ve-border);
    background: var(--ve-card);
    box-shadow: 0 18px 48px rgba(7, 26, 61, 0.10);
    backdrop-filter: blur(18px);
}

.gino-stage {
    border-radius: 24px;
    padding: 1rem;
    display: grid;
    gap: 1rem;
}

.gino-portrait-card {
    position: relative;
    min-height: clamp(520px, 36vw, 670px);
    border-radius: 26px;
    overflow: hidden;
    background: radial-gradient(circle at 50% 34%, rgba(0, 116, 255, 0.42), transparent 28%), radial-gradient(circle at 75% 82%, rgba(107, 63, 242, 0.28), transparent 30%), radial-gradient(circle at 20% 26%, rgba(0, 198, 255, 0.13), transparent 30%), linear-gradient(145deg, #06163b 0%, #0b2b62 55%, #0f63b8 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), inset 0 -40px 90px rgba(0, 0, 0, 0.18), 0 24px 60px rgba(7, 26, 61, 0.22);
}

    .gino-portrait-card::before,
    .gino-portrait-card::after {
        content: "";
        position: absolute;
        top: 27%;
        width: 230px;
        height: 230px;
        border-radius: 50%;
        background: repeating-radial-gradient(circle, rgba(73, 169, 255, 0.20) 0 1px, transparent 2px 13px);
        opacity: 0.32;
        pointer-events: none;
    }

    .gino-portrait-card::before {
        left: 7%;
    }

    .gino-portrait-card::after {
        right: 7%;
    }

.gino-status-pill {
    position: absolute;
    top: 1.25rem;
    left: 1.25rem;
    z-index: 6;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.55rem 0.9rem;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 999px;
    font-size: 0.9rem;
    font-weight: 900;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 10px 26px rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(10px);
}

    .gino-status-pill::before {
        content: "";
        width: 0.72rem;
        height: 0.72rem;
        border-radius: 50%;
        background: #34e184;
        box-shadow: 0 0 16px rgba(52, 225, 132, 0.72);
    }

    .gino-status-pill.gino-off {
        color: #ffffff;
        background: linear-gradient(135deg, #c62828, #8b0000);
        border-color: rgba(255, 255, 255, 0.34);
    }

        .gino-status-pill.gino-off::before {
            background: #ffb2b2;
            box-shadow: 0 0 16px rgba(255, 178, 178, 0.65);
        }

.gino-orb-zone {
    position: absolute;
    inset: 0;
    z-index: 4;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 4.4rem 2rem 2rem 2rem;
    text-align: center;
}

.gino-orb-button {
    position: relative;
    width: clamp(175px, 15vw, 245px);
    height: clamp(175px, 15vw, 245px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.42rem;
    border: 0;
    border-radius: 50%;
    color: #ffffff;
    background: radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.55), transparent 18%), radial-gradient(circle at 30% 28%, rgba(105, 205, 255, 0.58), transparent 28%), linear-gradient(145deg, #1185ff 0%, #2d46ff 45%, #7740f2 100%);
    font-size: clamp(2.4rem, 4.1vw, 4.25rem);
    font-weight: 950;
    letter-spacing: -0.05em;
    text-shadow: 0 3px 12px rgba(0, 0, 0, 0.28);
    cursor: pointer;
    box-shadow: 0 0 0 5px rgba(130, 170, 255, 0.42), 0 0 40px rgba(0, 116, 255, 0.70), 0 0 70px rgba(107, 63, 242, 0.44), 0 28px 38px rgba(0, 0, 0, 0.30), inset 0 5px 18px rgba(255, 255, 255, 0.42), inset 0 -24px 34px rgba(25, 0, 140, 0.30);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
    animation: ginoOrbIdlePulse 2.65s infinite ease-in-out;
}

.gino-orb-face-wrap {
    width: clamp(74px, 6.2vw, 104px);
    height: clamp(74px, 6.2vw, 104px);
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.16);
    box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.24), 0 12px 24px rgba(0, 0, 0, 0.22);
    overflow: hidden;
}

.gino-orb-face {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
}

.gino-orb-name {
    display: block;
    font-size: clamp(1.75rem, 3.15vw, 3.25rem);
    line-height: 0.95;
    font-weight: 950;
}

    .gino-orb-button::after {
        content: "";
        position: absolute;
        inset: -14px;
        border-radius: 50%;
        border: 2px solid rgba(83, 190, 255, 0.22);
        opacity: 0.85;
        pointer-events: none;
    }

    .gino-orb-button:hover,
    .gino-orb-button:focus {
        transform: translateY(-3px) scale(1.015);
        filter: saturate(1.08) brightness(1.05);
    }

    .gino-orb-button:active {
        transform: translateY(4px) scale(0.985);
        box-shadow: 0 0 0 4px rgba(130, 170, 255, 0.34), 0 0 32px rgba(0, 116, 255, 0.58), 0 18px 25px rgba(0, 0, 0, 0.30), inset 0 6px 24px rgba(0, 0, 0, 0.25), inset 0 -14px 24px rgba(25, 0, 140, 0.25);
    }

@keyframes ginoOrbIdlePulse {
    0%, 100% {
        transform: translateY(0) scale(1);
        box-shadow: 0 0 0 5px rgba(130, 170, 255, 0.42), 0 0 40px rgba(0, 116, 255, 0.70), 0 0 70px rgba(107, 63, 242, 0.44), 0 28px 38px rgba(0, 0, 0, 0.30), inset 0 5px 18px rgba(255, 255, 255, 0.42), inset 0 -24px 34px rgba(25, 0, 140, 0.30);
    }

    50% {
        transform: translateY(-2px) scale(1.018);
        box-shadow: 0 0 0 7px rgba(130, 170, 255, 0.48), 0 0 54px rgba(0, 198, 255, 0.78), 0 0 86px rgba(107, 63, 242, 0.54), 0 30px 42px rgba(0, 0, 0, 0.30), inset 0 5px 18px rgba(255, 255, 255, 0.46), inset 0 -24px 34px rgba(25, 0, 140, 0.30);
    }
}

.gino-portrait-card.is-live .gino-orb-button {
    animation: ginoOrbPulse 1.75s infinite ease-in-out;
}

@keyframes ginoOrbPulse {
    0%, 100% {
        box-shadow: 0 0 0 5px rgba(130, 170, 255, 0.42), 0 0 40px rgba(0, 116, 255, 0.70), 0 0 70px rgba(107, 63, 242, 0.44), 0 28px 38px rgba(0, 0, 0, 0.30), inset 0 5px 18px rgba(255, 255, 255, 0.42), inset 0 -24px 34px rgba(25, 0, 140, 0.30);
    }

    50% {
        box-shadow: 0 0 0 8px rgba(130, 170, 255, 0.50), 0 0 58px rgba(0, 198, 255, 0.86), 0 0 92px rgba(107, 63, 242, 0.58), 0 31px 42px rgba(0, 0, 0, 0.30), inset 0 5px 18px rgba(255, 255, 255, 0.46), inset 0 -24px 34px rgba(25, 0, 140, 0.30);
    }
}

.gino-orb-title {
    margin-top: 1.7rem;
    color: #ffffff;
    font-size: clamp(1.45rem, 2.2vw, 2.15rem);
    font-weight: 950;
    letter-spacing: -0.035em;
}

.gino-orb-subtitle {
    margin-top: 0.28rem;
    color: rgba(222, 232, 255, 0.82);
    font-size: clamp(0.95rem, 1.4vw, 1.25rem);
    font-weight: 850;
}

.gino-capability-line {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem 0.7rem;
    margin-top: 1.05rem;
    color: rgba(226, 235, 255, 0.78);
    font-size: 0.95rem;
    font-weight: 800;
}

    .gino-capability-line span:not(:last-child)::after {
        content: "•";
        margin-left: 0.7rem;
        color: rgba(226, 235, 255, 0.45);
    }

.gino-starter-chips {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.65rem;
    width: min(100%, 760px);
    margin-top: 1.5rem;
}

    .gino-starter-chips span {
        padding: 0.62rem 0.9rem;
        color: rgba(255, 255, 255, 0.92);
        background: rgba(255, 255, 255, 0.10);
        border: 1px solid rgba(255, 255, 255, 0.14);
        border-radius: 999px;
        font-size: 0.84rem;
        font-weight: 850;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.10), 0 10px 20px rgba(0, 0, 0, 0.13);
        backdrop-filter: blur(10px);
    }

.stage-hangup-button {
    width: min(88%, 360px);
    margin-top: 1.1rem;
    border: 0;
    border-radius: 999px;
    padding: 0.95rem 1.25rem;
    color: #ffffff;
    background: linear-gradient(135deg, #c62828, #8b0000);
    font-size: 1.05rem;
    font-weight: 900;
    box-shadow: 0 18px 42px rgba(139, 0, 0, 0.34);
}

    .stage-hangup-button:hover,
    .stage-hangup-button:focus {
        transform: translateY(-1px);
    }

.voice-wave {
    position: absolute;
    right: 1.3rem;
    bottom: 1.25rem;
    display: flex;
    gap: 0.4rem;
    align-items: end;
    z-index: 5;
    opacity: 0.45;
}

    .voice-wave span {
        width: 10px;
        height: 18px;
        border-radius: 99px;
        background: linear-gradient(to top, #17d5ff, #7a4dff);
        box-shadow: 0 0 18px rgba(23, 213, 255, 0.55);
        animation: veWave 1.1s infinite ease-in-out;
        animation-play-state: paused;
    }

        .voice-wave span:nth-child(2) {
            height: 30px;
            animation-delay: 0.10s;
        }

        .voice-wave span:nth-child(3) {
            height: 42px;
            animation-delay: 0.20s;
        }

        .voice-wave span:nth-child(4) {
            height: 60px;
            animation-delay: 0.30s;
        }

        .voice-wave span:nth-child(5) {
            height: 46px;
            animation-delay: 0.40s;
        }

        .voice-wave span:nth-child(6) {
            height: 34px;
            animation-delay: 0.50s;
        }

.gino-portrait-card.is-live .voice-wave {
    opacity: 1;
}

    .gino-portrait-card.is-live .voice-wave span {
        animation-play-state: running;
    }

@keyframes veWave {
    0%, 100% {
        transform: scaleY(0.42);
        opacity: 0.48;
    }

    50% {
        transform: scaleY(1);
        opacity: 1;
    }
}

/* Transcript */

.transcript-card {
    border: 1px solid rgba(7, 26, 61, 0.10);
    border-radius: 20px;
    background: #ffffff;
    overflow: hidden;
}

.transcript-header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem;
    color: var(--ve-navy);
    background: #f4f7ff;
    border-bottom: 1px solid rgba(7, 26, 61, 0.08);
    font-weight: 900;
}

.transcript-small {
    color: var(--ve-muted);
    font-size: 0.78rem;
    font-weight: 700;
}

.transcript-log {
    min-height: clamp(150px, 14vw, 240px);
    max-height: 260px;
    overflow-y: auto;
    padding: 1rem;
}

.transcript-line {
    margin-bottom: 0.7rem;
    padding: 0.72rem 0.85rem;
    border-radius: 14px;
    color: #253149;
    background: #f7f9fe;
    line-height: 1.45;
    font-size: 0.94rem;
}

.transcript-gino {
    background: rgba(0, 116, 255, 0.09);
}

.transcript-system {
    color: var(--ve-muted);
    background: #f5f6fa;
}

.transcript-user {
    color: var(--ve-navy);
    background: rgba(107, 63, 242, 0.08);
}

/* Temporary live transcript panel */

.live-transcript-panel {
    grid-column: 1 / -1;
    width: min(100%, 880px);
    margin: 0 auto;
    animation: liveTranscriptAppear 0.22s ease-out;
}

    .live-transcript-panel[hidden] {
        display: none;
    }

    .live-transcript-panel .transcript-log {
        min-height: 110px;
        max-height: 185px;
    }

@keyframes liveTranscriptAppear {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Printer proof overlay */

.gino-stage {
    position: relative;
}

.printer-proof-overlay {
    position: absolute;
    inset: 0;
    z-index: 30;
    display: grid;
    place-items: center;
    padding: 1rem;
    background: rgba(7, 26, 61, 0.42);
    backdrop-filter: blur(10px);
    border-radius: 24px;
}

    .printer-proof-overlay[hidden] {
        display: none;
    }

.printer-proof-card {
    width: min(100%, 760px);
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 24px;
    padding: 1rem;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(242, 246, 255, 0.94));
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.30);
    overflow: hidden;
}

.printer-proof-header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: baseline;
    margin-bottom: 0.9rem;
    color: var(--ve-navy);
}

    .printer-proof-header span {
        font-size: 1.05rem;
        font-weight: 950;
    }

    .printer-proof-header small {
        color: var(--ve-muted);
        font-weight: 800;
    }

.printer-proof-printers {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.printer-proof-unit {
    position: relative;
    min-height: 355px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
}

.printer-slot {
    position: absolute;
    top: 0;
    width: min(84%, 250px);
    height: 270px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    overflow: hidden;
    border-radius: 10px 10px 4px 4px;
    background: linear-gradient(180deg, #111318 0%, #1b1f27 18%, transparent 19%);
    box-shadow: inset 0 12px 18px rgba(0, 0, 0, 0.42);
}

.printer-base {
    width: min(96%, 310px);
    height: 92px;
    display: grid;
    place-items: end center;
    padding-bottom: 1rem;
    border-radius: 18px 18px 24px 24px;
    color: rgba(255, 255, 255, 0.82);
    background: linear-gradient(145deg, #111318 0%, #292f3a 55%, #090a0d 100%);
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.10), inset 0 -10px 24px rgba(0, 0, 0, 0.42), 0 16px 30px rgba(0, 0, 0, 0.26);
}

    .printer-base span {
        font-size: 0.82rem;
        font-weight: 900;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }

.thermal-ticket {
    width: 210px;
    min-height: 360px;
    padding: 0.85rem 0.75rem 1.1rem 0.75rem;
    color: #151515;
    background: #fffdf2;
    font-family: "Courier New", monospace;
    font-size: 0.82rem;
    line-height: 1.25;
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.25);
    transform: translateY(-112%);
}

.printer-proof-overlay.printing .thermal-ticket {
    animation: thermalTicketFeed 1.25s steps(9, end) forwards;
}

.printer-proof-overlay.printing .checkout-ticket {
    animation-delay: 0.16s;
}

@keyframes thermalTicketFeed {
    0% {
        transform: translateY(-112%);
    }

    72% {
        transform: translateY(-10%);
    }

    100% {
        transform: translateY(0);
    }
}

.ticket-small {
    text-align: center;
    font-weight: 700;
}

.ticket-number {
    margin: 0.1rem 0 0.35rem 0;
    text-align: center;
    font-size: 2.6rem;
    line-height: 1;
    font-weight: 900;
}

.ticket-mode {
    margin: 0.35rem 0 0.65rem 0;
    text-align: center;
    font-size: 1.05rem;
    font-weight: 900;
}

.ticket-store {
    text-align: center;
    margin-bottom: 0.16rem;
}

.ticket-heading {
    margin: 0.9rem 0 0.35rem 0;
    font-weight: 900;
}

.ticket-line,
.ticket-time {
    margin-bottom: 0.28rem;
}

.kitchen-ticket {
    font-size: 0.92rem;
}

    .kitchen-ticket .ticket-number {
        font-size: 3rem;
    }

.checkout-ticket {
    min-height: 455px;
}

@media (max-width: 720px) {
    .printer-proof-printers {
        grid-template-columns: 1fr;
    }

    .printer-proof-card {
        max-height: 92vh;
        overflow-y: auto;
    }
}

/* Control board iPad preview */

.control-board {
    min-width: 0;
}

    .control-board.gino-off .ipad-device {
        box-shadow: 0 30px 90px rgba(198, 40, 40, 0.22);
    }

.ipad-control-board {
    border: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    padding: 0;
}

.ipad-device {
    position: relative;
    width: min(100%, 520px);
    margin: 0 auto;
    padding: 34px 26px 48px 26px;
    border-radius: 34px;
    background: linear-gradient(145deg, #1a1b1f, #030406 58%, #14161a);
    box-shadow: 0 34px 92px rgba(7, 26, 61, 0.34), 0 10px 0 rgba(0, 0, 0, 0.18), inset 0 2px 0 rgba(255, 255, 255, 0.16), inset 0 -10px 24px rgba(0, 0, 0, 0.42), inset 0 0 0 2px rgba(255, 255, 255, 0.06);
}

.ipad-camera {
    position: absolute;
    top: 16px;
    left: 50%;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: radial-gradient(circle, #27374d, #050609);
    transform: translateX(-50%);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.06);
}

.ipad-home-button {
    position: absolute;
    left: 50%;
    bottom: 12px;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    transform: translateX(-50%);
    background: radial-gradient(circle at 35% 30%, #23262b, #06070a);
    box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.10);
}

.ipad-screen {
    overflow: hidden;
    border-radius: 8px;
    background: #f7f8fb;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.10), inset 0 4px 18px rgba(0, 0, 0, 0.22), 0 1px 0 rgba(255, 255, 255, 0.08);
}

.ipad-status-bar {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 0.7rem;
    padding: 0.55rem 0.75rem;
    color: rgba(255, 255, 255, 0.92);
    background: linear-gradient(to bottom, #333941, #1f242b);
    font-size: 0.74rem;
    font-weight: 800;
}

    .ipad-status-bar span:nth-child(2) {
        text-align: center;
    }

    .ipad-status-bar span:nth-child(3) {
        text-align: right;
    }

.ipad-board-surface {
    position: relative;
    min-height: 640px;
    padding: 1rem 1rem 1.25rem 1rem;
    background: linear-gradient(180deg, #ffffff 0%, #f6f7f9 100%);
}

.ipad-pickup-card {
    padding: 1rem;
    border: 1px solid rgba(7, 26, 61, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.76);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55);
}

    .ipad-pickup-card h2 {
        margin: 0 0 1.2rem 0;
        color: #6f7884;
        font-size: clamp(2.2rem, 4vw, 3.3rem);
        line-height: 1;
        font-weight: 900;
        letter-spacing: -0.055em;
        text-align: center;
    }

.ipad-pickup-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem 1.05rem;
}

.ipad-pickup-button {
    position: relative;
    min-height: 82px;
    border: 3px solid rgba(0, 0, 0, 0.15);
    border-radius: 14px;
    color: #ffffff;
    font-size: clamp(1.15rem, 2.1vw, 1.65rem);
    font-weight: 900;
    text-shadow: 0 2px 3px rgba(0, 0, 0, 0.24);
    cursor: pointer;
    touch-action: manipulation;
    box-shadow: inset 0 3px 0 rgba(255, 255, 255, 0.30), inset 0 -8px 0 rgba(0, 0, 0, 0.12), 0 7px 0 rgba(0, 0, 0, 0.18), 0 10px 18px rgba(0, 0, 0, 0.14);
}

    .ipad-pickup-button::before {
        content: "";
        position: absolute;
        top: 8px;
        right: 9px;
        left: 9px;
        height: 38%;
        border-radius: 10px;
        background: linear-gradient(to bottom, rgba(255, 255, 255, 0.30), rgba(255, 255, 255, 0.08));
        pointer-events: none;
    }

    .ipad-pickup-button:active,
    .ipad-pickup-button.selected {
        transform: translateY(4px);
        box-shadow: inset 0 4px 8px rgba(0, 0, 0, 0.18), inset 0 2px 0 rgba(255, 255, 255, 0.14), 0 3px 0 rgba(0, 0, 0, 0.18), 0 5px 10px rgba(0, 0, 0, 0.13);
        filter: saturate(1.04) brightness(0.94);
    }

    .ipad-pickup-button.v15 {
        background: linear-gradient(to bottom, #b9f6a5 0%, #6fcd4f 100%);
    }

    .ipad-pickup-button.v20 {
        background: linear-gradient(to bottom, #9bea7a 0%, #43b929 100%);
    }

    .ipad-pickup-button.v25 {
        background: linear-gradient(to bottom, #6fd85a 0%, #218f16 100%);
    }

    .ipad-pickup-button.v30 {
        background: linear-gradient(to bottom, #d6ed5b 0%, #9dbb20 100%);
    }

    .ipad-pickup-button.v35 {
        background: linear-gradient(to bottom, #ffe76a 0%, #d5b100 100%);
    }

    .ipad-pickup-button.v40 {
        background: linear-gradient(to bottom, #ffbc5e 0%, #ef7f00 100%);
    }

    .ipad-pickup-button.v45 {
        background: linear-gradient(to bottom, #ff9a9a 0%, #e25555 100%);
    }

    .ipad-pickup-button.v50 {
        background: linear-gradient(to bottom, #ff5f5f 0%, #c81919 100%);
    }

.ipad-credit-panel {
    margin-top: 1.35rem;
    padding: 1.45rem 1.35rem 1.1rem 1.35rem;
    border: 1px solid rgba(7, 26, 61, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.74);
    box-shadow: 0 10px 24px rgba(7, 26, 61, 0.06), inset 0 0 0 1px rgba(255, 255, 255, 0.65);
}

.ipad-credit-title {
    display: block;
    margin-bottom: 0.25rem;
    color: #6f7884;
    font-size: clamp(1.05rem, 1.7vw, 1.35rem);
    font-weight: 900;
    text-align: center;
}

.ipad-credit-value {
    color: #424a56;
    font-size: clamp(1.8rem, 3vw, 2.35rem);
    font-weight: 900;
    letter-spacing: -0.04em;
    text-align: center;
}

.ipad-credit-slider {
    width: 100%;
    margin-top: 1rem;
    accent-color: #35af31;
}

.ipad-credit-range {
    display: flex;
    justify-content: space-between;
    margin-top: 0.35rem;
    color: #687280;
    font-size: 0.95rem;
    font-weight: 900;
}

.ipad-control-bottom-row {
    position: absolute;
    right: 1rem;
    bottom: 1.25rem;
    left: 1rem;
    display: flex;
    justify-content: space-between;
    gap: 0.9rem;
    align-items: center;
}

.ipad-footer-button {
    min-width: 128px;
    border: 0;
    border-radius: 999px;
    padding: 0.78rem 1rem;
    color: #ffffff;
    font-size: 0.94rem;
    font-weight: 900;
    text-align: center;
    box-shadow: inset 0 3px 0 rgba(255, 255, 255, 0.25), inset 0 -7px 0 rgba(0, 0, 0, 0.14), 0 7px 0 rgba(0, 0, 0, 0.18), 0 10px 20px rgba(0, 0, 0, 0.20);
    cursor: pointer;
    user-select: none;
    touch-action: manipulation;
}

    .ipad-footer-button:active {
        transform: translateY(4px);
        box-shadow: inset 0 3px 0 rgba(255, 255, 255, 0.18), inset 0 -6px 0 rgba(0, 0, 0, 0.18), 0 3px 0 rgba(0, 0, 0, 0.16), 0 6px 12px rgba(0, 0, 0, 0.18);
    }

    .ipad-footer-button input {
        position: absolute;
        opacity: 0;
        pointer-events: none;
    }

.ai-answering-button {
    background: linear-gradient(to bottom, #34b95a 0%, #1f8f3a 100%);
}

    .ai-answering-button.staff-answering {
        background: linear-gradient(to bottom, #e04a4a 0%, #c62828 100%);
    }

.conversations-button {
    background: linear-gradient(to bottom, #6a727f 0%, #4f5661 100%);
}

.ipad-conversation-screen {
    position: absolute;
    inset: 0;
    z-index: 8;
    display: flex;
    flex-direction: column;
    padding: 1rem;
    background: linear-gradient(180deg, #ffffff 0%, #f6f7f9 100%);
}

    .ipad-conversation-screen[hidden] {
        display: none;
    }

.ipad-conversation-header {
    display: flex;
    justify-content: space-between;
    gap: 0.85rem;
    align-items: flex-start;
    padding: 0.85rem 0.9rem;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 10px 24px rgba(7, 26, 61, 0.08), inset 0 0 0 1px rgba(7, 26, 61, 0.08);
}

.ipad-conversation-title {
    color: #005cbf;
    font-size: 1.35rem;
    font-weight: 900;
    line-height: 1.1;
}

.ipad-conversation-meta {
    margin-top: 0.22rem;
    color: #6f7884;
    font-size: 0.82rem;
    font-weight: 800;
}

.ipad-conversation-back {
    border: 0;
    border-radius: 999px;
    padding: 0.55rem 0.75rem;
    color: #ffffff;
    background: linear-gradient(to bottom, #6a727f 0%, #4f5661 100%);
    font-size: 0.8rem;
    font-weight: 900;
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.22), inset 0 -5px 0 rgba(0, 0, 0, 0.14), 0 5px 0 rgba(0, 0, 0, 0.16);
}

.ipad-conversation-transcript {
    flex: 1;
    overflow-y: auto;
    margin-top: 0.85rem;
    padding-right: 0.25rem;
}

.ipad-conversation-turn {
    margin-bottom: 0.75rem;
    padding: 0.75rem 0.85rem;
    border-radius: 14px;
    background: #f1f3f7;
    box-shadow: inset 0 0 0 1px rgba(7, 26, 61, 0.04);
}

.ipad-conversation-role {
    margin-bottom: 0.3rem;
    color: #6f7884;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.ipad-conversation-turn.gino .ipad-conversation-role {
    color: #1f8f3a;
}

.ipad-conversation-turn.customer .ipad-conversation-role {
    color: #c77700;
}

.ipad-conversation-text {
    color: #111827;
    font-size: 0.86rem;
    font-weight: 650;
    line-height: 1.34;
    white-space: pre-wrap;
}

.ipad-conversation-hint {
    margin-top: 0.65rem;
    color: #6f7884;
    font-size: 0.78rem;
    font-weight: 800;
    text-align: center;
}

.ipad-hidden-summary,
.visually-hidden-control {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    white-space: nowrap !important;
}

@media (max-width: 1250px) {
    .ipad-device {
        width: min(100%, 620px);
    }
}

@media (max-width: 620px) {
    .ipad-device {
        padding: 28px 16px 42px 16px;
        border-radius: 28px;
    }

    .ipad-board-surface {
        min-height: 575px;
        padding: 0.75rem;
    }

    .ipad-pickup-grid {
        gap: 0.75rem;
    }

    .ipad-pickup-button {
        min-height: 68px;
    }

    .ipad-footer-button {
        min-width: 112px;
        padding: 0.72rem 0.8rem;
        font-size: 0.84rem;
    }
}

/* Lower sections */

.feature-section,
.content-section {
    width: 100%;
    max-width: 1900px;
    margin: 0 auto 2rem auto;
}

.feature-section {
    padding: clamp(1rem, 2vw, 1.25rem);
}

.section-heading {
    max-width: 820px;
    margin-bottom: 1rem;
}

    .section-heading h2 {
        color: var(--ve-navy);
        font-size: clamp(1.8rem, 3vw, 3rem);
        font-weight: 900;
        letter-spacing: -0.035em;
    }

.feature-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.feature-card {
    min-height: 180px;
    border-radius: 22px;
    padding: 1.25rem;
}

    .feature-card h3 {
        color: var(--ve-navy);
        font-weight: 900;
        margin-bottom: 0.7rem;
    }

    .feature-card p {
        color: var(--ve-muted);
        line-height: 1.6;
        margin: 0;
    }

.content-section {
    border-radius: 20px;
    padding: 1.25rem;
}

    .content-section p {
        margin: 0;
    }

/* Existing content pages */

.page-title,
.section-title {
    font-weight: 800;
    margin-bottom: 1rem;
}

.page-title {
    font-size: 2rem;
}

.section-title {
    font-size: 1.25rem;
    margin-top: 1.5rem;
}

/* Footer */

.footer {
    position: static;
    width: 100%;
    white-space: nowrap;
    line-height: 60px;
    background: rgba(255, 255, 255, 0.82);
}

.footer-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footer-links a {
    text-decoration: none;
}

/* Responsive behavior */

@container (max-width: 720px) {
    .demo-shell {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 1250px) {
    .hero-fluid-grid {
        grid-template-columns: 1fr;
    }

    .hero-copy {
        justify-content: flex-start;
    }
}

@media (max-width: 1200px) {
    .feature-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-height: 820px) and (min-width: 901px) {
    .ve-hero {
        padding: clamp(0.75rem, 1.4vw, 1.4rem);
    }

    .hero-logo {
        width: clamp(105px, 10vw, 175px);
        margin-bottom: 0.7rem !important;
    }

    .hero-eyebrow {
        margin-bottom: 0.4rem;
        font-size: 0.72rem;
    }

    .hero-title {
        margin-bottom: 0.65rem;
        font-size: clamp(2rem, 3.4vw, 4rem);
        line-height: 1;
    }

    .hero-subtitle {
        margin-bottom: 0.8rem;
        font-size: clamp(0.95rem, 1.15vw, 1.12rem);
        line-height: 1.45;
    }

    .hero-note {
        display: none;
    }

    .gino-stage {
        padding: 0.7rem;
        gap: 0.7rem;
    }

    .gino-portrait-card {
        min-height: clamp(220px, 20vw, 300px);
    }

    .transcript-log {
        min-height: 120px;
        max-height: 160px;
        padding: 0.75rem;
    }

    .control-board {
        padding: 0.75rem;
    }

    .control-board-header {
        margin-bottom: 0.6rem;
    }

    .control-row {
        padding: 0.65rem 0;
    }

    .control-help {
        font-size: 0.78rem;
    }

    .control-summary {
        margin-top: 0.65rem;
    }
}

@media (max-height: 700px) and (min-width: 901px) {
    .hero-subtitle {
        display: none;
    }

    .hero-title {
        font-size: clamp(1.8rem, 3vw, 3.35rem);
    }

    .gino-portrait-card {
        min-height: 210px;
    }

    .transcript-log {
        min-height: 95px;
        max-height: 120px;
    }

    .control-help {
        display: none;
    }
}

@media (max-width: 768px) {
    .hero-actions {
        align-items: stretch;
        flex-direction: column;
    }

        .hero-actions .btn {
            width: 100%;
        }

    .gino-portrait-card {
        min-height: 260px;
    }

    .gino-portrait-placeholder {
        padding-bottom: 5.8rem;
    }

    .feature-grid {
        grid-template-columns: 1fr;
    }

    .control-summary {
        grid-template-columns: 1fr;
    }

    .footer {
        white-space: normal;
        line-height: 1.5;
        padding: 1rem 0;
    }

    .footer-inner {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.5rem;
    }
}
