﻿/* =========================================================================
   SnapsJo Ã¢â‚¬â€ Digital Portrait Atelier
   Warm, editorial, gallery-inspired. No purple/blue AI-SaaS gradients.
   Mobile-first. PageSpeed-focused. ~32KB.
   ========================================================================= */

/* ---------- Layout: footer sticks to bottom; content visible without JS reveal ---------- */
html, body {
    min-height: 100%;
}

body.landing-body {
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
}

body.landing-body #main {
    flex: 1 0 auto;
}

body.landing-body .site-footer {
    flex-shrink: 0;
}

/* ---------- Tokens ---------- */
:root {
    /* Brand */
    --ink:           #171412;
    --ink-soft:      #2A211C;
    --charcoal:      #2A211C;
    --porcelain:     #FAF7F2;
    --canvas:        #F3E7D3;
    --oat:           #E8DCC8;
    --clay:          #B87952;
    --terracotta:    #D66A3D;
    --champagne:     #E7C873;
    --gold:          #E7C873;
    --film-amber:    #F4B860;
    --amber:         #F4B860;
    --sage:          #A8B9A3;
    --sage-soft:     #DDE8D5;
    --olive:         #3F4A35;
    --rose:          #D9A6A0;
    --rose-soft:     #F7D6CE;
    --blush:         #F7D6CE;
    --mint:          #DDE8D5;
    --shadow-warm:   #85796B;
    --shadow:        rgba(42, 33, 28, 0.12);

    /* Text */
    --text-900:      #171412;
    --text-700:      #3F362F;
    --text-600:      #5C5046;
    --text-500:      #85796B;
    --text-400:      #A89B8B;

    /* Lines */
    --line:          rgba(42, 33, 28, 0.08);
    --line-warm:     rgba(184, 121, 82, 0.18);
    --line-strong:   rgba(42, 33, 28, 0.16);

    /* Surfaces */
    --paper:         rgba(255, 252, 246, 0.82);
    --vellum:        rgba(250, 247, 242, 0.65);

    /* Radii */
    --r-sm:          12px;
    --r:             18px;
    --r-lg:          28px;
    --r-xl:          36px;
    --r-arch:        50% 50% 24px 24px / 30% 30% 10px 10px;
    --r-pill:        9999px;

    /* Shadows */
    --sh-xs:         0 1px 2px rgba(42, 33, 28, 0.06);
    --sh-sm:         0 8px 24px rgba(42, 33, 28, 0.07);
    --sh:            0 24px 60px rgba(42, 33, 28, 0.10);
    --sh-lg:         0 32px 90px rgba(42, 33, 28, 0.14);
    --sh-warm:       0 32px 90px rgba(184, 121, 82, 0.18);
    --sh-frame:      0 24px 60px rgba(42, 33, 28, 0.18),
                     0 4px 12px rgba(42, 33, 28, 0.10),
                     inset 0 0 0 1px rgba(255, 252, 246, 0.5);

    /* Gradients */
    --g-studio:      radial-gradient(circle at 30% 20%, rgba(231, 200, 115, 0.35), transparent 38%),
                     radial-gradient(circle at 80% 15%, rgba(216, 106, 61, 0.18), transparent 34%),
                     linear-gradient(135deg, #FAF7F2 0%, #F3E7D3 100%);
    --g-dark:        linear-gradient(135deg, #171412 0%, #2A211C 55%, #3F4A35 100%);
    --g-paper:       linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(243, 231, 211, 0.72));
    --g-cta:         linear-gradient(135deg, #171412 0%, #3F4A35 48%, #B87952 100%);
    --g-gold:        linear-gradient(135deg, #E7C873, #F4B860, #D66A3D);
    --g-receipt:     linear-gradient(180deg, #FFFCF6 0%, #FAF7F2 100%);

    /* Motion */
    --ease:          cubic-bezier(.22, 1, .36, 1);
    --t:             260ms var(--ease);

    /* Layout */
    --w:             1240px;
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
    margin: 0;
    background: var(--porcelain);
    color: var(--text-900);
    font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 16px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

/* Landing uses a floating fixed header; hero supplies top offset (see site-header.css). */
body.landing-body.has-site-header {
    padding-top: 0;
}

img, svg { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; background: transparent; border: 0; color: inherit; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 {
    margin: 0;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.1;
    color: var(--ink);
    font-family: 'Fraunces', 'Cormorant Garamond', Georgia, serif;
}
p { margin: 0; color: var(--text-600); }
:focus-visible {
    outline: 2px solid var(--clay);
    outline-offset: 3px;
    border-radius: 6px;
}

::selection { background: var(--champagne); color: var(--ink); }

/* ---------- Layout ---------- */
.container {
    width: 100%;
    max-width: var(--w);
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

.section { padding: 72px 0; position: relative; }
.atelier-section { overflow: hidden; }
.atelier-section::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    opacity: 0.45;
    background-image:
        linear-gradient(rgba(42, 33, 28, 0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(42, 33, 28, 0.025) 1px, transparent 1px);
    background-size: 88px 110px;
    mask-image: radial-gradient(ellipse at center, black 20%, transparent 78%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 20%, transparent 78%);
}
.atelier-section > .container { position: relative; z-index: 1; }
@media (min-width: 768px) { .section { padding: 112px 0; } }

.section--canvas { background: var(--canvas); }
.section--porcelain { background: var(--porcelain); }
.section--dark { background: var(--ink); color: var(--porcelain); }
.section--dark p { color: rgba(250, 247, 242, 0.72); }
.section--dark h2, .section--dark h3 { color: var(--porcelain); }

/* Soft paper texture (CSS-only, free) */
.section--canvas,
.section--porcelain {
    background-image:
        radial-gradient(rgba(42, 33, 28, 0.025) 1px, transparent 1px);
    background-size: 22px 22px;
    background-position: 0 0;
}
.section--canvas { background-color: var(--canvas); }
.section--porcelain { background-color: var(--porcelain); }

/* Section headings */
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 7px 14px 7px 10px;
    border-radius: var(--r-pill);
    background: rgba(255, 252, 246, 0.7);
    border: 1px solid var(--line-warm);
    color: var(--clay);
    font-size: 12.5px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.eyebrow::before {
    content: "";
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--terracotta);
    box-shadow: 0 0 0 4px rgba(214, 106, 61, 0.18);
}

.section-head {
    max-width: 720px;
    margin: 0 auto 56px;
    text-align: center;
}
.section-head h2 {
    font-size: clamp(28px, 4.2vw, 48px);
    margin: 16px 0 14px;
}
.section-head p {
    font-size: 17px;
    color: var(--text-600);
}

.serif { font-family: 'Fraunces', 'Cormorant Garamond', Georgia, serif; }
.italic-accent {
    font-family: 'Fraunces', 'Cormorant Garamond', Georgia, serif;
    font-style: italic;
    font-weight: 400;
    color: var(--clay);
}
.gold-text {
    background: var(--g-gold);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    height: 52px;
    padding: 0 24px;
    border-radius: var(--r-pill);
    font-weight: 600;
    font-size: 15px;
    border: 1px solid transparent;
    transition: transform var(--t), box-shadow var(--t), background var(--t), color var(--t), border-color var(--t);
    white-space: nowrap;
    will-change: transform;
    letter-spacing: 0.005em;
}
.btn svg { width: 16px; height: 16px; }
.btn:active { transform: translateY(1px); }

.btn--primary {
    color: var(--porcelain);
    background: var(--g-cta);
    box-shadow: 0 14px 32px rgba(23, 20, 18, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.12);
    position: relative;
    overflow: hidden;
}
.btn--primary > *,
.btn--primary svg {
    position: relative;
    z-index: 1;
}
.btn--primary::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(115deg, transparent 35%, rgba(231, 200, 115, 0.35) 50%, transparent 65%);
    transform: translateX(-120%);
    transition: transform 800ms var(--ease);
}
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 20px 40px rgba(23, 20, 18, 0.32); }
.btn--primary:hover::after { transform: translateX(120%); }

.btn--ghost {
    background: var(--paper);
    color: var(--ink);
    border-color: var(--line-strong);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.btn--ghost:hover { background: var(--porcelain); border-color: var(--clay); color: var(--clay); }

.btn--gold {
    color: var(--ink);
    background: var(--g-gold);
    box-shadow: 0 14px 32px rgba(216, 106, 61, 0.28);
}
.btn--gold:hover { transform: translateY(-2px); box-shadow: 0 20px 40px rgba(216, 106, 61, 0.36); }

.btn--invert {
    color: var(--ink);
    background: var(--porcelain);
}
.btn--invert:hover { background: var(--champagne); transform: translateY(-2px); }

.btn--lg { height: 58px; padding: 0 30px; font-size: 16px; }
.btn--block { width: 100%; }

@media (max-width: 540px) {
    .btn--responsive { width: 100%; }
}

/* ---------- Bubble Header ---------- */
.bubble-header {
    position: fixed;
    top: 14px;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 28px);
    max-width: 980px;
    z-index: 50;
    transition:
        top 480ms var(--ease),
        width 480ms var(--ease),
        max-width 480ms var(--ease),
        transform 480ms var(--ease);
}
.bubble-header__inner {
    background: rgba(250, 247, 242, 0.78);
    backdrop-filter: saturate(140%) blur(16px);
    -webkit-backdrop-filter: saturate(140%) blur(16px);
    border: 1px solid rgba(42, 33, 28, 0.10);
    border-radius: var(--r-pill);
    box-shadow: 0 18px 60px rgba(42, 33, 28, 0.10);
    padding: 0 20px;
    transition:
        border-radius 480ms var(--ease),
        background 360ms var(--ease),
        box-shadow 360ms var(--ease),
        border-color 360ms var(--ease),
        padding 480ms var(--ease);
}
.bubble-header.header-scrolled {
    top: 0;
    left: 0;
    transform: none;
    width: 100%;
    max-width: none;
}
.bubble-header.header-scrolled .bubble-header__inner {
    border-radius: 0;
    background: rgba(250, 247, 242, 0.96);
    border-color: var(--line-warm);
    border-left-color: transparent;
    border-right-color: transparent;
    box-shadow: 0 10px 32px rgba(42, 33, 28, 0.10);
    padding: 0 24px;
}
@media (min-width: 960px) {
    .bubble-header.header-scrolled .bubble-header__inner {
        padding: 0 max(24px, calc((100% - var(--w)) / 2 + 24px));
    }
}

.site-header { /* legacy alias */ }

.nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 64px;
    gap: 16px;
}
@media (min-width: 960px) {
    .nav {
        display: grid;
        grid-template-columns: 1fr auto 1fr;
        height: 68px;
        gap: 24px;
        align-items: center;
    }
    .brand { justify-self: start; }
    .nav__links {
        justify-self: center;
        flex: none;
    }
    .nav__cta { justify-self: end; }
}
.brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-weight: 600;
    font-size: 20px;
    letter-spacing: -0.02em;
    color: var(--ink);
    font-family: 'Fraunces', 'Cormorant Garamond', Georgia, serif;
}
.brand--logo { gap: 0; line-height: 0; }
.brand__logo {
    display: block;
    height: 42px;
    width: auto;
    max-width: min(190px, 48vw);
    object-fit: contain;
    background: transparent;
}
.brand--logo-footer {
    display: inline-flex;
    padding: 0;
    border-radius: 0;
    background: transparent;
}
.bubble-header .brand__logo { height: 38px; }
@media (min-width: 920px) {
    .bubble-header .brand__logo { height: 44px; }
}
.brand__mark {
    display: inline-grid;
    place-items: center;
    width: 38px; height: 38px;
    border-radius: 12px;
    background: var(--g-cta);
    color: var(--champagne);
    box-shadow: 0 8px 20px rgba(23, 20, 18, 0.28);
    position: relative;
}
.brand__mark svg { width: 20px; height: 20px; }
.brand__mark::after {
    content: "";
    position: absolute;
    inset: 4px;
    border: 1px solid rgba(231, 200, 115, 0.32);
    border-radius: 8px;
    pointer-events: none;
}

.nav__links { display: none; align-items: center; gap: 32px; }
.nav__links a {
    color: var(--text-700);
    font-size: 14.5px;
    font-weight: 500;
    transition: color var(--t);
    position: relative;
}
.nav__links a:hover { color: var(--clay); }

.nav__cta { display: none; }

.nav__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    border-radius: 12px;
    border: 1px solid var(--line-strong);
    background: var(--porcelain);
    color: var(--ink);
    margin-left: auto;
    flex-shrink: 0;
}
.nav__toggle svg { width: 20px; height: 20px; }

@media (min-width: 960px) {
    .nav__links { display: flex; }
    .nav__cta { display: inline-flex; }
    .nav__toggle { display: none; margin-left: 0; }
}

.mobile-menu {
    position: fixed;
    left: 16px; right: 16px;
    top: 78px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    background: var(--porcelain);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-lg);
    padding: 12px;
    opacity: 0;
    transform: translateY(-12px) scale(0.98);
    pointer-events: none;
    transition: opacity var(--t), transform var(--t), top 320ms var(--ease);
    z-index: 49;
}
.bubble-header.header-scrolled .mobile-menu { top: 72px; }
.mobile-menu.is-open {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}
.mobile-menu__nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.mobile-menu__actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 10px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
}
.mobile-menu a:not(.btn) {
    display: flex;
    align-items: center;
    padding: 12px 14px;
    border-radius: 12px;
    font-weight: 500;
    font-size: 16px;
    line-height: 1.35;
    color: var(--ink);
}
.mobile-menu a:not(.btn):hover {
    background: var(--canvas);
    color: var(--clay);
}
.mobile-menu a.mobile-menu__muted {
    justify-content: center;
    padding: 10px 14px;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-500);
}
.mobile-menu a.mobile-menu__muted:hover {
    background: transparent;
    color: var(--clay);
}
.mobile-menu a.btn {
    width: 100%;
    min-height: 52px;
    justify-content: center;
    font-weight: 600;
    font-size: 15px;
}
.mobile-menu a.btn--primary {
    color: var(--porcelain);
    background: var(--g-cta);
}
.mobile-menu a.btn--primary:hover {
    color: var(--porcelain);
    transform: translateY(-1px);
}
.mobile-menu a.btn--gold {
    color: var(--ink);
}

/* ---------- Home hero ---------- */
.home-hero {
    position: relative;
    margin-top: 0;
    padding: calc(var(--site-header-offset, 16px) + var(--site-header-height, 60px) + 28px) 0 72px;
    background: var(--g-studio);
    overflow: hidden;
    isolation: isolate;
    min-height: 0;
}

.home-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(42, 33, 28, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(42, 33, 28, 0.03) 1px, transparent 1px);
    background-size: 88px 108px;
    mask-image: radial-gradient(ellipse at 50% 40%, black 20%, transparent 78%);
    -webkit-mask-image: radial-gradient(ellipse at 50% 40%, black 20%, transparent 78%);
    opacity: 0.45;
    pointer-events: none;
}

.home-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 14% 18%, rgba(231, 200, 115, 0.22) 0%, transparent 38%),
        radial-gradient(circle at 88% 12%, rgba(216, 106, 61, 0.12) 0%, transparent 34%),
        radial-gradient(circle at 78% 78%, rgba(168, 185, 163, 0.12) 0%, transparent 40%),
        radial-gradient(circle at 50% 100%, rgba(42, 33, 28, 0.04) 0%, transparent 55%);
    pointer-events: none;
}

.home-hero-shell {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: center;
    max-width: 1180px;
    margin: 0 auto;
}

@media (min-width: 1024px) {
    .home-hero-shell {
        grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
        gap: clamp(56px, 5vw, 72px);
    }
}

.home-hero-copy {
    text-align: center;
    max-width: 560px;
    margin: 0 auto;
}

@media (min-width: 1024px) {
    .home-hero-copy {
        text-align: left;
        margin: 0;
        max-width: 540px;
    }
}

.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px 6px 10px;
    border-radius: 999px;
    background: rgba(255, 252, 246, 0.88);
    border: 1px solid rgba(184, 121, 82, 0.14);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-600);
}

.hero-eyebrow__dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--terracotta);
    box-shadow: 0 0 0 4px rgba(216, 106, 61, 0.14);
}

.hero-title {
    margin: 16px 0 12px;
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(2.25rem, 4.8vw, 3.35rem);
    font-weight: 500;
    letter-spacing: -0.028em;
    line-height: 1.06;
    text-wrap: balance;
    color: var(--ink);
}

@media (min-width: 1024px) {
    .hero-title { max-width: 11em; }
}

.hero-title__accent {
    font-style: italic;
    color: var(--terracotta);
}

.hero-subtitle {
    margin: 0;
    font-size: clamp(1rem, 1.5vw, 1.08rem);
    line-height: 1.62;
    color: var(--text-600);
    max-width: 44ch;
}

@media (max-width: 1023px) {
    .hero-subtitle { margin: 0 auto; }
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin-top: 22px;
}

@media (min-width: 1024px) {
    .hero-actions { justify-content: flex-start; }
}

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

.hero-primary-cta,
.hero-secondary-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 48px;
    padding: 0 22px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 600;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.hero-primary-cta svg {
    width: 16px;
    height: 16px;
    transition: transform 0.2s ease;
}

.hero-primary-cta {
    color: #faf7f2;
    background: linear-gradient(135deg, #171412 0%, #2a211c 46%, #b87952 100%);
    box-shadow: 0 12px 28px rgba(23, 20, 18, 0.24);
}

.hero-primary-cta:hover {
    color: #faf7f2;
    transform: translateY(-2px);
    box-shadow: 0 16px 34px rgba(23, 20, 18, 0.28);
}

.hero-primary-cta:hover svg {
    transform: translateX(3px);
}

.hero-primary-cta:focus-visible,
.hero-secondary-cta:focus-visible {
    outline: 2px solid var(--clay);
    outline-offset: 3px;
}

.hero-secondary-cta {
    color: var(--charcoal);
    background: rgba(255, 252, 246, 0.92);
    border: 1px solid rgba(42, 33, 28, 0.14);
    box-shadow: 0 4px 14px rgba(42, 33, 28, 0.05);
}

.hero-secondary-cta:hover {
    color: var(--clay);
    border-color: rgba(184, 121, 82, 0.35);
    background: #fff;
    transform: translateY(-1px);
}

.hero-cta-microcopy {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 14px 0 0;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 250, 240, 0.92);
    border: 1px solid rgba(184, 121, 82, 0.22);
    color: var(--text-700, #2a211c);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.3;
    box-shadow: 0 2px 8px rgba(42, 33, 28, 0.04);
}

.hero-cta-microcopy__dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, #2e8b57 0%, #67b08a 100%);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
}

@media (max-width: 540px) {
    .hero-cta-microcopy {
        font-size: 12.5px;
        padding: 8px 12px;
        align-self: stretch;
        justify-content: center;
        text-align: center;
    }
}

.hero-proof-chips-wrap {
    margin-top: 20px;
}

.hero-proof-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin: 0;
    padding: 0;
    list-style: none;
    max-width: 520px;
}

@media (min-width: 1024px) {
    .hero-proof-chips {
        justify-content: flex-start;
    }
}

.hero-proof-chip,
.hero-proof-chips li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 36px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(250, 247, 242, 0.72);
    border: 1px solid rgba(184, 121, 82, 0.16);
    font-size: 12px;
    font-weight: 500;
    color: var(--text-700);
    white-space: nowrap;
}

.hero-proof-chips svg {
    width: 14px;
    height: 14px;
    color: var(--clay);
    flex-shrink: 0;
}

.hero-proof-note {
    margin: 12px 0 0;
    font-size: 12px;
    line-height: 1.5;
    color: var(--text-500);
    text-align: center;
    max-width: 520px;
}

@media (min-width: 1024px) {
    .hero-proof-note { text-align: left; }
}

.home-hero-visual {
    width: 100%;
    max-width: 540px;
    margin: 0 auto;
}

@media (min-width: 1024px) {
    .home-hero-visual {
        max-width: none;
        margin: 0;
        justify-self: end;
        width: min(100%, 560px);
    }
}

.hero-studio-board {
    position: relative;
    padding: 24px 24px 20px;
    border-radius: 32px;
    background:
        radial-gradient(circle at 75% 20%, rgba(231, 200, 115, 0.18), transparent 32%),
        rgba(250, 247, 242, 0.82);
    border: 1px solid rgba(184, 121, 82, 0.16);
    box-shadow: 0 32px 80px rgba(42, 33, 28, 0.14);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.hero-studio-board::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(42, 33, 28, 0.04) 1px, transparent 1px);
    background-size: 18px 18px;
    opacity: 0.35;
    pointer-events: none;
}

.hero-studio-board:hover {
    transform: translateY(-3px);
    box-shadow: 0 36px 88px rgba(42, 33, 28, 0.16);
}

.hero-studio-board__badge {
    position: relative;
    z-index: 1;
    display: inline-flex;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #2f4a35;
    background: rgba(221, 232, 213, 0.95);
    border: 1px solid rgba(63, 74, 53, 0.12);
}

.hero-studio-board__sticker {
    position: absolute;
    top: 20px;
    right: 20px;
    z-index: 2;
    padding: 6px 10px;
    border-radius: 8px;
    font-size: 11px;
    font-weight: 600;
    color: var(--ink);
    background: rgba(244, 184, 96, 0.32);
    border: 1px solid rgba(184, 121, 82, 0.2);
    transform: rotate(3deg);
}

.hero-studio-board__flow {
    position: relative;
    z-index: 1;
    margin: 10px 0 0;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--text-500);
}

.hero-studio-board__cards,
.hero-card-row {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 0.78fr 0.92fr 1.18fr;
    gap: 12px;
    align-items: end;
    min-height: 196px;
    margin: 18px 0 14px;
}

.hero-portrait-card {
    margin: 0;
    animation: homeHeroCardFloat 8s ease-in-out infinite;
}

.hero-portrait-card--input {
    animation-delay: 0s;
    z-index: 1;
    opacity: 0.92;
}

.hero-portrait-card--style {
    animation-delay: 0.8s;
    z-index: 2;
}

.hero-portrait-card--output {
    animation-delay: 1.4s;
    z-index: 3;
}

.hero-portrait-card figcaption {
    display: block;
    margin-bottom: 6px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-500);
}

.hero-portrait-card__frame {
    position: relative;
    aspect-ratio: 3 / 4;
    border-radius: 16px;
    overflow: hidden;
    background: #f3ebe0;
    border: 1px solid rgba(42, 33, 28, 0.1);
    box-shadow: 0 12px 28px rgba(42, 33, 28, 0.1);
}

.hero-portrait-card--output .hero-portrait-card__frame {
    box-shadow:
        0 20px 40px rgba(42, 33, 28, 0.16),
        0 0 0 1px rgba(231, 200, 115, 0.22);
}

.hero-portrait-card__frame--arch {
    border-radius: 50% 50% 18px 18px / 20% 20% 12px 12px;
}

.hero-portrait-card__frame--plain {
    background: linear-gradient(180deg, #f3ebe0 0%, #e8dcc8 100%);
}

.hero-portrait-card__frame--style {
    background: linear-gradient(168deg, #faf6f0 0%, #f2e6d6 50%, #f7d6ce 100%);
}

.hero-portrait-card__demo.protected-demo-wrap {
    position: absolute;
    inset: 0;
    z-index: 2;
    border-radius: inherit;
}

.hero-portrait-card__demo .protected-demo-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-portrait-card__demo .protected-demo-wrap__label {
    display: none;
}

.hero-photo-placeholder {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
}

.hero-photo-placeholder--input {
    background:
        radial-gradient(circle at 50% 34%, rgba(255, 252, 246, 0.95) 0 16%, transparent 17%),
        linear-gradient(180deg, #e8dcc8 0%, #d4c4ae 100%);
}

.hero-photo-placeholder--style {
    background:
        radial-gradient(circle at 50% 36%, rgba(247, 214, 206, 0.55) 0 22%, transparent 23%),
        linear-gradient(168deg, #faf6f0 0%, #f2e6d6 50%, #f7d6ce 100%);
}

.hero-photo-placeholder--portrait {
    background:
        radial-gradient(circle at 50% 30%, #f7d6ce 0 14%, transparent 15%),
        radial-gradient(ellipse at 50% 38%, rgba(250, 247, 242, 0.92) 0 18%, transparent 19%),
        linear-gradient(165deg, #4a3428 0%, #2a211c 52%, #3f2a1c 100%);
}

.hero-photo-placeholder--portrait::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 18%;
    width: 56%;
    height: 28%;
    transform: translateX(-50%);
    border-radius: 50% 50% 42% 42%;
    background: rgba(250, 247, 242, 0.88);
    opacity: 0.85;
}

.hero-portrait-card__frame.has-fallback .hero-portrait-card__demo {
    display: none;
}

.hero-portrait-card__seal {
    position: absolute;
    left: 50%;
    bottom: 10px;
    z-index: 3;
    transform: translateX(-50%);
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink);
    background: rgba(231, 200, 115, 0.88);
    border: 1px solid rgba(184, 121, 82, 0.24);
    box-shadow: 0 4px 12px rgba(42, 33, 28, 0.12);
}

.hero-portrait-card__hint {
    display: block;
    margin-top: 6px;
    font-size: 10px;
    color: var(--text-500);
    font-style: italic;
}

.hero-flow-stepper {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    gap: 8px;
    margin: 0 0 12px;
    padding: 10px 12px;
    list-style: none;
    border-radius: 12px;
    background: rgba(255, 252, 246, 0.82);
    border: 1px solid rgba(42, 33, 28, 0.08);
}

.hero-flow-stepper li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-700);
}

.hero-flow-stepper li span {
    width: 20px;
    height: 20px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    font-size: 10px;
    color: var(--ink);
    background: rgba(184, 121, 82, 0.14);
}

.hero-style-strip,
.hero-world-strip {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(42, 33, 28, 0.08);
}

.hero-style-strip__label {
    flex-shrink: 0;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-500);
}

.hero-style-strip__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    min-width: 0;
}

.hero-style-strip__chips span {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-600);
    background: rgba(255, 252, 246, 0.9);
    border: 1px solid rgba(42, 33, 28, 0.08);
}

.hero-style-strip__chips span.is-active {
    color: #2f4a35;
    background: rgba(221, 232, 213, 0.9);
    border-color: rgba(63, 74, 53, 0.14);
    animation: homeHeroChipPulse 3s ease-in-out infinite;
}

.home-hero-sticky {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 900;
    padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
    background: rgba(250, 247, 242, 0.96);
    border-top: 1px solid rgba(184, 121, 82, 0.14);
    box-shadow: 0 -10px 30px rgba(42, 33, 28, 0.08);
    transform: translateY(110%);
    transition: transform 0.28s ease;
}

.home-hero-sticky.is-visible {
    transform: translateY(0);
}

.home-hero-sticky__inner {
    max-width: 520px;
    margin: 0 auto;
}

.hero-primary-cta--sticky {
    width: 100%;
    min-height: 48px;
}

@media (max-width: 767px) {
    .landing-body.has-home-hero-sticky #main {
        padding-bottom: calc(72px + env(safe-area-inset-bottom, 0));
    }
    .landing-body.has-home-hero-sticky .site-footer {
        padding-bottom: calc(28px + 72px + env(safe-area-inset-bottom, 0));
    }
}

@media (max-width: 767px) {
    .home-hero {
        padding-top: calc(var(--site-header-offset, 16px) + var(--site-header-height, 60px) + 20px);
        padding-bottom: 44px;
    }

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

    .hero-studio-board {
        padding: 18px 16px 16px;
        border-radius: 24px;
    }

    .hero-studio-board__flow,
    .hero-portrait-card__hint,
    .hero-style-strip__chip--hide-mobile {
        display: none;
    }

    .hero-studio-board__cards,
    .hero-card-row {
        grid-template-columns: 0.72fr 0.82fr 1fr;
        min-height: 148px;
        gap: 8px;
    }

    .hero-portrait-card--input figcaption {
        font-size: 9px;
    }

    .hero-flow-stepper li:nth-child(2) {
        display: none;
    }

    .hero-proof-chips {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        max-width: none;
    }

    .hero-proof-chip,
    .hero-proof-chips li {
        font-size: 11px;
        white-space: normal;
        padding: 8px 10px;
    }
}

@media (min-width: 768px) {
    .home-hero-sticky { display: none !important; }
}

@media (prefers-reduced-motion: reduce) {
    .hero-portrait-card,
    .hero-style-strip__chips span.is-active,
    .hero-studio-board,
    .hero-primary-cta svg {
        animation: none !important;
        transition: none !important;
    }
}

/* Paper labels (shared) */
.paper-label {
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    letter-spacing: 0.04em;
}
.paper-label--light { color: rgba(255, 252, 246, 0.88); }

/* ---------- SECTION 2 Ã¢â‚¬â€ Gallery Wall ---------- */
.gallery {
    position: relative;
}
.gallery__rail {
    position: absolute;
    top: 24px;
    left: 5%; right: 5%;
    height: 80px;
    pointer-events: none;
    z-index: 0;
}
.gallery__rail svg { width: 100%; height: 100%; }

.gallery__wall {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
    position: relative;
    z-index: 1;
}
@media (min-width: 720px)  { .gallery__wall { grid-template-columns: repeat(4, 1fr); gap: 22px; } }

.gframe {
    position: relative;
    display: block;
    background: var(--paper);
    border: 1px solid var(--line);
    box-shadow: var(--sh-sm);
    padding: 14px 14px 16px;
    transition: transform var(--t), box-shadow var(--t);
    color: inherit;
}
.portrait-frame { box-shadow: var(--sh-frame); }
.gframe:hover { transform: translateY(-6px) rotate(-0.5deg); box-shadow: var(--sh-warm); }

/* Frame variants */
.gframe--arch    { border-radius: 50% 50% 18px 18px / 30% 30% 8px 8px; }
.gframe--oval    { border-radius: 50%; padding: 18px; aspect-ratio: 1 / 1.1; }
.gframe--rect    { border-radius: 18px; }
.gframe--portrait { border-radius: 22px 22px 18px 18px; }

.gframe__wire {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    height: 14px;
    background: linear-gradient(180deg, var(--clay), rgba(184, 121, 82, 0.2));
}
.gframe__wire::before {
    content: "";
    position: absolute;
    top: -5px;
    left: 50%;
    transform: translateX(-50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--clay);
    box-shadow: 0 2px 4px rgba(42, 33, 28, 0.2);
}
.gframe--featured {
    transform: scale(1.04) rotate(0deg);
    z-index: 2;
    border-color: var(--line-warm);
    box-shadow: var(--sh-warm);
}
@media (min-width: 720px) {
    .gframe--featured { grid-column: span 1; transform: scale(1.08) rotate(0deg); }
}
.gframe--featured:hover { transform: translateY(-8px) scale(1.06) rotate(0deg); }
.gframe--featured .gframe__wire { height: 18px; top: -18px; }

/* Tilted hanging */
.gframe:nth-child(2n) { transform: rotate(0.8deg); }
.gframe:nth-child(3n) { transform: rotate(-0.6deg); }
.gframe:hover { transform: translateY(-6px) rotate(0deg); }

.gframe__media {
    width: 100%;
    aspect-ratio: 4 / 5;
    border-radius: inherit;
    background: var(--oat);
    display: grid;
    place-items: center;
    color: var(--clay);
    overflow: hidden;
    position: relative;
}
.gframe--arch .gframe__media { border-radius: 50% 50% 8px 8px / 30% 30% 6px 6px; aspect-ratio: 4 / 5; }
.gframe--oval .gframe__media  { border-radius: 50%; aspect-ratio: 1 / 1; }
.gframe--portrait .gframe__media { aspect-ratio: 3 / 4; border-radius: 16px; }

/* Tinted media gradients per category */
.gframe[data-cat="baby"]     .gframe__media { background: linear-gradient(140deg, var(--rose-soft) 0%, var(--rose) 100%); color: var(--ink); }
.gframe[data-cat="headshot"] .gframe__media { background: linear-gradient(140deg, var(--ink-soft) 0%, var(--olive) 100%); color: var(--champagne); }
.gframe[data-cat="classic"]  .gframe__media { background: linear-gradient(140deg, var(--canvas) 0%, var(--champagne) 100%); }
.gframe[data-cat="family"]   .gframe__media { background: linear-gradient(140deg, var(--sage-soft) 0%, var(--sage) 100%); color: var(--olive); }
.gframe[data-cat="kids"]     .gframe__media { background: linear-gradient(140deg, var(--film-amber) 0%, var(--terracotta) 100%); }
.gframe[data-cat="pet"]      .gframe__media { background: linear-gradient(140deg, var(--oat) 0%, var(--clay) 100%); }
.gframe[data-cat="couple"]   .gframe__media { background: linear-gradient(140deg, var(--rose) 0%, var(--terracotta) 100%); }
.gframe[data-cat="festive"]  .gframe__media { background: linear-gradient(140deg, var(--champagne) 0%, var(--terracotta) 100%); color: var(--ink); }

.gframe__media svg { width: 36%; height: 36%; opacity: 0.85; }

.gframe__body {
    padding: 14px 6px 0;
    text-align: center;
}
.gframe__title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 16px;
    font-weight: 600;
    color: var(--ink);
    margin-bottom: 4px;
    letter-spacing: -0.01em;
}
.gframe__sub {
    font-size: 12.5px;
    color: var(--text-500);
    line-height: 1.5;
    margin: 0;
}
.gframe__status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 10px;
    padding: 3px 10px;
    border-radius: var(--r-pill);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.gframe__status--available {
    background: var(--sage-soft);
    color: var(--olive);
    border: 1px solid rgba(63, 74, 53, 0.18);
}
.gframe__status--available::before {
    content: "";
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--olive);
}
.gframe__status--soon {
    background: rgba(133, 121, 107, 0.12);
    color: var(--text-500);
    border: 1px solid rgba(133, 121, 107, 0.18);
}

/* ---------- SECTION 3 Ã¢â‚¬â€ Studio Process Table ---------- */
.process {
    position: relative;
}
.process__rail {
    display: none;
    position: absolute;
    top: 88px;
    left: 12%; right: 12%;
    height: 2px;
    background-image: linear-gradient(90deg, var(--champagne) 50%, transparent 50%);
    background-size: 14px 2px;
    z-index: 0;
}
@media (min-width: 768px) { .process__rail { display: block; } }

.process__steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 22px;
    position: relative;
    z-index: 1;
}
@media (min-width: 768px) { .process__steps { grid-template-columns: repeat(3, 1fr); gap: 32px; } }

.studio-ticket {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 32px 26px 28px;
    text-align: center;
    box-shadow: var(--sh-sm);
    position: relative;
    transition: transform var(--t), box-shadow var(--t);
}
.studio-ticket:hover { transform: translateY(-4px); box-shadow: var(--sh); }

/* Perforated edges */
.studio-ticket::before,
.studio-ticket::after {
    content: "";
    position: absolute;
    width: 18px; height: 18px;
    border-radius: 50%;
    background: var(--canvas);
    border: 1px solid var(--line);
    top: 50%;
    transform: translateY(-50%);
}
.studio-ticket::before { left: -10px; }
.studio-ticket::after  { right: -10px; }
@media (max-width: 767px) {
    .process-desk { position: relative; padding-left: 28px; }
    .process-desk::before {
        content: "";
        position: absolute;
        left: 10px;
        top: 24px;
        bottom: 24px;
        width: 2px;
        background-image: linear-gradient(180deg, var(--champagne) 50%, transparent 50%);
        background-size: 2px 12px;
    }
    .studio-ticket::before,
    .studio-ticket::after { display: none; }
}

.studio-ticket__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--g-cta);
    color: var(--champagne);
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 17px;
    font-weight: 500;
    margin-bottom: 18px;
    box-shadow: 0 8px 20px rgba(23, 20, 18, 0.28);
    position: relative;
}
.studio-ticket__num::after {
    content: "";
    position: absolute;
    inset: 3px;
    border: 1px dashed rgba(231, 200, 115, 0.5);
    border-radius: 50%;
    pointer-events: none;
}
.studio-ticket__icon {
    width: 64px; height: 64px;
    margin: 0 auto 18px;
    border-radius: 18px;
    background: var(--canvas);
    display: grid; place-items: center;
    color: var(--clay);
}
.studio-ticket__icon svg { width: 28px; height: 28px; }
.studio-ticket h3 { font-size: 19px; margin-bottom: 10px; font-weight: 600; }
.studio-ticket p { font-size: 14.5px; }

.process__note {
    text-align: center;
    margin-top: 48px;
    font-size: 14.5px;
    color: var(--text-500);
}
.process__note strong { color: var(--ink); font-weight: 600; }
.process__note span { white-space: nowrap; }
.process__note .dot {
    display: inline-block;
    width: 4px; height: 4px;
    border-radius: 50%;
    background: var(--clay);
    margin: 0 14px;
    vertical-align: middle;
}

/* Studio production desk surface */
.production-desk {
    position: relative;
    background: var(--g-paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-xl);
    padding: 28px 20px 36px;
    box-shadow: var(--sh-sm);
    overflow: hidden;
}
.production-desk::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(rgba(42, 33, 28, 0.035) 1px, transparent 1px);
    background-size: 20px 20px;
    opacity: 0.5;
    pointer-events: none;
}
.production-desk > * { position: relative; z-index: 1; }
@media (min-width: 768px) {
    .production-desk { padding: 44px 36px 48px; }
}

/* ---------- SECTION 4 Ã¢â‚¬â€ Before / After Reveal ---------- */
.reveal-frames {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--r-xl);
    padding: 28px;
    box-shadow: var(--sh);
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    position: relative;
    overflow: hidden;
}
@media (min-width: 768px) { .reveal-frames { grid-template-columns: 1fr auto 1fr; padding: 44px; gap: 36px; align-items: center; } }

.gallery-reveal {
    border-color: var(--line-warm);
    background:
        linear-gradient(145deg, rgba(255, 252, 246, 0.95), rgba(243, 231, 211, 0.72));
}
.gallery-reveal::after {
    content: "";
    position: absolute;
    inset: 14px;
    border: 1px dashed rgba(184, 121, 82, 0.22);
    border-radius: calc(var(--r-xl) - 10px);
    pointer-events: none;
    z-index: 0;
}

.reveal-frames::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 50%, rgba(231, 200, 115, 0.12) 0%, transparent 60%);
    pointer-events: none;
}

.reveal-cell {
    position: relative;
    border-radius: var(--r-lg);
    aspect-ratio: 4 / 5;
    background: var(--oat);
    overflow: hidden;
    box-shadow: var(--sh-frame);
    margin: 0;
}
.reveal-cell__photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}
.reveal-cell--before {
    background: var(--oat);
    border: 10px solid var(--porcelain);
    box-shadow: inset 0 0 0 1px var(--line), var(--sh-sm);
}
.reveal-cell--before .reveal-cell__photo {
    inset: 0;
    border-radius: calc(var(--r-lg) - 10px);
}
.reveal-cell--before::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg,
        transparent 0%,
        rgba(231, 200, 115, 0) 42%,
        rgba(231, 200, 115, 0.45) 50%,
        rgba(231, 200, 115, 0) 58%,
        transparent 100%);
    animation: sweep 4.5s linear infinite;
    pointer-events: none;
}
.reveal-cell--after {
    background: var(--porcelain);
    border: 1px solid var(--line-warm);
    padding: 12px;
    box-sizing: border-box;
}
.reveal-cell--after .reveal-cell__photo {
    inset: 12px;
    width: auto;
    height: auto;
    border-radius: calc(var(--r-lg) - 8px);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}
.reveal-cell--after > svg,
.reveal-cell--after .reveal-cell__inner {
    width: 100%;
    height: 100%;
    border-radius: calc(var(--r-lg) - 8px);
    overflow: hidden;
}
.reveal-cell--after .reveal-cell__inner {
    background:
        radial-gradient(ellipse at 50% 30%, rgba(247, 214, 206, 0.85) 0%, transparent 60%),
        linear-gradient(165deg, var(--champagne) 0%, var(--terracotta) 50%, var(--ink-soft) 100%);
    position: relative;
    aspect-ratio: 4 / 5;
}

.reveal-cell__sticker {
    position: absolute;
    top: 16px; left: 16px;
    background: var(--porcelain);
    color: var(--ink);
    padding: 6px 14px;
    border-radius: 4px;
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 13px;
    box-shadow: 0 4px 10px rgba(42, 33, 28, 0.18);
    transform: rotate(-3deg);
    z-index: 2;
}
.reveal-cell--after .reveal-cell__sticker { color: var(--clay); }

/* Golden vertical light sweep divider */
.reveal-divider {
    display: grid;
    place-items: center;
    width: 100%; min-height: 80px;
    position: relative;
}
@media (min-width: 768px) { .reveal-divider { width: 100px; min-height: auto; } }

.reveal-divider__beam {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 0%, var(--champagne) 50%, transparent 100%);
    opacity: 0.4;
    filter: blur(2px);
    animation: beamPulse 3.5s ease-in-out infinite;
}
@media (max-width: 767px) {
    .reveal-divider__beam {
        background: linear-gradient(90deg, transparent 0%, var(--champagne) 50%, transparent 100%);
    }
}

.reveal-divider__node {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--g-gold);
    color: var(--ink);
    display: grid; place-items: center;
    box-shadow: 0 14px 32px rgba(216, 106, 61, 0.32);
    position: relative;
    z-index: 1;
}
.reveal-divider__node svg { width: 22px; height: 22px; }
@media (max-width: 767px) { .reveal-divider__node svg { transform: rotate(90deg); } }

.reveal-foot {
    margin-top: 36px;
    text-align: center;
    color: var(--text-600);
    font-size: 16px;
}
.reveal-foot .italic-accent { font-size: 18px; }

/* ---------- SECTION 5 Ã¢â‚¬â€ Why SnapsJo (Editorial Bento) ---------- */
.bento {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
}
@media (min-width: 768px) {
    .bento {
        grid-template-columns: repeat(6, 1fr);
        gap: 22px;
    }
}

.b-tile {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 26px;
    box-shadow: var(--sh-sm);
    transition: transform var(--t), box-shadow var(--t);
    position: relative;
    overflow: hidden;
}
.b-tile:hover { transform: translateY(-4px); box-shadow: var(--sh); }
.b-tile h3 { font-size: 18px; margin-bottom: 8px; font-weight: 600; }
.b-tile p { font-size: 14.5px; color: var(--text-600); }

.b-icon {
    width: 42px; height: 42px;
    border-radius: 12px;
    background: var(--canvas);
    display: grid; place-items: center;
    color: var(--clay);
    margin-bottom: 18px;
}
.b-icon svg { width: 20px; height: 20px; }

/* Bento positions (desktop) */
@media (min-width: 768px) {
    .b-1 { grid-column: span 3; grid-row: span 2; padding: 36px; background: var(--g-paper); border-color: var(--line-warm); }
    .b-2 { grid-column: span 3; }
    .b-3 { grid-column: span 3; background: var(--ink); color: var(--porcelain); border-color: rgba(231, 200, 115, 0.18); }
    .b-3 h3, .b-3 p { color: var(--porcelain); }
    .b-3 p { color: rgba(250, 247, 242, 0.7); }
    .b-3 .b-icon { background: rgba(231, 200, 115, 0.16); color: var(--champagne); }
    .b-4 { grid-column: span 2; }
    .b-5 { grid-column: span 2; background: var(--canvas); border-color: var(--line-warm); }
    .b-6 { grid-column: span 2; }
}
.b-1 h3 { font-family: 'Fraunces', Georgia, serif; font-size: clamp(22px, 2.6vw, 30px); margin-bottom: 14px; max-width: 22ch; line-height: 1.15; }
.b-1 p { font-size: 16px; max-width: 46ch; }
.b-1::after {
    content: "";
    position: absolute;
    width: 240px; height: 240px;
    bottom: -100px; right: -100px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(216, 106, 61, 0.16) 0%, transparent 70%);
    pointer-events: none;
}

/* Editorial bento Ã¢â‚¬â€ asymmetric overlaps */
.editorial-bento { position: relative; }
@media (min-width: 768px) {
    .editorial-bento .b-2 { margin-top: 24px; z-index: 2; }
    .editorial-bento .b-4 { margin-top: -12px; }
    .editorial-bento .b-5 { margin-top: 18px; z-index: 3; box-shadow: var(--sh); }
    .editorial-bento .b-6 { margin-top: -6px; }
}
.bento__note {
    position: absolute;
    top: 12px;
    right: 14px;
    padding: 4px 10px;
    background: rgba(255, 252, 246, 0.92);
    border: 1px solid var(--line-warm);
    border-radius: 4px;
    font-size: 11px;
    color: var(--clay);
    box-shadow: var(--sh-xs);
    transform: rotate(3deg);
    z-index: 2;
}
.bento__note::before {
    content: "";
    position: absolute;
    top: -4px;
    left: 10px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--terracotta);
}

/* ---------- Style Selector Studio ---------- */
.style-studio-section {
    background:
        radial-gradient(circle at 14% 12%, rgba(231, 200, 115, 0.14) 0%, transparent 36%),
        radial-gradient(circle at 88% 88%, rgba(216, 106, 61, 0.08) 0%, transparent 34%),
        linear-gradient(180deg, var(--canvas) 0%, var(--porcelain) 52%, var(--canvas) 100%);
    background-color: var(--canvas);
}

.style-studio-shell {
    display: grid;
    gap: 32px;
    grid-template-columns: 1fr;
    grid-template-areas:
        "copy"
        "desk"
        "groups"
        "cta";
}
@media (min-width: 1024px) {
    .style-studio-shell {
        grid-template-columns: minmax(320px, 0.92fr) minmax(400px, 1.08fr);
        gap: 40px 56px;
        align-items: start;
        grid-template-areas:
            "copy  desk"
            "cta   desk";
    }
}

.style-studio-copy {
    grid-area: copy;
}

.style-studio-head {
    text-align: center;
    max-width: 640px;
    margin: 0 auto;
}
@media (min-width: 1024px) {
    .style-studio-head { text-align: left; margin: 0; max-width: none; }
}
.style-studio-head h2 {
    font-size: clamp(28px, 4vw, 44px);
    margin: 16px 0 14px;
    line-height: 1.08;
}
.style-studio-intro {
    font-size: clamp(16px, 1.6vw, 18px);
    line-height: 1.65;
    color: var(--text-600);
    max-width: 52ch;
    margin: 0 auto;
}
@media (min-width: 1024px) { .style-studio-intro { margin: 0; } }
.style-studio-micro {
    margin: 14px auto 0;
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--text-500);
    max-width: 48ch;
}
@media (min-width: 1024px) { .style-studio-micro { margin: 14px 0 0; } }

.style-studio-cta {
    grid-area: cta;
    text-align: center;
}
@media (min-width: 1024px) { .style-studio-cta { text-align: left; } }

.style-studio-cta__btn {
    min-height: 52px;
    width: 100%;
    max-width: 340px;
}
@media (min-width: 1024px) { .style-studio-cta__btn { width: auto; min-width: 280px; } }
.style-studio-cta__btn svg { transition: transform var(--t); }
.style-studio-cta__btn:hover svg { transform: translateX(3px); }
.style-studio-cta__note {
    margin: 12px 0 0;
    font-size: 13.5px;
    color: var(--text-500);
}

/* Portrait Style Desk mockup */
.style-desk {
    grid-area: desk;
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
    border-radius: 30px;
    background:
        radial-gradient(circle at 18% 0%, rgba(231, 200, 115, 0.16), transparent 40%),
        linear-gradient(165deg, rgba(255, 252, 246, 0.96) 0%, rgba(243, 231, 211, 0.9) 100%);
    border: 1px solid rgba(42, 33, 28, 0.1);
    box-shadow:
        0 28px 64px rgba(42, 33, 28, 0.11),
        inset 0 1px 0 rgba(255, 252, 246, 0.88);
    overflow: hidden;
}
@media (min-width: 1024px) {
    .style-desk { max-width: none; margin: 0; position: sticky; top: 108px; }
}

.style-desk-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 22px;
    border-bottom: 1px solid rgba(42, 33, 28, 0.08);
    background: rgba(255, 252, 246, 0.75);
}
.style-desk-header__title {
        margin: 0;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 18px;
    font-weight: 600;
    color: var(--ink);
}
.style-desk-header__label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-500);
    white-space: nowrap;
}

.style-desk__body {
    padding: 20px 22px 22px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.style-selected-card {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 16px;
    border-radius: 20px;
    background: rgba(255, 252, 246, 0.88);
    border: 1px solid rgba(184, 121, 82, 0.22);
    box-shadow:
        0 12px 28px rgba(42, 33, 28, 0.07),
        0 0 0 1px rgba(231, 200, 115, 0.18);
    transition: box-shadow var(--t), border-color var(--t);
}
.style-selected-card.is-glow {
    box-shadow:
        0 16px 36px rgba(42, 33, 28, 0.09),
        0 0 0 2px rgba(231, 200, 115, 0.35);
}

.style-selected-card__frame {
    flex-shrink: 0;
    width: 88px;
    aspect-ratio: 4 / 5;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(42, 33, 28, 0.08);
    box-shadow: 0 8px 20px rgba(42, 33, 28, 0.1);
}
.style-selected-card__frame svg { width: 100%; height: 100%; display: block; }

.style-selected-card__copy { min-width: 0; }
.style-selected-card__name {
    margin: 0 0 6px;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 20px;
    font-weight: 600;
    color: var(--ink);
    line-height: 1.15;
}
.style-selected-card__desc {
    margin: 0 0 10px;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-600);
}
.style-selected-card__ready {
    display: inline-flex;
    margin-top: 8px;
    padding: 5px 11px;
    border-radius: var(--r-pill);
    background: linear-gradient(135deg, var(--gold), var(--amber));
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--ink);
}

.style-status-active,
.style-status-soon {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: var(--r-pill);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    white-space: nowrap;
}
.style-status-active {
    background: rgba(168, 185, 163, 0.28);
    border: 1px solid rgba(63, 74, 53, 0.14);
    color: var(--olive);
}
.style-status-soon {
    background: rgba(255, 252, 246, 0.9);
    border: 1px solid rgba(42, 33, 28, 0.1);
    color: var(--text-500);
}

.style-mood-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.style-mood-chip {
    padding: 6px 12px;
    border-radius: var(--r-pill);
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-600);
    background: rgba(255, 252, 246, 0.88);
    border: 1px solid rgba(42, 33, 28, 0.08);
    transition: background var(--t), border-color var(--t), color var(--t);
}
.style-mood-chip.is-active {
    background: linear-gradient(135deg, rgba(231, 200, 115, 0.45), rgba(244, 184, 96, 0.35));
    border-color: rgba(184, 121, 82, 0.28);
    color: var(--ink);
}

.style-preview-rail {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
}
.style-preview-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: center;
    transition: transform var(--t);
}
.style-preview-card:hover { transform: translateY(-2px); }
.style-preview-card.is-active .style-preview-card__frame {
    box-shadow: 0 0 0 2px rgba(255, 252, 246, 0.95), 0 0 0 3.5px var(--gold);
}
.style-preview-card__frame {
    width: 100%;
    aspect-ratio: 3 / 4;
    border-radius: 10px;
    border: 1px solid rgba(42, 33, 28, 0.08);
    box-shadow: 0 6px 14px rgba(42, 33, 28, 0.08);
    background: linear-gradient(145deg, var(--blush), var(--rose));
}
.style-preview-card__frame::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    background-image: radial-gradient(rgba(255, 252, 246, 0.2) 1px, transparent 1px);
    background-size: 10px 10px;
}
.style-preview-card[data-tone="blush"] .style-preview-card__frame { background: linear-gradient(145deg, var(--blush), var(--rose)); }
.style-preview-card[data-tone="clay"] .style-preview-card__frame { background: linear-gradient(145deg, var(--oat), var(--clay)); }
.style-preview-card[data-tone="canvas"] .style-preview-card__frame { background: linear-gradient(145deg, var(--canvas), var(--gold)); }
.style-preview-card[data-tone="gold"] .style-preview-card__frame { background: linear-gradient(145deg, var(--gold), var(--terracotta)); }
.style-preview-card[data-tone="mint"] .style-preview-card__frame { background: linear-gradient(145deg, var(--mint), var(--sage)); }
.style-preview-card[data-tone="oat"] .style-preview-card__frame { background: linear-gradient(145deg, var(--porcelain), var(--oat)); }
.style-preview-card[data-tone="olive"] .style-preview-card__frame { background: linear-gradient(145deg, var(--sage), var(--olive)); }
.style-preview-card[data-tone="charcoal"] .style-preview-card__frame { background: linear-gradient(145deg, var(--charcoal), var(--ink)); }
.style-preview-card[data-tone="rose"] .style-preview-card__frame { background: linear-gradient(145deg, var(--rose-soft), var(--rose)); }
.style-preview-card[data-tone="terracotta"] .style-preview-card__frame { background: linear-gradient(145deg, var(--terracotta), var(--amber)); }
.style-preview-card__label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-500);
    text-align: center;
}

.style-group-list {
    display: none;
    flex-direction: column;
    gap: 8px;
    margin-top: 4px;
}
@media (min-width: 1024px) { .style-group-list { display: flex; } }

.style-group-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 100%;
    text-align: left;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 252, 246, 0.72);
    border: 1px solid rgba(42, 33, 28, 0.08);
    cursor: pointer;
    transition: background var(--t), border-color var(--t), transform var(--t), box-shadow var(--t);
}
.style-group-item:hover {
    transform: translateY(-1px);
    border-color: rgba(184, 121, 82, 0.22);
    box-shadow: 0 8px 20px rgba(42, 33, 28, 0.06);
}
.style-group-item.is-active {
    background: rgba(255, 252, 246, 0.96);
    border-color: rgba(184, 121, 82, 0.28);
    box-shadow: inset 0 0 0 1px rgba(231, 200, 115, 0.22);
}
.style-group-item.is-muted { opacity: 0.82; }
.style-group-item.is-muted.is-active { opacity: 1; }
.style-group-item:focus-visible {
    outline: 2px solid var(--clay);
    outline-offset: 2px;
}
.style-group-item__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.style-group-item__head strong {
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
}
.style-group-item__copy {
    font-size: 13px;
    line-height: 1.5;
    color: var(--text-600);
}

/* Mobile style group cards */
.style-studio-groups {
    grid-area: groups;
    display: grid;
    gap: 12px;
}
@media (min-width: 1024px) { .style-studio-groups { display: none; } }

.style-studio-group-card {
    padding: 18px 20px;
    border-radius: 18px;
    background: rgba(255, 252, 246, 0.88);
    border: 1px solid rgba(42, 33, 28, 0.08);
    box-shadow: 0 8px 22px rgba(42, 33, 28, 0.05);
    cursor: pointer;
    transition: transform var(--t), border-color var(--t), box-shadow var(--t);
    min-height: 44px;
}
.style-studio-group-card:hover,
.style-studio-group-card.is-active {
    border-color: rgba(184, 121, 82, 0.24);
    box-shadow: 0 12px 28px rgba(42, 33, 28, 0.08);
}
.style-studio-group-card.is-active {
    box-shadow: inset 0 0 0 1px rgba(231, 200, 115, 0.25), 0 12px 28px rgba(42, 33, 28, 0.08);
}
.style-studio-group-card.is-muted { opacity: 0.85; }
.style-studio-group-card.is-muted.is-active { opacity: 1; }
.style-studio-group-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
}
.style-studio-group-card__head h3 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
}
.style-studio-group-card > p {
    margin: 0 0 12px;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-600);
}
.style-studio-group-card__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.style-studio-group-card__chips span {
    padding: 5px 10px;
    border-radius: var(--r-pill);
    font-size: 12px;
    font-weight: 600;
    color: var(--text-600);
    background: rgba(255, 252, 246, 0.95);
    border: 1px solid rgba(42, 33, 28, 0.08);
}

@media (max-width: 767px) {
    .style-selected-card { flex-direction: column; align-items: stretch; }
    .style-selected-card__frame { width: 100%; max-width: 140px; margin: 0 auto; }
    .style-preview-rail { grid-template-columns: repeat(2, 1fr); }
    .style-preview-card:nth-child(n+3) { display: none; }
}

/* ---------- SaaS Product Value (Portrait Studio Workspace) ---------- */
.saas-value-section {
    background:
        radial-gradient(circle at 12% 18%, rgba(221, 232, 213, 0.45) 0%, transparent 38%),
        radial-gradient(circle at 88% 82%, rgba(231, 200, 115, 0.14) 0%, transparent 36%),
        linear-gradient(180deg, var(--porcelain) 0%, var(--mint) 48%, var(--porcelain) 100%);
    background-color: var(--porcelain);
}

.saas-value-shell {
    display: grid;
    gap: 32px;
    grid-template-columns: 1fr;
    grid-template-areas:
        "head"
        "workspace"
        "features"
        "cta";
}
@media (min-width: 1024px) {
    .saas-value-shell {
        grid-template-columns: minmax(340px, 1fr) minmax(380px, 1.05fr);
        gap: 40px 56px;
        align-items: start;
        grid-template-areas:
            "head      workspace"
            "features  workspace"
            "cta       workspace";
    }
}

.saas-value-head {
    grid-area: head;
    text-align: center;
    max-width: 640px;
    margin: 0 auto;
}
@media (min-width: 1024px) {
    .saas-value-head { text-align: left; margin: 0; max-width: none; }
}
.saas-value-head h2 {
    font-size: clamp(28px, 4vw, 44px);
    margin: 16px 0 14px;
    line-height: 1.08;
}
.saas-value-intro {
    font-size: clamp(16px, 1.6vw, 18px);
    line-height: 1.65;
    color: var(--text-600);
    max-width: 52ch;
    margin: 0 auto;
}
@media (min-width: 1024px) { .saas-value-intro { margin: 0; } }

/* Workspace mockup */
.saas-workspace {
    grid-area: workspace;
    width: 100%;
    max-width: 520px;
    margin: 0 auto;
}
@media (min-width: 1024px) {
    .saas-workspace { max-width: none; margin: 0; position: sticky; top: 108px; }
}

.saas-workspace__panel {
    border-radius: 28px;
    background:
        radial-gradient(circle at 20% 0%, rgba(231, 200, 115, 0.16), transparent 42%),
        linear-gradient(165deg, rgba(255, 252, 246, 0.96) 0%, rgba(243, 231, 211, 0.88) 100%);
    border: 1px solid rgba(42, 33, 28, 0.1);
    box-shadow:
        0 28px 64px rgba(42, 33, 28, 0.1),
        inset 0 1px 0 rgba(255, 252, 246, 0.85);
    overflow: hidden;
    transition: transform var(--t), box-shadow var(--t);
}
.saas-workspace__panel:hover {
    transform: translateY(-3px);
    box-shadow: 0 32px 72px rgba(42, 33, 28, 0.12);
}

.saas-workspace-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 20px;
    border-bottom: 1px solid rgba(42, 33, 28, 0.08);
    background: rgba(255, 252, 246, 0.72);
}
.saas-workspace-header__title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 18px;
    font-weight: 600;
    color: var(--ink);
    margin: 0;
}
.saas-workspace-header__badge {
    flex-shrink: 0;
    padding: 5px 10px;
    border-radius: var(--r-pill);
    background: rgba(168, 185, 163, 0.28);
    border: 1px solid rgba(63, 74, 53, 0.14);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--olive);
    white-space: nowrap;
}

.saas-workspace__body {
    padding: 18px 20px 22px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.saas-portrait-preview {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px;
    border-radius: 18px;
    background: rgba(255, 252, 246, 0.82);
    border: 1px solid rgba(42, 33, 28, 0.08);
    transition: transform var(--t);
}
.saas-portrait-preview:hover { transform: translateY(-2px); }

.saas-portrait-preview__frame {
    flex-shrink: 0;
    width: 72px;
    aspect-ratio: 4 / 5;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid rgba(42, 33, 28, 0.08);
    box-shadow: 0 8px 20px rgba(42, 33, 28, 0.1);
}
.saas-portrait-preview__frame svg { width: 100%; height: 100%; display: block; }
.saas-portrait-preview__label {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 15px;
    font-weight: 600;
    color: var(--charcoal);
}

.saas-workspace__widgets {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.saas-credit-widget {
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--g-receipt);
    border: 1px solid var(--line-warm);
    box-shadow: inset 0 1px 0 rgba(255, 252, 246, 0.9);
}
.saas-credit-widget__eyebrow {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-500);
    margin-bottom: 10px;
}
.saas-credit-widget__row {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}
.saas-credit-widget__stat {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.saas-credit-widget__stat strong {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 26px;
    font-weight: 600;
    line-height: 1;
    color: var(--ink);
}
.saas-credit-widget__stat span {
    font-size: 12.5px;
    color: var(--text-500);
}

.saas-edit-widget {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 252, 246, 0.88);
    border: 1px solid rgba(42, 33, 28, 0.08);
    animation: saasChipGlow 4s ease-in-out infinite;
}
.saas-edit-widget__icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: var(--sage-soft);
    color: var(--olive);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}
.saas-edit-widget__icon svg { width: 18px; height: 18px; }
.saas-edit-widget strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
    line-height: 1.2;
}
.saas-edit-widget span {
    font-size: 12px;
    color: var(--text-500);
}

.saas-saved-strip {
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 252, 246, 0.75);
    border: 1px solid rgba(42, 33, 28, 0.07);
}
.saas-saved-strip__label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-500);
    margin-bottom: 10px;
}
.saas-saved-strip__thumbs {
    display: flex;
    align-items: center;
    gap: 8px;
}
.saas-saved-strip__thumb {
    width: 44px;
    aspect-ratio: 3 / 4;
    border-radius: 8px;
    border: 1px solid rgba(42, 33, 28, 0.08);
    box-shadow: 0 4px 10px rgba(42, 33, 28, 0.07);
}
.saas-saved-strip__thumb--1 { background: linear-gradient(145deg, var(--blush), var(--rose)); }
.saas-saved-strip__thumb--2 { background: linear-gradient(145deg, var(--gold), var(--terracotta)); }
.saas-saved-strip__thumb--3 { background: linear-gradient(145deg, var(--mint), var(--sage)); }
.saas-saved-strip__more {
    width: 44px;
    aspect-ratio: 3 / 4;
    border-radius: 8px;
    border: 1px dashed rgba(42, 33, 28, 0.18);
    display: grid;
    place-items: center;
    font-size: 18px;
    font-weight: 600;
    color: var(--text-400);
    background: rgba(255, 252, 246, 0.6);
}

.saas-style-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.saas-style-chip {
    padding: 7px 14px;
    border-radius: var(--r-pill);
    font-size: 13px;
    font-weight: 600;
    color: var(--text-600);
    background: rgba(255, 252, 246, 0.88);
    border: 1px solid rgba(42, 33, 28, 0.1);
    transition: background var(--t), border-color var(--t), color var(--t);
}
.saas-style-chip.is-active {
    background: linear-gradient(135deg, var(--gold), var(--amber));
    border-color: rgba(184, 121, 82, 0.35);
    color: var(--ink);
    box-shadow: 0 4px 14px rgba(231, 200, 115, 0.35);
}

/* Feature cards */
.saas-value-features {
    grid-area: features;
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr;
}
@media (min-width: 640px) {
    .saas-value-features { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (min-width: 1024px) {
    .saas-value-features { grid-template-columns: 1fr; }
}

.saas-feature-card {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 16px 18px;
    border-radius: 16px;
    background: rgba(255, 252, 246, 0.78);
    border: 1px solid rgba(42, 33, 28, 0.08);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.saas-feature-card:hover {
    transform: translateY(-2px);
    border-color: rgba(184, 121, 82, 0.22);
    box-shadow: 0 10px 28px rgba(42, 33, 28, 0.07);
}
.saas-feature-card--primary {
    padding: 18px 20px;
    background: rgba(255, 252, 246, 0.92);
}
.saas-feature-card--primary h3 { font-size: 16px; }
.saas-feature-card--secondary h3 { font-size: 15px; }
.saas-feature-card__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: var(--sage-soft);
    color: var(--olive);
}
.saas-feature-card--primary .saas-feature-card__icon {
    background: rgba(231, 200, 115, 0.28);
    color: var(--clay);
}
.saas-feature-card__icon svg { width: 20px; height: 20px; }
.saas-feature-card h3 {
    margin: 0 0 6px;
    font-weight: 600;
    color: var(--ink);
}
.saas-feature-card p {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-600);
}

/* CTA */
.saas-value-cta {
    grid-area: cta;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    text-align: center;
}
@media (min-width: 1024px) {
    .saas-value-cta { align-items: flex-start; text-align: left; }
}

.saas-value-cta__btn {
    min-height: 52px;
    width: 100%;
    max-width: 360px;
    transition: transform var(--t), box-shadow var(--t);
}
@media (min-width: 1024px) { .saas-value-cta__btn { width: auto; min-width: 280px; } }
.saas-value-cta__btn svg { transition: transform var(--t); }
.saas-value-cta__btn:hover svg { transform: translateX(3px); }

.saas-value-cta__link {
    font-size: 14.5px;
    font-weight: 600;
    color: var(--clay);
    text-decoration: underline;
    text-underline-offset: 3px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
}
.saas-value-cta__link:hover { color: var(--terracotta); }

.saas-value-cta__note {
    margin: 0;
    font-size: 13.5px;
    color: var(--text-500);
}

@keyframes saasChipGlow {
    0%, 100% { box-shadow: 0 0 0 rgba(231, 200, 115, 0); }
    50%      { box-shadow: 0 0 0 3px rgba(231, 200, 115, 0.22); }
}

/* ---------- SECTION 8 — Pricing Receipt ---------- */
.receipt,
.studio-receipt {
    max-width: 480px;
    margin: 0 auto;
    background: var(--g-receipt);
    border: 1px solid var(--line-warm);
    border-radius: 4px;
    padding: 36px 32px 32px;
    box-shadow: var(--sh);
    text-align: center;
    position: relative;
    transition: transform var(--t), box-shadow var(--t);
}
.studio-receipt {
    transform: rotate(-0.6deg);
}
.studio-receipt:hover {
    transform: rotate(0deg) translateY(-4px);
    box-shadow: var(--sh-warm);
}
/* Perforated top */
.receipt::before {
    content: "";
    position: absolute;
    top: -6px;
    left: 0; right: 0;
    height: 12px;
    background: radial-gradient(circle at 8px 0, var(--porcelain) 6px, transparent 6.5px);
    background-size: 16px 12px;
    background-repeat: repeat-x;
}
/* Perforated bottom */
.receipt::after {
    content: "";
    position: absolute;
    bottom: -6px;
    left: 0; right: 0;
    height: 12px;
    background: radial-gradient(circle at 8px 12px, var(--porcelain) 6px, transparent 6.5px);
    background-size: 16px 12px;
    background-repeat: repeat-x;
}

.receipt__header {
    border-bottom: 1px dashed var(--line-strong);
    padding-bottom: 22px;
    margin-bottom: 22px;
}
.receipt__brand {
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 14px;
    color: var(--clay);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 10px;
}
.receipt h3 {
    font-size: clamp(22px, 3vw, 30px);
    font-weight: 600;
    margin-bottom: 8px;
    line-height: 1.2;
}
.receipt__sub {
    font-size: 14.5px;
    color: var(--text-600);
}

.receipt__lines {
    list-style: none;
    margin: 0 0 28px;
    padding: 0;
    text-align: left;
    display: grid;
    gap: 12px;
}
.receipt__lines li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 14.5px;
    color: var(--text-700);
    padding-bottom: 12px;
    border-bottom: 1px dotted var(--line-strong);
}
.receipt__lines li:last-child { border-bottom: 0; padding-bottom: 0; }
.receipt__lines svg {
    width: 18px; height: 18px;
    color: var(--clay);
    flex-shrink: 0;
    margin-top: 2px;
}
.receipt__free {
    margin-left: auto;
    background: var(--canvas);
    color: var(--clay);
    padding: 3px 10px;
    border-radius: 4px;
    font-size: 11.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
}

.receipt__total {
    background: var(--canvas);
    border: 1px dashed var(--line-strong);
    border-radius: 6px;
    padding: 14px 16px;
    margin-bottom: 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 18px;
    font-weight: 500;
    color: var(--ink);
}
.receipt__total strong { color: var(--clay); font-weight: 600; }

.receipt__note {
    margin: 16px 0 0;
    font-size: 13px;
    line-height: 1.55;
    color: var(--text-500);
}

.receipt__note .hv-link {
    color: var(--clay);
    font-weight: 600;
}

/* ---------- SECTION 9 — FAQ Atelier ---------- */
.faq {
    max-width: 720px;
    margin: 0 auto;
    display: grid;
    gap: 0;
}

.faq__item {
    border-bottom: 1px solid var(--line);
    transition: background var(--t), box-shadow var(--t), border-color var(--t);
}

.faq__item:last-child {
    border-bottom: 0;
}

.faq__item.is-open {
    background: linear-gradient(180deg, rgba(255, 252, 246, 0.96) 0%, rgba(243, 231, 211, 0.42) 100%);
    box-shadow: inset 3px 0 0 var(--clay);
}

.faq__q {
    width: 100%;
    min-height: 58px;
    padding: 18px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    text-align: left;
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 500;
    color: var(--ink);
    font-size: clamp(16px, 1.6vw, 17.5px);
    line-height: 1.35;
    cursor: pointer;
    background: transparent;
    border: 0;
    transition: color var(--t);
}

.faq__q:hover,
.faq__q:focus-visible {
    color: var(--clay);
}

.faq__q:focus-visible {
    outline: 2px solid rgba(184, 121, 82, 0.45);
    outline-offset: -2px;
    border-radius: 4px;
}

.faq__q-text {
    flex: 1;
    min-width: 0;
}

.faq__q-icon {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    flex-shrink: 0;
    border-radius: 999px;
    color: var(--clay);
    background: rgba(184, 121, 82, 0.08);
    border: 1px solid rgba(184, 121, 82, 0.14);
    transition: transform var(--t), background var(--t), border-color var(--t);
}

.faq__q-icon svg {
    width: 16px;
    height: 16px;
    transition: transform var(--t);
}

.faq__item.is-open .faq__q-icon {
    background: rgba(184, 121, 82, 0.14);
    border-color: rgba(184, 121, 82, 0.28);
}

.faq__item.is-open .faq__q-icon svg {
    transform: rotate(180deg);
}

.faq__a {
    overflow: hidden;
    padding: 0 22px 22px 25px;
    color: var(--text-700);
    font-size: 15px;
    line-height: 1.68;
}

.faq__a p {
    margin: 0;
    max-width: 62ch;
}

.faq__item.is-open .faq__q {
    padding-bottom: 10px;
}

/* ---------- FAQ Notebook shell ---------- */
.faq-notebook {
    background: var(--porcelain);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    padding: 8px 10px;
    box-shadow: var(--sh-sm);
}

.faq-notebook .faq__item {
    border-radius: var(--r-sm);
    margin: 2px 0;
    border-bottom: 0;
    background: transparent;
}

.faq-notebook .faq__item + .faq__item {
    border-top: 1px solid var(--line);
}

.faq-notebook .faq__item.is-open {
    margin: 6px 0;
    border: 1px solid rgba(184, 121, 82, 0.22);
    border-radius: 14px;
    box-shadow: var(--sh-xs);
}

@media (max-width: 560px) {
    .faq-notebook {
        padding: 6px 4px;
        border-radius: var(--r);
    }
    .faq__q {
        min-height: 54px;
        padding: 16px 16px;
        gap: 12px;
    }
    .faq__a {
        padding: 0 16px 18px 19px;
        font-size: 14.5px;
    }
    .faq__q-icon {
        width: 32px;
        height: 32px;
    }
}

/* ---------- SECTION 10 Ã¢â‚¬â€ Final CTA Gallery ---------- */
.gallery-cta {
    padding: 64px 0;
    background: var(--porcelain);
}
.gallery-cta__card {
    position: relative;
    border-radius: var(--r-xl);
    overflow: hidden;
    padding: 64px 28px;
    text-align: center;
    background: var(--ink);
    color: var(--porcelain);
    box-shadow: var(--sh-lg);
    background-image:
        radial-gradient(circle at 18% 25%, rgba(231, 200, 115, 0.22) 0%, transparent 45%),
        radial-gradient(circle at 82% 78%, rgba(216, 106, 61, 0.20) 0%, transparent 45%),
        linear-gradient(135deg, #171412 0%, #2A211C 100%);
}
@media (min-width: 768px) { .gallery-cta__card { padding: 92px 56px; } }

.gallery-cta__card > * { position: relative; z-index: 2; }

/* Background warm frames inside dark cta */
.gallery-cta__card::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(231, 200, 115, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(231, 200, 115, 0.05) 1px, transparent 1px);
    background-size: 90px 110px;
    background-position: center;
    mask-image: radial-gradient(ellipse at center, black 25%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 25%, transparent 70%);
    z-index: 1;
}

.gallery-cta h2 {
    color: var(--porcelain);
    font-size: clamp(30px, 5vw, 52px);
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 500;
    max-width: 20ch;
    margin: 0 auto 18px;
    line-height: 1.1;
}
.gallery-cta h2 .italic-accent { color: var(--champagne); }
.gallery-cta p {
    color: rgba(250, 247, 242, 0.75);
    max-width: 54ch;
    margin: 0 auto;
    font-size: 17px;
}
.gallery-cta .btn { margin-top: 32px; }

.gcta__tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin-top: 32px;
}
.gcta__tags .tag-pill {
    background: rgba(231, 200, 115, 0.10);
    border: 1px solid rgba(231, 200, 115, 0.28);
    color: var(--champagne);
    padding: 6px 14px;
    border-radius: var(--r-pill);
    font-size: 12.5px;
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-weight: 500;
}

.gcta__frame {
    position: absolute;
    border: 1px solid rgba(231, 200, 115, 0.14);
    border-radius: 18px;
    background: rgba(231, 200, 115, 0.04);
    z-index: 1;
    pointer-events: none;
    opacity: 0.55;
}
.gcta__frame--1 {
    width: 120px; height: 150px;
    top: 12%; left: 6%;
    transform: rotate(-12deg);
    border-radius: 50% 50% 16px 16px / 28% 28% 8px 8px;
}
.gcta__frame--2 {
    width: 90px; height: 110px;
    bottom: 14%; right: 8%;
    transform: rotate(8deg);
}
.gcta__frame--3 {
    width: 70px; height: 86px;
    top: 28%; right: 18%;
    transform: rotate(-6deg);
    border-radius: 50%;
}

.gcta__spark {
    position: absolute;
    color: var(--champagne);
    z-index: 2;
    pointer-events: none;
    animation: twinkle 4.2s ease-in-out infinite;
    filter: drop-shadow(0 0 6px rgba(231, 200, 115, 0.5));
}
.gcta__spark svg { width: 18px; height: 18px; }
.gcta__spark--1 { top: 14%; left: 12%; }
.gcta__spark--2 { top: 22%; right: 14%; animation-delay: 1s; }
.gcta__spark--3 { bottom: 18%; left: 16%; animation-delay: 2s; color: var(--rose); }
.gcta__spark--4 { bottom: 14%; right: 10%; animation-delay: 3s; color: var(--terracotta); }

/* ---------- Footer ---------- */
.site-footer {
    background: var(--ink);
    color: rgba(250, 247, 242, 0.72);
    padding: 64px 0 28px;
}
.footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 36px;
}
@media (min-width: 768px) {
    .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px; }
}
.footer-grid h4 {
    color: var(--champagne);
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 20px;
    font-weight: 700;
    font-family: 'Inter', sans-serif;
}
.footer-grid a {
    display: block;
    padding: 7px 0;
    color: rgba(250, 247, 242, 0.7);
    font-size: 14.5px;
    transition: color var(--t);
}
.footer-grid a:hover { color: var(--champagne); }
.footer-grid p {
    color: rgba(250, 247, 242, 0.55);
    font-size: 14.5px;
    max-width: 38ch;
    margin-top: 16px;
}
.footer-brand .brand { color: var(--porcelain); }
.footer-bottom {
    margin-top: 56px;
    padding-top: 24px;
    border-top: 1px solid rgba(231, 200, 115, 0.12);
    display: flex;
    flex-direction: column;
    gap: 14px;
    justify-content: space-between;
    align-items: center;
    color: rgba(250, 247, 242, 0.45);
    font-size: 13px;
}
@media (min-width: 640px) { .footer-bottom { flex-direction: row; } }
.socials { display: flex; gap: 8px; }
.socials a {
    width: 38px; height: 38px;
    display: grid; place-items: center;
    border-radius: 10px;
    background: rgba(231, 200, 115, 0.08);
    color: var(--champagne);
    padding: 0;
}
.socials a:hover { background: var(--champagne); color: var(--ink); }
.socials svg { width: 16px; height: 16px; }

/* ---------- Reveal animation (progressive — visible without JS) ---------- */
.r-up,
.fade-up {
    opacity: 1;
    transform: none;
}

html.reveal-enhanced .r-up:not(.is-visible),
html.reveal-enhanced .fade-up:not(.is-visible) {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 720ms var(--ease), transform 720ms var(--ease);
    will-change: opacity, transform;
}

html.reveal-enhanced .r-up.is-visible,
html.reveal-enhanced .fade-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ---------- Keyframes ---------- */
@keyframes homeHeroCardFloat {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-6px); }
}
@keyframes homeHeroChipPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(63, 74, 53, 0); }
    50%      { box-shadow: 0 0 0 4px rgba(63, 74, 53, 0.08); }
}

@keyframes floatA {
    0%, 100% { transform: translateY(0) rotate(var(--rot, -5deg)); }
    50%      { transform: translateY(-10px) rotate(var(--rot, -5deg)); }
}

@keyframes floatB {
    0%, 100% { transform: translateY(0) rotate(var(--rot, 2.5deg)); }
    50%      { transform: translateY(-12px) rotate(var(--rot, 2.5deg)); }
}

@keyframes sweep {
    0%   { transform: translateY(-100%); }
    100% { transform: translateY(100%); }
}
@keyframes twinkle {
    0%, 100% { opacity: 0.4; transform: scale(0.85) rotate(0deg); }
    50%      { opacity: 1;   transform: scale(1.1) rotate(15deg); }
}
@keyframes beamPulse {
    0%, 100% { opacity: 0.3; }
    50%      { opacity: 0.55; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
    .r-up, .fade-up { opacity: 1 !important; transform: none !important; }
}

/* =========================================================================
   PORTRAIT WORLDS â€” Open Studio Room (.pw-* namespace)
   ========================================================================= */
.pw-section {
    position: relative;
    overflow: hidden;
    padding: clamp(56px, 9vw, 112px) 0;
    background:
        radial-gradient(circle at 14% 10%, rgba(231, 200, 115, 0.13), transparent 32%),
        radial-gradient(circle at 86% 90%, rgba(216, 106, 61, 0.10), transparent 36%),
        var(--porcelain);
}

.pw-section *,
.pw-section *::before,
.pw-section *::after { box-sizing: border-box; }

.pw-shell {
    position: relative;
    display: grid;
    grid-template-columns: minmax(340px, 0.9fr) minmax(620px, 1.1fr);
    gap: clamp(40px, 5vw, 56px);
    align-items: center;
    max-width: 1240px;
    margin: 0 auto;
    padding: clamp(40px, 5vw, 64px);
    border-radius: 36px;
    overflow: hidden;
    color: var(--porcelain);
    background:
        radial-gradient(circle at 78% 30%, rgba(231, 200, 115, 0.16), transparent 30%),
        radial-gradient(circle at 18% 90%, rgba(216, 106, 61, 0.08), transparent 35%),
        linear-gradient(135deg, #171412 0%, #221b17 56%, #2A211C 100%);
    box-shadow:
        0 32px 90px rgba(42, 33, 28, 0.28),
        inset 0 1px 0 rgba(250, 247, 242, 0.08);
    isolation: isolate;
}

.pw-shell::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(250, 247, 242, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(250, 247, 242, 0.035) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(circle at 70% 50%, #000 0%, transparent 72%);
    -webkit-mask-image: radial-gradient(circle at 70% 50%, #000 0%, transparent 72%);
    pointer-events: none;
    z-index: 0;
}

.pw-shell > * { position: relative; z-index: 1; min-width: 0; }

/* â”€â”€ LEFT COPY â”€â”€ */
.pw-copy {
    align-self: center;
    max-width: 480px;
}

.pw-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    color: var(--gold);
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.pw-eyebrow::before {
    content: "";
    width: 28px;
    height: 1px;
    background: linear-gradient(90deg, var(--gold), transparent);
}

.pw-title {
    margin: 0 0 18px;
    color: var(--porcelain);
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(40px, 5.4vw, 62px);
    line-height: 1.05;
    letter-spacing: -0.04em;
    max-width: 11ch;
    overflow-wrap: break-word;
}

.pw-title .italic-accent { color: var(--gold); }

.pw-intro {
    margin: 0;
    max-width: 44ch;
    color: rgba(250, 247, 242, 0.74);
    font-size: clamp(15.5px, 1.2vw, 17px);
    line-height: 1.7;
}

.pw-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.pw-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 22px;
    border-radius: 9999px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    transition: transform var(--t), box-shadow var(--t), background var(--t), color var(--t), border-color var(--t);
}

.pw-cta svg { width: 18px; height: 18px; transition: transform var(--t); }

.pw-cta--primary {
    color: var(--ink);
    background: linear-gradient(135deg, var(--gold) 0%, var(--amber) 60%, var(--terracotta) 100%);
    border: 1px solid rgba(231, 200, 115, 0.65);
    box-shadow: 0 18px 40px rgba(231, 200, 115, 0.20);
}

.pw-cta--primary:hover,
.pw-cta--primary:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 24px 52px rgba(231, 200, 115, 0.28);
}

.pw-cta--primary:hover svg,
.pw-cta--primary:focus-visible svg {
    transform: translateX(4px);
}

.pw-cta--secondary {
    color: rgba(250, 247, 242, 0.86);
    background: rgba(250, 247, 242, 0.055);
    border: 1px solid rgba(231, 200, 115, 0.28);
}

.pw-cta--secondary:hover,
.pw-cta--secondary:focus-visible {
    transform: translateY(-2px);
    color: var(--gold);
    background: rgba(250, 247, 242, 0.09);
    border-color: rgba(231, 200, 115, 0.5);
}

/* â”€â”€ STUDIO STATUS CARD â”€â”€ */
.pw-status-card {
    margin-top: 32px;
    padding: 18px 20px 16px;
    border-radius: 20px;
    border: 1px solid rgba(231, 200, 115, 0.24);
    background:
        linear-gradient(180deg, rgba(231, 200, 115, 0.07), rgba(250, 247, 242, 0.02)),
        rgba(23, 20, 18, 0.22);
    box-shadow:
        0 12px 32px rgba(0, 0, 0, 0.18),
        inset 0 1px 0 rgba(250, 247, 242, 0.06);
}

.pw-status-card__label {
    display: block;
    margin-bottom: 12px;
    color: rgba(231, 200, 115, 0.92);
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 12px;
    letter-spacing: 0.06em;
    text-align: center;
}

.pw-status-card__list {
    list-style: none;
    margin: 0 0 12px;
    padding: 0;
    display: grid;
    gap: 10px;
}

.pw-status-card__list li {
    display: flex;
    align-items: center;
    gap: 10px;
}

.pw-status-card__text {
    color: rgba(250, 247, 242, 0.90);
    font-size: 13.5px;
    line-height: 1.45;
}

.pw-status-card__note {
    margin: 0;
    padding-top: 12px;
    border-top: 1px dashed rgba(231, 200, 115, 0.18);
    color: rgba(250, 247, 242, 0.84);
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 13.5px;
    line-height: 1.5;
    text-align: center;
}

.pw-status-card--mobile { display: none; }

/* â”€â”€ BADGES â”€â”€ */
.pw-badge-open,
.pw-badge-soon {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 26px;
    padding: 4px 10px;
    border-radius: 9999px;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
    flex: 0 0 auto;
}

.pw-badge-open::before,
.pw-badge-soon::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex: 0 0 auto;
}

.pw-badge-open {
    color: var(--ink);
    background: linear-gradient(135deg, var(--gold), var(--amber) 58%, var(--terracotta));
    border: 1px solid rgba(231, 200, 115, 0.65);
    box-shadow: 0 8px 20px rgba(231, 200, 115, 0.16);
}

.pw-badge-open::before {
    background: var(--ink);
    box-shadow: 0 0 0 3px rgba(23, 20, 18, 0.10);
}

.pw-badge-soon {
    color: rgba(250, 247, 242, 0.84);
    background: rgba(250, 247, 242, 0.07);
    border: 1px solid rgba(168, 185, 163, 0.32);
    letter-spacing: 0.04em;
    text-transform: none;
    font-size: 10.5px;
}

.pw-badge-soon::before {
    background: var(--sage);
    box-shadow: 0 0 0 3px rgba(168, 185, 163, 0.14);
}

/* â”€â”€ BOARD WRAP â”€â”€ */
.pw-board-wrap {
    min-width: 0;
    width: 100%;
}

/* â”€â”€ OPEN STUDIO BOARD â”€â”€ */
.pw-board {
    position: relative;
    display: grid;
    grid-template-columns: minmax(280px, 0.88fr) minmax(340px, 1.12fr);
    gap: 28px;
    min-height: 0;
    padding: 32px;
    border-radius: 30px;
    background:
        radial-gradient(circle at 28% 42%, rgba(231, 200, 115, 0.10), transparent 38%),
        rgba(250, 247, 242, 0.06);
    border: 1px solid rgba(250, 247, 242, 0.12);
    box-shadow:
        inset 0 1px 0 rgba(250, 247, 242, 0.08),
        inset 0 -24px 48px rgba(0, 0, 0, 0.12);
    overflow: hidden;
}

.pw-board::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(250, 247, 242, 0.022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(250, 247, 242, 0.022) 1px, transparent 1px),
        radial-gradient(circle, rgba(231, 200, 115, 0.10) 1px, transparent 1px);
    background-size: 32px 32px, 32px 32px, 24px 24px;
    background-position: 0 0, 0 0, 12px 12px;
    mask-image: linear-gradient(105deg, rgba(0, 0, 0, 0.72) 0%, rgba(0, 0, 0, 0.42) 52%, rgba(0, 0, 0, 0.18) 100%);
    -webkit-mask-image: linear-gradient(105deg, rgba(0, 0, 0, 0.72) 0%, rgba(0, 0, 0, 0.42) 52%, rgba(0, 0, 0, 0.18) 100%);
    pointer-events: none;
    z-index: 0;
}

.pw-board::after {
    content: "";
    position: absolute;
    top: 32px;
    bottom: 32px;
    left: calc(44% - 0.5px);
    width: 1px;
    background: linear-gradient(180deg, transparent, rgba(231, 200, 115, 0.16) 16%, rgba(231, 200, 115, 0.16) 84%, transparent);
    pointer-events: none;
    z-index: 0;
}

.pw-board > * { position: relative; z-index: 1; min-width: 0; }

/* â”€â”€ ACTIVE BABY ROOM â”€â”€ */
.pw-active-room {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 0;
    padding: 28px;
    border-radius: 28px;
    color: var(--porcelain);
    text-decoration: none;
    background:
        radial-gradient(circle at 50% 38%, rgba(247, 214, 206, 0.14), transparent 52%),
        radial-gradient(circle at 82% 18%, rgba(231, 200, 115, 0.12), transparent 40%),
        linear-gradient(165deg, rgba(63, 42, 28, 0.94), rgba(23, 20, 18, 0.98));
    border: 2px solid rgba(231, 200, 115, 0.78);
    box-shadow:
        0 28px 70px rgba(0, 0, 0, 0.38),
        0 0 0 1px rgba(250, 247, 242, 0.08) inset,
        0 0 72px rgba(231, 200, 115, 0.20);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
    overflow: hidden;
}

.pw-active-room:hover,
.pw-active-room:focus-visible {
    transform: translateY(-4px);
    border-color: rgba(231, 200, 115, 0.95);
    box-shadow:
        0 36px 90px rgba(0, 0, 0, 0.44),
        0 0 0 1px rgba(250, 247, 242, 0.10) inset,
        0 0 90px rgba(231, 200, 115, 0.30);
}

.pw-active-room:focus-visible {
    outline: 2px solid rgba(231, 200, 115, 0.75);
    outline-offset: 3px;
}

.pw-active-room__glow {
    position: absolute;
    inset: -20%;
    background: radial-gradient(circle at 68% 32%, rgba(231, 200, 115, 0.28), transparent 44%);
    pointer-events: none;
    z-index: 0;
    animation: pwRoomGlow 6s ease-in-out infinite;
}

.pw-active-room__texture {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(250, 247, 242, 0.045) 1px, transparent 1px);
    background-size: 16px 16px;
    opacity: 0.55;
    pointer-events: none;
    z-index: 0;
}

.pw-active-room__vignette {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 40%, transparent 42%, rgba(23, 20, 18, 0.55) 100%);
    pointer-events: none;
    z-index: 0;
}

@keyframes pwRoomGlow {
    0%, 100% { opacity: 0.65; transform: scale(0.98); }
    50%      { opacity: 1;   transform: scale(1.03); }
}

.pw-active-room__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-rows: auto minmax(180px, 1fr) auto;
    gap: 18px;
    flex: 1;
    min-height: 0;
}

.pw-active-room__top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
}

.pw-active-room__content {
    display: grid;
    gap: 14px;
    align-content: end;
    min-width: 0;
    padding-top: 4px;
}

.pw-active-room__label {
    margin: 0;
    color: rgba(250, 247, 242, 0.58);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.pw-active-room__title {
    margin: 0;
    color: var(--porcelain);
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(30px, 2.9vw, 40px);
    font-weight: 600;
    line-height: 1.04;
    letter-spacing: -0.03em;
    overflow-wrap: break-word;
}

.pw-active-room__desc {
    margin: 0;
    max-width: 38ch;
    color: rgba(250, 247, 242, 0.84);
    font-size: 15.5px;
    line-height: 1.6;
}

.pw-primary-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-top: 6px;
    padding: 0 24px;
    min-height: 46px;
    width: fit-content;
    max-width: 100%;
    color: var(--porcelain);
    background: rgba(250, 247, 242, 0.10);
    border: 1px solid rgba(231, 200, 115, 0.42);
    border-radius: 9999px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
    transition: transform var(--t), background var(--t), border-color var(--t), box-shadow var(--t);
}

.pw-active-room:hover .pw-primary-link,
.pw-active-room:focus-visible .pw-primary-link {
    background: rgba(250, 247, 242, 0.14);
    border-color: rgba(231, 200, 115, 0.62);
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.22);
}

.pw-primary-link__arrow {
    display: inline-block;
    transition: transform var(--t);
}

.pw-active-room:hover .pw-primary-link__arrow,
.pw-active-room:focus-visible .pw-primary-link__arrow {
    transform: translateX(4px);
}

/* â”€â”€ PORTRAIT STACK â”€â”€ */
.pw-active-visual {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 0;
    padding: 14px 0 10px;
    overflow: visible;
}

.pw-active-visual__glow {
    position: absolute;
    width: min(100%, 240px);
    height: 180px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -54%);
    background: radial-gradient(circle, rgba(231, 200, 115, 0.22), transparent 68%);
    pointer-events: none;
    z-index: 0;
}

.pw-portrait-stack {
    position: relative;
    width: 210px;
    height: 204px;
    max-width: 100%;
    margin: 0 auto;
    z-index: 1;
    animation: pwPortraitFloat 5.5s ease-in-out infinite;
}

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

.pw-portrait-stack__photo {
    position: absolute;
    display: block;
    overflow: hidden;
    border: 4px solid rgba(250, 247, 242, 0.94);
    background: var(--porcelain);
    box-shadow:
        0 20px 40px rgba(0, 0, 0, 0.32),
        0 0 0 1px rgba(231, 200, 115, 0.12);
}

.pw-portrait-stack__photo svg { width: 100%; height: 100%; display: block; }

.pw-portrait-stack__photo--back {
    width: 78px;
    height: 96px;
    left: 8px;
    top: 44px;
    border-radius: 16px;
    opacity: 0.82;
    transform: rotate(-8deg);
}

.pw-portrait-stack__photo--front {
    width: 118px;
    height: 142px;
    right: 6px;
    top: 8px;
    border-radius: 50% 50% 20px 20px / 28% 28% 14px 14px;
    transform: rotate(4deg);
}

.pw-style-chips {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin-top: 16px;
    z-index: 2;
}

.pw-style-chip {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 4px 12px;
    border-radius: 999px;
    color: rgba(250, 247, 242, 0.90);
    font-family: 'Inter', sans-serif;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    background: rgba(250, 247, 242, 0.07);
    border: 1px solid rgba(231, 200, 115, 0.28);
}

.pw-active-room__seal {
    position: absolute;
    right: 10%;
    bottom: 20%;
    padding: 5px 11px;
    color: var(--gold);
    background: rgba(23, 20, 18, 0.55);
    border: 1px solid rgba(231, 200, 115, 0.38);
    border-radius: 999px;
    font-family: 'Fraunces', Georgia, serif;
    font-style: italic;
    font-size: 11.5px;
    font-weight: 600;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.22);
    white-space: nowrap;
    z-index: 3;
    transform: rotate(-3deg);
}

/* —— COMING SOON PANEL —— */
.pw-room-panel {
    display: flex;
    flex-direction: column;
    min-height: 0;
    min-width: 0;
    padding: 12px 14px;
    border-radius: 22px;
    background: rgba(23, 20, 18, 0.38);
    border: 1px solid rgba(250, 247, 242, 0.06);
    overflow: visible;
}

.pw-room-panel__head {
    margin-bottom: 18px;
    padding-right: 4px;
}

.pw-room-panel__title {
    margin: 0 0 6px;
    color: var(--porcelain);
    font-family: 'Fraunces', Georgia, serif;
    font-size: 21px;
    font-weight: 600;
    letter-spacing: -0.02em;
}

.pw-room-panel__sub {
    margin: 0;
    color: rgba(250, 247, 242, 0.66);
    font-size: 13px;
    line-height: 1.48;
}

.pw-room-panel__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0;
    flex: 1;
    align-content: start;
}

.pw-room-group {
    list-style: none;
    margin: 0;
    padding: 0;
}

.pw-room-group + .pw-room-group {
    margin-top: 16px;
}

.pw-room-group__label {
    display: block;
    margin-bottom: 10px;
    padding-left: 2px;
    color: rgba(231, 200, 115, 0.78);
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.pw-room-group__rows {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.pw-room-row {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr) max-content;
    align-items: center;
    gap: 10px;
    min-width: 0;
    min-height: 56px;
    padding: 10px 12px;
    border-radius: 16px;
    background: rgba(250, 247, 242, 0.048);
    border: 1px solid rgba(250, 247, 242, 0.09);
    box-shadow: inset 0 1px 0 rgba(250, 247, 242, 0.03);
    transition: transform var(--t), background var(--t), border-color var(--t), box-shadow var(--t);
}

.pw-room-row:hover {
    transform: translateY(-2px);
    background: rgba(250, 247, 242, 0.09);
    border-color: rgba(231, 200, 115, 0.26);
    box-shadow:
        0 10px 24px rgba(0, 0, 0, 0.14),
        inset 0 1px 0 rgba(250, 247, 242, 0.06);
}

.pw-room-icon {
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    color: var(--gold);
    background: rgba(231, 200, 115, 0.12);
    border: 1px solid rgba(231, 200, 115, 0.24);
    border-radius: 12px;
    flex: 0 0 auto;
}

.pw-room-icon svg { width: 18px; height: 18px; }

.pw-room-row__main {
    min-width: 0;
}

.pw-room-row__title {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    min-width: 0;
    color: var(--porcelain);
    font-family: 'Fraunces', Georgia, serif;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.18;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-word;
}

.pw-room-row .pw-badge-soon {
    min-height: 22px;
    padding: 3px 8px;
    font-size: 9.5px;
    letter-spacing: 0.08em;
    align-self: center;
    white-space: nowrap;
    flex-shrink: 0;
}

/* On the desktop "Coming soon" panel the panel header already says
   "Coming soon", so collapse the per-row badge to a compact dot indicator
   that never clips. Mobile rows keep the full badge. */
.pw-room-row:not(.pw-room-row--mobile) .pw-badge-soon {
    width: 8px;
    height: 8px;
    min-height: 8px;
    padding: 0;
    font-size: 0;
    line-height: 0;
    border-radius: 999px;
    background: rgba(231, 200, 115, 0.7);
    border: 1px solid rgba(231, 200, 115, 0.45);
    color: transparent;
}
.pw-room-row:not(.pw-room-row--mobile) .pw-badge-soon::before {
    display: none;
}

/* —— MOBILE ROADMAP (hidden on desktop) —— */
.pw-mobile-roadmap { display: none; }

/* â”€â”€ RESPONSIVE â”€â”€ */
@media (max-width: 1100px) {
    .pw-shell {
        grid-template-columns: 1fr;
        gap: 36px;
        padding: clamp(32px, 4vw, 48px);
    }
    .pw-copy { max-width: 720px; }
    .pw-title { max-width: 14ch; }
    .pw-board {
        min-height: 0;
        grid-template-columns: minmax(260px, 0.9fr) minmax(300px, 1.1fr);
        gap: 24px;
        padding: 28px;
    }
    .pw-board::after { left: calc(47% - 0.5px); }
}

@media (min-width: 901px) and (max-width: 1180px) {
    .pw-board {
        grid-template-columns: minmax(240px, 0.82fr) minmax(320px, 1.18fr);
    }
    .pw-board::after { left: calc(43% - 0.5px); }
}

@media (max-width: 900px) {
    .pw-board {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 22px;
    }
    .pw-board::after { display: none; }
    .pw-room-panel {
        padding: 18px 20px 16px;
        border-top: 0;
        border-radius: 20px;
    }
    .pw-active-room {
        min-height: 0;
    }
    .pw-active-room__inner {
        grid-template-rows: auto minmax(160px, 1fr) auto;
    }
    .pw-active-visual {
        width: 100%;
        max-width: 280px;
        margin: 0 auto;
    }
    .pw-portrait-stack {
        width: 200px;
        height: 196px;
    }
    .pw-active-room__seal {
        right: 8%;
        bottom: 22%;
    }
}

@media (max-width: 768px) {
    .pw-shell {
        padding: 24px;
        border-radius: 28px;
        overflow: visible;
    }
    .pw-status-card--desktop { display: none; }
    .pw-status-card--mobile {
        display: block;
        margin-top: 20px;
    }
    .pw-board {
        padding: 0;
        background: transparent;
        border: 0;
        box-shadow: none;
        gap: 0;
    }
    .pw-board::before { display: none; }
    .pw-room-panel { display: none; }
    .pw-active-room {
        padding: 22px;
        border-radius: 26px;
        min-height: 0;
    }
    .pw-active-visual {
        width: 100%;
        max-width: 260px;
        margin: 0 auto;
    }
    .pw-primary-link {
        width: 100%;
        max-width: none;
    }
    .pw-mobile-roadmap {
        display: block;
        margin-top: 22px;
        padding: 20px 16px 18px;
        border-radius: 22px;
        background: rgba(23, 20, 18, 0.42);
        border: 1px solid rgba(250, 247, 242, 0.08);
        min-width: 0;
        width: 100%;
        box-sizing: border-box;
    }
    .pw-mobile-roadmap .pw-room-panel__head {
        margin-bottom: 16px;
    }
    .pw-mobile-roadmap .pw-room-row,
    .pw-mobile-roadmap .pw-room-row--mobile {
        grid-template-columns: 38px minmax(0, 1fr);
        grid-template-rows: auto auto;
        column-gap: 10px;
        row-gap: 6px;
        align-items: start;
        min-height: 0;
        padding: 12px;
    }
    .pw-mobile-roadmap .pw-room-icon {
        grid-row: 1 / span 2;
        align-self: center;
    }
    .pw-mobile-roadmap .pw-room-row__main {
        grid-column: 2;
        grid-row: 1;
    }
    .pw-mobile-roadmap .pw-room-row .pw-badge-soon {
        grid-column: 2;
        grid-row: 2;
        justify-self: start;
        align-self: start;
    }
    .pw-room-row--mobile:hover {
        transform: none;
        background: rgba(250, 247, 242, 0.048);
        border-color: rgba(250, 247, 242, 0.09);
        box-shadow: inset 0 1px 0 rgba(250, 247, 242, 0.03);
    }
}

@media (max-width: 560px) {
    .pw-section { padding: clamp(36px, 8vw, 56px) 0; overflow: visible; }
    .pw-shell {
        margin-inline: 0;
        padding: 20px 16px;
        border-radius: 26px;
        overflow: visible;
    }
    .pw-title { font-size: clamp(36px, 11vw, 48px); }
    .pw-actions { flex-direction: column; align-items: stretch; }
    .pw-cta { width: 100%; }
    .pw-mobile-roadmap {
        padding: 18px 14px 16px;
    }
    .pw-mobile-roadmap .pw-room-row,
    .pw-mobile-roadmap .pw-room-row--mobile {
        padding: 11px 10px;
    }
    .pw-mobile-roadmap .pw-room-row__title {
        font-size: 13.5px;
        line-height: 1.25;
    }
    .pw-active-room { padding: 20px; border-radius: 24px; }
    .pw-active-room__title { font-size: 28px; }
    .pw-active-room__desc { font-size: 15px; }
    .pw-portrait-stack__photo--back { width: 72px; height: 90px; top: 24px; }
    .pw-portrait-stack__photo--front { width: 108px; height: 132px; }
}

@media (prefers-reduced-motion: reduce) {
    .pw-active-room__glow { animation: none !important; }
    .pw-portrait-stack { animation: none !important; }
    .pw-cta,
    .pw-cta svg,
    .pw-active-room,
    .pw-primary-link__arrow,
    .pw-room-row { transition: none !important; }
}

/* ─────────────────────────────────────────────────────────────
   HERO TRUST STRIP (audit 2 injection)
   ───────────────────────────────────────────────────────────── */
.hero-trust-strip {
    margin-top: 18px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
    padding: 10px 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid var(--line-warm, #e8dcc8);
    backdrop-filter: blur(6px);
    box-shadow: 0 12px 28px -22px rgba(42, 33, 28, 0.35);
}
.hero-trust-strip__item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--ink-soft, #2A211C);
}
.hero-trust-strip__item svg {
    width: 14px; height: 14px;
    color: var(--clay, #B87952);
    flex-shrink: 0;
}
.hero-trust-strip__sep {
    color: var(--text-400, #a99a8d);
    font-size: 11px;
}
@media (max-width: 540px) {
    .hero-trust-strip { flex-direction: column; align-items: flex-start; padding: 12px 14px; }
    .hero-trust-strip__sep { display: none; }
}

/* ─────────────────────────────────────────────────────────────
   NARRATIVE BLOCKS (audit injection: Cost / Privacy / Aesthetic)
   ───────────────────────────────────────────────────────────── */
.section--narrative { padding: clamp(56px, 7vw, 96px) 0; }
.narrative-cost { background: linear-gradient(180deg, var(--porcelain) 0%, #fff7ea 100%); }
.narrative-privacy { background: #1c1714; color: #faf6ef; }
.narrative-aesthetic { background: linear-gradient(180deg, #fff7ea 0%, var(--porcelain) 100%); }

.narrative-grid {
    display: grid;
    gap: 36px;
    align-items: center;
}
@media (min-width: 880px) {
    .narrative-grid { grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr); gap: 56px; }
}
.narrative-copy .eyebrow {
    display: inline-block;
    color: var(--clay);
    font-weight: 700;
    margin-bottom: 12px;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.narrative-copy h2 {
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(28px, 3.6vw, 42px);
    font-weight: 500;
    line-height: 1.08;
    margin: 0 0 18px;
    color: var(--ink);
}
.narrative-copy > p {
    margin: 0 0 20px;
    color: var(--text-600, #5a4f47);
    font-size: 16.5px;
    line-height: 1.7;
    max-width: 56ch;
}
.narrative-bullets {
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.narrative-bullets li {
    display: flex;
    align-items: baseline;
    gap: 12px;
    font-size: 15px;
    color: var(--ink-soft, #2A211C);
}
.narrative-bullets li strong {
    flex: 0 0 auto;
    min-width: 70px;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 22px;
    color: var(--clay);
    font-weight: 600;
}
.narrative-bullets li span { color: var(--text-600, #5a4f47); }
.narrative-bullets--inline {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
}
.narrative-bullets--inline li {
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid var(--line-warm, #e8dcc8);
    font-size: 13px;
    color: var(--ink-soft, #2A211C);
}
.narrative-bullets--inline li strong { display: none; }

.narrative-compare {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.compare-card {
    padding: 22px 20px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid var(--line-warm, #e8dcc8);
    text-align: center;
    box-shadow: 0 14px 32px -22px rgba(42, 33, 28, 0.3);
}
.compare-card--studio { opacity: 0.78; }
.compare-card--snapsjo {
    background: linear-gradient(160deg, #fff7ea, #fff);
    border: 1px solid rgba(244, 184, 96, 0.55);
    box-shadow: 0 22px 38px -22px rgba(244, 184, 96, 0.5);
    transform: translateY(-6px);
}
.compare-card__tag {
    display: inline-block;
    padding: 5px 12px;
    border-radius: 999px;
    background: var(--canvas);
    color: var(--text-600, #5a4f47);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
}
.compare-card__tag--gold {
    background: linear-gradient(135deg, #c9922a, #b87a18);
    color: #fff;
}
.compare-card__price {
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(28px, 3.4vw, 36px);
    font-weight: 500;
    color: var(--ink);
    margin-bottom: 14px;
}
.compare-card__price small {
    display: block;
    font-size: 12px;
    color: var(--text-500, #897a6f);
    font-weight: 500;
    margin-top: 4px;
}
.compare-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.compare-card ul li {
    font-size: 13.5px;
    color: var(--text-600, #5a4f47);
    padding-left: 18px;
    position: relative;
}
.compare-card ul li::before {
    content: '';
    position: absolute;
    left: 0; top: 9px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--clay);
    opacity: 0.6;
}
.compare-card--snapsjo ul li::before { background: var(--gold); opacity: 1; }

/* Privacy section (dark) */
.narrative-privacy-card {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
    padding: 40px 32px;
}
.narrative-privacy-card .eyebrow {
    color: var(--gold);
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-size: 12px;
    margin-bottom: 10px;
    display: inline-block;
}
.narrative-privacy-card h2 {
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(30px, 4vw, 44px);
    font-weight: 500;
    line-height: 1.1;
    margin: 0 0 18px;
    color: #fff7e6;
}
.narrative-privacy-card h2 .italic-accent { color: var(--gold); }
.narrative-privacy-card > p {
    margin: 0 0 24px;
    color: rgba(250, 246, 239, 0.82);
    font-size: 16.5px;
    line-height: 1.7;
}
.narrative-privacy-card > p strong { color: #fff7e6; }
.narrative-privacy-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px; height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, #c9922a, #b87a18);
    color: #fff;
    margin-bottom: 18px;
}
.narrative-privacy-card__icon svg { width: 28px; height: 28px; }
.narrative-pills {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}
.narrative-pills li {
    padding: 10px 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(244, 184, 96, 0.3);
    color: #fff7e6;
    font-size: 13.5px;
    font-weight: 600;
}

/* Aesthetic section */
.narrative-aesthetic__grid {
    display: grid;
    gap: 36px;
    align-items: center;
}
@media (min-width: 880px) {
    .narrative-aesthetic__grid { grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr); gap: 56px; }
}
.narrative-aesthetic__copy .eyebrow {
    display: inline-block;
    color: var(--clay);
    font-weight: 700;
    margin-bottom: 12px;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.narrative-aesthetic__copy h2 {
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(28px, 3.6vw, 42px);
    font-weight: 500;
    line-height: 1.08;
    margin: 0 0 18px;
    color: var(--ink);
}
.narrative-aesthetic__copy > p {
    margin: 0 0 20px;
    color: var(--text-600, #5a4f47);
    font-size: 16.5px;
    line-height: 1.7;
    max-width: 56ch;
}
.narrative-aesthetic__visual {
    position: relative;
    aspect-ratio: 4/5;
    max-width: 380px;
    margin: 0 auto;
}
.aesthetic-stack {
    position: relative;
    width: 100%;
    height: 100%;
}
.aesthetic-stack__frame {
    position: absolute;
    border-radius: 18px;
    background: linear-gradient(160deg, var(--rose-soft) 0%, var(--gold) 100%);
    border: 4px solid #fff;
    box-shadow: 0 18px 38px -22px rgba(42, 33, 28, 0.4);
}
.aesthetic-stack__frame--a { left: 0; top: 0; width: 62%; aspect-ratio: 3/4; background: linear-gradient(160deg, var(--rose-soft), var(--clay)); transform: rotate(-3deg); }
.aesthetic-stack__frame--b { right: 0; top: 8%; width: 58%; aspect-ratio: 3/4; background: linear-gradient(160deg, var(--mint), var(--olive)); transform: rotate(4deg); }
.aesthetic-stack__frame--c { left: 18%; bottom: 0; width: 60%; aspect-ratio: 3/4; background: linear-gradient(160deg, var(--gold), var(--terracotta)); transform: rotate(-1deg); z-index: 2; }
.aesthetic-stack__seal {
    position: absolute;
    right: -8px;
    bottom: 14%;
    z-index: 3;
    padding: 8px 14px;
    border-radius: 999px;
    background: var(--ink);
    color: var(--gold);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* Secondary CTA band */
.narrative-cta-band {
    padding: clamp(40px, 5vw, 64px) 0;
    background: linear-gradient(135deg, #2A211C 0%, #3d2e22 100%);
    color: #fdf2dc;
    text-align: center;
}
.narrative-cta-band__inner { max-width: 720px; margin: 0 auto; padding: 0 20px; }
.narrative-cta-band__kicker {
    color: var(--gold);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin: 0 0 12px;
}
.narrative-cta-band h2 {
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(28px, 3.6vw, 40px);
    font-weight: 500;
    line-height: 1.1;
    margin: 0 0 24px;
    color: #fff7e6;
}
.narrative-cta-band h2 .italic-accent { color: var(--gold); }
.narrative-cta-band .btn--gold {
    padding: 16px 32px;
    font-size: 16px;
}
.narrative-cta-band__micro {
    margin: 16px 0 0;
    font-size: 13.5px;
    color: rgba(255, 247, 230, 0.7);
}

@media (max-width: 720px) {
    .narrative-compare { grid-template-columns: 1fr; }
    .compare-card--snapsjo { transform: none; }
    .narrative-aesthetic__visual { max-width: 260px; }
}

/* =========================================================================
   HOMEPAGE V2 — AI Portrait Generator hub (multi-niche positioning).
   Namespace: .hv-* (homepage-v2).
   Reuses tokens + .btn from above.
   ========================================================================= */

.hv-link {
    color: var(--clay);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
    font-weight: 600;
}
.hv-link:hover { color: var(--terracotta); }

/* ---------- Baby theme preview placeholders (mirrored from themes.css) ---- */
.hv-style-card .baby-theme-preview {
    position: relative;
    background: var(--canvas);
    width: 100%;
}
.hv-style-card .baby-theme-preview__mat {
    position: relative;
    aspect-ratio: 3 / 4;
    overflow: hidden;
}
.hv-style-card .baby-theme-preview__mat::before {
    content: "";
    position: absolute;
    inset: 10px;
    border: 1px solid rgba(255, 255, 255, 0.35);
    border-radius: 12px;
    pointer-events: none;
    z-index: 2;
}
.hv-style-card .baby-theme-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s var(--ease);
}
.hv-style-card .baby-theme-preview__silhouette {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 50% 36%, rgba(255, 244, 232, 0.95) 0 16%, transparent 17%),
        radial-gradient(ellipse 55% 40% at 50% 36%, rgba(255, 255, 255, 0.25) 0, transparent 100%),
        radial-gradient(ellipse 75% 55% at 50% 100%, rgba(42, 33, 28, 0.2), transparent 65%);
}
.hv-style-card .baby-theme-preview__glow {
    position: absolute;
    inset: auto 15% 18%;
    height: 28%;
    border-radius: 50%;
    background: radial-gradient(ellipse, rgba(255, 255, 255, 0.35), transparent 70%);
    filter: blur(8px);
    pointer-events: none;
}
.hv-style-card .baby-theme-preview--moonlight-dream { background: linear-gradient(168deg, #3a4358 0%, #5c6880 42%, #c4b59a 100%); }
.hv-style-card .baby-theme-preview--royal-baby-portrait { background: linear-gradient(168deg, #3d2a24 0%, #8a5a3a 48%, #e7c873 100%); }
.hv-style-card .baby-theme-preview--angel-soft-portrait { background: linear-gradient(168deg, #faf6f0 0%, #f2e6d6 50%, #f7d6ce 100%); }
.hv-style-card .baby-theme-preview--fairy-tale-baby { background: linear-gradient(168deg, #dde8d5 0%, #c5d4b8 45%, #f4b860 100%); }
.hv-style-card .baby-theme-preview--birthday-studio { background: linear-gradient(168deg, #f7d6ce 0%, #f4b860 52%, #d9a6a0 100%); }
.hv-style-card .baby-theme-preview--classic-newborn-studio { background: linear-gradient(168deg, #e8dcc8 0%, #f3e7d3 50%, #b87952 100%); }

/* ---------- SECTION 1 — HERO ---------- */
.hv-hero {
    position: relative;
    padding: clamp(80px, 9vw, 120px) 0 clamp(56px, 6vw, 88px);
    background:
        radial-gradient(circle at 18% 12%, rgba(231, 200, 115, 0.25), transparent 42%),
        radial-gradient(circle at 88% 6%, rgba(216, 106, 61, 0.14), transparent 38%),
        linear-gradient(165deg, var(--porcelain) 0%, var(--canvas) 100%);
    overflow: hidden;
}
.hv-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(42, 33, 28, 0.03) 1px, transparent 1px);
    background-size: 22px 22px;
    mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
    pointer-events: none;
    z-index: 0;
}
.hv-hero__shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: clamp(28px, 4vw, 56px);
    align-items: center;
}
.hv-hero__copy { max-width: 640px; }
.hv-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 7px 14px 7px 10px;
    border-radius: var(--r-pill);
    background: rgba(255, 252, 246, 0.85);
    border: 1px solid var(--line-warm);
    color: var(--clay);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.hv-hero__badge-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: var(--terracotta);
    box-shadow: 0 0 0 4px rgba(214, 106, 61, 0.18);
}
.hv-hero__title {
    margin: 22px 0 18px;
    font-size: clamp(34px, 5.6vw, 64px);
    line-height: 1.04;
    letter-spacing: -0.02em;
}
.hv-hero__title em {
    font-style: italic;
    color: var(--clay);
    font-weight: 400;
}
.hv-hero__sub {
    font-size: clamp(16px, 1.4vw, 19px);
    color: var(--text-700);
    max-width: 56ch;
    line-height: 1.55;
    margin: 0 0 24px;
}
.hv-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 14px;
}
.hv-hero__micro {
    margin: 6px 0 18px;
    font-size: 13.5px;
    color: var(--text-500);
}
.hv-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}
.hv-hero__chips li {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-700);
}
.hv-hero__chip-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--clay);
}

/* Hero right card */
.hv-hero__card {
    position: relative;
    background: rgba(255, 252, 246, 0.92);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    padding: clamp(22px, 2.5vw, 32px);
    box-shadow: var(--sh);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.hv-hero__card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
}
.hv-hero__card-eyebrow {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 15px;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -0.01em;
}
.hv-hero__card-pill {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: var(--r-pill);
    background: var(--g-gold);
    color: var(--ink);
    font-size: 11.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.hv-hero__flow {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto 1fr;
    align-items: stretch;
    gap: 8px;
    margin-bottom: 20px;
}
.hv-flow-card {
    margin: 0;
    text-align: center;
}
.hv-flow-card__label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-500);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 6px;
}
.hv-flow-card__art {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 3 / 4;
    border-radius: 14px;
    overflow: hidden;
    background: var(--canvas);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.4);
}
.hv-flow-card__art img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.hv-flow-card__art--photo {
    background: var(--canvas);
}
.hv-flow-card__art--style {
    background: linear-gradient(168deg, #dde8d5 0%, #c5d4b8 45%, #f4b860 100%);
}
.hv-flow-card__art--portrait {
    background: var(--canvas);
}
.hv-flow-arrow {
    align-self: center;
    color: var(--clay);
    opacity: 0.7;
}
.hv-flow-arrow svg { width: 18px; height: 18px; }

.hv-hero__steps {
    list-style: none;
    margin: 0 0 18px;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px 14px;
}
.hv-hero__steps li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--text-700);
}
.hv-hero__step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--g-gold);
    color: var(--ink);
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
}
.hv-hero__card-cta { margin-bottom: 14px; }
.hv-hero__avail {
    margin: 0;
    font-size: 12.5px;
    line-height: 1.6;
    color: var(--text-600);
}

@media (max-width: 980px) {
    .hv-hero__shell { grid-template-columns: 1fr; }
    .hv-hero__card { order: 2; max-width: 560px; margin: 0 auto; }
    .hv-hero__copy { order: 1; }
}
@media (max-width: 560px) {
    .hv-hero__title { font-size: clamp(30px, 8vw, 40px); }
    .hv-hero__actions .btn { flex: 1 1 100%; }
    .hv-hero__flow { grid-template-columns: 1fr; }
    .hv-hero__flow .hv-flow-arrow { display: none; }
    .hv-hero__steps { grid-template-columns: 1fr; }
}

/* ---------- SECTION 2 — TRUST STRIP ---------- */
.hv-trust {
    padding: 18px 0 0;
    background: transparent;
}
.hv-trust__strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin: 0 auto;
    padding: 14px;
    list-style: none;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    box-shadow: var(--sh-sm);
}
.hv-trust__chip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 12px;
    border-radius: var(--r-sm);
    font-size: 13.5px;
    font-weight: 600;
    color: var(--text-700);
    text-align: center;
    background: rgba(255, 252, 246, 0.6);
}
.hv-trust__chip-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px; height: 26px;
    border-radius: 50%;
    background: rgba(184, 121, 82, 0.12);
    color: var(--clay);
    flex-shrink: 0;
}
.hv-trust__chip-icon svg { width: 14px; height: 14px; }

@media (max-width: 720px) {
    .hv-trust__strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 420px) {
    .hv-trust__strip { grid-template-columns: 1fr; }
}

/* ---------- SECTION 3 — HOW IT WORKS ---------- */
.hv-how__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    counter-reset: hv-how;
}
.hv-how__card {
    position: relative;
    padding: 28px 22px 24px;
    border-radius: var(--r);
    background: var(--paper);
    border: 1px solid var(--line-warm);
    box-shadow: var(--sh-sm);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.hv-how__card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh);
    border-color: var(--clay);
}
.hv-how__num {
    position: absolute;
    top: 18px;
    right: 22px;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 14px;
    color: var(--clay);
    font-weight: 600;
    letter-spacing: 0.05em;
}
.hv-how__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    border-radius: 12px;
    background: var(--g-gold);
    color: var(--ink);
    margin-bottom: 14px;
}
.hv-how__icon svg { width: 22px; height: 22px; }
.hv-how__card h3 {
    font-size: 18px;
    margin: 0 0 10px;
    line-height: 1.2;
}
.hv-how__card p {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--text-600);
}
.hv-how__cta {
    margin-top: 40px;
    display: flex;
    justify-content: center;
}

@media (max-width: 960px) {
    .hv-how__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 540px) {
    .hv-how__grid { grid-template-columns: 1fr; }
}

/* ---------- SECTION 4 — LIVE BABY PORTRAITS ---------- */
.hv-live {
    background:
        linear-gradient(180deg, var(--porcelain) 0%, #faf3e6 100%);
}
.hv-live__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}
.hv-style-card {
    display: flex;
    flex-direction: column;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    overflow: hidden;
    box-shadow: var(--sh-sm);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.hv-style-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh);
    border-color: var(--clay);
}
.hv-style-card__preview {
    display: block;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    position: relative;
}
.hv-style-card__preview .baby-theme-preview,
.hv-style-card__preview .baby-theme-preview__mat {
    width: 100%;
    height: 100%;
}
.hv-style-card__preview .baby-theme-preview__mat { aspect-ratio: auto; }
.hv-style-card:hover .baby-theme-preview img { transform: scale(1.04); }
.hv-style-card__body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    padding: 18px 18px 18px;
}
.hv-style-card__title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 19px;
    margin: 0 0 8px;
    line-height: 1.2;
}
.hv-style-card__title a {
    color: inherit;
    text-decoration: none;
    background-image: linear-gradient(transparent 92%, rgba(184, 121, 82, 0.4) 92%);
    background-repeat: no-repeat;
    background-size: 0% 100%;
    transition: background-size var(--t), color var(--t);
}
.hv-style-card__title a:hover {
    color: var(--clay);
    background-size: 100% 100%;
}
.hv-style-card__copy {
    margin: 0 0 10px;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-600);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.hv-style-card__best {
    margin: 0 0 14px;
    font-size: 13px;
    color: var(--text-500);
    line-height: 1.5;
}
.hv-style-card__best strong {
    color: var(--text-700);
    font-weight: 700;
}
.hv-style-card__actions {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.hv-style-card__detail-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--clay);
    text-decoration: none;
}
.hv-style-card__detail-link:hover { color: var(--terracotta); }
.hv-live__cta {
    margin-top: 36px;
    display: flex;
    justify-content: center;
}

@media (max-width: 900px) {
    .hv-live__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 540px) {
    .hv-live__grid { grid-template-columns: 1fr; }
}

/* ---------- SECTION 5 — FUTURE PORTRAIT WORLDS ---------- */
.hv-worlds__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}
.hv-world-card {
    display: flex;
    flex-direction: column;
    padding: 22px 20px 22px;
    border-radius: var(--r);
    background: var(--paper);
    border: 1px solid var(--line-warm);
    box-shadow: var(--sh-sm);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.hv-world-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh);
    border-color: var(--clay);
}
.hv-world-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
}
.hv-world-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    border-radius: 12px;
    background: rgba(231, 200, 115, 0.18);
    color: var(--clay);
}
.hv-world-card__icon svg { width: 24px; height: 24px; }
.hv-world-card__badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: var(--r-pill);
    background: rgba(184, 121, 82, 0.12);
    color: var(--clay);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.hv-world-card__title {
    margin: 0 0 8px;
    font-size: 17px;
    line-height: 1.2;
}
.hv-world-card__copy {
    margin: 0 0 16px;
    font-size: 13.5px;
    line-height: 1.5;
    color: var(--text-600);
    flex: 1 1 auto;
}
.hv-world-card__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--clay);
    font-size: 13.5px;
    font-weight: 600;
    text-decoration: none;
    margin-top: auto;
}
.hv-world-card__link svg { width: 14px; height: 14px; }
.hv-world-card__link:hover { color: var(--terracotta); }

@media (max-width: 1100px) {
    .hv-worlds__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
    .hv-worlds__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 440px) {
    .hv-worlds__grid { grid-template-columns: 1fr; }
}

/* ---------- SECTION 6 — WHY SNAPSJO TABLE ---------- */
.hv-why__table-wrap {
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    overflow-x: auto;
}
.hv-why__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 15px;
}
.hv-why__table th,
.hv-why__table td {
    padding: 18px 22px;
    text-align: left;
    vertical-align: top;
    border-bottom: 1px solid var(--line-warm);
}
.hv-why__table thead th {
    background: rgba(243, 231, 211, 0.5);
    font-family: 'Fraunces', Georgia, serif;
    font-size: 15px;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: -0.01em;
}
.hv-why__table tbody th {
    width: 18%;
    font-weight: 700;
    color: var(--text-700);
    background: rgba(255, 252, 246, 0.5);
    white-space: nowrap;
}
.hv-why__table tbody td {
    color: var(--text-600);
    line-height: 1.5;
}
.hv-why__col-snapsjo {
    color: var(--clay) !important;
    background: rgba(231, 200, 115, 0.12) !important;
}
.hv-why__table tbody td:last-child {
    color: var(--text-700);
    font-weight: 500;
    background: rgba(231, 200, 115, 0.05);
}
.hv-why__table tbody tr:last-child th,
.hv-why__table tbody tr:last-child td {
    border-bottom: none;
}
.hv-why__cta {
    margin-top: 36px;
    display: flex;
    justify-content: center;
}

@media (max-width: 720px) {
    .hv-why__table th,
    .hv-why__table td { padding: 14px 16px; font-size: 14px; }
    .hv-why__table tbody th { width: auto; }
}

/* ---------- SECTION 7 — PHOTO TIPS ---------- */
.hv-tips__list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}
.hv-tips__item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 22px 22px 22px 18px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    box-shadow: var(--sh-sm);
}
.hv-tips__num {
    flex: 0 0 auto;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 26px;
    color: var(--clay);
    line-height: 1;
    min-width: 38px;
}
.hv-tips__item-title {
    margin: 0 0 6px;
    font-size: 17px;
    line-height: 1.2;
}
.hv-tips__item-copy {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-600);
}
.hv-tips__cta {
    margin-top: 36px;
    display: flex;
    justify-content: center;
}

@media (max-width: 720px) {
    .hv-tips__list { grid-template-columns: 1fr; }
}

/* ---------- SECTION 8 — PRICING PREVIEW ---------- */
.hv-pricing__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    max-width: 880px;
    margin: 0 auto;
}
.hv-pricing-card {
    display: flex;
    flex-direction: column;
    padding: 30px 28px 28px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.hv-pricing-card--paid {
    border-color: rgba(231, 200, 115, 0.45);
    background:
        linear-gradient(160deg, rgba(255, 247, 230, 0.7) 0%, rgba(255, 252, 246, 0.95) 100%);
    box-shadow: var(--sh);
}
.hv-pricing-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh);
}
.hv-pricing-card__head {
    margin-bottom: 18px;
    padding-bottom: 16px;
    border-bottom: 1px dashed var(--line-warm);
}
.hv-pricing-card__tag {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: var(--r-pill);
    background: rgba(184, 121, 82, 0.12);
    color: var(--clay);
    font-size: 11.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 12px;
}
.hv-pricing-card__tag--gold {
    background: var(--g-gold);
    color: var(--ink);
}
.hv-pricing-card__title {
    margin: 0 0 8px;
    font-size: 22px;
    line-height: 1.15;
}
.hv-pricing-card__price {
    margin: 0 0 4px;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 36px;
    color: var(--ink);
    line-height: 1;
}
.hv-pricing-card__price small {
    font-size: 14px;
    color: var(--text-500);
    font-weight: 400;
    margin-left: 4px;
}
.hv-pricing-card__sub {
    margin: 0;
    font-size: 13.5px;
    color: var(--text-500);
}
.hv-pricing-card__list {
    list-style: none;
    margin: 0 0 22px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1 1 auto;
}
.hv-pricing-card__list li {
    position: relative;
    padding-left: 22px;
    font-size: 14px;
    line-height: 1.5;
    color: var(--text-700);
}
.hv-pricing-card__list li::before {
    content: "";
    position: absolute;
    left: 0; top: 7px;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--g-gold);
    box-shadow: inset 0 0 0 2px rgba(255, 252, 246, 0.9);
}
.hv-pricing__note {
    margin: 22px auto 0;
    max-width: 540px;
    text-align: center;
    font-size: 13px;
    color: var(--text-500);
}

@media (max-width: 720px) {
    .hv-pricing__grid { grid-template-columns: 1fr; }
}

/* ---------- SECTION 9 — AEO / GEO BLOCK ---------- */
.hv-aeo__head {
    max-width: 720px;
    margin: 0 auto 32px;
    text-align: center;
}
.hv-aeo__head h2 {
    font-size: clamp(26px, 4vw, 40px);
    margin: 14px 0 0;
}
.hv-aeo__answer {
    max-width: 760px;
    margin: 0 auto 36px;
    padding: 22px 26px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    font-size: 16px;
    line-height: 1.65;
    color: var(--text-700);
    text-align: center;
}
.hv-aeo__sub-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    max-width: 920px;
    margin: 0 auto;
}
.hv-aeo__sub {
    padding: 22px 24px;
    background: rgba(255, 252, 246, 0.7);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
}
.hv-aeo__sub h3 {
    margin: 0 0 10px;
    font-size: 17px;
    color: var(--clay);
}
.hv-aeo__sub p {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--text-600);
}

@media (max-width: 720px) {
    .hv-aeo__sub-grid { grid-template-columns: 1fr; }
}

/* ---------- SECTION 10 — FAQ ---------- */
.hv-faq__list {
    max-width: 820px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.hv-faq__item {
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    overflow: hidden;
    box-shadow: var(--sh-xs);
    transition: border-color var(--t), box-shadow var(--t);
}
.hv-faq__item[open] {
    border-color: var(--clay);
    box-shadow: var(--sh-sm);
}
.hv-faq__q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 18px 22px;
    list-style: none;
    cursor: pointer;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 17px;
    color: var(--ink);
    font-weight: 500;
    line-height: 1.3;
}
.hv-faq__q::-webkit-details-marker { display: none; }
.hv-faq__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(184, 121, 82, 0.12);
    color: var(--clay);
    flex-shrink: 0;
    transition: transform var(--t), background var(--t);
}
.hv-faq__icon svg { width: 16px; height: 16px; }
.hv-faq__item[open] .hv-faq__icon {
    transform: rotate(180deg);
    background: var(--g-gold);
}
.hv-faq__a {
    padding: 0 22px 18px;
    border-top: 1px dashed var(--line-warm);
    margin-top: -2px;
}
.hv-faq__a p {
    margin: 14px 0 0;
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--text-600);
}
.hv-faq__more {
    max-width: 760px;
    margin: 28px auto 0;
    text-align: center;
    font-size: 14px;
    color: var(--text-500);
    line-height: 1.55;
}

@media (max-width: 540px) {
    .hv-faq__q { font-size: 15.5px; padding: 16px 18px; }
    .hv-faq__a { padding: 0 18px 16px; }
}

/* ---------- SECTION 11 — FINAL CTA ---------- */
.hv-final {
    padding: clamp(48px, 6vw, 96px) 0;
    background: linear-gradient(165deg, var(--porcelain) 0%, var(--canvas) 100%);
    position: relative;
    overflow: hidden;
}
.hv-final::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 12% 80%, rgba(216, 106, 61, 0.16), transparent 42%),
        radial-gradient(circle at 88% 20%, rgba(231, 200, 115, 0.18), transparent 38%);
    pointer-events: none;
}
.hv-final__card {
    position: relative;
    z-index: 1;
    max-width: 760px;
    margin: 0 auto;
    padding: clamp(36px, 5vw, 64px) clamp(24px, 4vw, 56px);
    background: rgba(255, 252, 246, 0.95);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-xl);
    box-shadow: var(--sh-lg);
    text-align: center;
}
.hv-final__eyebrow {
    display: inline-block;
    margin-bottom: 12px;
    color: var(--clay);
    font-size: 12.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.hv-final__card h2 {
    font-size: clamp(28px, 4.4vw, 46px);
    line-height: 1.08;
    margin: 0 0 16px;
}
.hv-final__card p {
    max-width: 56ch;
    margin: 0 auto 28px;
    font-size: 16px;
    line-height: 1.6;
    color: var(--text-600);
}
.hv-final__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-bottom: 18px;
}
.hv-final__micro {
    margin: 0;
    font-size: 13px;
    color: var(--text-500);
}

@media (max-width: 540px) {
    .hv-final__actions .btn { flex: 1 1 100%; }
}

/* ---------- SEO expansion sections ---------- */
.hv-seo {
    padding: clamp(48px, 6vw, 88px) 0;
}
.hv-seo--compact {
    padding-top: clamp(32px, 4vw, 56px);
}
.hv-seo__prose {
    max-width: 72ch;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.hv-seo__prose--inset {
    max-width: none;
    margin: 0 0 32px;
    padding: 24px 26px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
}
.hv-seo__prose p,
.hv-seo__prose li {
    font-size: 16px;
    line-height: 1.65;
    color: var(--text-600);
}
.hv-seo__h3 {
    margin: 0 0 8px;
    font-size: clamp(20px, 2.5vw, 26px);
}
.hv-seo__note {
    padding: 14px 16px;
    border-left: 3px solid var(--champagne);
    background: rgba(231, 200, 115, 0.12);
    border-radius: 0 var(--r-sm) var(--r-sm) 0;
    font-size: 14.5px !important;
}
.hv-seo__cta {
    margin-top: 32px;
    display: flex;
    justify-content: center;
}
.hv-seo__cta--dual {
    gap: 12px;
    flex-wrap: wrap;
}
.hv-seo__split {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 24px;
    align-items: start;
}
.hv-checklist {
    padding: 24px 22px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
}
.hv-checklist__title {
    margin: 0 0 16px;
    font-size: 18px;
}
.hv-checklist__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.hv-checklist__list li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14.5px;
    color: var(--text-700);
    font-weight: 500;
}
.hv-checklist__list svg {
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    color: var(--clay);
}
.hv-style-guide__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}
.hv-style-guide__card {
    padding: 24px 22px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.hv-style-guide__title {
    margin: 0;
    font-size: 20px;
}
.hv-style-guide__copy {
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-600);
}
.hv-style-guide__meta {
    margin: 0;
    display: grid;
    gap: 8px;
}
.hv-style-guide__meta div {
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 8px;
    font-size: 14px;
}
.hv-style-guide__meta dt {
    font-weight: 700;
    color: var(--text-700);
}
.hv-style-guide__meta dd {
    margin: 0;
    color: var(--text-600);
}
.hv-style-guide__btn {
    align-self: flex-start;
    margin-top: 4px;
}
.hv-ideas-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.hv-ideas-card {
    padding: 22px 20px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    box-shadow: var(--sh-sm);
}
.hv-ideas-card__title {
    margin: 0 0 10px;
    font-size: 18px;
}
.hv-ideas-card__why,
.hv-ideas-card__style {
    margin: 0 0 8px;
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--text-600);
}
.hv-compare-cards {
    display: none;
    flex-direction: column;
    gap: 14px;
}
.hv-compare-cards__item {
    padding: 18px 16px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    box-shadow: var(--sh-sm);
}
.hv-compare-cards__topic {
    margin: 0 0 12px;
    font-size: 17px;
}
.hv-compare-cards__col {
    margin-bottom: 10px;
}
.hv-compare-cards__col:last-child {
    margin-bottom: 0;
}
.hv-compare-cards__label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-500);
    margin-bottom: 4px;
}
.hv-compare-cards__col p {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
}
.hv-compare-cards__col--snapsjo {
    padding-top: 10px;
    border-top: 1px dashed var(--line-warm);
}
.hv-compare-cards__col--snapsjo .hv-compare-cards__label {
    color: var(--clay);
}
.hv-glossary__list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 820px;
    margin: 0 auto;
}
.hv-glossary__item {
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    overflow: hidden;
}
.hv-glossary__term {
    padding: 16px 18px;
    font-weight: 600;
    cursor: pointer;
    list-style: none;
    color: var(--ink);
}
.hv-glossary__term::-webkit-details-marker { display: none; }
.hv-glossary__def {
    padding: 0 18px 16px;
}
.hv-glossary__def p {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.55;
}
.gcta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-bottom: 18px;
}
.hv-seo-guide__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
}
.hv-seo-guide__block {
    padding: 24px 24px 22px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
}
.hv-seo-guide__block h3 {
    margin: 0 0 12px;
    font-size: clamp(19px, 2.2vw, 24px);
}
.hv-seo-guide__block p {
    margin: 0 0 12px;
    font-size: 15.5px;
    line-height: 1.65;
    color: var(--text-600);
}
.hv-seo-guide__block p:last-child {
    margin-bottom: 0;
}
.hv-aeo__long {
    margin-top: 24px;
}

@media (max-width: 900px) {
    .hv-seo__split { grid-template-columns: 1fr; }
    .hv-style-guide__grid { grid-template-columns: 1fr; }
    .hv-ideas-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
    .hv-seo__table-desktop { display: none; }
    .hv-compare-cards { display: flex; }
    .hv-seo__cta .btn,
    .hv-seo__cta--dual .btn,
    .gcta__actions .btn { flex: 1 1 100%; }
}

/* =========================================================================
   Premium homepage redesign — Studio Guide, World Map, FAQ filters, motion.
   ========================================================================= */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
    }
    .r-up,
    .fade-up { opacity: 1 !important; transform: none !important; }
}

.section-head--centered {
    text-align: center;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

/* ---------- Portrait Studio Guide ---------- */
.studio-guide {
    position: relative;
    overflow: hidden;
}
.studio-guide::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 8% 10%, rgba(231, 200, 115, 0.16), transparent 38%),
        radial-gradient(circle at 92% 92%, rgba(216, 106, 61, 0.14), transparent 42%);
    pointer-events: none;
}
.studio-guide > .container { position: relative; z-index: 1; }
.studio-guide__layout {
    display: grid;
    grid-template-columns: minmax(280px, 360px) 1fr;
    gap: 40px;
    align-items: start;
    margin-top: 40px;
}
.studio-guide__art {
    position: sticky;
    top: 100px;
    padding: 24px;
    background: linear-gradient(165deg, rgba(255, 252, 246, 0.96), rgba(243, 231, 211, 0.7));
    border: 1px solid var(--line-warm);
    border-radius: var(--r-xl);
    box-shadow: var(--sh-sm);
    text-align: center;
}
.studio-guide__svg {
    width: 100%;
    max-width: 320px;
    height: auto;
    display: block;
    margin: 0 auto 18px;
}
.studio-guide__svg .sg-spark {
    transform-origin: center;
    animation: sgSpark 3.4s ease-in-out infinite;
}
.studio-guide__svg .sg-spark--2 { animation-delay: 1.2s; }
.studio-guide__svg .sg-line {
    stroke-dasharray: 4 6;
    animation: sgDash 6s linear infinite;
}
@keyframes sgSpark {
    0%, 100% { opacity: 0.55; transform: scale(0.85); }
    50% { opacity: 1; transform: scale(1.08); }
}
@keyframes sgDash {
    to { stroke-dashoffset: -40; }
}
.studio-guide__tags {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
}
.studio-guide__tags li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(255, 252, 246, 0.85);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-700);
}
.studio-guide__tag-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--clay);
}
.studio-guide__tag-dot--gold { background: var(--gold); }
.studio-guide__tag-dot--rose { background: var(--rose); }

.studio-guide__cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.studio-guide-card {
    position: relative;
    padding: 22px 22px 0;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.studio-guide-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh);
    border-color: rgba(184, 121, 82, 0.32);
}
.studio-guide-card__head {
    display: grid;
    grid-template-columns: 40px 1fr 24px;
    align-items: center;
    gap: 14px;
    padding-bottom: 18px;
    cursor: pointer;
    list-style: none;
}
.studio-guide-card__head::-webkit-details-marker { display: none; }
.studio-guide-card__icon {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: linear-gradient(150deg, rgba(231, 200, 115, 0.22), rgba(244, 184, 96, 0.18));
    color: var(--clay);
}
.studio-guide-card__icon svg { width: 22px; height: 22px; }
.studio-guide-card__q {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 17px;
    line-height: 1.25;
    color: var(--ink);
    font-weight: 600;
}
.studio-guide-card__chev {
    color: var(--text-500);
    transition: transform 240ms var(--ease);
}
.studio-guide-card__chev svg { width: 18px; height: 18px; }
.studio-guide-card[open] .studio-guide-card__chev { transform: rotate(180deg); color: var(--clay); }
.studio-guide-card__a {
    padding: 0 4px 22px 54px;
}
.studio-guide-card__a p {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--text-600);
}
.studio-guide__cta {
    margin-top: 40px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
}

@media (max-width: 900px) {
    .studio-guide__layout { grid-template-columns: 1fr; }
    .studio-guide__art { position: relative; top: 0; padding: 20px; }
    .studio-guide__cards { grid-template-columns: 1fr; }
    .studio-guide-card__a { padding-left: 54px; }
}
@media (max-width: 540px) {
    .studio-guide__cta .btn { flex: 1 1 100%; }
}

/* ---------- World Map (Portrait Worlds) ---------- */
.world-map {
    position: relative;
    margin-top: 56px;
    padding: 48px 24px 32px;
}
.world-map__lines {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
}
.world-map__hub {
    position: relative;
    z-index: 2;
    max-width: 520px;
    margin: 0 auto 56px;
    padding: 32px 28px 28px;
    background: linear-gradient(160deg, rgba(255, 252, 246, 0.98), rgba(243, 231, 211, 0.95));
    border: 1px solid rgba(231, 200, 115, 0.45);
    border-radius: var(--r-xl);
    box-shadow: var(--sh-warm);
    text-align: center;
    overflow: hidden;
}
.world-map__hub-eyebrow {
    display: inline-block;
    margin-bottom: 8px;
    padding: 4px 12px;
    background: var(--g-gold);
    color: var(--ink);
    border-radius: var(--r-pill);
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.world-map__hub-title {
    margin: 0 0 10px;
    font-size: clamp(26px, 3.4vw, 38px);
}
.world-map__hub-copy {
    margin: 0 auto 22px;
    max-width: 44ch;
    font-size: 15.5px;
    line-height: 1.55;
    color: var(--text-600);
}
.world-map__hub-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}
.world-map__hub-badge {
    position: absolute;
    top: 18px;
    right: 22px;
    padding: 4px 10px;
    background: rgba(168, 185, 163, 0.95);
    color: #FFFCF6;
    border-radius: var(--r-pill);
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.world-map__hub-glow {
    position: absolute;
    inset: -40%;
    background: radial-gradient(circle at 50% 50%, rgba(231, 200, 115, 0.25), transparent 60%);
    pointer-events: none;
    animation: hubGlow 6s ease-in-out infinite;
}
@keyframes hubGlow {
    0%, 100% { opacity: 0.5; transform: scale(1); }
    50% { opacity: 0.9; transform: scale(1.04); }
}

.world-map__orbits {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.world-orbit--group {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.world-orbit__group {
    display: inline-block;
    padding: 4px 10px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-700);
    align-self: flex-start;
}
.world-orbit__card {
    position: relative;
    padding: 20px 18px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    box-shadow: var(--sh-xs);
    transition: transform var(--t), box-shadow var(--t);
}
.world-orbit__card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh-sm);
}
.world-orbit__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}
.world-orbit__icon {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(184, 121, 82, 0.12);
    color: var(--clay);
}
.world-orbit__icon svg { width: 18px; height: 18px; }
.world-orbit__badge,
.floating-badge {
    padding: 3px 8px;
    background: rgba(133, 121, 107, 0.14);
    color: var(--text-600);
    border-radius: var(--r-pill);
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.world-orbit__title {
    margin: 0 0 6px;
    font-size: 17px;
    line-height: 1.2;
}
.world-orbit__copy {
    margin: 0;
    font-size: 13.5px;
    line-height: 1.5;
    color: var(--text-600);
}

@media (max-width: 1000px) {
    .world-map__orbits { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
    .world-map { padding: 32px 0 16px; }
    .world-map__orbits { grid-template-columns: 1fr; }
    .world-map__lines { display: none; }
}

/* ---------- FAQ category filters + premium polish ---------- */
.hv-faq__filters {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin: 24px auto 28px;
    max-width: 880px;
}
.hv-faq__filter {
    padding: 8px 16px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    color: var(--text-700);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--t), color var(--t), border-color var(--t), transform var(--t);
}
.hv-faq__filter:hover {
    border-color: rgba(184, 121, 82, 0.35);
    color: var(--ink);
}
.hv-faq__filter.is-active {
    background: var(--g-cta);
    color: #FFFCF6;
    border-color: transparent;
    transform: translateY(-1px);
    box-shadow: var(--sh-sm);
}
.hv-faq__item[hidden] { display: none !important; }

/* ---------- Reveal animation (used by .r-up) ---------- */
.r-up {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 520ms var(--ease), transform 520ms var(--ease);
}
.r-up.is-visible {
    opacity: 1;
    transform: none;
}

/* ---------- Mobile sticky hero CTA (already wired in JS) ---------- */
body.has-home-hero-sticky { padding-bottom: 80px; }

/* =========================================================================
   Premium SEO callouts, side rails, bento grids, and product-style sections.
   These wrap the existing long-form SEO copy without changing text.
   ========================================================================= */

.section-head--centered .eyebrow { display: inline-block; }

.seo-callout {
    position: relative;
    padding: 18px 22px 20px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    box-shadow: var(--sh-xs);
    transition: transform var(--t), box-shadow var(--t);
}
.seo-callout:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh-sm);
}
.seo-callout--feature {
    background: linear-gradient(160deg, rgba(255, 252, 246, 0.96), rgba(243, 231, 211, 0.78));
    border-color: rgba(231, 200, 115, 0.45);
    box-shadow: var(--sh-sm);
}
.seo-callout__chip {
    display: inline-block;
    margin-bottom: 10px;
    padding: 3px 10px;
    background: rgba(184, 121, 82, 0.12);
    border-radius: var(--r-pill);
    color: var(--clay);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.seo-callout--feature .seo-callout__chip {
    background: var(--g-gold);
    color: var(--ink);
}
.seo-callout p {
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-700);
}

.seo-rail {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 28px;
    align-items: start;
    margin-top: 36px;
}
.seo-rail__main {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.seo-rail__side {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.seo-note {
    padding: 22px 22px 20px;
    background: linear-gradient(160deg, rgba(255, 252, 246, 0.96), rgba(248, 240, 224, 0.88));
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-xs);
}
.seo-note--rose {
    background: linear-gradient(160deg, rgba(247, 214, 206, 0.6), rgba(255, 252, 246, 0.92));
    border-color: rgba(217, 166, 160, 0.35);
}
.seo-note--portrait {
    background:
        radial-gradient(circle at 80% 18%, rgba(231, 200, 115, 0.22), transparent 55%),
        linear-gradient(160deg, rgba(255, 252, 246, 0.96), rgba(243, 231, 211, 0.7));
}
.seo-note__eyebrow {
    display: inline-block;
    margin-bottom: 12px;
    padding: 3px 10px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    color: var(--text-700);
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.seo-note__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 9px;
    font-size: 14px;
    color: var(--text-700);
}
.seo-note__list li { display: flex; align-items: center; gap: 10px; }
.seo-note__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--clay);
    flex: 0 0 8px;
}
.seo-note__dot--gold { background: var(--gold); }
.seo-note__dot--rose { background: var(--rose); }
.seo-note__chips {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.seo-note__chips li {
    padding: 4px 10px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    font-size: 12.5px;
    color: var(--text-700);
}
.seo-note__copy {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-700);
}

.seo-three-col {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 32px;
}

@media (max-width: 960px) {
    .seo-rail { grid-template-columns: 1fr; }
    .seo-rail__side { position: relative; top: 0; }
    .seo-three-col { grid-template-columns: 1fr; }
}

/* ---------- No-prompts flow ---------- */
.no-prompts__flow {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 16px;
    align-items: center;
    margin: 32px 0;
}
.np-card {
    position: relative;
    padding: 22px 20px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-xs);
}
.np-card--cross { opacity: 0.78; }
.np-card__label {
    display: inline-block;
    margin-bottom: 12px;
    padding: 3px 10px;
    background: rgba(133, 121, 107, 0.16);
    color: var(--text-600);
    border-radius: var(--r-pill);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.np-card--styles .np-card__label {
    background: var(--g-gold);
    color: var(--ink);
}
.np-card__prompt {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    padding: 14px 14px;
    background: rgba(133, 121, 107, 0.08);
    border-radius: var(--r);
    font-family: 'Inter', monospace;
    font-size: 13px;
    line-height: 1.45;
    color: var(--text-600);
    font-style: italic;
}
.np-card__cursor {
    width: 2px;
    height: 18px;
    background: var(--text-500);
    animation: npBlink 1.1s steps(2) infinite;
}
@keyframes npBlink { 50% { opacity: 0; } }
.np-card__strike {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 47%, rgba(216, 106, 61, 0.55) 49%, rgba(216, 106, 61, 0.55) 51%, transparent 53%);
    pointer-events: none;
    border-radius: var(--r-lg);
}
.np-card__styles {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.np-card__styles li {
    padding: 8px 12px;
    background: linear-gradient(150deg, rgba(231, 200, 115, 0.18), rgba(244, 184, 96, 0.14));
    border: 1px solid rgba(231, 200, 115, 0.4);
    border-radius: var(--r-pill);
    color: var(--ink);
    font-weight: 600;
    font-size: 13px;
}
.np-arrow {
    color: var(--clay);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.np-arrow svg { width: 32px; height: 32px; }

@media (max-width: 720px) {
    .no-prompts__flow { grid-template-columns: 1fr; }
    .np-arrow svg { transform: rotate(90deg); }
}

/* ---------- Photo tips board ---------- */
.photo-tips__board {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 40px 0 32px;
}
.photo-tips__card {
    padding: 24px 24px 22px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
}
.photo-tips__card--good {
    background: linear-gradient(160deg, rgba(221, 232, 213, 0.5), rgba(255, 252, 246, 0.95));
    border-color: rgba(168, 185, 163, 0.45);
}
.photo-tips__card--avoid {
    background: linear-gradient(160deg, rgba(247, 214, 206, 0.4), rgba(255, 252, 246, 0.95));
    border-color: rgba(217, 166, 160, 0.45);
}
.photo-tips__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.photo-tips__badge {
    padding: 4px 12px;
    border-radius: var(--r-pill);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.photo-tips__badge--good { background: rgba(63, 74, 53, 0.14); color: var(--olive); }
.photo-tips__badge--avoid { background: rgba(216, 106, 61, 0.18); color: var(--terracotta); }
.photo-tips__icon { width: 36px; height: 36px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; }
.photo-tips__icon svg { width: 18px; height: 18px; }
.photo-tips__icon--good { background: rgba(168, 185, 163, 0.32); color: var(--olive); }
.photo-tips__icon--avoid { background: rgba(217, 166, 160, 0.35); color: var(--terracotta); }
.photo-tips__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    font-size: 14.5px;
    color: var(--text-700);
}
.photo-tips__list li {
    position: relative;
    padding-left: 22px;
}
.photo-tips__list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--olive);
    font-weight: 800;
}
.photo-tips__list--avoid li::before {
    content: "✕";
    color: var(--terracotta);
}

@media (max-width: 720px) {
    .photo-tips__board { grid-template-columns: 1fr; }
}

/* ---------- Credits grid ---------- */
.credits-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 18px;
    margin-top: 40px;
}
.credits-card {
    padding: 28px 24px 24px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    display: flex;
    flex-direction: column;
}
.credits-card--free { background: var(--g-paper); }
.credits-card--pack {
    background: linear-gradient(160deg, rgba(255, 247, 230, 0.85), rgba(244, 184, 96, 0.18));
    border-color: rgba(231, 200, 115, 0.45);
    box-shadow: var(--sh);
}
.credits-card--note { background: linear-gradient(160deg, rgba(255, 252, 246, 0.96), rgba(248, 240, 224, 0.85)); }
.credits-card__badge {
    align-self: flex-start;
    padding: 3px 10px;
    background: rgba(184, 121, 82, 0.14);
    color: var(--clay);
    border-radius: var(--r-pill);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 14px;
}
.credits-card__badge--gold { background: var(--g-gold); color: var(--ink); }
.credits-card__badge--soft { background: rgba(133, 121, 107, 0.16); color: var(--text-600); }
.credits-card__title {
    margin: 0 0 8px;
    font-size: 22px;
}
.credits-card__price {
    margin: 0 0 14px;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 32px;
    color: var(--ink);
    line-height: 1;
}
.credits-card__price small {
    font-size: 13px;
    color: var(--text-500);
    font-weight: 400;
}
.credits-card__list {
    list-style: none;
    margin: 0 0 18px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 14px;
    color: var(--text-700);
    flex: 1 1 auto;
}
.credits-card__list li {
    position: relative;
    padding-left: 22px;
}
.credits-card__list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--clay);
    font-weight: 800;
}
.credits-defs { margin: 0; display: flex; flex-direction: column; gap: 12px; }
.credits-defs div { display: flex; flex-direction: column; gap: 4px; }
.credits-defs dt {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
    font-size: 14px;
    color: var(--ink);
}
.credits-defs__dot {
    width: 9px; height: 9px;
    border-radius: 50%;
    background: var(--clay);
}
.credits-defs__dot--gold { background: var(--gold); }
.credits-defs__dot--rose { background: var(--rose); }
.credits-defs dd { margin: 0; font-size: 13.5px; color: var(--text-600); padding-left: 17px; }

@media (max-width: 960px) {
    .credits-grid { grid-template-columns: 1fr; }
}

/* ---------- Account mock card ---------- */
.account-mock {
    max-width: 720px;
    margin: 40px auto 32px;
}
.account-mock__card {
    background: linear-gradient(160deg, #FFFCF6 0%, #F4ECDC 100%);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-xl);
    box-shadow: var(--sh-lg);
    overflow: hidden;
}
.account-mock__head {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--line);
    background: rgba(255, 252, 246, 0.6);
}
.account-mock__dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(133, 121, 107, 0.5); }
.account-mock__dot--gold { background: var(--gold); }
.account-mock__dot--rose { background: var(--rose); }
.account-mock__title {
    margin-left: 8px;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-600);
    letter-spacing: 0.04em;
}
.account-mock__body {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    padding: 20px;
}
.account-mock__tile {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r);
    box-shadow: var(--sh-xs);
}
.account-mock__tile-img {
    width: 100%;
    aspect-ratio: 3 / 4;
    border-radius: var(--r-sm);
    background: linear-gradient(160deg, #DDE8D5, #B87952);
}
.account-mock__tile-img--moon { background: linear-gradient(165deg, #3a4358 0%, #5c6880 42%, #c4b59a 100%); }
.account-mock__tile-img--royal { background: linear-gradient(165deg, #3d2a24 0%, #8a5a3a 48%, #e7c873 100%); }
.account-mock__tile-label {
    font-size: 12.5px;
    color: var(--text-700);
    font-weight: 600;
}
.account-mock__tile--add {
    align-items: center;
    justify-content: center;
    background: rgba(231, 200, 115, 0.16);
    border-style: dashed;
    border-color: rgba(184, 121, 82, 0.4);
    color: var(--clay);
}
.account-mock__plus {
    font-size: 32px;
    font-weight: 600;
    line-height: 1;
    color: var(--clay);
}
.account-mock__foot {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    padding: 16px 20px;
    background: rgba(255, 252, 246, 0.6);
    border-top: 1px solid var(--line);
}
.account-mock__chip {
    padding: 4px 10px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    font-size: 12px;
    font-weight: 600;
    color: var(--text-700);
}
.account-mock__chip--gold { background: var(--g-gold); border-color: transparent; color: var(--ink); }
.account-mock__btn {
    margin-left: auto;
    padding: 6px 14px;
    background: var(--g-cta);
    color: #FFFCF6;
    border-radius: var(--r-pill);
    font-size: 12.5px;
    font-weight: 700;
}

@media (max-width: 540px) {
    .account-mock__body { grid-template-columns: 1fr 1fr; }
    .account-mock__tile--add { grid-column: span 2; }
}

/* ---------- Reel section ---------- */
.reel-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 40px;
    align-items: start;
    margin-top: 40px;
}
.reel-phone {
    position: sticky;
    top: 100px;
    margin: 0 auto;
    width: 240px;
    height: 460px;
    border-radius: 36px;
    background: linear-gradient(160deg, #2A211C, #171412);
    box-shadow: 0 30px 60px rgba(42, 33, 28, 0.3), inset 0 0 0 6px rgba(255, 252, 246, 0.08);
    padding: 14px;
    position: relative;
}
.reel-phone__notch {
    position: absolute;
    top: 22px;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 8px;
    border-radius: 4px;
    background: #171412;
    z-index: 2;
}
.reel-phone__screen {
    width: 100%;
    height: 100%;
    border-radius: 26px;
    background:
        radial-gradient(circle at 30% 20%, rgba(231, 200, 115, 0.35), transparent 50%),
        linear-gradient(160deg, #F7D6CE 0%, #F4B860 50%, #B87952 100%);
    position: relative;
    overflow: hidden;
    padding: 18px;
}
.reel-phone__card {
    position: absolute;
    background: rgba(255, 252, 246, 0.94);
    border-radius: 14px;
    padding: 12px 14px;
    box-shadow: 0 10px 24px rgba(42, 33, 28, 0.18);
    width: 76%;
}
.reel-phone__card--1 { top: 38px; left: 12%; transform: rotate(-2deg); }
.reel-phone__card--2 { top: 50%; left: 12%; transform: translateY(-50%) rotate(1deg); }
.reel-phone__card--3 { bottom: 30px; left: 12%; transform: rotate(-1deg); }
.reel-phone__tag {
    display: inline-block;
    padding: 2px 8px;
    background: var(--g-gold);
    border-radius: var(--r-pill);
    color: var(--ink);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 6px;
}
.reel-phone__title {
    display: block;
    font-family: 'Fraunces', Georgia, serif;
    font-size: 14px;
    color: var(--ink);
    font-weight: 600;
}
.reel-phone__floating {
    position: absolute;
    padding: 6px 12px;
    background: rgba(255, 252, 246, 0.96);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    font-size: 12px;
    font-weight: 600;
    color: var(--ink);
    box-shadow: var(--sh-sm);
    animation: reelFloat 4s ease-in-out infinite;
}
.reel-phone__floating--royal { top: 60px; right: -32px; animation-delay: 0s; }
.reel-phone__floating--birthday { bottom: 100px; left: -36px; animation-delay: 1.2s; }
.reel-phone__floating--moon { bottom: 30px; right: -28px; animation-delay: 2.4s; }
@keyframes reelFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}
.reel-steps__list { list-style: none; margin: 22px 0 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.reel-step {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 16px;
    padding: 18px 20px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-xs);
}
.reel-step__num {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--g-gold);
    color: var(--ink);
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 600;
    font-size: 20px;
}
.reel-step__title {
    margin: 0 0 6px;
    font-size: 17px;
}
.reel-step p {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--text-600);
}
.reel-intro, .reel-foot {
    margin: 0 0 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-700);
}
.reel-foot { margin-top: 18px; font-style: italic; color: var(--text-600); }

@media (max-width: 900px) {
    .reel-layout { grid-template-columns: 1fr; }
    .reel-phone { position: relative; top: 0; }
    .reel-phone__floating { display: none; }
}

/* ---------- SEO bento tags + featured block ---------- */
.seo-bento-tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin: 8px auto 32px;
    max-width: 880px;
}
.seo-bento-tag {
    padding: 5px 12px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    font-size: 12px;
    font-weight: 600;
    color: var(--text-700);
}
.seo-bento { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.seo-bento__block {
    position: relative;
}
.seo-bento__tag {
    display: inline-block;
    margin-bottom: 12px;
    padding: 3px 10px;
    background: rgba(184, 121, 82, 0.12);
    border-radius: var(--r-pill);
    color: var(--clay);
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.seo-bento__block--featured {
    grid-column: span 2;
    background: linear-gradient(160deg, rgba(255, 247, 230, 0.85), rgba(243, 231, 211, 0.7)) !important;
    border-color: rgba(231, 200, 115, 0.45) !important;
}
.seo-bento__block--featured .seo-bento__tag { background: var(--g-gold); color: var(--ink); }

@media (max-width: 900px) {
    .seo-bento { grid-template-columns: 1fr !important; }
    .seo-bento__block--featured { grid-column: span 1; }
}

/* ---------- Reveal chips ---------- */
.reveal-chips {
    list-style: none;
    margin: 24px auto 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}
.reveal-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    background: var(--paper);
    border: 1px solid var(--line-warm);
    border-radius: var(--r-pill);
    font-size: 13px;
    font-weight: 600;
    color: var(--text-700);
}
.reveal-chip__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--clay);
}
.reveal-chip__dot--gold { background: var(--gold); }
.reveal-chip__dot--rose { background: var(--rose); }

/* ---------- Final gallery CTA upgrades ---------- */
.gcta__eyebrow {
    display: inline-block;
    margin-bottom: 8px;
    padding: 4px 12px;
    background: var(--g-gold);
    color: var(--ink);
    border-radius: var(--r-pill);
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.gcta__trust {
    margin: 16px 0 0;
    font-size: 13.5px;
    color: var(--text-500);
    font-style: italic;
}

/* ---------- Footer link button (cookie settings) ---------- */
.footer-link-btn {
    display: inline;
    background: none;
    border: 0;
    padding: 0;
    margin: 0;
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
}
