:root {
    --bg: #080b10;
    --panel: #101722;
    --panel-2: #151f2e;
    --text: #f8fafc;
    --muted: #9aa7b8;
    --line: rgba(255, 255, 255, 0.12);
    --blue: #6aa9ff;
    --cyan: #68f0d8;
    --green: #25d366;
    --gold: #f1c46a;
    --rose: #ff7b91;
    --lime: #c7ff4b;
    --radius: 18px;
    --shadow: 0 26px 80px rgba(0, 0, 0, 0.38);
}

/* Refined premium dark atmosphere */
:root {
    --bg: #0b1020;
    --panel: rgba(30, 41, 59, 0.78);
    --panel-2: rgba(36, 48, 68, 0.82);
    --text: #f3f4f6;
    --muted: #a7b0bf;
    --line: rgba(209, 213, 219, 0.13);
    --blue: #7fb4ff;
    --cyan: #7dd8ee;
    --green: #25d366;
    --gold: #d7b46a;
    --rose: #d98aa6;
    --lime: #b8d978;
    --shadow: 0 20px 56px rgba(3, 7, 18, 0.28);
}

body {
    background:
        radial-gradient(circle at 8% 0%, rgba(125, 216, 238, 0.08), transparent 28%),
        radial-gradient(circle at 90% 8%, rgba(127, 180, 255, 0.07), transparent 30%),
        linear-gradient(180deg, #0b1020 0%, #111827 46%, #0b1020 100%);
}

.site-header {
    border-bottom-color: rgba(209, 213, 219, 0.11);
    background: rgba(11, 16, 32, 0.76);
    backdrop-filter: blur(14px);
}

.logo span,
.btn.primary {
    background: linear-gradient(135deg, #8fc5ff, #7dd8ee);
    color: #08111f;
}

.nav a:hover,
.back-link:hover {
    text-shadow: none;
}

.studio-hero {
    background:
        radial-gradient(circle at 18% 20%, rgba(127, 180, 255, 0.16), transparent 32%),
        radial-gradient(circle at 76% 26%, rgba(125, 216, 238, 0.11), transparent 30%),
        linear-gradient(135deg, #0b1020 0%, #111827 55%, #161b26 100%);
}

.studio-hero::before {
    background:
        linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px);
    opacity: .24;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.62), transparent 82%);
}

.hero-bg-photo {
    background:
        linear-gradient(90deg, rgba(11,16,32,0.96), rgba(11,16,32,0.28)),
        url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?q=80&w=1600&auto=format&fit=crop") center/cover;
    opacity: .18;
}

.hero-orbit {
    border-color: rgba(209, 213, 219, 0.09);
    opacity: .65;
}

.hero-orbit::before,
.hero-orbit::after {
    background: #7dd8ee;
    opacity: .7;
}

.hero-badge,
.eyebrow,
.demo-body strong,
.service-card span,
.process-card b {
    color: #8bdcf0;
}

.hero-badge {
    border-color: rgba(125, 216, 238, 0.2);
    background: rgba(125, 216, 238, 0.08);
    box-shadow: none;
}

.hero-text,
.section-note,
.service-card p,
.demo-body p,
.contact-box p,
.demo-section p,
.pricing-card p,
.trust-card p,
.category-card p,
.feature-card p,
.team-card p,
.faq-list p,
.footer {
    color: #aeb7c6;
}

.hero-proof span,
.mini-stats span,
.lang-switch,
.site-window-grid span,
.hero-mini-cards a,
.trust-badges span {
    border-color: rgba(209, 213, 219, 0.12);
    background: rgba(30, 41, 59, 0.58);
    color: #d1d5db;
}

.btn {
    box-shadow: none;
}

.btn:hover {
    box-shadow: 0 14px 34px rgba(3, 7, 18, 0.24);
}

.btn.primary {
    border-color: rgba(255,255,255,0.12);
    box-shadow: 0 16px 42px rgba(125, 216, 238, 0.14);
}

.btn.secondary,
.btn.ghost {
    border-color: rgba(209, 213, 219, 0.14);
    background: rgba(30, 41, 59, 0.56);
}

.browser-frame,
.service-card,
.demo-card,
.contact-box,
.pricing-card,
.trust-card,
.category-card,
.process-card,
.feature-card,
.team-card,
.stat-card,
.faq-list details,
.reservation-form,
.menu-item,
.map-card {
    border-color: rgba(209, 213, 219, 0.12);
    background: linear-gradient(180deg, rgba(36, 48, 68, 0.86), rgba(30, 41, 59, 0.78));
    box-shadow: 0 18px 48px rgba(3, 7, 18, 0.24);
}

.browser-frame {
    border-radius: 28px;
    backdrop-filter: blur(10px);
}

.hero-preview {
    background:
        radial-gradient(circle at 18% 18%, rgba(125,216,238,.10), transparent 30%),
        linear-gradient(145deg, rgba(36,48,68,.78), rgba(22,27,38,.86));
}

.site-window {
    background: rgba(17, 24, 39, 0.76);
    border-color: rgba(209, 213, 219, 0.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 22px 54px rgba(3,7,18,.22);
    backdrop-filter: blur(10px);
}

.site-window-hero {
    background:
        linear-gradient(135deg, rgba(125,216,238,.13), rgba(127,180,255,.10)),
        linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
    border-color: rgba(209, 213, 219, 0.12);
}

.site-window-hero a,
.floating-stat {
    background: #f3f4f6;
    color: #111827;
    box-shadow: 0 16px 36px rgba(3, 7, 18, 0.22);
}

.site-window-bars i {
    background: linear-gradient(90deg, rgba(125,216,238,.42), rgba(209,213,219,.14));
}

.trust-intro,
.portfolio-section,
.faq-section {
    background:
        radial-gradient(circle at 12% 0%, rgba(125,216,238,0.055), transparent 28%),
        #111827;
}

.trust-intro-inner {
    background: rgba(30, 41, 59, 0.44);
    border-color: rgba(209, 213, 219, 0.12);
}

.demo-card:hover {
    transform: translateY(-6px);
    border-color: rgba(125,216,238,.24);
}

.demo-visual::after {
    background: linear-gradient(180deg, transparent 22%, rgba(11,16,32,.84));
}

.contact-section {
    background:
        radial-gradient(circle at 82% 0%, rgba(125,216,238,.08), transparent 30%),
        linear-gradient(135deg,#111827,#0b1020);
}

.footer {
    border-top-color: rgba(209, 213, 219, 0.1);
    background: #0b1020;
}

.faq-list details:hover {
    border-color: rgba(125,216,238,.2);
    background: rgba(36,48,68,.9);
}

.faq-list details[open] {
    border-color: rgba(125,216,238,.24);
    background: rgba(36,48,68,.92);
}

.faq-list summary::after {
    background: rgba(125,216,238,.10);
    color: #8bdcf0;
}

.demo-page:not(.demo-clinic) {
    background: #111827;
}

.demo-page.demo-clinic {
    background: #f4f8fb;
}

.demo-page .site-header {
    background: rgba(11, 16, 32, 0.76);
}

.demo-hero::before {
    background: linear-gradient(90deg,rgba(11,16,32,.78),rgba(11,16,32,.24)), var(--hero-image);
    background-size: cover;
    background-position: center;
}

.demo-hero::after {
    background: linear-gradient(180deg, transparent 56%, rgba(11,16,32,.78));
}

.demo-coffee .demo-hero::before,
.demo-beauty .demo-hero::before {
    background: linear-gradient(90deg,rgba(11,16,32,.80),rgba(11,16,32,.25)), var(--hero-image);
    background-size: cover;
    background-position: center;
}

.today-special,
.reservation-options button {
    border-color: rgba(209,213,219,.13);
    background: rgba(36,48,68,.72);
    box-shadow: 0 16px 42px rgba(3,7,18,.22);
}

.reservation-options button:hover,
.demo-coffee .category-card:hover {
    border-color: rgba(125,216,238,.24);
    background: rgba(42,53,72,.86);
    box-shadow: 0 20px 48px rgba(3,7,18,.24);
}

/* Final end-of-file lock: exact FWS reference hero glow */
.studio-page .hero-logo {
    width: clamp(214px, 22vw, 304px) !important;
    height: clamp(214px, 22vw, 304px) !important;
    padding: 0 !important;
    margin: 0 auto 72px !important;
    border-radius: clamp(52px, 5.8vw, 74px) !important;
    background: transparent !important;
    box-shadow:
        -108px -6px 180px rgba(112, 255, 0, .22),
        -78px 54px 172px rgba(255, 142, 0, .18),
        -38px 86px 178px rgba(255, 34, 54, .20),
        0 -94px 178px rgba(255, 32, 132, .18),
        88px -10px 190px rgba(100, 44, 255, .20),
        130px 18px 210px rgba(0, 114, 255, .28),
        32px 112px 180px rgba(255, 0, 140, .16) !important;
    animation: fwsReferenceGlowFinal 5.8s ease-in-out infinite !important;
}

@keyframes fwsReferenceGlowFinal {
    0%, 100% {
        box-shadow:
            -96px -6px 166px rgba(112, 255, 0, .18),
            -70px 48px 158px rgba(255, 142, 0, .15),
            -34px 78px 164px rgba(255, 34, 54, .17),
            0 -84px 164px rgba(255, 32, 132, .15),
            80px -8px 176px rgba(100, 44, 255, .16),
            118px 16px 194px rgba(0, 114, 255, .23),
            28px 100px 164px rgba(255, 0, 140, .13);
    }

    50% {
        box-shadow:
            -118px -6px 194px rgba(112, 255, 0, .24),
            -86px 58px 186px rgba(255, 142, 0, .20),
            -42px 94px 192px rgba(255, 34, 54, .23),
            0 -104px 194px rgba(255, 32, 132, .21),
            96px -10px 204px rgba(100, 44, 255, .23),
            140px 20px 224px rgba(0, 114, 255, .31),
            36px 122px 194px rgba(255, 0, 140, .18);
    }
}

@media (max-width: 760px) {
    .studio-page .hero-logo {
        width: 178px !important;
        height: 178px !important;
        margin-bottom: 48px !important;
        border-radius: 44px !important;
    }
}

/* Final lock: exact FWS reference hero glow */
.studio-page .hero-logo {
    width: clamp(214px, 22vw, 304px) !important;
    height: clamp(214px, 22vw, 304px) !important;
    padding: 0 !important;
    margin: 0 auto 72px !important;
    border-radius: clamp(52px, 5.8vw, 74px) !important;
    background: transparent !important;
    box-shadow:
        -108px -6px 180px rgba(112, 255, 0, .22),
        -78px 54px 172px rgba(255, 142, 0, .18),
        -38px 86px 178px rgba(255, 34, 54, .20),
        0 -94px 178px rgba(255, 32, 132, .18),
        88px -10px 190px rgba(100, 44, 255, .20),
        130px 18px 210px rgba(0, 114, 255, .28),
        32px 112px 180px rgba(255, 0, 140, .16) !important;
    animation: fwsReferenceGlow 5.8s ease-in-out infinite !important;
}

@keyframes fwsReferenceGlow {
    0%, 100% {
        box-shadow:
            -96px -6px 166px rgba(112, 255, 0, .18),
            -70px 48px 158px rgba(255, 142, 0, .15),
            -34px 78px 164px rgba(255, 34, 54, .17),
            0 -84px 164px rgba(255, 32, 132, .15),
            80px -8px 176px rgba(100, 44, 255, .16),
            118px 16px 194px rgba(0, 114, 255, .23),
            28px 100px 164px rgba(255, 0, 140, .13);
    }

    50% {
        box-shadow:
            -118px -6px 194px rgba(112, 255, 0, .24),
            -86px 58px 186px rgba(255, 142, 0, .20),
            -42px 94px 192px rgba(255, 34, 54, .23),
            0 -104px 194px rgba(255, 32, 132, .21),
            96px -10px 204px rgba(100, 44, 255, .23),
            140px 20px 224px rgba(0, 114, 255, .31),
            36px 122px 194px rgba(255, 0, 140, .18);
    }
}

@media (max-width: 760px) {
    .studio-page .hero-logo {
        width: 178px !important;
        height: 178px !important;
        margin-bottom: 48px !important;
        border-radius: 44px !important;
    }
}

/* Reference-matched FWS Hero */
.studio-page .studio-hero {
    min-height: 100vh;
    padding: 128px 0 82px;
    display: grid;
    align-items: center;
    background:
        radial-gradient(circle at 50% 34%, rgba(0, 102, 255, .32), transparent 22%),
        radial-gradient(circle at 42% 32%, rgba(139, 0, 255, .24), transparent 20%),
        radial-gradient(circle at 36% 34%, rgba(255, 48, 124, .22), transparent 18%),
        radial-gradient(circle at 31% 34%, rgba(255, 154, 0, .18), transparent 18%),
        radial-gradient(circle at 27% 32%, rgba(104, 255, 0, .22), transparent 20%),
        radial-gradient(circle at 50% 56%, rgba(255, 0, 120, .10), transparent 22%),
        #000;
}

.studio-page .studio-hero::before {
    opacity: .08;
    background:
        radial-gradient(circle at 50% 30%, rgba(255,255,255,.10), transparent 24%),
        linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
    background-size: auto, 72px 72px, 72px 72px;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.52), transparent 88%);
}

.studio-page .hero-bg-photo,
.studio-page .hero-orbit,
.studio-page .hero-showcase {
    display: none !important;
}

.studio-page .hero-grid {
    display: block;
    max-width: 920px;
    text-align: center;
}

.studio-page .hero-copy {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 820px;
    margin: 0 auto;
}

.studio-page .hero-logo {
    width: clamp(214px, 22vw, 304px);
    height: clamp(214px, 22vw, 304px);
    margin: 0 auto 72px;
    border-radius: clamp(52px, 5.8vw, 74px);
    box-shadow:
        -108px -6px 180px rgba(112, 255, 0, .22),
        -78px 54px 172px rgba(255, 142, 0, .18),
        -38px 86px 178px rgba(255, 34, 54, .20),
        0 -94px 178px rgba(255, 32, 132, .18),
        88px -10px 190px rgba(100, 44, 255, .20),
        130px 18px 210px rgba(0, 114, 255, .28),
        32px 112px 180px rgba(255, 0, 140, .16);
    animation: heroGlow 5.8s ease-in-out infinite;
}

.studio-page .hero-kicker {
    order: 2;
    margin: 0 0 28px;
    padding: 10px 24px;
    color: rgba(243,244,246,.88);
    border-color: rgba(255,255,255,.22);
    background: rgba(0,0,0,.42);
    box-shadow:
        0 0 22px rgba(255, 170, 0, .12),
        0 0 26px rgba(0, 120, 255, .12);
    backdrop-filter: blur(14px);
}

.studio-page .hero-kicker span {
    display: none;
}

.studio-page .hero-copy h1 {
    order: 3;
    max-width: 790px;
    margin: 0 auto;
    font-size: clamp(2.9rem, 5vw, 5.15rem);
    line-height: 1.08;
    letter-spacing: 0;
    text-align: center;
    text-wrap: balance;
    color: #f4f4f5;
    text-shadow: 0 16px 42px rgba(255,255,255,.08);
}

.studio-page .hero-copy h1 span {
    color: inherit;
    background: none;
    -webkit-text-fill-color: currentColor;
}

.studio-page .hero-text {
    order: 4;
    max-width: 590px;
    margin: 26px auto 0;
    color: rgba(243,244,246,.56);
    font-size: clamp(1rem, 1.45vw, 1.22rem);
    line-height: 1.55;
    text-align: center;
}

.studio-page .button-row {
    order: 5;
    justify-content: center;
    margin-top: 34px;
}

.studio-page .button-row .btn {
    min-width: 168px;
    border-radius: 999px;
}

.studio-page .button-row .btn.primary {
    color: #f8fafc;
    background: #020202;
    border-color: rgba(255,255,255,.12);
    box-shadow:
        -16px 0 34px rgba(255, 196, 0, .16),
        0 0 38px rgba(255, 0, 120, .14),
        22px 0 38px rgba(0, 90, 255, .18),
        inset 0 1px 0 rgba(255,255,255,.12);
}

.studio-page .button-row .btn.secondary {
    color: rgba(243,244,246,.66);
    background: transparent;
    border-color: transparent;
}

@keyframes heroGlow {
    0%, 100% {
        box-shadow:
            -96px -6px 166px rgba(112, 255, 0, .18),
            -70px 48px 158px rgba(255, 142, 0, .15),
            -34px 78px 164px rgba(255, 34, 54, .17),
            0 -84px 164px rgba(255, 32, 132, .15),
            80px -8px 176px rgba(100, 44, 255, .16),
            118px 16px 194px rgba(0, 114, 255, .23),
            28px 100px 164px rgba(255, 0, 140, .13);
    }

    50% {
        box-shadow:
            -118px -6px 194px rgba(112, 255, 0, .24),
            -86px 58px 186px rgba(255, 142, 0, .20),
            -42px 94px 192px rgba(255, 34, 54, .23),
            0 -104px 194px rgba(255, 32, 132, .21),
            96px -10px 204px rgba(100, 44, 255, .23),
            140px 20px 224px rgba(0, 114, 255, .31),
            36px 122px 194px rgba(255, 0, 140, .18);
    }
}

@media (max-width: 760px) {
    .studio-page .studio-hero {
        min-height: auto;
        padding: 116px 0 62px;
        background:
            radial-gradient(circle at 50% 27%, rgba(0, 102, 255, .30), transparent 30%),
            radial-gradient(circle at 38% 27%, rgba(255, 46, 120, .23), transparent 27%),
            radial-gradient(circle at 25% 28%, rgba(106, 255, 0, .18), transparent 30%),
            #000;
    }

    .studio-page .hero-logo {
        width: 178px;
        height: 178px;
        margin-bottom: 48px;
        border-radius: 44px;
    }

    .studio-page .hero-kicker {
        margin-bottom: 22px;
        padding: 9px 18px;
    }

    .studio-page .hero-copy h1 {
        font-size: clamp(2.2rem, 11vw, 3.15rem);
        line-height: 1.12;
    }

    .studio-page .hero-text {
        max-width: 340px;
        font-size: 1rem;
    }

    .studio-page .button-row {
        width: 100%;
    }

    .studio-page .button-row .btn {
        width: min(100%, 280px);
    }
}

.logo strong {
    text-transform: none !important;
    letter-spacing: 0;
}

/* HERO LOGO */
.hero-logo {
    display: block;
    width: clamp(126px, 13vw, 178px);
    height: clamp(126px, 13vw, 178px);
    padding: 0;
    margin: 0 0 26px;
    border-radius: 38px;
    object-fit: contain;
    box-shadow:
        -44px 8px 70px rgba(119,255,0,0.17),
        -24px 46px 78px rgba(255,31,31,0.20),
        0 -40px 82px rgba(255,64,160,0.18),
        48px 4px 92px rgba(0,110,255,0.22),
        0 34px 90px rgba(255,0,132,0.16);
    animation: heroGlow 4.8s ease-in-out infinite;
    transition: transform .4s ease, box-shadow .4s ease;
}

.hero-logo:hover {
    transform: scale(1.03);
}

@keyframes heroGlow {
    0%, 100% {
        box-shadow:
            -40px 8px 64px rgba(119,255,0,0.15),
            -22px 42px 70px rgba(255,31,31,0.17),
            0 -36px 76px rgba(255,64,160,0.15),
            44px 4px 84px rgba(0,110,255,0.19),
            0 30px 82px rgba(255,0,132,0.13);
    }

    50% {
        box-shadow:
            -54px 8px 88px rgba(119,255,0,0.21),
            -28px 54px 96px rgba(255,31,31,0.24),
            0 -48px 100px rgba(255,64,160,0.22),
            58px 4px 116px rgba(0,110,255,0.27),
            0 42px 108px rgba(255,0,132,0.19);
    }
}

@media (max-width: 760px) {
    .hero-logo {
        width: 122px;
        height: 122px;
        margin-bottom: 20px;
        border-radius: 30px;
    }
}

/* Hero developer artwork: keep the floating preview rounded and artifact-free. */
.macbook-window,
.macbook-window *,
.macbook-window::before,
.macbook-window::after {
    backface-visibility: hidden;
}

.macbook-window {
    border-radius: 28px !important;
    overflow: hidden !important;
    isolation: isolate !important;
    transform-style: preserve-3d !important;
}

.macbook-image,
.macbook-image img,
.macbook-image::after,
.macbook-overlay {
    border-radius: inherit;
}

.macbook-image img {
    object-fit: contain;
    object-position: center center;
    transform: translateZ(0);
}

.macbook-window:hover .macbook-image img {
    transform: translateZ(0) scale(1.025);
}

/* Keep the Apple preview shadow rounded, not rectangular */
.macbook-window {
    box-shadow: inset 0 1px 0 rgba(255,255,255,.16) !important;
}

.macbook-window:hover {
    box-shadow: inset 0 1px 0 rgba(255,255,255,.18) !important;
}

.macbook-window::after {
    content: "";
    position: absolute;
    inset: -34px;
    z-index: -1;
    border-radius: 42px;
    pointer-events: none;
    background:
        radial-gradient(ellipse at 50% 58%, rgba(3,7,18,.46), transparent 68%),
        radial-gradient(ellipse at 62% 44%, rgba(125,216,238,.10), transparent 58%);
    filter: blur(18px);
    opacity: .86;
    transition: opacity .6s ease, transform .6s ease;
}

.macbook-window:hover::after {
    opacity: 1;
    transform: translateY(7px) scale(1.02);
}

/* Hard clamp for Apple Hero window: no external square shadow artifacts */
.hero-showcase {
    filter: none !important;
}

.macbook-window {
    overflow: hidden !important;
    isolation: isolate !important;
    transform-style: preserve-3d !important;
    backface-visibility: hidden !important;
    border-radius: 28px !important;
    box-shadow: none !important;
    filter: none !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.045)) !important;
}

.macbook-window:hover {
    box-shadow: none !important;
    filter: none !important;
}

.macbook-window::before {
    border-radius: inherit !important;
    inset: 0 !important;
    overflow: hidden !important;
}

.macbook-window::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 1 !important;
    border-radius: inherit !important;
    pointer-events: none !important;
    filter: none !important;
    opacity: 1 !important;
    background:
        radial-gradient(circle at 74% 22%, rgba(125,216,238,.12), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,.06), transparent 38%, rgba(11,16,32,.12)) !important;
    transform: none !important;
}

.macbook-window:hover::after {
    transform: none !important;
}

.macbook-top,
.macbook-image,
.macbook-image img,
.macbook-image::after,
.macbook-overlay {
    border-radius: inherit;
    backface-visibility: hidden;
}

.macbook-top {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.macbook-image {
    isolation: isolate;
}

.macbook-image img {
    display: block;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.macbook-image::after {
    inset: 0 !important;
    filter: none !important;
    overflow: hidden !important;
}

.macbook-overlay {
    box-shadow: none !important;
    overflow: hidden;
}

/* Reference-inspired premium hero polish */
.site-header {
    min-height: 88px;
    padding-inline: max(32px, calc((100vw - 1240px) / 2));
    background: rgba(5, 8, 16, .62);
    border-bottom: 1px solid rgba(255,255,255,.055);
}

.logo {
    gap: 14px;
}

.logo img {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    object-fit: cover;
    box-shadow:
        0 0 18px rgba(255, 45, 178, .12),
        0 0 22px rgba(0, 119, 255, .16);
}

.logo strong {
    font-size: .9rem;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.nav {
    align-items: center;
    gap: clamp(18px, 3vw, 44px);
}

.nav a:not(.nav-cta):not(.lang-switch) {
    position: relative;
}

.nav a:not(.nav-cta):not(.lang-switch):hover::after {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.nav a:not(.nav-cta):not(.lang-switch)::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -14px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #2f7bff;
    opacity: 0;
    transform: translateX(-50%) translateY(4px);
    transition: opacity .25s ease, transform .25s ease;
}

.nav-cta {
    min-height: 46px;
    padding: 0 22px;
    border: 1px solid rgba(47,123,255,.58);
    border-radius: 999px;
    color: #fff !important;
    background: rgba(8,14,28,.46);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
}

.nav-cta::after {
    content: "→";
    position: static;
    width: auto;
    height: auto;
    margin-left: 10px;
    background: none;
    opacity: 1;
    transform: none;
}

.studio-hero {
    min-height: 980px;
    padding: 164px 0 110px;
    background:
        radial-gradient(circle at 79% 21%, rgba(47,123,255,.24), transparent 34%),
        radial-gradient(circle at 31% 48%, rgba(47,123,255,.10), transparent 28%),
        radial-gradient(circle at 72% 78%, rgba(125,216,238,.08), transparent 30%),
        linear-gradient(135deg, #02050d 0%, #070b16 44%, #0b1020 100%);
}

.studio-hero::before {
    opacity: .11;
    background-image:
        linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
    background-size: 88px 88px;
}

.hero-bg-photo {
    opacity: .08;
}

.hero-grid {
    width: min(1240px, calc(100% - 64px));
    grid-template-columns: minmax(0, .9fr) minmax(500px, 1.12fr);
    gap: clamp(68px, 8vw, 124px);
}

.hero-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    margin-bottom: 30px;
    padding: 0 18px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 999px;
    background: rgba(255,255,255,.035);
    color: rgba(243,244,246,.72);
    font-size: .82rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    backdrop-filter: blur(12px);
}

.hero-kicker span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #2f7bff;
    box-shadow: 0 0 24px rgba(47,123,255,.66);
}

.hero-copy h1,
html[lang="ka"] .studio-hero h1 {
    max-width: 720px;
    color: #f7f7f8;
    font-size: clamp(3.4rem, 5.9vw, 6.3rem);
    line-height: 1.04;
    letter-spacing: -.058em;
}

.hero-copy h1 span {
    display: inline-block;
    color: #2f7bff;
    text-shadow: 0 0 40px rgba(47,123,255,.22);
}

html[lang="ka"] .hero-copy h1 span {
    display: inline;
}

.hero-text {
    max-width: 620px;
    margin-top: 28px;
    color: rgba(243,244,246,.68);
    font-size: 1.13rem;
    line-height: 1.85;
}

.button-row {
    margin-top: 38px;
    gap: 16px;
}

.btn.primary {
    background: linear-gradient(135deg, #1167ff, #2f7bff);
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.20), 0 16px 42px rgba(47,123,255,.24);
}

.btn.secondary {
    border-color: rgba(255,255,255,.20);
    background: rgba(255,255,255,.035);
}

.hero-feature-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    max-width: 650px;
    margin-top: 46px;
}

.hero-feature-grid article {
    display: grid;
    grid-template-columns: 50px 1fr;
    gap: 14px;
    align-items: start;
}

.hero-feature-grid i {
    display: grid;
    place-items: center;
    width: 50px;
    height: 50px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 13px;
    background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.045));
    color: #fff;
    font-style: normal;
    font-size: 1.35rem;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.hero-feature-grid strong {
    display: block;
    margin-bottom: 5px;
    color: #fff;
    font-size: .98rem;
}

.hero-feature-grid span {
    display: block;
    color: rgba(209,213,219,.72);
    font-size: .9rem;
    line-height: 1.55;
}

.macbook-window {
    border-radius: 26px !important;
    border-color: rgba(196,211,232,.34);
    background: rgba(8,12,22,.72) !important;
}

.macbook-top {
    height: 48px;
    background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.035));
}

.macbook-image,
.macbook-image img {
    min-height: 540px;
    height: 540px;
}

.macbook-image img {
    filter: saturate(1.05) contrast(1.08) brightness(.62);
}

.macbook-window:hover .macbook-image img {
    filter: saturate(1.08) contrast(1.08) brightness(.70);
}

.macbook-image::after {
    background:
        radial-gradient(circle at 20% 70%, rgba(47,123,255,.36), transparent 34%),
        radial-gradient(circle at 72% 26%, rgba(47,123,255,.18), transparent 30%),
        linear-gradient(180deg, rgba(0,0,0,.08), rgba(2,5,13,.76)) !important;
}

.macbook-overlay {
    max-width: 520px;
    background: rgba(4,8,17,.48);
    border-color: rgba(255,255,255,.13);
}

.hero-mini-cards,
.floating-stat {
    display: none;
}

@media (max-width: 1100px) {
    .nav-cta {
        display: none;
    }

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

@media (max-width: 760px) {
    .site-header {
        padding-inline: 18px;
    }

    .hero-grid {
        width: min(100% - 28px, 1180px);
    }

    .hero-feature-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .hero-feature-grid article {
        grid-template-columns: 46px 1fr;
    }

    .hero-feature-grid i {
        width: 46px;
        height: 46px;
    }

    .macbook-image,
    .macbook-image img {
        min-height: 360px;
        height: 360px;
    }
}

.tour-product-grid {
    display: grid;
    gap: 22px;
}

.tour-product-card {
    display: grid;
    grid-template-columns: minmax(260px, .72fr) minmax(0, 1fr);
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(36, 48, 68, 0.86), rgba(30, 41, 59, 0.78));
    box-shadow: var(--shadow);
}

.tour-product-card img {
    width: 100%;
    height: 100%;
    min-height: 360px;
    object-fit: cover;
}

.tour-product-card > div {
    padding: 30px;
}

.tour-product-card span,
.guide-card span {
    display: block;
    margin-bottom: 12px;
    color: var(--accent);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.tour-product-card h3 {
    font-size: clamp(1.55rem, 2.8vw, 2.4rem);
}

.tour-product-card p {
    margin-top: 14px;
    line-height: 1.72;
}

.tour-product-card ul,
.guide-card ul {
    display: grid;
    gap: 9px;
    margin: 18px 0 24px;
    padding: 0;
    list-style: none;
    color: var(--muted);
}

.tour-product-card li,
.guide-card li {
    padding-left: 18px;
    position: relative;
}

.tour-product-card li::before,
.guide-card li::before {
    content: "";
    position: absolute;
    left: 0;
    top: .72em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent);
}

.tour-calendar {
    display: grid;
    gap: 14px;
}

.tour-calendar article {
    display: grid;
    grid-template-columns: 150px 1fr auto;
    align-items: center;
    gap: 20px;
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: rgba(30, 41, 59, 0.72);
    box-shadow: 0 16px 42px rgba(3, 7, 18, 0.18);
}

.tour-calendar time {
    color: var(--accent);
    font-weight: 900;
}

.tour-calendar h3 {
    margin-bottom: 4px;
}

.tour-calendar a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    background: var(--accent);
    color: #10151e;
    font-weight: 900;
}

.guide-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
}

.guide-card {
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(36, 48, 68, 0.86), rgba(30, 41, 59, 0.78));
    box-shadow: var(--shadow);
}

.guide-card img {
    width: 100%;
    height: 360px;
    object-fit: cover;
    object-position: center;
}

.guide-card > div {
    padding: 28px;
}

.guide-card p {
    margin-top: 14px;
    line-height: 1.72;
}

@media (max-width: 980px) {
    .tour-product-card,
    .tour-calendar article,
    .guide-grid {
        grid-template-columns: 1fr;
    }

    .tour-product-card img {
        min-height: 280px;
        height: 320px;
    }

    .tour-calendar article {
        align-items: start;
    }

    .tour-calendar a {
        width: 100%;
    }
}

/* Restaurant delivery marketplace demo */
.delivery-demo {
    --delivery-red: #e43d30;
    --delivery-text: #25211f;
    --delivery-muted: #7d7470;
    --delivery-line: #ece5df;
    --delivery-soft: #f6f1ec;
    --delivery-card: #ffffff;
    background: #fbf7f2;
    color: var(--delivery-text);
    font-family: "Noto Sans Georgian", Inter, Arial, sans-serif;
}

.delivery-container {
    width: min(1180px, calc(100% - 38px));
    margin: 0 auto;
}

.delivery-header {
    position: sticky;
    top: 0;
    z-index: 30;
    min-height: 78px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 0 max(19px, calc((100vw - 1180px) / 2));
    border-bottom: 1px solid var(--delivery-line);
    background: rgba(251,247,242,.92);
    backdrop-filter: blur(12px);
}

.delivery-logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--delivery-text);
    font-weight: 900;
    font-size: 1.15rem;
}

.delivery-logo span {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--delivery-red);
    color: #fff;
}

.delivery-header nav {
    display: flex;
    align-items: center;
    gap: 24px;
    color: var(--delivery-muted);
    font-weight: 800;
    font-size: .94rem;
}

.delivery-header nav a:hover {
    color: var(--delivery-red);
}

.delivery-back {
    padding: 10px 14px;
    border: 1px solid var(--delivery-line);
    border-radius: 999px;
    color: var(--delivery-text);
    background: #fff;
}

.delivery-hero {
    padding: 64px 0 44px;
}

.delivery-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: 26px;
    align-items: stretch;
}

.delivery-city {
    margin-bottom: 18px;
    color: var(--delivery-red);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.delivery-hero h1 {
    max-width: 820px;
    color: var(--delivery-text);
    font-size: clamp(2.7rem, 5.8vw, 5.9rem);
    line-height: .96;
    letter-spacing: -.055em;
}

.delivery-lead {
    max-width: 650px;
    margin-top: 22px;
    color: var(--delivery-muted);
    font-size: 1.08rem;
    line-height: 1.72;
}

.delivery-address,
.delivery-cart,
.delivery-search,
.dish-card,
.delivery-promos article,
.restaurant-strip article,
.benefit-grid article {
    border: 1px solid var(--delivery-line);
    background: var(--delivery-card);
    box-shadow: 0 16px 42px rgba(80, 54, 38, .08);
}

.delivery-address {
    max-width: 770px;
    margin-top: 34px;
    padding: 24px;
    border-radius: 24px;
}

.delivery-address span,
.delivery-search span,
.delivery-section-head p,
.delivery-promos span {
    display: block;
    margin-bottom: 8px;
    color: var(--delivery-red);
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.delivery-address strong {
    display: block;
    margin-bottom: 18px;
    font-size: 1.1rem;
}

.delivery-address form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
}

.delivery-address input,
.delivery-search input {
    min-height: 52px;
    width: 100%;
    border: 1px solid var(--delivery-line);
    border-radius: 999px;
    padding: 0 18px;
    background: #fbf7f2;
    color: var(--delivery-text);
    font: inherit;
}

.delivery-address button,
.dish-card button {
    min-height: 52px;
    border: 0;
    border-radius: 999px;
    padding: 0 20px;
    background: var(--delivery-red);
    color: #fff;
    font-weight: 900;
    cursor: pointer;
}

.delivery-cart {
    display: grid;
    align-content: start;
    gap: 14px;
    padding: 26px;
    border-radius: 28px;
}

.delivery-cart span {
    color: var(--delivery-muted);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .76rem;
}

.delivery-cart h2 {
    color: var(--delivery-text);
    font-size: 3.4rem;
    letter-spacing: -.06em;
}

.delivery-cart p {
    color: var(--delivery-muted);
}

.delivery-cart a {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    min-height: 50px;
    margin-top: 10px;
    border-radius: 999px;
    background: #25211f;
    color: #fff;
    font-weight: 900;
}

.delivery-section {
    padding: 38px 0;
}

.delivery-tabs,
.delivery-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.delivery-tabs a,
.delivery-categories button {
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid var(--delivery-line);
    border-radius: 999px;
    background: #fff;
    color: var(--delivery-muted);
    font-weight: 900;
}

.delivery-tabs .active,
.delivery-categories button:hover {
    border-color: var(--delivery-red);
    color: var(--delivery-red);
}

.delivery-search {
    display: grid;
    grid-template-columns: 1fr minmax(260px, 420px);
    gap: 18px;
    align-items: center;
    margin: 24px 0 18px;
    padding: 22px;
    border-radius: 24px;
}

.delivery-search strong {
    font-size: 1.35rem;
}

.delivery-section-head {
    max-width: 760px;
    margin-bottom: 24px;
}

.delivery-section-head h2 {
    color: var(--delivery-text);
    font-size: clamp(2rem, 3.8vw, 3.4rem);
    line-height: 1.06;
    letter-spacing: -.04em;
}

.dish-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.dish-card {
    overflow: hidden;
    border-radius: 26px;
}

.dish-card img {
    width: 100%;
    height: 220px;
    object-fit: cover;
}

.dish-card div {
    padding: 20px;
}

.dish-card small {
    color: var(--delivery-muted);
    font-weight: 800;
}

.dish-card h3 {
    margin: 10px 0 8px;
    color: var(--delivery-text);
}

.dish-card p {
    min-height: 52px;
    color: var(--delivery-muted);
}

.dish-card strong {
    display: block;
    margin: 18px 0 12px;
    color: var(--delivery-text);
    font-size: 1.35rem;
}

.dish-card button {
    width: 100%;
}

.delivery-promos {
    padding-top: 46px;
}

.promo-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}

.delivery-promos article {
    display: grid;
    grid-template-columns: 42% 1fr;
    overflow: hidden;
    border-radius: 30px;
}

.delivery-promos img {
    width: 100%;
    height: 100%;
    min-height: 260px;
    object-fit: cover;
}

.delivery-promos div {
    padding: 26px;
}

.delivery-promos h3 {
    color: var(--delivery-text);
    font-size: 1.6rem;
}

.delivery-promos p,
.restaurant-strip p,
.benefit-grid p,
.delivery-footer p {
    margin-top: 10px;
    color: var(--delivery-muted);
}

.delivery-promos a {
    display: inline-flex;
    margin-top: 20px;
    color: var(--delivery-red);
    font-weight: 900;
}

.restaurant-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.restaurant-strip article {
    overflow: hidden;
    border-radius: 24px;
}

.restaurant-strip img {
    width: 100%;
    height: 170px;
    object-fit: cover;
}

.restaurant-strip h3,
.restaurant-strip p {
    padding: 0 18px;
}

.restaurant-strip h3 {
    margin-top: 18px;
    color: var(--delivery-text);
}

.restaurant-strip p {
    padding-bottom: 20px;
}

.delivery-benefits {
    background: var(--delivery-soft);
    margin-top: 26px;
    padding: 62px 0;
}

.benefit-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.benefit-grid article {
    padding: 24px;
    border-radius: 24px;
}

.benefit-grid span {
    color: var(--delivery-red);
    font-weight: 900;
}

.benefit-grid h3 {
    margin-top: 26px;
    color: var(--delivery-text);
}

.delivery-footer {
    padding: 54px 0;
    background: #25211f;
    color: #fff;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.5fr .7fr .7fr;
    gap: 34px;
}

.delivery-footer h2 {
    font-size: 2.8rem;
}

.delivery-footer strong,
.delivery-footer a {
    display: block;
}

.delivery-footer strong {
    margin-bottom: 14px;
}

.delivery-footer a {
    margin-top: 9px;
    color: rgba(255,255,255,.72);
}

@media (max-width: 980px) {
    .delivery-header {
        position: relative;
        align-items: flex-start;
        flex-direction: column;
        padding: 18px;
    }

    .delivery-header nav,
    .delivery-tabs,
    .delivery-categories {
        gap: 8px;
    }

    .delivery-hero-grid,
    .delivery-search,
    .promo-grid,
    .delivery-promos article,
    .footer-grid {
        grid-template-columns: 1fr;
    }

    .dish-grid,
    .restaurant-strip,
    .benefit-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 640px) {
    .delivery-container {
        width: min(100% - 28px, 1180px);
    }

    .delivery-hero {
        padding-top: 38px;
    }

    .delivery-hero h1 {
        font-size: 2.45rem;
        line-height: 1.08;
    }

    .delivery-address form,
    .dish-grid,
    .restaurant-strip,
    .benefit-grid {
        grid-template-columns: 1fr;
    }

    .delivery-address,
    .delivery-cart,
    .delivery-search {
        padding: 18px;
        border-radius: 20px;
    }
}

/* Final Apple hero layer */
.studio-hero {
    min-height: 920px;
    padding: 158px 0 104px;
    background:
        radial-gradient(circle at 22% 16%, rgba(127,180,255,.16), transparent 32%),
        radial-gradient(circle at 74% 22%, rgba(125,216,238,.10), transparent 30%),
        linear-gradient(135deg, #0b1020 0%, #111827 50%, #151b28 100%);
}

.hero-grid {
    grid-template-columns: minmax(0, .86fr) minmax(430px, 1.05fr);
    gap: clamp(54px, 7vw, 104px);
}

.hero-copy h1 {
    max-width: 760px;
    letter-spacing: -.055em;
}

html[lang="ka"] .studio-hero h1 {
    max-width: 720px;
    font-size: clamp(2.95rem, 5vw, 5rem);
    line-height: 1.08;
}

.hero-text {
    max-width: 610px;
    margin-top: 26px;
    color: rgba(209,213,219,.84);
    font-size: 1.18rem;
    line-height: 1.78;
}

.macbook-window {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid rgba(255,255,255,.16);
    background: linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.045));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
    backdrop-filter: blur(18px);
    transition: transform .6s cubic-bezier(.2,.8,.2,1), box-shadow .6s ease, border-color .6s ease;
    animation: heroFloat 7s ease-in-out infinite;
}

.macbook-window::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(115deg, rgba(255,255,255,.18), transparent 28%, transparent 70%, rgba(255,255,255,.06));
    mix-blend-mode: screen;
}

.macbook-window::after {
    content: "";
    position: absolute;
    inset: -34px;
    z-index: -1;
    border-radius: 42px;
    pointer-events: none;
    background:
        radial-gradient(ellipse at 50% 58%, rgba(3,7,18,.46), transparent 68%),
        radial-gradient(ellipse at 62% 44%, rgba(125,216,238,.10), transparent 58%);
    filter: blur(18px);
    opacity: .86;
    transition: opacity .6s ease, transform .6s ease;
}

.macbook-window:hover {
    transform: translateY(-10px) rotateX(1.5deg) rotateY(-2deg);
    border-color: rgba(125,216,238,.28);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}

.macbook-window:hover::after {
    opacity: 1;
    transform: translateY(7px) scale(1.02);
}

.macbook-top {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 8px;
    height: 48px;
    padding: 0 18px;
    border-bottom: 1px solid rgba(255,255,255,.10);
    background: rgba(17,24,39,.72);
}

.macbook-top span {
    width: 11px;
    height: 11px;
    border-radius: 50%;
}

.macbook-top span:nth-child(1) { background: #ff5f57; }
.macbook-top span:nth-child(2) { background: #ffbd2e; }
.macbook-top span:nth-child(3) { background: #28c840; }

.macbook-image {
    position: relative;
    min-height: 520px;
    overflow: hidden;
}

.macbook-image img {
    width: 100%;
    height: 520px;
    object-fit: cover;
    transform: scale(1.02);
    filter: saturate(.92) contrast(1.03) brightness(.82);
    transition: transform .8s ease, filter .8s ease;
}

.macbook-window:hover .macbook-image img {
    transform: scale(1.06);
    filter: saturate(1) contrast(1.04) brightness(.9);
}

.macbook-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 72% 28%, rgba(125,216,238,.16), transparent 26%), linear-gradient(180deg, transparent 38%, rgba(11,16,32,.86));
}

.macbook-overlay {
    position: absolute;
    left: 28px;
    right: 28px;
    bottom: 28px;
    z-index: 2;
    display: grid;
    gap: 8px;
    max-width: 520px;
    padding: 24px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 22px;
    background: rgba(11,16,32,.50);
    backdrop-filter: blur(18px);
    box-shadow: 0 20px 60px rgba(3,7,18,.28);
}

.macbook-overlay span {
    color: #8bdcf0;
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.macbook-overlay strong {
    color: #fff;
    font-size: clamp(1.55rem, 3vw, 2.25rem);
    line-height: 1.04;
    letter-spacing: -.035em;
}

.macbook-overlay small {
    color: rgba(209,213,219,.78);
    font-size: .98rem;
}

@media (max-width: 980px) {
    .studio-hero {
        min-height: auto;
        padding: 122px 0 72px;
    }

    .hero-grid {
        grid-template-columns: 1fr;
        gap: 42px;
    }

    .macbook-image,
    .macbook-image img {
        min-height: 420px;
        height: 420px;
    }
}

@media (max-width: 640px) {
    .studio-hero {
        padding: 112px 0 58px;
    }

    .hero-copy h1,
    html[lang="ka"] .studio-hero h1 {
        font-size: clamp(2.35rem, 11vw, 3.1rem);
        line-height: 1.12;
    }

    .hero-text {
        margin-top: 18px;
        font-size: 1rem;
        line-height: 1.68;
    }

    .macbook-window {
        border-radius: 22px;
    }

    .macbook-top {
        height: 42px;
    }

    .macbook-image,
    .macbook-image img {
        min-height: 320px;
        height: 320px;
    }

    .macbook-overlay {
        left: 16px;
        right: 16px;
        bottom: 16px;
        padding: 18px;
        border-radius: 18px;
    }

    .macbook-overlay strong {
        font-size: 1.35rem;
    }
}

/* Apple-inspired cinematic hero */
.studio-hero {
    min-height: 920px;
    padding: 158px 0 104px;
    background:
        radial-gradient(circle at 22% 16%, rgba(127,180,255,.16), transparent 32%),
        radial-gradient(circle at 74% 22%, rgba(125,216,238,.10), transparent 30%),
        linear-gradient(135deg, #0b1020 0%, #111827 50%, #151b28 100%);
}

.studio-hero::before {
    opacity: .16;
    background:
        linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
    background-size: 82px 82px;
}

.hero-bg-photo {
    opacity: .11;
    filter: saturate(.85) contrast(1.02);
}

.hero-orbit {
    opacity: .28;
    filter: blur(.2px);
}

.hero-grid {
    grid-template-columns: minmax(0, .86fr) minmax(430px, 1.05fr);
    gap: clamp(54px, 7vw, 104px);
}

.hero-copy {
    padding-top: 10px;
}

.hero-copy h1 {
    max-width: 760px;
    letter-spacing: -.055em;
    text-wrap: balance;
}

html[lang="ka"] .studio-hero h1 {
    max-width: 720px;
    font-size: clamp(2.95rem, 5vw, 5rem);
    line-height: 1.08;
}

.hero-text {
    max-width: 610px;
    margin-top: 26px;
    color: rgba(209,213,219,.84);
    font-size: 1.18rem;
    line-height: 1.78;
}

.button-row {
    gap: 12px;
    margin-top: 36px;
}

.btn {
    min-height: 56px;
    padding: 0 24px;
    border-radius: 999px;
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease, background .28s ease;
}

.btn.primary {
    background: linear-gradient(135deg, #d9ecff, #84dff2);
    color: #0b1020;
    box-shadow: 0 18px 46px rgba(125,216,238,.16);
}

.btn.secondary {
    background: rgba(255,255,255,.055);
    border-color: rgba(255,255,255,.16);
    backdrop-filter: blur(10px);
}

.btn:hover {
    transform: translateY(-3px);
}

.hero-proof {
    margin-top: 30px;
    opacity: .88;
}

.mini-stats {
    margin-top: 22px;
}

.hero-showcase {
    perspective: 1200px;
}

.macbook-window {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid rgba(255,255,255,.16);
    background: linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.045));
    box-shadow:
        0 36px 120px rgba(3,7,18,.44),
        inset 0 1px 0 rgba(255,255,255,.16);
    backdrop-filter: blur(18px);
    transform: translateY(0) rotateX(0) rotateY(0);
    transition: transform .6s cubic-bezier(.2,.8,.2,1), box-shadow .6s ease, border-color .6s ease;
    animation: heroFloat 7s ease-in-out infinite;
}

.macbook-window::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(115deg, rgba(255,255,255,.18), transparent 28%, transparent 70%, rgba(255,255,255,.06));
    mix-blend-mode: screen;
}

.macbook-window:hover {
    transform: translateY(-10px) rotateX(1.5deg) rotateY(-2deg);
    border-color: rgba(125,216,238,.28);
    box-shadow:
        0 42px 132px rgba(3,7,18,.52),
        0 0 54px rgba(125,216,238,.08),
        inset 0 1px 0 rgba(255,255,255,.18);
}

.macbook-top {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 8px;
    height: 48px;
    padding: 0 18px;
    border-bottom: 1px solid rgba(255,255,255,.10);
    background: rgba(17,24,39,.72);
}

.macbook-top span {
    width: 11px;
    height: 11px;
    border-radius: 50%;
}

.macbook-top span:nth-child(1) { background: #ff5f57; }
.macbook-top span:nth-child(2) { background: #ffbd2e; }
.macbook-top span:nth-child(3) { background: #28c840; }

.macbook-image {
    position: relative;
    min-height: 520px;
    overflow: hidden;
}

.macbook-image img {
    width: 100%;
    height: 520px;
    object-fit: cover;
    transform: scale(1.02);
    filter: saturate(.92) contrast(1.03) brightness(.82);
    transition: transform .8s ease, filter .8s ease;
}

.macbook-window:hover .macbook-image img {
    transform: scale(1.06);
    filter: saturate(1) contrast(1.04) brightness(.9);
}

.macbook-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 72% 28%, rgba(125,216,238,.16), transparent 26%),
        linear-gradient(180deg, transparent 38%, rgba(11,16,32,.86));
}

.macbook-overlay {
    position: absolute;
    left: 28px;
    right: 28px;
    bottom: 28px;
    z-index: 2;
    display: grid;
    gap: 8px;
    max-width: 520px;
    padding: 24px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 22px;
    background: rgba(11,16,32,.50);
    backdrop-filter: blur(18px);
    box-shadow: 0 20px 60px rgba(3,7,18,.28);
}

.macbook-overlay span {
    color: #8bdcf0;
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.macbook-overlay strong {
    color: #fff;
    font-size: clamp(1.55rem, 3vw, 2.25rem);
    line-height: 1.04;
    letter-spacing: -.035em;
}

.macbook-overlay small {
    color: rgba(209,213,219,.78);
    font-size: .98rem;
}

.hero-mini-cards {
    margin-top: 16px;
}

.hero-mini-cards a {
    min-height: 68px;
    background: rgba(255,255,255,.055);
    backdrop-filter: blur(12px);
}

.floating-stat {
    background: rgba(243,244,246,.92);
}

@keyframes heroFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

@media (max-width: 980px) {
    .studio-hero {
        min-height: auto;
        padding: 122px 0 72px;
    }

    .hero-grid {
        grid-template-columns: 1fr;
        gap: 42px;
    }

    .macbook-image,
    .macbook-image img {
        min-height: 420px;
        height: 420px;
    }
}

@media (max-width: 640px) {
    .studio-hero {
        padding: 112px 0 58px;
    }

    .hero-copy h1,
    html[lang="ka"] .studio-hero h1 {
        font-size: clamp(2.35rem, 11vw, 3.1rem);
        line-height: 1.12;
    }

    .hero-text {
        margin-top: 18px;
        font-size: 1rem;
        line-height: 1.68;
    }

    .macbook-window {
        border-radius: 22px;
    }

    .macbook-top {
        height: 42px;
    }

    .macbook-image,
    .macbook-image img {
        min-height: 320px;
        height: 320px;
    }

    .macbook-overlay {
        left: 16px;
        right: 16px;
        bottom: 16px;
        padding: 18px;
        border-radius: 18px;
    }

    .macbook-overlay strong {
        font-size: 1.35rem;
    }

    .macbook-overlay small {
        font-size: .88rem;
    }
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { min-width: 320px; background: var(--bg); color: var(--text); font-family: "Noto Sans Georgian", Inter, Arial, sans-serif; line-height: 1.6; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
img { display: block; max-width: 100%; }
.container { width: min(1180px, calc(100% - 36px)); margin: 0 auto; }
.site-header { position: fixed; inset: 0 0 auto; z-index: 50; display: flex; align-items: center; justify-content: space-between; gap: 24px; min-height: 78px; padding: 0 max(18px, calc((100vw - 1220px) / 2)); border-bottom: 1px solid var(--line); background: rgba(8, 11, 16, 0.76); backdrop-filter: blur(18px); }
.logo { display: inline-flex; align-items: center; gap: 12px; font-weight: 900; }
.logo strong { white-space: nowrap; }
.logo img { width: 48px; height: 48px; border-radius: 14px; object-fit: contain; box-shadow: 0 0 18px rgba(255,45,178,.12), 0 0 22px rgba(0,119,255,.16); }
.logo span { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; background: linear-gradient(135deg, var(--blue), var(--cyan)); color: #071017; }
.nav { display: flex; gap: 24px; color: var(--muted); font-weight: 700; }
.nav a {
    display: inline-flex;
    align-items: center;
    transform-origin: center;
    transition: color .2s ease, transform .2s ease, text-shadow .2s ease;
}
.nav a:hover, .back-link:hover {
    color: var(--text);
    transform: scale(1.06);
    text-shadow: 0 0 18px rgba(104, 240, 216, .22);
}
.lang-switch { display:inline-flex; align-items:center; justify-content:center; min-width:44px; min-height:34px; padding:0 12px; border:1px solid var(--line); border-radius:999px; color:var(--text); background:rgba(255,255,255,.07); }
.menu-btn { display: none; border: 1px solid var(--line); border-radius: 999px; background: transparent; color: var(--text); padding: 10px 14px; cursor: pointer; }
.back-link { color: var(--cyan); font-weight: 900; }
.studio-hero { position: relative; min-height: 900px; display: grid; align-items: center; overflow: hidden; padding: 150px 0 90px; background: radial-gradient(circle at 14% 24%, rgba(106,169,255,.24), transparent 30%), radial-gradient(circle at 72% 18%, rgba(104,240,216,.18), transparent 28%), radial-gradient(circle at 72% 76%, rgba(241,196,106,.12), transparent 34%), linear-gradient(135deg,#05070b 0%,#0c1320 48%,#06110f 100%); }
.studio-hero::before { content:""; position:absolute; inset:0; background: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 72px 72px; mask-image: linear-gradient(180deg, rgba(0,0,0,.8), transparent 86%); opacity:.38; }
.hero-bg-photo { position: absolute; inset: 0 0 0 auto; width: min(50vw, 760px); height: 100%; background: linear-gradient(90deg, rgba(5,7,11,1), rgba(5,7,11,.24)), url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?q=80&w=1600&auto=format&fit=crop") center/cover; opacity: .28; clip-path: polygon(22% 0,100% 0,100% 100%,0 100%); }
.hero-orbit { position: absolute; right: -140px; top: 120px; width: 520px; height: 520px; border: 1px solid rgba(255,255,255,.12); border-radius: 50%; animation: spin 28s linear infinite; }
.hero-orbit::before,.hero-orbit::after { content:""; position:absolute; border-radius:50%; background:var(--cyan); }
.hero-orbit::before { width:16px; height:16px; top:52px; left:82px; }
.hero-orbit::after { width:9px; height:9px; right:94px; bottom:72px; background:var(--blue); }
@keyframes spin { to { transform: rotate(360deg); } }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, .9fr); gap: 54px; align-items: center; }
.hero-copy { position:relative; z-index:2; min-width:0; }
.hero-showcase { min-width:0; }
.hero-brand-logo { width: min(420px, 100%); height: auto; margin: 0 0 18px; filter: drop-shadow(0 18px 44px rgba(47,123,255,.14)); }
.hero-badge { display:inline-flex; align-items:center; width:fit-content; margin-bottom:18px; padding:9px 13px; border:1px solid rgba(104,240,216,.26); border-radius:999px; background:rgba(104,240,216,.08); color:#b9fff3; font-size:.74rem; font-weight:900; letter-spacing:.12em; text-transform:uppercase; box-shadow:0 18px 60px rgba(104,240,216,.08); }
.eyebrow { margin-bottom: 14px; color: var(--cyan); font-size: .78rem; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
h1,h2 { line-height: 1.02; letter-spacing: -.04em; }
h1 { font-size: clamp(3.35rem, 7vw, 6.8rem); }
h2 { font-size: clamp(2.25rem, 4.6vw, 4.65rem); }
h3 { font-size: 1.25rem; line-height: 1.2; }
html[lang="ka"] h1,
html[lang="ka"] h2 {
    line-height: 1.14;
    letter-spacing: 0;
    overflow-wrap: anywhere;
}
html[lang="ka"] h1 { font-size: clamp(2.75rem, 5.6vw, 5.55rem); }
html[lang="ka"] h2 { font-size: clamp(2rem, 3.9vw, 3.85rem); }
html[lang="ka"] h3 {
    line-height: 1.3;
    letter-spacing: 0;
    overflow-wrap: anywhere;
}
html[lang="ka"] p,
html[lang="ka"] a,
html[lang="ka"] span,
html[lang="ka"] summary,
html[lang="ka"] strong {
    overflow-wrap: anywhere;
}
html[lang="ka"] .eyebrow {
    line-height: 1.5;
    letter-spacing: .08em;
}
html[lang="ka"] .nav {
    gap: 16px;
    font-size: .94rem;
}
html[lang="ka"] .studio-hero h1 {
    max-width: 700px;
    font-size: clamp(2.65rem, 4vw, 4.1rem);
    line-height: 1.12;
}
@media (min-width: 1180px) {
    html[lang="ka"] .studio-hero h1 {
        white-space: normal;
    }
}
html[lang="ka"] .btn {
    min-height: auto;
    padding: 14px 20px;
    line-height: 1.28;
    text-align: center;
    white-space: normal;
}
html[lang="ka"] .mini-stats span,
html[lang="ka"] .floating-stat,
html[lang="ka"] .demo-visual span,
html[lang="ka"] .hero-panel span,
html[lang="ka"] .hero-panel strong {
    line-height: 1.35;
}
.hero-text,.section-note,.service-card p,.demo-body p,.contact-box p,.demo-section p,.pricing-card p,.trust-card p,.category-card p,.feature-card p,.team-card p,.faq-list p,.footer { color: var(--muted); }
.hero-text { max-width: 680px; margin-top: 22px; font-size: 1.22rem; }
.hero-proof { display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.hero-proof span { display:inline-flex; align-items:center; min-height:36px; padding:0 13px; border:1px solid rgba(255,255,255,.14); border-radius:999px; background:rgba(255,255,255,.055); color:rgba(248,250,252,.86); font-weight:800; font-size:.86rem; }
.button-row,.contact-actions,.demo-actions,.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 54px; padding: 0 22px; border: 1px solid transparent; border-radius: 999px; font-weight: 900; cursor: pointer; transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 34px rgba(0,0,0,.24); }
.btn.primary { background: linear-gradient(135deg, var(--blue), var(--cyan)); color: #061018; }
.btn.secondary { border-color: var(--line); background: rgba(255,255,255,.06); color: var(--text); }
.btn.whatsapp { background: var(--green); color: #fff; }
.btn.whatsapp:hover { box-shadow: 0 16px 34px rgba(35, 183, 91, 0.24); }
.btn.ghost { border-color: rgba(255,255,255,.28); background: rgba(255,255,255,.08); color: var(--text); }
.mini-stats { display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.mini-stats span { padding: 10px 12px; border:1px solid var(--line); border-radius:999px; background:rgba(255,255,255,.05); color:var(--muted); }
.mini-stats b { color:var(--text); }
.hero-showcase { position: relative; }
.browser-frame { overflow: hidden; border: 1px solid rgba(255,255,255,.16); border-radius: 30px; background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.055)); box-shadow: 0 34px 100px rgba(0,0,0,.52); backdrop-filter: blur(18px); }
.browser-top { display:flex; gap:8px; padding:18px; border-bottom:1px solid var(--line); }
.browser-top span { width:11px; height:11px; border-radius:50%; background:rgba(255,255,255,.38); }
.browser-frame img { width:100%; height:440px; object-fit:cover; }
.hero-preview { position:relative; min-height:440px; overflow:hidden; padding:24px; background: radial-gradient(circle at 18% 18%, rgba(104,240,216,.18), transparent 28%), radial-gradient(circle at 88% 12%, rgba(106,169,255,.16), transparent 30%), linear-gradient(145deg, rgba(255,255,255,.1), rgba(255,255,255,.035)); }
.hero-preview img { height:440px; }
.site-window { height:392px; display:grid; grid-template-rows:auto 1fr auto auto; gap:16px; padding:20px; border:1px solid rgba(255,255,255,.16); border-radius:24px; background:rgba(5,7,11,.6); box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 28px 80px rgba(0,0,0,.34); backdrop-filter:blur(18px); }
.site-window-header { display:flex; align-items:center; justify-content:space-between; gap:16px; color:rgba(248,250,252,.72); font-size:.82rem; }
.site-window-header b { color:#fff; }
.site-window-hero { display:grid; grid-template-columns:1fr auto; align-items:end; gap:18px; min-height:150px; padding:22px; border-radius:20px; background:linear-gradient(135deg, rgba(104,240,216,.18), rgba(106,169,255,.12)), linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.04)); border:1px solid rgba(255,255,255,.14); }
.site-window-hero small { display:block; margin-bottom:8px; color:var(--cyan); font-size:.72rem; font-weight:900; letter-spacing:.13em; text-transform:uppercase; }
.site-window-hero strong { display:block; max-width:270px; color:#fff; font-size:1.55rem; line-height:1.05; }
.site-window-hero a { align-self:end; white-space:nowrap; padding:11px 14px; border-radius:999px; background:#fff; color:#071017; font-weight:900; font-size:.8rem; }
.site-window-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.site-window-grid span { min-height:54px; display:flex; align-items:center; padding:12px; border-radius:14px; background:rgba(255,255,255,.075); border:1px solid rgba(255,255,255,.1); color:rgba(248,250,252,.9); font-weight:800; }
.site-window-bars { display:grid; gap:8px; }
.site-window-bars i { display:block; height:9px; border-radius:999px; background:linear-gradient(90deg, rgba(104,240,216,.5), rgba(255,255,255,.12)); }
.site-window-bars i:nth-child(2) { width:74%; }
.site-window-bars i:nth-child(3) { width:46%; }
.preview-overlay { position:absolute; left:22px; right:22px; bottom:22px; display:grid; gap:5px; padding:20px; border:1px solid rgba(255,255,255,.18); border-radius:20px; background:rgba(5,7,11,.62); backdrop-filter: blur(16px); box-shadow:0 22px 60px rgba(0,0,0,.35); }
.preview-overlay span { color:var(--cyan); font-size:.75rem; font-weight:900; letter-spacing:.14em; text-transform:uppercase; }
.preview-overlay strong { font-size:1.45rem; line-height:1.1; }
.preview-overlay small { color:var(--muted); }
.showcase-caption { display:flex; justify-content:space-between; gap:18px; padding:20px; }
.showcase-caption small { color:var(--muted); }
.hero-mini-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:12px; }
.hero-mini-cards a { min-height:72px; display:flex; align-items:end; padding:14px; border:1px solid rgba(255,255,255,.14); border-radius:18px; background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.045)); color:#fff; font-weight:900; transition:transform .22s ease, border-color .22s ease, background .22s ease; }
.hero-mini-cards a:hover { transform:translateY(-4px) scale(1.02); border-color:rgba(104,240,216,.36); background:linear-gradient(135deg,rgba(104,240,216,.16),rgba(255,255,255,.06)); }
.floating-stat { width: fit-content; margin: 18px 0 0 auto; padding:14px 18px; border-radius:999px; background:#fff; color:#08111c; font-weight:900; box-shadow:var(--shadow); }
.section { padding: 96px 0; }
.section-head { max-width: 880px; margin-bottom: 42px; }
.section-note { max-width: 720px; margin-top: 18px; }
.trust-intro {
    padding: 54px 0;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0)),
        #070b12;
}
.trust-intro-inner {
    max-width: 820px;
    text-align: center;
    padding: 36px 32px;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 24px;
    background: rgba(255,255,255,0.035);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}
.trust-intro-inner .eyebrow {
    margin-bottom: 10px;
}
.trust-intro-inner h2 {
    max-width: 700px;
    margin: 0 auto;
    font-size: clamp(2rem, 4vw, 3.1rem);
    line-height: 1.18;
}
.trust-intro-inner p:not(.eyebrow) {
    max-width: 620px;
    margin: 14px auto 0;
    color: rgba(226,232,240,0.76);
    font-size: 1.02rem;
    line-height: 1.68;
}
.trust-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}
.trust-badges span {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 15px;
    border: 1px solid rgba(255,255,255,0.13);
    border-radius: 999px;
    background: rgba(255,255,255,0.045);
    color: rgba(248,250,252,0.86);
    font-size: 0.88rem;
    font-weight: 800;
}
.service-grid,.demo-grid,.process-grid,.pricing-grid,.trust-grid,.category-grid,.feature-grid,.team-grid,.image-grid { display:grid; gap:18px; }
.stats-grid { display:grid; gap:14px; }
.service-grid { grid-template-columns: repeat(4, 1fr); }
.demo-grid { grid-template-columns: repeat(4, 1fr); }
.process-grid,.pricing-grid,.trust-grid,.category-grid,.feature-grid,.team-grid,.stats-grid { grid-template-columns: repeat(3, 1fr); }
.service-card,.demo-card,.contact-box,.pricing-card,.trust-card,.category-card,.process-card,.feature-card,.team-card,.stat-card,.faq-list details { border:1px solid var(--line); border-radius:var(--radius); background:var(--panel); box-shadow:var(--shadow); }
.service-card,.process-card,.pricing-card,.trust-card,.category-card,.feature-card,.team-card { padding:26px; }
.stat-card { padding:18px 20px; min-height:112px; }
.category-card,.feature-card,.team-card { overflow:hidden; }
.category-card img,.feature-card img,.team-card img { width:calc(100% + 52px); max-width:none; height:230px; object-fit:cover; margin:-26px -26px 22px; border-radius: var(--radius) var(--radius) 12px 12px; }
.team-card img { height:280px; object-position:center top; }
.pricing-card.featured { border-color: color-mix(in srgb, var(--accent) 54%, transparent); transform: translateY(-8px); }
.service-price-grid { grid-template-columns: repeat(4, 1fr); }
.service-price-grid .pricing-card.featured { transform:none; }
.service-card span,.process-card b { display:inline-block; margin-bottom:30px; color:var(--cyan); font-weight:900; }
.portfolio-section,.faq-section { background:#0c111a; }
.demo-card { overflow:hidden; transition: transform .24s ease, border-color .24s ease; }
.demo-card:hover { transform: translateY(-8px); border-color:rgba(255,255,255,.28); }
.demo-visual { position:relative; min-height:245px; overflow:hidden; display:flex; align-items:end; padding:22px; color:#fff; font-weight:900; font-size:1.2rem; }
.demo-visual img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.demo-card:hover .demo-visual img { transform:scale(1.06); }
.demo-visual::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent, rgba(0,0,0,.78)); }
.demo-visual span { position:relative; z-index:1; }
.demo-body { padding:24px; }
.demo-body strong { display:inline-block; margin-top:24px; color:var(--cyan); }
.contact-section { background:linear-gradient(135deg,#0b111b,#07120f); }
.contact-box { display:grid; grid-template-columns:1fr auto; gap:36px; align-items:center; padding:40px; }
.footer { padding:32px 0; border-top:1px solid var(--line); background:#05070a; }
.footer-inner { display:flex; justify-content:space-between; gap:20px; }
.split { display:grid; grid-template-columns:.9fr 1.1fr; gap:54px; align-items:start; }
.faq-section {
    background:
        radial-gradient(circle at 12% 0%, rgba(104,240,216,0.08), transparent 28%),
        #0c111a;
}
.faq-shell {
    max-width: 940px;
}
.faq-intro {
    max-width: 640px;
    margin: 0 auto 38px;
    text-align: center;
}
.faq-intro h2 {
    margin-top: 10px;
}
.faq-intro p:not(.eyebrow) {
    margin-top: 14px;
    color: rgba(226,232,240,0.72);
}
.faq-list {
    display:grid;
    gap:14px;
}
.faq-list details {
    padding: 0;
    overflow: hidden;
    border-radius: 22px;
    background: rgba(255,255,255,.045);
    transition: border-color .22s ease, background .22s ease, transform .22s ease;
}
.faq-list details:hover {
    transform: translateY(-2px);
    border-color: rgba(255,255,255,.22);
    background: rgba(255,255,255,.065);
}
.faq-list details[open] {
    border-color: rgba(104,240,216,.26);
    background: rgba(255,255,255,.06);
}
.faq-list summary {
    position: relative;
    cursor:pointer;
    list-style: none;
    padding: 22px 58px 22px 24px;
    font-weight:900;
}
.faq-list summary::-webkit-details-marker {
    display: none;
}
.faq-list summary::after {
    content: "+";
    position: absolute;
    right: 22px;
    top: 50%;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
    color: var(--cyan);
    transform: translateY(-50%);
    transition: transform .22s ease, background .22s ease;
}
.faq-list details[open] summary::after {
    content: "−";
    background: rgba(104,240,216,.12);
    transform: translateY(-50%) rotate(180deg);
}
.faq-list p {
    max-width: 720px;
    margin: -4px 58px 24px 24px;
    line-height: 1.68;
}

/* Demo pages */
.demo-page { --accent: var(--cyan); }
.demo-page.demo-travel { --accent: var(--gold); }
.demo-page.demo-clinic { --accent:#33bdf2; background:#f4fbff; color:#07111f; --text:#07111f; --muted:#526274; --line:rgba(7,17,31,.12); --panel:#fff; --panel-2:#eaf7ff; }
.demo-page.demo-sports { --accent: var(--lime); }
.demo-page.demo-realty { --accent:#d7b46a; background:#0b0907; }
.demo-page.demo-legal { --accent:#b89b5e; background:#101014; }
.demo-page.demo-restaurant { --accent:#ffb15c; background:#120d09; }
.demo-page.demo-home { --accent:#62d6ff; background:#071017; }
.demo-page.demo-beauty { --accent:#f2a7c4; background:#160d14; }
.demo-page.demo-coffee { --accent:#d8a25f; background:#130f0b; }
.demo-page .site-header { background:rgba(8,11,16,.78); color:#f8fafc; }
.demo-clinic .site-header { background:rgba(255,255,255,.76); color:#07111f; }
.demo-clinic .nav { color:#526274; }
.demo-hero { position:relative; min-height:780px; display:grid; align-items:end; padding:140px 0 76px; overflow:hidden; color:#fff; }
.demo-hero::before { content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(0,0,0,.78),rgba(0,0,0,.2)), var(--hero-image); background-size:cover; background-position:center; transform:scale(1.02); }
.demo-hero::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.82)); }
.demo-hero .container { position:relative; z-index:1; max-width:960px; margin-left:max(18px, calc((100vw - 1180px) / 2)); }
.demo-hero p { max-width:720px; }
.demo-hero .hero-text { color:rgba(255,255,255,.88); }
.demo-travel .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1464822759023-fed622ff2c3b?q=80&w=1800&auto=format&fit=crop"); }
.demo-clinic .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1505751172876-fa1923c5c528?q=80&w=1800&auto=format&fit=crop"); }
.demo-sports .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1517836357463-d25dfeac3438?q=80&w=1800&auto=format&fit=crop"); }
.demo-realty .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1600596542815-ffad4c1539a9?q=80&w=1800&auto=format&fit=crop"); }
.demo-legal .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1589829545856-d10d557cf95f?q=80&w=1800&auto=format&fit=crop"); }
.demo-restaurant .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?q=80&w=1800&auto=format&fit=crop"); }
.today-special { display:flex; align-items:center; justify-content:space-between; gap:18px; margin-bottom:34px; padding:18px 20px; border:1px solid rgba(255,255,255,.14); border-radius:18px; background:linear-gradient(135deg,rgba(255,177,92,.18),rgba(255,255,255,.06)); box-shadow:var(--shadow); }
.today-special strong { color:var(--accent); font-size:1.05rem; }
.today-special span { color:var(--text); }
.today-special a { padding:10px 14px; border-radius:999px; background:#fff; color:#120d09; font-weight:900; white-space:nowrap; }
.reservation-layout { display:grid; grid-template-columns:.88fr 1.12fr; gap:20px; align-items:start; }
.reservation-options { display:grid; gap:12px; }
.reservation-options button { min-height:64px; padding:16px 18px; border:1px solid rgba(255,255,255,.14); border-radius:16px; background:rgba(255,255,255,.06); color:var(--text); font-weight:900; text-align:left; cursor:pointer; transition:transform .2s ease, border-color .2s ease, background .2s ease; }
.reservation-options button:hover { transform:translateY(-3px); border-color:rgba(255,177,92,.45); background:rgba(255,177,92,.12); }
.reservation-form { display:grid; grid-template-columns:1fr 1fr; gap:14px; padding:22px; border:1px solid rgba(255,255,255,.14); border-radius:20px; background:var(--panel); box-shadow:var(--shadow); }
.reservation-form label { display:grid; gap:8px; color:var(--muted); font-weight:800; }
.reservation-form input,.reservation-form select { width:100%; min-height:48px; padding:0 14px; border:1px solid rgba(255,255,255,.14); border-radius:12px; background:rgba(255,255,255,.06); color:var(--text); font:inherit; }
.reservation-form .btn { grid-column:1 / -1; }
.reservation-quick { justify-content:center; }
.menu-preview-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.menu-item { display:grid; grid-template-columns:150px 1fr; gap:18px; padding:18px; border:1px solid rgba(255,255,255,.12); border-radius:18px; background:var(--panel); box-shadow:var(--shadow); }
.menu-item img { width:150px; height:135px; object-fit:cover; border-radius:14px; }
.menu-item h3 { margin-bottom:8px; }
.menu-item strong { display:inline-block; margin-top:12px; color:var(--accent); font-size:1.2rem; }
.instagram-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
.instagram-grid img { width:100%; aspect-ratio:1; object-fit:cover; border-radius:14px; box-shadow:var(--shadow); transition:transform .25s ease; }
.instagram-grid img:hover { transform:scale(1.035); }
.map-card { min-height:420px; border:1px solid rgba(255,255,255,.14); border-radius:22px; overflow:hidden; background:var(--panel); box-shadow:var(--shadow); }
.map-placeholder { height:100%; min-height:420px; display:grid; place-items:center; align-content:center; gap:10px; padding:30px; text-align:center; background:linear-gradient(135deg,rgba(255,177,92,.18),rgba(255,255,255,.06)), linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px), linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px); background-size:auto,42px 42px,42px 42px; }
.map-placeholder span { color:var(--accent); font-weight:900; text-transform:uppercase; letter-spacing:.12em; }
.map-placeholder strong { font-size:2rem; }
.map-placeholder small,.location-details p { color:var(--muted); }
.location-details { display:grid; gap:10px; margin:22px 0 4px; }
.demo-home .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1581578731548-c64695cc6952?q=80&w=1800&auto=format&fit=crop"); }
.demo-beauty .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1560066984-138dadb4c035?q=80&w=1800&auto=format&fit=crop"); }
.demo-coffee .demo-hero { --hero-image: url("https://images.unsplash.com/photo-1495474472287-4d71bcdd2085?q=80&w=1800&auto=format&fit=crop"); }
.demo-coffee .demo-hero::before { background:linear-gradient(90deg,rgba(18,11,6,.88),rgba(18,11,6,.32)), var(--hero-image); background-size:cover; background-position:center; }
.demo-coffee .pricing-card.featured { background:linear-gradient(135deg,rgba(216,162,95,.18),rgba(255,255,255,.05)); }
.demo-coffee .category-card {
    transition: transform .24s ease, border-color .24s ease, box-shadow .24s ease;
}
.demo-coffee .category-card:hover {
    transform: translateY(-6px) scale(1.025);
    border-color: rgba(216, 162, 95, .44);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .46);
}
.demo-coffee .category-card:hover img {
    transform: scale(1.045);
}
.demo-coffee .category-card img {
    transition: transform .45s ease;
}
.demo-beauty .demo-hero::before { background:linear-gradient(90deg,rgba(12,8,7,.9),rgba(12,8,7,.36)), var(--hero-image); background-size:cover; background-position:center; }
.demo-beauty .demo-visual::after { background:linear-gradient(180deg, transparent, rgba(12,8,7,.84)); }
.demo-beauty .pricing-card.featured { background:linear-gradient(135deg,rgba(242,167,196,.16),rgba(255,255,255,.05)); }
.compact-gallery { grid-template-columns:1fr 1fr; margin-top:0; }
.compact-gallery img:first-child { height:420px; grid-column:span 2; grid-row:auto; }
.demo-section { padding:86px 0; }
.demo-section.light { background:rgba(255,255,255,.04); }
.demo-clinic .demo-section.light { background:#eaf7ff; }
.feature-list { display:grid; gap:14px; list-style:none; }
.feature-list li { padding:16px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.05); }
.demo-clinic .feature-list li { background:#fff; }
.price { display:block; margin:22px 0 12px; color:var(--accent); font-size:2rem; font-weight:900; }
.image-grid { grid-template-columns:1.2fr .8fr .8fr; margin-top:34px; }
.image-grid img,.service-image { width:100%; height:260px; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow); }
.image-grid img:first-child { height:540px; grid-row:span 2; }
.service-image { margin-top:22px; }
.stat-card strong { display:block; color:var(--accent); font-size:1.72rem; line-height:1; margin-bottom:7px; }
.stat-card span { display:block; font-size:.92rem; line-height:1.35; }
.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

@media (max-width: 1100px) {
    .demo-grid,.service-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 980px) {
    .menu-btn { display:inline-flex; }
    .nav { position:fixed; top:78px; left:18px; right:18px; display:none; flex-direction:column; padding:16px; border:1px solid var(--line); border-radius:var(--radius); background:#080b10; box-shadow:var(--shadow); }
    .nav.open { display:flex; }
    .hero-grid,.contact-box,.split { grid-template-columns:1fr; }
    .process-grid,.pricing-grid,.trust-grid,.category-grid,.feature-grid,.team-grid,.stats-grid,.image-grid { grid-template-columns:1fr 1fr; }
    .reservation-layout,.menu-preview-grid { grid-template-columns:1fr; }
    .instagram-grid { grid-template-columns:repeat(3,1fr); }
    .service-price-grid { grid-template-columns:1fr 1fr; }
    .image-grid img:first-child { height:320px; grid-row:auto; grid-column:span 2; }
    html[lang="ka"] .nav { gap: 12px; font-size: 1rem; }
    html[lang="ka"] .contact-box { align-items: stretch; }
}
@media (max-width: 640px) {
    .site-header { min-height:72px; }
    .logo { gap: 9px; }
    .logo img { width: 42px; height: 42px; border-radius: 12px; }
    .logo span { width: 38px; height: 38px; border-radius: 11px; }
    .logo strong { display:inline; max-width: 142px; overflow: hidden; text-overflow: ellipsis; font-size: .92rem; }
    .hero-brand-logo { width: min(300px, 100%); margin-bottom: 14px; }
    .studio-hero,.demo-hero { min-height:auto; padding:122px 0 58px; }
    h1 { font-size:2.85rem; }
    h2 { font-size:2.25rem; }
    html[lang="ka"] h1 { font-size: 2.2rem; line-height: 1.18; }
    html[lang="ka"] h2 { font-size: 1.85rem; line-height: 1.2; }
    html[lang="ka"] h3 { font-size: 1.12rem; }
    html[lang="ka"] .hero-text { font-size: 1.05rem; }
    html[lang="ka"] .floating-stat { width: 100%; margin-left: 0; text-align: center; border-radius: 16px; }
    html[lang="ka"] .demo-visual { min-height: 230px; }
    html[lang="ka"] .demo-body { padding: 20px; }
    html[lang="ka"] .service-card,
    html[lang="ka"] .process-card,
    html[lang="ka"] .pricing-card,
    html[lang="ka"] .trust-card,
    html[lang="ka"] .category-card,
    html[lang="ka"] .feature-card,
    html[lang="ka"] .team-card,
    html[lang="ka"] .stat-card { padding: 16px 18px; }
    html[lang="ka"] .stat-card strong { font-size: 1.55rem; }
    html[lang="ka"] .stat-card span { font-size: .88rem; line-height: 1.35; }
    .button-row,.contact-actions,.demo-actions,.hero-actions { flex-direction:column; }
    .btn { width:100%; }
    .section,.demo-section { padding:66px 0; }
    .trust-intro { padding: 40px 0; }
    .trust-intro-inner { padding: 28px 18px; border-radius: 20px; }
    .trust-intro-inner h2 { font-size: 1.72rem; line-height: 1.32; }
    .trust-intro-inner p:not(.eyebrow) { font-size: 1rem; line-height: 1.7; }
    .trust-badges { gap: 9px; }
    .trust-badges span { min-height: 36px; padding: 0 12px; font-size: 0.82rem; }
    .demo-grid,.service-grid,.process-grid,.pricing-grid,.trust-grid,.category-grid,.feature-grid,.team-grid,.stats-grid,.image-grid { grid-template-columns:1fr; }
    .faq-intro { margin-bottom: 28px; text-align: left; }
    .faq-list summary { padding: 20px 50px 20px 18px; }
    .faq-list summary::after { right: 16px; }
    .faq-list p { margin: -2px 18px 22px; }
    .reservation-form { grid-template-columns:1fr; padding:18px; }
    .today-special { align-items:flex-start; flex-direction:column; }
    .today-special a { width:100%; text-align:center; }
    .menu-item { grid-template-columns:1fr; }
    .menu-item img { width:100%; height:210px; }
    .instagram-grid { grid-template-columns:repeat(2,1fr); }
    .map-card,.map-placeholder { min-height:320px; }
    .service-price-grid { grid-template-columns:1fr; }
    .image-grid img:first-child { grid-column:auto; }
    .contact-box { padding:24px; }
    .footer-inner { flex-direction:column; }
}

/* Georgian typography and responsive safety layer */
html[lang="ka"],
html[lang="ka"] body {
    font-family: "Noto Sans Georgian", "Noto Serif Georgian", "BPG Arial", Arial, sans-serif;
    line-height: 1.62;
    letter-spacing: normal;
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: none;
    white-space: normal;
}

html[lang="ka"] *,
html[lang="ka"] *::before,
html[lang="ka"] *::after {
    letter-spacing: normal;
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: none;
}

html[lang="ka"] h1,
html[lang="ka"] h2,
html[lang="ka"] h3,
html[lang="ka"] p,
html[lang="ka"] a,
html[lang="ka"] span,
html[lang="ka"] strong,
html[lang="ka"] small,
html[lang="ka"] summary {
    max-width: 100%;
    white-space: normal;
}

html[lang="ka"] h1 {
    line-height: 1.22;
    font-size: clamp(2.25rem, 4.4vw, 4.35rem);
}

html[lang="ka"] h2 {
    line-height: 1.26;
    font-size: clamp(1.8rem, 3.3vw, 3.25rem);
}

html[lang="ka"] h3 {
    line-height: 1.38;
}

html[lang="ka"] p,
html[lang="ka"] .hero-text,
html[lang="ka"] .section-note,
html[lang="ka"] .demo-body p,
html[lang="ka"] .demo-section p,
html[lang="ka"] .pricing-card p,
html[lang="ka"] .trust-card p,
html[lang="ka"] .category-card p,
html[lang="ka"] .feature-card p,
html[lang="ka"] .team-card p,
html[lang="ka"] .faq-list p {
    line-height: 1.65;
}

html[lang="ka"] .eyebrow,
html[lang="ka"] .hero-badge {
    line-height: 1.45;
    letter-spacing: normal;
    text-transform: none;
}

html[lang="ka"] .studio-hero,
html[lang="ka"] .demo-hero {
    min-height: auto;
    height: auto;
}

html[lang="ka"] .hero-grid,
html[lang="ka"] .split,
html[lang="ka"] .contact-box {
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr);
    align-items: start;
}

html[lang="ka"] .service-grid,
html[lang="ka"] .demo-grid,
html[lang="ka"] .process-grid,
html[lang="ka"] .pricing-grid,
html[lang="ka"] .trust-grid,
html[lang="ka"] .category-grid,
html[lang="ka"] .feature-grid,
html[lang="ka"] .team-grid,
html[lang="ka"] .stats-grid,
html[lang="ka"] .service-price-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
}

html[lang="ka"] .service-card,
html[lang="ka"] .demo-card,
html[lang="ka"] .contact-box,
html[lang="ka"] .pricing-card,
html[lang="ka"] .trust-card,
html[lang="ka"] .category-card,
html[lang="ka"] .process-card,
html[lang="ka"] .feature-card,
html[lang="ka"] .team-card,
html[lang="ka"] .stat-card,
html[lang="ka"] .faq-list details {
    height: auto;
    min-height: 0;
}

html[lang="ka"] .btn,
html[lang="ka"] .lang-switch,
html[lang="ka"] .nav a,
html[lang="ka"] .hero-proof span,
html[lang="ka"] .mini-stats span,
html[lang="ka"] .floating-stat,
html[lang="ka"] .hero-mini-cards a,
html[lang="ka"] .site-window-hero a {
    min-height: 0;
    height: auto;
    line-height: 1.4;
    white-space: normal;
    text-align: center;
}

html[lang="ka"] .btn {
    padding: 14px 20px;
}

html[lang="ka"] .demo-visual,
html[lang="ka"] .hero-preview,
html[lang="ka"] .site-window,
html[lang="ka"] .site-window-hero,
html[lang="ka"] .hero-mini-cards a {
    height: auto;
    min-height: 0;
}

html[lang="ka"] .site-window {
    grid-template-rows: auto auto auto auto;
}

html[lang="ka"] .site-window-hero {
    grid-template-columns: minmax(0, 1fr);
}

html[lang="ka"] .site-window-hero strong {
    max-width: none;
    line-height: 1.3;
}

html[lang="ka"] .demo-visual {
    min-height: 220px;
}

html[lang="ka"] .stat-card strong {
    line-height: 1.15;
}

html[lang="ka"] .stat-card span {
    line-height: 1.45;
}

html[lang="ka"] .price {
    line-height: 1.2;
}

.floating-whatsapp {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 80;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 56px;
    padding: 0 20px;
    border-radius: 999px;
    background: rgba(37, 211, 102, 0.82);
    color: #fff;
    font-weight: 800;
    box-shadow: 0 14px 34px rgba(37, 211, 102, 0.20);
    border: 1px solid rgba(255,255,255,0.22);
    backdrop-filter: blur(10px);
    transform: translateY(0);
}

.floating-whatsapp::before {
    content: "☎";
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255,255,255,0.18);
    font-size: 0.95rem;
}

.floating-whatsapp:hover {
    transform: translateY(-3px) scale(1.03);
    background: rgba(37, 211, 102, 0.94);
    box-shadow: 0 18px 42px rgba(37, 211, 102, 0.30);
}

@media (max-width: 980px) {
    html[lang="ka"] .hero-grid,
    html[lang="ka"] .split,
    html[lang="ka"] .contact-box {
        grid-template-columns: 1fr;
    }

    html[lang="ka"] .hero-copy,
    html[lang="ka"] .hero-showcase,
    html[lang="ka"] .section-head,
    html[lang="ka"] .contact-box > *,
    html[lang="ka"] .demo-hero .container {
        width: 100%;
        max-width: 100%;
    }
}

@media (max-width: 760px) {
    html[lang="ka"] .container {
        width: min(100% - 28px, 1180px);
    }

    html[lang="ka"] .studio-hero,
    html[lang="ka"] .demo-hero {
        padding: 116px 0 56px;
    }

    html[lang="ka"] h1 {
        font-size: clamp(2rem, 9vw, 2.75rem);
        line-height: 1.24;
    }

    html[lang="ka"] h2 {
        font-size: clamp(1.55rem, 7vw, 2.05rem);
        line-height: 1.3;
    }

    html[lang="ka"] h3 {
        font-size: 1.08rem;
        line-height: 1.42;
    }

    html[lang="ka"] .hero-text,
    html[lang="ka"] p {
        font-size: 1rem;
        line-height: 1.68;
    }

    html[lang="ka"] .hero-proof,
    html[lang="ka"] .mini-stats,
    html[lang="ka"] .button-row,
    html[lang="ka"] .contact-actions,
    html[lang="ka"] .hero-actions {
        align-items: stretch;
    }

    html[lang="ka"] .hero-proof span,
    html[lang="ka"] .mini-stats span,
    html[lang="ka"] .btn {
        width: 100%;
        justify-content: center;
    }

    html[lang="ka"] .hero-mini-cards,
    html[lang="ka"] .site-window-grid {
        grid-template-columns: 1fr;
    }

    html[lang="ka"] .showcase-caption {
        flex-direction: column;
    }

    html[lang="ka"] .browser-frame,
    html[lang="ka"] .contact-box,
    html[lang="ka"] .service-card,
    html[lang="ka"] .process-card,
    html[lang="ka"] .pricing-card,
    html[lang="ka"] .trust-card,
    html[lang="ka"] .category-card,
    html[lang="ka"] .feature-card,
    html[lang="ka"] .team-card,
    html[lang="ka"] .stat-card {
        border-radius: 16px;
    }

    html[lang="ka"] .category-card img,
    html[lang="ka"] .feature-card img,
    html[lang="ka"] .team-card img {
        height: 210px;
    }

    .floating-whatsapp {
        right: 14px;
        bottom: 14px;
        min-height: 52px;
        padding: 0 16px;
        font-size: 0.92rem;
    }
}

/* Final refined theme overrides */
:root {
    --bg: #0b1020;
    --panel: rgba(30, 41, 59, 0.78);
    --panel-2: rgba(36, 48, 68, 0.82);
    --text: #f3f4f6;
    --muted: #a7b0bf;
    --line: rgba(209, 213, 219, 0.13);
    --blue: #7fb4ff;
    --cyan: #7dd8ee;
    --green: #25d366;
    --gold: #d7b46a;
    --rose: #d98aa6;
    --lime: #b8d978;
    --shadow: 0 20px 56px rgba(3, 7, 18, 0.28);
}

body {
    background: radial-gradient(circle at 8% 0%, rgba(125, 216, 238, 0.08), transparent 28%),
        radial-gradient(circle at 90% 8%, rgba(127, 180, 255, 0.07), transparent 30%),
        linear-gradient(180deg, #0b1020 0%, #111827 46%, #0b1020 100%);
}

.site-header,
.demo-page .site-header {
    border-bottom-color: rgba(209, 213, 219, 0.11);
    background: rgba(11, 16, 32, 0.76);
    backdrop-filter: blur(14px);
}

.logo span,
.btn.primary {
    background: linear-gradient(135deg, #8fc5ff, #7dd8ee);
    color: #08111f;
}

.nav a:hover,
.back-link:hover {
    text-shadow: none;
}

.studio-hero {
    background: radial-gradient(circle at 18% 20%, rgba(127, 180, 255, 0.16), transparent 32%),
        radial-gradient(circle at 76% 26%, rgba(125, 216, 238, 0.11), transparent 30%),
        linear-gradient(135deg, #0b1020 0%, #111827 55%, #161b26 100%);
}

.studio-hero::before {
    background: linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px);
    opacity: .24;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.62), transparent 82%);
}

.hero-bg-photo {
    background: linear-gradient(90deg, rgba(11,16,32,0.96), rgba(11,16,32,0.28)),
        url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?q=80&w=1600&auto=format&fit=crop") center/cover;
    opacity: .18;
}

.hero-orbit {
    border-color: rgba(209, 213, 219, 0.09);
    opacity: .65;
}

.hero-orbit::before,
.hero-orbit::after {
    background: #7dd8ee;
    opacity: .7;
}

.hero-badge,
.eyebrow,
.demo-body strong,
.service-card span,
.process-card b {
    color: #8bdcf0;
}

.hero-badge {
    border-color: rgba(125, 216, 238, 0.2);
    background: rgba(125, 216, 238, 0.08);
    box-shadow: none;
}

.hero-text,
.section-note,
.service-card p,
.demo-body p,
.contact-box p,
.demo-section p,
.pricing-card p,
.trust-card p,
.category-card p,
.feature-card p,
.team-card p,
.faq-list p,
.footer {
    color: #aeb7c6;
}

.hero-proof span,
.mini-stats span,
.lang-switch,
.site-window-grid span,
.hero-mini-cards a,
.trust-badges span {
    border-color: rgba(209, 213, 219, 0.12);
    background: rgba(30, 41, 59, 0.58);
    color: #d1d5db;
}

.btn {
    box-shadow: none;
}

.btn:hover {
    box-shadow: 0 14px 34px rgba(3, 7, 18, 0.24);
}

.btn.primary {
    border-color: rgba(255,255,255,0.12);
    box-shadow: 0 16px 42px rgba(125, 216, 238, 0.14);
}

.btn.secondary,
.btn.ghost {
    border-color: rgba(209, 213, 219, 0.14);
    background: rgba(30, 41, 59, 0.56);
}

.browser-frame,
.service-card,
.demo-card,
.contact-box,
.pricing-card,
.trust-card,
.category-card,
.process-card,
.feature-card,
.team-card,
.stat-card,
.faq-list details,
.reservation-form,
.menu-item,
.map-card {
    border-color: rgba(209, 213, 219, 0.12);
    background: linear-gradient(180deg, rgba(36, 48, 68, 0.86), rgba(30, 41, 59, 0.78));
    box-shadow: 0 18px 48px rgba(3, 7, 18, 0.24);
}

.browser-frame {
    border-radius: 28px;
    backdrop-filter: blur(10px);
}

.hero-preview {
    background: radial-gradient(circle at 18% 18%, rgba(125,216,238,.10), transparent 30%),
        linear-gradient(145deg, rgba(36,48,68,.78), rgba(22,27,38,.86));
}

.site-window {
    background: rgba(17, 24, 39, 0.76);
    border-color: rgba(209, 213, 219, 0.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 22px 54px rgba(3,7,18,.22);
    backdrop-filter: blur(10px);
}

.site-window-hero {
    background: linear-gradient(135deg, rgba(125,216,238,.13), rgba(127,180,255,.10)),
        linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
    border-color: rgba(209, 213, 219, 0.12);
}

.site-window-hero a,
.floating-stat {
    background: #f3f4f6;
    color: #111827;
    box-shadow: 0 16px 36px rgba(3, 7, 18, 0.22);
}

.site-window-bars i {
    background: linear-gradient(90deg, rgba(125,216,238,.42), rgba(209,213,219,.14));
}

.trust-intro,
.portfolio-section,
.faq-section {
    background: radial-gradient(circle at 12% 0%, rgba(125,216,238,0.055), transparent 28%), #111827;
}

.trust-intro-inner {
    background: rgba(30, 41, 59, 0.44);
    border-color: rgba(209, 213, 219, 0.12);
}

.demo-card:hover {
    transform: translateY(-6px);
    border-color: rgba(125,216,238,.24);
}

.demo-visual::after {
    background: linear-gradient(180deg, transparent 22%, rgba(11,16,32,.84));
}

.contact-section {
    background: radial-gradient(circle at 82% 0%, rgba(125,216,238,.08), transparent 30%),
        linear-gradient(135deg,#111827,#0b1020);
}

.footer {
    border-top-color: rgba(209, 213, 219, 0.1);
    background: #0b1020;
}

.faq-list details:hover {
    border-color: rgba(125,216,238,.2);
    background: rgba(36,48,68,.9);
}

.faq-list details[open] {
    border-color: rgba(125,216,238,.24);
    background: rgba(36,48,68,.92);
}

.faq-list summary::after {
    background: rgba(125,216,238,.10);
    color: #8bdcf0;
}

.demo-page:not(.demo-clinic) {
    background: #111827;
}

.demo-page.demo-clinic {
    background: #f4f8fb;
}

.demo-hero::before {
    background: linear-gradient(90deg,rgba(11,16,32,.78),rgba(11,16,32,.24)), var(--hero-image);
    background-size: cover;
    background-position: center;
}

.demo-hero::after {
    background: linear-gradient(180deg, transparent 56%, rgba(11,16,32,.78));
}

.demo-coffee .demo-hero::before,
.demo-beauty .demo-hero::before {
    background: linear-gradient(90deg,rgba(11,16,32,.80),rgba(11,16,32,.25)), var(--hero-image);
    background-size: cover;
    background-position: center;
}

.today-special,
.reservation-options button {
    border-color: rgba(209,213,219,.13);
    background: rgba(36,48,68,.72);
    box-shadow: 0 16px 42px rgba(3,7,18,.22);
}

.reservation-options button:hover,
.demo-coffee .category-card:hover {
    border-color: rgba(125,216,238,.24);
    background: rgba(42,53,72,.86);
    box-shadow: 0 20px 48px rgba(3,7,18,.24);
}

/* Brand wordmark gradient to match the FWS logo */
.logo strong {
    color: transparent !important;
    background: linear-gradient(90deg,
        #52ff2e 0%,
        #ffe13a 17%,
        #ff3b2f 34%,
        #ff1493 52%,
        #9a35ff 70%,
        #0498ff 88%,
        #18caff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    text-shadow:
        0 0 16px rgba(255, 45, 178, .18),
        0 0 22px rgba(0, 119, 255, .16);
    font-weight: 850;
}

html,
body {
    background-color: #000 !important;
}

body.menu-open {
    overflow: auto !important;
}

.demo-floating-back,
.demo-return-cta {
    display: none;
}

@media (max-width: 768px) {
    .demo-floating-back {
        position: fixed;
        top: calc(env(safe-area-inset-top, 0px) + 82px);
        left: 12px;
        z-index: 130;
        display: inline-flex;
        min-height: 38px;
        align-items: center;
        justify-content: center;
        padding: 0 14px;
        border: 1px solid rgba(125, 216, 238, .36);
        border-radius: 999px;
        color: #f8fafc;
        background:
            linear-gradient(135deg, rgba(8, 12, 24, .94), rgba(17, 24, 39, .86)),
            rgba(0, 0, 0, .72);
        box-shadow:
            0 12px 34px rgba(0, 0, 0, .34),
            0 0 28px rgba(0, 119, 255, .16);
        backdrop-filter: blur(16px) saturate(1.25);
        -webkit-backdrop-filter: blur(16px) saturate(1.25);
        font-size: .78rem;
        font-weight: 800;
        letter-spacing: 0;
        text-decoration: none;
        transform: translateZ(0);
        transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease;
        touch-action: manipulation;
    }

    .demo-floating-back:hover,
    .demo-floating-back:focus-visible {
        border-color: rgba(125, 216, 238, .58);
        box-shadow:
            0 16px 42px rgba(0, 0, 0, .38),
            0 0 34px rgba(0, 119, 255, .22);
        transform: translateY(-1px) scale(1.02);
    }

    .demo-floating-back:active {
        transform: translateY(0) scale(.98);
    }

    .demo-return-cta {
        display: grid;
        place-items: center;
        padding: 28px 18px calc(112px + env(safe-area-inset-bottom, 0px));
        background: #000;
    }

    .demo-return-cta a {
        display: inline-flex;
        min-height: 46px;
        align-items: center;
        justify-content: center;
        padding: 0 20px;
        border: 1px solid rgba(125, 216, 238, .32);
        border-radius: 999px;
        color: #f8fafc;
        background:
            linear-gradient(135deg, rgba(8, 12, 24, .92), rgba(17, 24, 39, .84)),
            rgba(255, 255, 255, .05);
        box-shadow:
            0 18px 44px rgba(0, 0, 0, .28),
            0 0 34px rgba(0, 119, 255, .14);
        font-size: .92rem;
        font-weight: 850;
        text-align: center;
        text-decoration: none;
        transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
        touch-action: manipulation;
    }

    .demo-return-cta a:hover,
    .demo-return-cta a:focus-visible {
        border-color: rgba(125, 216, 238, .56);
        box-shadow:
            0 22px 52px rgba(0, 0, 0, .32),
            0 0 40px rgba(0, 119, 255, .2);
        transform: translateY(-1px);
    }

    .demo-return-cta a:active {
        transform: scale(.98);
    }
}

/* iPhone safe-area support */
@supports (padding-top: env(safe-area-inset-top)) {
    @media (max-width: 760px) {
        body::before {
            content: "";
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            height: env(safe-area-inset-top);
            background: #000;
            z-index: 49;
            pointer-events: none;
        }

        .site-header,
        .demo-page .site-header {
            top: 0 !important;
            background: rgba(0, 0, 0, .88) !important;
            padding-top: env(safe-area-inset-top) !important;
            min-height: calc(72px + env(safe-area-inset-top)) !important;
        }

        .nav {
            top: calc(72px + env(safe-area-inset-top)) !important;
        }

        .studio-hero,
        .demo-hero {
            padding-top: calc(122px + env(safe-area-inset-top)) !important;
        }
    }
}
