/* Cherry Bomb - public marketing site + store. Builds on css/book.css design tokens. */

html, body.site-page {
    margin: 0;
    min-height: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

:root {
    /* Cherry Bomb brand palette (Brand Guide CBS) - promoted to :root so the shared
       chrome (header/nav/footer) renders correctly even on non-marketing bodies
       like the embedded booking flow (body.book-page). */
    --cb-ink: #1D1D1B;
    --cb-cream: #F9F4EB;
    --cb-red: #FF3131;
    --cb-pink: #FFA7E1;
    --cb-pink-deep: #ff7fcf;
    --cb-lime: #A6FF34;
    /* Type system - Obviously Wide for big display moments, Acumin Pro for
       everything functional. Archivo / Montserrat stay in the stack as graceful
       fallbacks until the Adobe Fonts kit id is set (see public/_site.php).
       "obviously" (regular width) is a secondary fallback in case a kit exposes
       the Wide cut under the base family name. */
    --site-display: "obviously-wide", "obviously", "Archivo", "Archivo Black", system-ui, sans-serif;
    --site-body: "acumin-pro", "Montserrat", var(--book-font), system-ui, sans-serif;
    /* Small uppercase UI labels (announce bar, eyebrows, micro-labels) ride the
       functional family - Obviously Wide is far too wide to read below ~20px. */
    --site-label: var(--site-body);
    --fw-display-black: 900;
    --fw-display-bold: 700;
    --fw-display-medium: 500;
}

body.site-page {
    background: var(--cb-ink);
    color: var(--cb-cream);
    font-family: var(--site-body);
    font-size: 18px;
    line-height: 1.65;
    font-weight: 400;
}

.site-page a { color: var(--cb-pink); text-decoration: none; }
.site-page a:hover { color: var(--cb-red); }
.site-page img { max-width: 100%; display: block; }

/* ============================================================
   DISPLAY TYPE - Obviously Wide. Treated as a graphic element,
   not just a font: huge, tight, negative-tracked, ALL CAPS, and
   allowed to break aggressively across lines like a poster.
   Obviously Wide only ever appears at large sizes; small labels
   use Acumin (it's far too wide to read below ~20px).
   ============================================================ */
.site-hero h1,
.site-section h1,
.site-section h2,
.site-card-body h3,
.site-artist-head .meta h1,
.site-price-group h3,
.site-cta-band h2 {
    font-family: var(--site-display);
    text-transform: uppercase;
    /* Don't let the browser fake weights/widths - use real Obviously cuts. */
    font-synthesis: none;
}

/* Hero H1 - the loudest moment on the page. Poster-scale, Obviously Wide Black. */
.site-hero h1 {
    font-weight: var(--fw-display-black);
    font-size: clamp(44px, 8vw, 108px);
    line-height: 0.85;
    letter-spacing: -0.03em;
}
/* Section headings + CTA band headings - Obviously Wide Bold. */
.site-section h2,
.site-cta-band h2 {
    font-weight: var(--fw-display-bold);
    font-size: clamp(36px, 5vw, 58px);
    line-height: 0.9;
    letter-spacing: -0.02em;
}
/* Page-title H1s living inside a plain section (merch, cart, checkout, product,
   etc.) - Obviously Wide Bold. Restrained vs. the hero so long product names
   don't blow out the 2-column product layout. */
.site-section h1 {
    font-weight: var(--fw-display-bold);
    font-size: clamp(30px, 4vw, 46px);
    line-height: 0.92;
    letter-spacing: -0.02em;
    overflow-wrap: break-word;
}
/* Card / price-group titles - Obviously Wide Bold, scaled down but still wide. */
.site-card-body h3, .site-price-group h3 {
    font-weight: var(--fw-display-bold);
    letter-spacing: -0.01em;
    line-height: 0.95;
}

.site-wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; width: 100%; }

/* Announcement banner */
.site-announce {
    background: var(--cb-lime); color: var(--cb-ink);
    text-align: center; font-family: var(--site-label); text-transform: uppercase;
    font-weight: 600; font-size: 12px; letter-spacing: 0.12em; line-height: 1.2;
    padding: 7px 16px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.site-announce a { color: var(--cb-ink) !important; text-decoration: none; }
@media (max-width: 600px) {
    .site-announce { font-size: 10.5px; letter-spacing: 0.04em; padding: 5px 12px; }
}
.site-announce a:hover { text-decoration: underline; }

/* Header / nav - centered logo on top, nav row below, actions upper-right */
.site-header {
    position: sticky; top: 0; z-index: 40;
    background: rgba(29, 29, 27, 0.92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255, 167, 225, 0.22);
}
.site-header-top {
    position: relative;
    max-width: 1180px; margin: 0 auto; padding: 14px 24px 8px;
    display: flex; align-items: center; justify-content: center;
}
.site-brand {
    font-weight: var(--fw-display-bold); font-size: 22px; letter-spacing: -0.01em;
    color: var(--cb-pink) !important; text-transform: uppercase; font-family: var(--site-display);
}
.site-brand--logo { display: flex; align-items: center; justify-content: center; }
.site-brand--logo img { height: 48px; width: auto; max-width: 340px; }
@media (max-width: 520px) { .site-brand--logo img { height: 32px; max-width: 180px; } }

.site-header-actions {
    position: absolute; right: 24px; top: 50%; transform: translateY(-50%);
    display: flex; align-items: center; gap: 14px;
}
.site-cart {
    position: relative; display: inline-flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; color: var(--cb-cream) !important;
}
.site-cart:hover { color: var(--cb-pink) !important; }
.site-cart-count {
    position: absolute; top: -1px; right: -2px; min-width: 18px; height: 18px; padding: 0 5px;
    background: var(--cb-red); color: #fff; border-radius: 9px; font-size: 11px; font-weight: 700;
    display: flex; align-items: center; justify-content: center; font-family: var(--book-mono);
}

.site-nav {
    display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 20px;
    max-width: 1180px; margin: 0 auto; padding: 0 24px 12px;
}
.site-nav-link {
    color: var(--cb-cream) !important; font-size: 14px; font-weight: 500;
    letter-spacing: 0.08em; white-space: nowrap; text-transform: uppercase;
    font-family: var(--site-label);
}
/* Self-contained reset so header links (logo, nav, CTA, social icons) never inherit
   the browser default underline on pages whose body lacks .site-page (e.g. booking). */
.site-header a { text-decoration: none; }
@media (max-width: 1120px) and (min-width: 941px) { .site-nav { gap: 16px; } .site-nav-link { font-size: 13px; } }
.site-nav-link:hover, .site-nav-link.is-active { color: var(--cb-pink) !important; }

/* Nested dropdowns */
.site-nav-folder { position: relative; }
.site-nav-folder-toggle { display: inline-flex; align-items: center; gap: 5px; }
.site-nav-folder.is-active > .site-nav-folder-toggle { color: var(--cb-pink) !important; }
.site-nav-caret { font-size: 9px; opacity: 0.8; transition: transform 0.15s ease; }
.site-nav-folder-menu {
    position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(6px);
    background: var(--cb-ink); border: 1px solid rgba(255, 167, 225, 0.28);
    border-radius: 14px; padding: 8px; min-width: 190px; display: none;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.5); z-index: 50;
}
/* Invisible bridge so the menu stays open while the cursor crosses the gap. */
.site-nav-folder-menu::before {
    content: ''; position: absolute; left: 0; right: 0; top: -10px; height: 10px;
}
/* Hover-to-open only on desktop. In the mobile drawer (<=940px) folders are
   click-to-open accordions, so these hover rules must not apply there. */
@media (min-width: 941px) {
    .site-nav-folder:hover .site-nav-folder-menu, .site-nav-folder:focus-within .site-nav-folder-menu { display: block; }
    .site-nav-folder:hover .site-nav-caret { transform: rotate(180deg); }
}
.site-nav-sublink {
    display: block; padding: 9px 14px; border-radius: 9px;
    color: var(--cb-cream) !important; font-family: var(--site-label); text-transform: uppercase;
    font-size: 12.5px; font-weight: 500; letter-spacing: 0.08em;
}
.site-nav-sublink:hover, .site-nav-sublink.is-active { background: rgba(255, 167, 225, 0.16); color: var(--cb-pink) !important; }

.site-nav-cta {
    background: var(--cb-red); color: #fff !important;
    padding: 10px 20px; border-radius: var(--book-radius-pill);
    font-weight: 600; font-size: 13.5px; text-transform: uppercase; letter-spacing: 0.12em;
    font-family: var(--site-label);
}
.site-nav-cta:hover { background: var(--cb-pink-deep); color: var(--cb-ink) !important; }
.site-nav-cta--mobile { display: none; }
.site-nav-head, .site-nav-connect { display: none; }

/* Pink connect-icon row (footer + mobile drawer). */
.site-connect { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.site-connect-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 42px; border-radius: 50%;
    border: 1px solid rgba(255, 167, 225, 0.4); color: var(--cb-pink) !important;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}
.site-connect-icon:hover { background: var(--cb-pink); color: var(--cb-ink) !important; border-color: var(--cb-pink); transform: translateY(-2px); }
.site-footer-connect { margin-top: 16px; }

.site-nav-toggle {
    display: none; background: none; border: 0; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px;
    position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
}
.site-nav-toggle span { width: 24px; height: 2px; background: var(--cb-pink); display: block; }
.site-nav-close { display: none; }

@media (max-width: 940px) {
    .site-nav-toggle { display: flex; }
    .site-header-top { padding: 12px 16px; }
    .site-header-actions { right: 12px; gap: 6px; }
    .site-header-actions .site-nav-cta { display: none; }
    /* Full-screen drawer that slides over from the left (doesn't push the page). */
    .site-nav {
        position: fixed; inset: 0; z-index: 100;
        display: flex; flex-direction: column; align-items: stretch; flex-wrap: nowrap; gap: 0;
        width: 100%; max-width: none; height: 100vh; height: 100dvh; margin: 0;
        padding: 0 0 calc(8px + env(safe-area-inset-bottom));
        background: var(--cb-ink); border-top: 0;
        overflow-y: auto; -webkit-overflow-scrolling: touch;
        transform: translateX(-100%);
        transition: transform 0.28s ease;
    }
    body.site-nav-open { overflow: hidden; }
    body.site-nav-open .site-nav { transform: translateX(0); }
    .site-nav-close {
        position: fixed; top: 10px; right: 14px; z-index: 5;
        display: flex; align-items: center; justify-content: center;
        width: 44px; height: 44px; padding: 0; border: 0; background: transparent;
        color: var(--cb-pink); font-size: 34px; line-height: 1; cursor: pointer;
    }
    /* Drawer header: logo + tagline as the first block at the top of the drawer.
       Kept in normal flow (NOT position:sticky) - iOS Safari mis-renders a sticky
       element inside a fixed, scrolling flex container, floating it over the list. */
    .site-nav-head {
        display: flex; flex-direction: column; align-items: center; gap: 12px;
        padding: 52px 24px 20px; border-bottom: 1px solid rgba(255, 167, 225, 0.12);
        flex: 0 0 auto; background: var(--cb-ink);
    }
    .site-nav-head img { width: 168px; max-width: 62%; height: auto; }
    .site-nav-head-name { font-family: var(--site-display); font-weight: 900; font-size: 22px; text-transform: uppercase; }
    .site-nav-head .tagline {
        margin: 0; color: var(--cb-pink); text-align: center; line-height: 1.5;
        font-family: var(--book-mono); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase;
    }
    .site-nav-link { padding: 14px 24px; font-size: 16px; white-space: normal; border-bottom: 1px solid rgba(255, 167, 225, 0.12); }
    .site-nav-folder { display: flex; flex-direction: column; }
    .site-nav-folder-toggle { justify-content: space-between; }
    /* Smooth grid-rows accordion: animates to the submenu's exact height (no max-height jump). */
    .site-nav-folder-menu {
        position: static; transform: none; display: grid; grid-template-rows: 0fr;
        border: 0; box-shadow: none; background: rgba(255, 167, 225, 0.06);
        border-radius: 0; padding: 0; min-width: 0;
        transition: grid-template-rows 0.28s ease;
    }
    .site-nav-folder-inner { overflow: hidden; min-height: 0; }
    .site-nav-folder.is-open .site-nav-folder-menu { grid-template-rows: 1fr; }
    /* Replace the dropdown arrow with a +/− expand toggle on mobile. */
    .site-nav-caret { font-size: 0; transform: none !important; line-height: 1; opacity: 1; width: 22px; text-align: center; }
    .site-nav-caret::before { content: "+"; font-size: 22px; font-weight: 700; opacity: 1; }
    .site-nav-folder.is-open .site-nav-caret::before { content: "\2212"; }
    .site-nav-folder-menu::before { display: none; }
    .site-nav-sublink { padding: 12px 40px; border-radius: 0; }
    .site-nav-cta--mobile { display: block; margin: 16px 24px 0; text-align: center; }
    /* Connect icons pinned to the bottom of the drawer. */
    .site-nav-connect {
        display: flex; justify-content: center; gap: 16px;
        margin-top: auto; padding: 22px 24px 8px;
    }
}

/* Sections - generous whitespace so the big type has room to breathe. */
.site-main { display: block; }
.site-section { padding: 104px 0; }
/* Sawtooth ::before handles section joins — no flat border (causes a hairline at zigzags). */
.site-section + .site-section { border-top: 0; }
/* Authoritative H2 sizing (matches the display block above; kept here so it
   wins over later component rules). Margin is intentionally large. */
.site-section h2 {
    font-size: clamp(36px, 5vw, 58px); font-weight: var(--fw-display-bold);
    line-height: 0.9; letter-spacing: -0.02em; margin: 0 0 28px;
    overflow-wrap: break-word;
}
.site-section .site-lead { color: var(--book-text-muted); font-size: 19px; line-height: 1.6; max-width: 620px; margin: 0 0 40px; }
.site-lead--lime { color: var(--cb-lime); }
.site-lead--lime strong { color: var(--cb-lime); font-weight: 700; }
.site-eyebrow { color: var(--book-pink); font-family: var(--book-mono); font-size: 13px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 18px; }

/* Hero */
.site-hero { position: relative; padding: 132px 0 104px; text-align: center; overflow: hidden; }
.site-hero::after {
    content: ""; position: absolute; inset: 0; z-index: -1;
    background: radial-gradient(60% 60% at 50% 0%, var(--book-pink-glow), transparent 70%);
}
/* Poster-scale H1. No max-width clamp - let it wrap big and hard. */
.site-hero h1 {
    font-size: clamp(44px, 8vw, 108px); line-height: 0.85; font-weight: var(--fw-display-black);
    letter-spacing: -0.03em; margin: 0 auto 28px; max-width: 14ch;
    overflow-wrap: break-word;
}
/* Service pages (Piercings, Tattoos, etc.) — short titles stay on one line. */
.site-hero h1.site-hero-title--compact {
    max-width: none;
    overflow-wrap: normal;
    word-break: normal;
    white-space: nowrap;
    font-size: clamp(38px, 10.5vw, 96px);
}
@media (max-width: 600px) {
    .site-hero h1.site-hero-title--compact {
        font-size: clamp(34px, 10vw, 52px);
    }
}
@media (max-width: 360px) {
    .site-hero h1.site-hero-title--compact {
        white-space: normal;
        text-wrap: balance;
        font-size: clamp(30px, 9vw, 44px);
    }
}
.site-hero .site-hero-sub { font-size: 20px; line-height: 1.55; color: var(--book-text-muted); max-width: 600px; margin: 0 auto 36px; }
.site-hero-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* Buttons */
.site-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 15px 30px; border-radius: var(--book-radius-pill);
    font-family: var(--site-label); font-weight: 600; font-size: 15px;
    text-transform: uppercase; letter-spacing: 0.12em; line-height: 1;
    background: var(--book-pink); color: #fff !important; border: 0; cursor: pointer;
}
.site-btn:hover { background: var(--book-pink-hover); color: #fff !important; }
.site-btn.secondary { background: transparent; color: var(--book-text) !important; border: 1px solid var(--book-dark-border); }
.site-btn.secondary:hover { border-color: var(--book-pink); color: var(--book-text) !important; background: transparent; }
.site-btn.block { display: flex; width: 100%; }
.site-btn[disabled] { opacity: 0.5; pointer-events: none; }

/* Card grid */
.site-grid { display: grid; gap: 24px; }
.site-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.site-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.site-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .site-grid.cols-3, .site-grid.cols-4 { grid-template-columns: repeat(2, 1fr); } }
/* In the 2-up layout, center a lone odd last card (e.g. the 3rd of 3) across both columns. */
@media (min-width: 601px) and (max-width: 900px) {
    .site-grid.cols-3 > :last-child:nth-child(odd) { grid-column: 1 / -1; width: calc(50% - 12px); justify-self: center; }
}
@media (max-width: 600px) { .site-grid.cols-2, .site-grid.cols-3, .site-grid.cols-4 { grid-template-columns: 1fr; } }

.site-card {
    background: var(--book-dark-elevated); border: 1px solid var(--book-dark-border-soft);
    border-radius: var(--book-radius); overflow: hidden; display: flex; flex-direction: column;
}
.site-card .site-card-media { aspect-ratio: 4 / 3; background: var(--book-dark-surface); object-fit: cover; width: 100%; }
/* Merch collection grid reads cleaner with uniform square tiles. */
.page-merch .site-card .site-card-media { aspect-ratio: 1 / 1; }
/* Pink lift-on-hover for every merch card (matches the gift card). */
.page-merch .site-card { transition: transform 0.15s, border-color 0.2s, box-shadow 0.2s; }
.page-merch .site-card:hover { transform: translateY(-2px); border-color: var(--cb-pink); }
/* Artist listing cards: show the full (already-polaroid) photo, square corners, no frame. */
.site-card--artist { background: transparent; border: 0; border-radius: 0; overflow: visible; align-items: center; text-align: center; }
.site-card--artist .site-card-media {
    aspect-ratio: auto; height: auto; width: 100%; object-fit: contain; border-radius: 0;
    filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.4));
}
.site-card--artist .site-card-media.placeholder { aspect-ratio: 1; background: var(--book-dark-surface); }
.site-card--artist .site-card-body { padding: 16px 4px 0; align-items: center; }

/* Homepage crew cards: full polaroid up top (square top edges), rounded name tab below. */
.site-card--crew { border-top-left-radius: 0; border-top-right-radius: 0; }
.site-card--crew .site-card-media {
    aspect-ratio: auto; height: auto; width: 100%; object-fit: contain; background: transparent; border-radius: 0;
}
.site-card--crew .site-card-media.placeholder { aspect-ratio: 1; background: var(--book-dark-surface); }
.site-card--crew .site-card-body { gap: 4px; }
.site-card--crew .site-card-body .pronouns { font-family: var(--site-body); font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--book-text-muted); }
.site-card--crew .site-card-body .specs { font-size: 14px; color: var(--book-text-muted); }
.site-card .site-card-media.placeholder { display: flex; align-items: center; justify-content: center; color: var(--book-text-faint); font-family: var(--book-mono); }

/* Polaroid tilt: a subtle, per-artist askew angle so photos feel pinned-up and real.
   The angle comes from an inline --tilt var (see site_tilt()). The tilt lives on a thin
   wrapper (.site-polaroid) or the whole crew card so the photo's drop-shadow rotates WITH
   it - keeping transform and the drop-shadow filter on separate elements avoids a Safari
   bug that leaves a stray axis-aligned shadow rectangle behind a rotated image.
   Hover/focus straightens it for a playful, readable beat. */
.site-polaroid { display: block; line-height: 0; transform: rotate(var(--tilt, 0deg)); transition: transform 0.3s ease; }
.site-card--artist .site-polaroid { width: 100%; }
.site-card--crew { transform: rotate(var(--tilt, 0deg)); transition: transform 0.3s ease; }
.site-card--artist:hover .site-polaroid, .site-card--artist:focus-visible .site-polaroid,
.site-artist-mini:hover .site-polaroid, .site-artist-mini:focus-visible .site-polaroid,
.site-card--crew:hover, .site-card--crew:focus-visible { transform: rotate(0deg); }
@media (prefers-reduced-motion: reduce) {
    .site-polaroid, .site-card--crew { transition: none; }
}

/* Merch gift-card tile - a "dummy product" that routes into the gift card flow. */
.site-card--giftcard { transition: transform 0.15s, border-color 0.2s; }
.site-card--giftcard:hover { transform: translateY(-2px); border-color: var(--cb-pink); }
.site-card .site-card-media.giftcard {
    aspect-ratio: 1 / 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
    background: radial-gradient(120% 120% at 50% 0%, var(--cb-pink-deep), var(--cb-pink) 55%, #d65fb0 100%);
    color: #2a0a1f; text-align: center;
}
.site-card--giftcard .giftcard-mark { font-size: 52px; line-height: 1; filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.2)); }
.site-card--giftcard .giftcard-label {
    font-family: var(--site-label); font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.16em; font-size: 14px;
}
.site-card-body { padding: 22px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.site-card-body h3 { margin: 0; font-size: clamp(20px, 2.2vw, 26px); font-weight: var(--fw-display-bold); }
.site-card-body p { margin: 0; color: var(--book-text-muted); font-size: 15px; }
/* Crew (artist) cards - names read like a magazine cover, Obviously Wide Medium. */
.site-card--crew .site-card-body h3 {
    font-weight: var(--fw-display-medium);
    font-size: clamp(20px, 2.2vw, 28px); line-height: 0.92; letter-spacing: -0.02em;
}
.site-card-body .site-card-foot { margin-top: auto; padding-top: 14px; }
.site-card-price { font-family: var(--book-mono); color: var(--book-text); font-size: 16px; }

/* Rich text blocks */
.site-rich { color: var(--book-text); font-size: 18px; line-height: 1.7; max-width: 720px; }
.site-rich > :first-child { margin-top: 0; }
.site-rich > :last-child { margin-bottom: 0; }
.site-rich p { margin: 0 0 1.35em; }
.site-rich p + p { margin-top: 0.15em; }
.site-rich br { display: block; margin-bottom: 1.15em; content: ""; }
.site-rich h2, .site-rich h3 { margin: 1.4em 0 0.4em; }
.site-rich ul, .site-rich ol { padding-left: 1.4em; }
.site-rich a { text-decoration: underline; }

/* Pricing */
.site-price-group { margin-bottom: 40px; }
.site-price-group h3 { font-size: 22px; margin: 0 0 14px; border-bottom: 1px solid var(--book-dark-border-soft); padding-bottom: 10px; }
.site-price-subhead { font-family: var(--book-mono); text-transform: uppercase; letter-spacing: 0.14em; font-size: 13px; color: var(--book-pink); margin: 24px 0 6px; }
.site-price-note { color: var(--book-text-muted); font-size: 14px; margin: -4px 0 16px; }
.site-price-note strong { color: var(--book-text); }
.site-price-list { display: grid; gap: 2px; }
.site-price-row { display: flex; align-items: baseline; gap: 0 12px; padding: 12px 0; border-bottom: 1px solid var(--book-dark-border-soft); }
.site-price-row > div:first-child { flex: 0 1 auto; min-width: 0; }
.site-price-row .name { font-weight: 600; }
.site-price-row .desc { color: var(--book-text-muted); font-size: 14px; }
/* Dotted leader bridging the item and its price so they read together across the gap. */
.site-price-row .leader { flex: 1 1 auto; min-width: 20px; align-self: baseline; border-bottom: 2px dotted rgba(255, 167, 225, 0.32); }
.site-price-row .price { font-family: var(--book-mono); white-space: nowrap; flex: 0 0 auto; transition: color 0.15s ease; }
/* Cute, subtle hover: light up the leader + price in pink to track the row. */
.site-price-row:hover .leader { border-bottom-color: var(--cb-pink); }
.site-price-row:hover .price { color: var(--cb-pink); }

/* Testimonials */
.site-quote { background: var(--book-dark-elevated); border-left: 3px solid var(--book-pink); border-radius: var(--book-radius-md); padding: 24px 28px; }
.site-quote p { font-size: 19px; margin: 0 0 12px; font-style: italic; }
.site-quote cite { color: var(--book-text-muted); font-style: normal; font-family: var(--book-mono); font-size: 14px; }

/* Artist profile */
.site-artist-head { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; margin-bottom: 32px; }
/* Artist photo (uploads are already polaroids): square corners, full uncropped image, no frame. */
.site-artist-head img {
    width: 210px; height: auto; max-width: 60vw;
    border-radius: 0; object-fit: contain;
    filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.4));
}
.site-artist-head .meta h1 {
    margin: 0 0 10px; font-weight: var(--fw-display-medium);
    font-size: clamp(30px, 3.4vw, 42px); line-height: 0.9; letter-spacing: -0.02em;
    overflow-wrap: break-word;
}
.site-artist-head .meta .pronouns { color: var(--book-text-muted); font-family: var(--site-body); font-size: 13px; text-transform: uppercase; letter-spacing: 0.12em; }
.site-tag { display: inline-block; background: var(--book-dark-surface); border: 1px solid var(--book-dark-border); border-radius: var(--book-radius-pill); padding: 5px 12px; font-size: 13px; color: var(--book-text-muted); margin: 4px 6px 0 0; }
.site-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.site-gallery img { aspect-ratio: 1; object-fit: cover; border-radius: var(--book-radius-md); width: 100%; }
.site-gallery.has-captions { grid-template-columns: repeat(3, 1fr); }
.site-gallery figure { margin: 0; }
.site-gallery figure img { aspect-ratio: 4 / 5; }
/* Reference charts (tooth gem menus, etc.) — full image, no crop */
.site-gallery.site-gallery--reference-charts figure img {
    aspect-ratio: auto;
    object-fit: contain;
    height: auto;
    background: var(--book-dark-elevated);
    border: 1px solid var(--book-dark-border-soft);
}
.site-gallery figcaption { color: var(--book-text-muted); font-size: 13px; margin-top: 6px; }
@media (max-width: 700px) { .site-gallery { grid-template-columns: repeat(2, 1fr); } .site-gallery.has-captions { grid-template-columns: repeat(2, 1fr); } }

/* Visit */
.site-visit-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; }
@media (max-width: 800px) { .site-visit-grid { grid-template-columns: 1fr; } }
.site-visit-gallery-head { text-align: center; max-width: 640px; margin: 0 auto 40px; }
.site-visit-gallery-head h2 { margin: 0 0 12px; }
.site-visit-gallery-head .site-lead { margin: 0 auto; }
.site-visit-gallery {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
    align-items: start;
    overflow: visible;
}
.site-visit-gallery-item {
    margin: 0;
    text-align: center;
    overflow: visible;
}
.site-visit-polaroid {
    display: inline-block;
    width: 100%;
    max-width: 100%;
    background: #fff;
    padding: 10px 10px 32px;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.38);
    line-height: 0;
    transform: rotate(var(--tilt, 0deg));
    transform-origin: center center;
    transition: transform 0.25s ease;
    backface-visibility: hidden;
}
.site-visit-polaroid img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 2px;
}
.site-visit-gallery-item:hover .site-visit-polaroid,
.site-visit-gallery-item:focus-within .site-visit-polaroid {
    transform: rotate(0deg);
}
@media (max-width: 960px) {
    .site-visit-gallery { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
    .site-visit-gallery {
        grid-template-columns: minmax(0, 1fr);
        max-width: 380px;
        margin: 0 auto;
    }
}
@media (prefers-reduced-motion: reduce) {
    .site-visit-polaroid { transition: none; }
    .site-visit-gallery-item:hover .site-visit-polaroid,
    .site-visit-gallery-item:focus-within .site-visit-polaroid { transform: rotate(var(--tilt, 0deg)); }
}
.site-info-box { background: var(--book-dark-elevated); border: 1px solid var(--book-dark-border-soft); border-radius: var(--book-radius); padding: 24px; }
.site-info-box h3 { margin: 0 0 12px; }
.site-hours-table { width: 100%; }
.site-hours-table li, .site-hours li { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--book-dark-border-soft); list-style: none; }
.site-hours { padding: 0; margin: 0; }

/* Footer */
.site-footer { background: var(--book-dark); margin-top: 0; position: relative; }
.site-footer::before {
    content: ""; position: absolute; left: 0; right: 0; top: 0; height: 15px;
    transform: translateY(-98%); background: var(--book-dark);
    -webkit-mask: var(--saw-mask) repeat-x bottom / 34px 15px;
            mask: var(--saw-mask) repeat-x bottom / 34px 15px;
    pointer-events: none; z-index: 2;
}
.site-footer-inner { max-width: 1120px; margin: 0 auto; padding: 56px 24px 24px; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; }
@media (max-width: 860px) { .site-footer-inner { grid-template-columns: 1fr 1fr; gap: 28px; } }
@media (max-width: 560px) { .site-footer-inner { grid-template-columns: 1fr; gap: 24px; } }
.site-footer-col h3 { font-family: var(--site-label); font-weight: 600; font-size: 13px; text-transform: uppercase; margin: 0 0 16px; letter-spacing: 0.14em; }
.site-footer-brand { display: inline-block; margin: 0 0 14px; }
.site-footer-brand img { height: 44px; width: auto; max-width: 220px; display: block; }
.site-footer-col p { color: var(--book-text-muted); margin: 0; }
.site-footer-links, .site-footer .site-hours { list-style: none; padding: 0; margin: 0; }
.site-footer-links li { padding: 5px 0; }
.site-footer-links a { color: var(--book-text-muted); }
.site-footer-links a:hover { color: var(--book-text); }
.site-hours-note { color: var(--book-text-faint); font-size: 13px; margin-top: 10px; }
.site-footer-base { max-width: 1120px; margin: 0 auto; padding: 16px 24px 32px; color: var(--book-text-faint); font-size: 13px; border-top: 1px solid var(--book-dark-border-soft); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 10px 20px; }
.site-footer-legal a { color: var(--book-text-muted); text-decoration: none; }
.site-footer-legal a:hover { color: var(--book-text); text-decoration: underline; }
.site-footer-legal span { color: var(--book-text-faint); margin: 0 4px; }
.site-legal-doc { max-width: 760px; margin: 0 auto; }
.site-legal-doc h2 { font-size: clamp(22px, 3vw, 28px); margin: 2em 0 0.6em; }
.site-legal-doc h3 { font-size: 18px; margin: 1.4em 0 0.5em; }
.site-legal-updated { color: var(--book-text-muted); font-size: 15px; margin: 0 0 1.5em; }

/* Store */
.site-flash { background: var(--book-dark-elevated); border: 1px solid var(--book-dark-border); border-radius: var(--book-radius-md); padding: 14px 18px; margin-bottom: 24px; }
.site-flash.error { border-color: #b3344e; color: #ffb3c2; }
.site-flash.success { border-color: #3a7d44; color: #b7f0c0; }

.shop-product { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
@media (max-width: 820px) { .shop-product { grid-template-columns: 1fr; gap: 28px; } }
.shop-gallery-main { border-radius: var(--book-radius); overflow: hidden; background: var(--book-dark-surface); aspect-ratio: 1; }
.shop-gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.shop-thumbs { display: flex; gap: 10px; margin-top: 10px; flex-wrap: wrap; }
.shop-thumbs img { width: 64px; height: 64px; object-fit: cover; border-radius: 10px; cursor: pointer; border: 2px solid transparent; }
.shop-thumbs img.is-active { border-color: var(--book-pink); }
.shop-price { font-family: var(--book-mono); font-size: 26px; margin: 8px 0 20px; }
.shop-variant-row { display: flex; gap: 10px; flex-wrap: wrap; margin: 0 0 22px; }
.shop-variant-opt { padding: 10px 16px; border: 1px solid var(--book-dark-border); border-radius: 10px; cursor: pointer; background: var(--book-dark-surface); color: var(--book-text); font-family: var(--site-body); font-size: 14px; font-weight: 600; }
.shop-variant-opt:hover { border-color: var(--book-pink); }
.shop-variant-opt.is-active { border-color: var(--book-pink); background: var(--book-pink); color: var(--book-black); }
.shop-variant-opt[disabled] { opacity: 0.4; cursor: not-allowed; text-decoration: line-through; }
.shop-options { display: flex; flex-direction: column; gap: 14px; margin: 0 0 18px; }
.shop-option { display: flex; flex-direction: column; gap: 6px; max-width: 320px; }
.shop-option-label { font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--book-text-muted); font-family: var(--site-label); }
.shop-option-select {
    appearance: none; -webkit-appearance: none;
    background: var(--book-dark-surface); color: var(--book-text);
    border: 1px solid var(--book-dark-border); border-radius: 10px;
    padding: 11px 38px 11px 14px; font-size: 15px; font-family: var(--site-body); cursor: pointer;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffa7e1' stroke-width='3'><path d='M6 9l6 6 6-6'/></svg>");
    background-repeat: no-repeat; background-position: right 14px center;
}
.shop-option-select:focus { outline: none; border-color: var(--book-pink); }
.shop-option-select option { color: #111; }
.shop-variant-msg { color: var(--cb-red); font-size: 14px; margin: 0 0 14px; min-height: 1px; }
.shop-qty { display: inline-flex; align-items: center; border: 1px solid var(--book-dark-border); border-radius: 10px; overflow: hidden; margin-right: 12px; }
.shop-qty button { background: var(--book-dark-surface); border: 0; color: var(--book-text); width: 40px; height: 44px; font-size: 20px; cursor: pointer; }
.shop-qty input { width: 48px; height: 44px; text-align: center; background: var(--book-black); border: 0; color: var(--book-text); font-size: 16px; }

.cart-table { width: 100%; border-collapse: collapse; }
.cart-table th, .cart-table td { text-align: left; padding: 14px 10px; border-bottom: 1px solid var(--book-dark-border-soft); }
.cart-table td.num, .cart-table th.num { text-align: right; font-family: var(--book-mono); }
.cart-summary { background: var(--book-dark-elevated); border: 1px solid var(--book-dark-border-soft); border-radius: var(--book-radius); padding: 24px; }
.cart-summary .row { display: flex; justify-content: space-between; padding: 8px 0; }
.cart-summary .row.total { border-top: 1px solid var(--book-dark-border); margin-top: 8px; padding-top: 14px; font-size: 20px; font-weight: 700; }

.site-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .site-form-grid { grid-template-columns: 1fr; } }
.site-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.site-field.full { grid-column: 1 / -1; }
.site-field label { font-size: 14px; color: var(--book-text-muted); }
.site-field:has(input[required]) > label::after,
.site-field:has(select[required]) > label::after,
.site-field:has(textarea[required]) > label::after {
    content: ' *';
    color: var(--book-pink);
    font-weight: 700;
}
.site-field input, .site-field select, .site-field textarea {
    background: var(--book-black); border: 1px solid var(--book-dark-border); border-radius: 10px;
    padding: 12px 14px; color: var(--book-text); font-size: 16px; font-family: inherit;
}
.site-field input:focus, .site-field select:focus, .site-field textarea:focus { outline: none; border-color: var(--book-pink); }

.site-badge { display: inline-block; font-size: 12px; font-family: var(--book-mono); padding: 3px 8px; border-radius: 6px; background: var(--book-dark-surface); color: var(--book-text-muted); }
.site-badge.sold-out { color: #ffb3c2; }

/* ---- Hero with photo ---- */
.site-hero.has-photo { padding: 120px 0 104px; }
.site-hero.has-photo::after {
    background:
        radial-gradient(70% 70% at 50% 0%, var(--book-pink-glow), transparent 72%),
        linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.78) 60%, var(--book-black) 100%),
        var(--site-hero-photo, none);
    background-size: cover, cover, cover;
    background-position: center;
}
.site-hero .site-hero-actions .site-btn { box-shadow: 0 10px 30px rgba(0,0,0,0.35); }

/* ---- Icon service cards ---- */
.site-icon-card { text-align: center; align-items: center; }
.site-icon-card .site-icon-wrap {
    display: flex; align-items: center; justify-content: center;
    padding: 30px 0 6px; background: radial-gradient(60% 60% at 50% 40%, var(--book-pink-glow), transparent 70%);
}
.site-icon-card .site-icon-wrap img { width: 96px; height: 96px; object-fit: contain; filter: drop-shadow(0 6px 16px rgba(0,0,0,0.4)); }
.site-icon-card .site-card-body { align-items: center; text-align: center; }
.site-icon-card .site-card-body p { font-size: 16px; }

/* ---- Trusted by ---- */
.site-trusted {
    position: relative;
    padding: 64px 0 72px;
    background:
        linear-gradient(180deg, rgba(166, 255, 52, 0.1) 0%, rgba(166, 255, 52, 0.02) 38%, transparent 100%),
        var(--cb-ink);
    border-top: 3px solid var(--cb-lime);
    border-bottom: 1px solid var(--book-dark-border-soft);
    overflow: hidden;
}
.site-trusted-glow {
    position: absolute;
    inset: -20% -10% auto;
    height: 70%;
    background: radial-gradient(ellipse 70% 80% at 50% 0%, rgba(166, 255, 52, 0.18), transparent 72%);
    pointer-events: none;
}
.site-trusted .site-wrap { position: relative; z-index: 1; }
.site-trusted-head { text-align: center; margin-bottom: 36px; }
.site-trusted-eyebrow { margin: 0 0 12px; color: var(--cb-lime); }
.site-trusted-title {
    font-family: var(--site-display);
    font-weight: var(--fw-display-bold);
    font-size: clamp(32px, 5vw, 52px);
    line-height: 0.92;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: var(--cb-cream);
    margin: 0;
}
.site-trusted-logos {
    position: relative;
    max-width: 980px;
    margin: 0 auto;
    padding: clamp(24px, 4vw, 36px) clamp(20px, 4vw, 40px);
    border-radius: var(--book-radius-md);
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(166, 255, 52, 0.28);
    box-shadow:
        0 0 48px rgba(166, 255, 52, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.07);
}
.site-trusted-logos::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(255, 167, 225, 0.06), transparent 55%);
    pointer-events: none;
}
.site-trusted-logos img {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
    margin: 0 auto;
    opacity: 1;
    filter: brightness(1.08) contrast(1.04);
}
@media (max-width: 640px) {
    .site-trusted { padding: 48px 0 56px; }
    .site-trusted-head { margin-bottom: 28px; }
    .site-trusted-logos { padding: 20px 16px; }
}

/* ---- CTA band ---- */
.site-cta-band { background: linear-gradient(135deg, rgba(234,100,174,0.12), rgba(176,252,56,0.06)); text-align: center; }

/* ---- Press ---- */
.site-press-list { display: grid; gap: 20px; }
.site-press-item {
    display: flex; gap: 0; align-items: stretch; overflow: hidden;
    background: var(--book-dark-elevated); border: 1px solid var(--book-dark-border-soft);
    border-left: 3px solid var(--book-pink); border-radius: var(--book-radius-md);
    text-decoration: none; color: inherit;
    transition: transform 0.15s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
a.site-press-item:hover { transform: translateY(-2px); border-color: var(--book-pink); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.38); }
.site-press-thumb { flex: 0 0 240px; align-self: stretch; width: 240px; object-fit: cover; background: var(--book-dark-surface); display: block; }
.site-press-body { padding: 24px 26px; display: flex; flex-direction: column; flex: 1 1 auto; min-width: 0; }
.site-press-item .pub { font-family: var(--site-label); font-weight: 600; text-transform: uppercase; letter-spacing: 0.14em; font-size: 12px; color: var(--book-pink); margin: 0 0 8px; }
.site-press-item h3 { margin: 0 0 10px; font-size: 21px; font-weight: 700; }
.site-press-item p { margin: 0 0 12px; color: var(--book-text-muted); }
.site-press-item .read { font-family: var(--book-mono); font-size: 13px; color: var(--book-pink); margin-top: auto; }
@media (max-width: 640px) {
    .site-press-item { flex-direction: column; }
    .site-press-thumb { flex-basis: auto; width: 100%; height: 200px; }
}

/* ---- Cutesy 404 ---- */
.site-404 { padding: 80px 0 96px; text-align: center; }
.site-404-bomb { position: relative; display: inline-block; margin-bottom: 6px; line-height: 1; }
.site-404-cherry { font-size: 72px; display: inline-block; animation: site-404-bob 2.4s ease-in-out infinite; filter: drop-shadow(0 8px 14px rgba(0,0,0,0.3)); }
.site-404-spark {
    position: absolute; top: -6px; right: -14px; font-size: 28px; color: var(--cb-red);
    animation: site-404-spark 1s steps(2, end) infinite;
}
@keyframes site-404-bob { 0%, 100% { transform: translateY(0) rotate(-4deg); } 50% { transform: translateY(-8px) rotate(4deg); } }
@keyframes site-404-spark { 0%, 100% { opacity: 1; transform: scale(1) rotate(0deg); } 50% { opacity: 0.3; transform: scale(1.4) rotate(45deg); } }
.site-404-code {
    font-family: var(--site-display); font-weight: 900; color: var(--cb-ink);
    font-size: clamp(96px, 22vw, 220px); line-height: 0.9; letter-spacing: -0.04em; margin: 4px 0 8px;
    text-shadow: 4px 4px 0 var(--cb-red), 8px 8px 0 rgba(29,29,27,0.18);
}
.site-404-o { display: inline-block; animation: site-404-bob 3s ease-in-out infinite; }
.site-404-lead { font-family: var(--site-display); font-weight: var(--fw-display-bold); text-transform: uppercase; letter-spacing: -0.01em; color: var(--cb-ink); font-size: clamp(22px, 4vw, 34px); line-height: 0.95; margin: 0 0 12px; }
.site-404-sub { color: rgba(29,29,27,0.82); max-width: 520px; margin: 0 auto 28px; font-size: 17px; }
.site-404-actions { margin-bottom: 30px; }
.site-404-links { display: flex; flex-wrap: wrap; gap: 8px 10px; justify-content: center; }
.site-404-links a {
    font-family: var(--book-mono); font-size: 13px; text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--cb-ink); border: 1px solid rgba(29,29,27,0.35); border-radius: var(--book-radius-pill);
    padding: 7px 14px; transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.site-404-links a:hover { background: var(--cb-ink); color: var(--cb-pink); border-color: var(--cb-ink); }
@media (prefers-reduced-motion: reduce) {
    .site-404-cherry, .site-404-spark, .site-404-o { animation: none; }
}

/* Full press article page */
.press-article { max-width: 760px; }
.press-article h1 { margin: 0 0 18px; }
.press-article-cover { width: 100%; max-height: 460px; object-fit: cover; border-radius: var(--book-radius-md); margin: 8px 0 26px; display: block; }
.press-article-body { font-size: 1.05rem; line-height: 1.7; }
.press-article-body p { margin: 0 0 1.35em; }
.press-article-body p + p { margin-top: 0.15em; }
.press-article-body br { display: block; margin-bottom: 1.15em; content: ""; }
.press-article-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 28px; }
.press-article-gallery img { width: 100%; border-radius: var(--book-radius-md); display: block; transition: opacity 0.15s ease; }
.press-article-gallery a:hover img { opacity: 0.9; }
@media (max-width: 600px) { .press-article-gallery { grid-template-columns: 1fr; } }

/* ---- FAQ accordion ---- */
.site-faq-group { margin-bottom: 40px; }
.site-faq-group > h2 { font-size: clamp(20px, 3vw, 26px); margin: 0 0 14px; }
.site-faq-item { border-bottom: 1px solid var(--book-dark-border-soft); }
.site-faq-item > summary { cursor: pointer; list-style: none; padding: 16px 40px 16px 0; position: relative; font-weight: 600; font-size: 17px; }
.site-faq-item > summary::-webkit-details-marker { display: none; }
.site-faq-item > summary::after { content: "+"; position: absolute; right: 6px; top: 14px; font-size: 22px; color: var(--book-pink); font-family: var(--book-mono); transition: transform 0.15s ease; }
.site-faq-item[open] > summary::after { content: "–"; }
.site-faq-item .site-faq-answer { padding: 0 0 18px; color: var(--book-text-muted); font-size: 16px; line-height: 1.7; }
.site-faq-item .site-faq-answer > :first-child { margin-top: 0; }
.site-faq-item .site-faq-answer > :last-child { margin-bottom: 0; }
.site-faq-item .site-faq-answer p { margin: 0 0 1.35em; }
.site-faq-item .site-faq-answer p + p { margin-top: 0.15em; }
.site-faq-item .site-faq-answer br { display: block; margin-bottom: 1.15em; content: ""; }

/* ---- Blog ---- */
.site-blog-list { display: grid; gap: 18px; }
.site-blog-card { display: grid; grid-template-columns: 220px 1fr; gap: 22px; background: var(--book-dark-elevated); border: 1px solid var(--book-dark-border-soft); border-radius: var(--book-radius); overflow: hidden; }
.site-blog-card .thumb { background: var(--book-dark-surface); aspect-ratio: 16/10; object-fit: cover; width: 100%; height: 100%; }
.site-blog-card .thumb.placeholder { display: flex; align-items: center; justify-content: center; color: var(--book-text-faint); font-family: var(--book-mono); font-size: 13px; }
.site-blog-card .body { padding: 22px 24px; display: flex; flex-direction: column; gap: 10px; }
.site-blog-card .meta { font-family: var(--book-mono); font-size: 12px; color: var(--book-text-faint); letter-spacing: 0.05em; }
/* Blog list titles stay on Acumin (Bold) - long sentence-case headlines need
   to scan cleanly; Obviously Wide is reserved for the article's own H1. */
.site-blog-card h3 { margin: 0; font-size: 22px; font-weight: 700; font-family: var(--site-body); text-transform: none; letter-spacing: -0.01em; line-height: 1.2; }
.site-blog-card h3 a { color: var(--book-text) !important; }
.site-blog-card h3 a:hover { color: var(--book-pink) !important; }
.site-blog-card p { margin: 0; color: var(--book-text-muted); font-size: 15px; }
.site-blog-card .read { margin-top: auto; font-family: var(--book-mono); font-size: 13px; }
@media (max-width: 640px) { .site-blog-card { grid-template-columns: 1fr; } .site-blog-card .thumb { aspect-ratio: 16/9; } }

.site-post { max-width: 760px; margin: 0 auto; }
.site-post .post-meta { font-family: var(--book-mono); font-size: 13px; color: var(--book-text-faint); margin: 0 0 10px; letter-spacing: 0.05em; }
.site-post h1 { font-family: var(--site-display); font-weight: var(--fw-display-bold); font-size: clamp(28px, 4.2vw, 46px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 28px; overflow-wrap: break-word; }
.site-post .post-hero { border-radius: var(--book-radius); margin: 0 0 28px; width: 100%; max-height: 460px; object-fit: cover; }
.site-post .site-rich { max-width: none; }
.site-back { display: inline-flex; align-items: center; gap: 6px; font-family: var(--book-mono); font-size: 13px; margin-bottom: 24px; }

/* ---- Map (dark mode) ---- */
.site-map { border: 0; width: 100%; height: 340px; border-radius: var(--book-radius); margin-top: 16px; filter: invert(0.92) hue-rotate(180deg) brightness(0.95) contrast(0.92) grayscale(0.25); }
.site-map.tall { height: 440px; }

/* ---- Section header w/ link ---- */
.site-section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 28px; }
.site-section-head h2 { margin: 0; }
.site-section-head a { font-family: var(--book-mono); font-size: 13px; white-space: nowrap; }

/* ============================================================
   BRAND COLOR SECTIONS - alternating pink / cream / lime / ink
   for the playful Cherry Bomb vibe. Light sections flip text +
   cards + borders to ink-on-light automatically.
   ============================================================ */
.site-section--pink { background: var(--cb-pink); color: var(--cb-ink); }
.site-section--cream { background: var(--cb-cream); color: var(--cb-ink); }
.site-section--lime { background: var(--cb-lime); color: var(--cb-ink); }
.site-section--ink { background: var(--cb-ink); color: var(--cb-cream); }

.site-section--pink + .site-section, .site-section--cream + .site-section,
.site-section--lime + .site-section, .site-section + .site-section--pink,
.site-section + .site-section--cream, .site-section + .site-section--lime,
.site-section + .site-section--ink { border-top: 0; }

/* Light-section overrides */
.site-section--pink h2, .site-section--cream h2, .site-section--lime h2,
.site-section--pink h3, .site-section--cream h3, .site-section--lime h3,
.site-section--pink .site-rich, .site-section--cream .site-rich, .site-section--lime .site-rich { color: var(--cb-ink); }
.site-section--pink .site-lead, .site-section--cream .site-lead, .site-section--lime .site-lead { color: rgba(29, 29, 27, 0.78); }
.site-section--pink .site-eyebrow, .site-section--cream .site-eyebrow, .site-section--lime .site-eyebrow { color: var(--cb-red); }
.site-section--pink a, .site-section--cream a, .site-section--lime a { color: var(--cb-red); }
.site-section--pink a:hover, .site-section--cream a:hover, .site-section--lime a:hover { color: var(--cb-ink); }

/* Cards on light sections become cream/white blocks with ink text */
.site-section--pink .site-card, .site-section--lime .site-card { background: #fff; border-color: rgba(29,29,27,0.14); }
.site-section--cream .site-card { background: #fff; border-color: rgba(29,29,27,0.12); }
.site-section--pink .site-card-body p, .site-section--cream .site-card-body p, .site-section--lime .site-card-body p { color: rgba(29,29,27,0.72); }
.site-section--pink .site-card-body h3, .site-section--cream .site-card-body h3, .site-section--lime .site-card-body h3 { color: var(--cb-ink); }
.site-section--pink .site-card-price, .site-section--cream .site-card-price, .site-section--lime .site-card-price { color: var(--cb-ink); }
.site-section--pink .site-card .site-card-media, .site-section--cream .site-card .site-card-media, .site-section--lime .site-card .site-card-media { background: rgba(29,29,27,0.06); }

/* Price rows / info boxes / quotes on light sections */
.site-section--pink .site-price-row, .site-section--cream .site-price-row, .site-section--lime .site-price-row,
.site-section--pink .site-price-group h3, .site-section--cream .site-price-group h3, .site-section--lime .site-price-group h3 { border-color: rgba(29,29,27,0.16); }
.site-section--pink .site-price-row .desc, .site-section--cream .site-price-row .desc, .site-section--lime .site-price-row .desc { color: rgba(29,29,27,0.7); }
.site-section--pink .site-price-row .leader, .site-section--cream .site-price-row .leader, .site-section--lime .site-price-row .leader { border-bottom-color: rgba(29,29,27,0.22); }
.site-section--pink .site-price-row:hover .leader, .site-section--cream .site-price-row:hover .leader, .site-section--lime .site-price-row:hover .leader { border-bottom-color: var(--cb-red); }
.site-section--pink .site-price-row:hover .price, .site-section--cream .site-price-row:hover .price, .site-section--lime .site-price-row:hover .price { color: var(--cb-red); }
.site-section--pink .site-info-box, .site-section--lime .site-info-box { background: #fff; border-color: rgba(29,29,27,0.14); }
.site-section--cream .site-info-box { background: #fff; border-color: rgba(29,29,27,0.12); }
.site-section--pink .site-hours li, .site-section--cream .site-hours li, .site-section--lime .site-hours li,
.site-section--pink .site-hours-table li, .site-section--cream .site-hours-table li { border-color: rgba(29,29,27,0.14); }
.site-section--pink .site-quote, .site-section--lime .site-quote { background: #fff; border-left-color: var(--cb-red); }
.site-section--cream .site-quote { background: #fff; border-left-color: var(--cb-red); }
.site-section--pink .site-quote cite, .site-section--cream .site-quote cite, .site-section--lime .site-quote cite { color: rgba(29,29,27,0.7); }
.site-section--pink .site-tag, .site-section--cream .site-tag, .site-section--lime .site-tag { background: rgba(29,29,27,0.06); border-color: rgba(29,29,27,0.18); color: var(--cb-ink); }

/* Secondary (outline) buttons need dark ink text + border on any light brand
   background (pink/cream/lime) - sections AND heroes - so they stay legible. */
.site-section--pink .site-btn.secondary, .site-section--cream .site-btn.secondary, .site-section--lime .site-btn.secondary,
.site-hero--pink .site-btn.secondary, .site-hero--cream .site-btn.secondary, .site-hero--lime .site-btn.secondary {
    border-color: var(--cb-ink); color: var(--cb-ink) !important;
}
.site-section--pink .site-btn.secondary:hover, .site-section--cream .site-btn.secondary:hover, .site-section--lime .site-btn.secondary:hover,
.site-hero--pink .site-btn.secondary:hover, .site-hero--cream .site-btn.secondary:hover, .site-hero--lime .site-btn.secondary:hover {
    background: var(--cb-ink); color: var(--cb-cream) !important;
}
/* Primary button on a light brand background: ink text on lime, white on red is fine.
   Guard against any remaining pink-fill primaries by forcing ink text on pink. */
.site-hero--pink .site-btn:not(.secondary):hover, .site-section--pink .site-btn:not(.secondary):hover {
    color: var(--cb-ink) !important;
}

/* Brand buttons everywhere - red primary */
.site-btn { background: var(--cb-red); }
.site-btn:hover { background: var(--cb-pink-deep); color: var(--cb-ink) !important; }

/* Value-prop list ("Why get pierced at Cherry Bomb") */
.site-why-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px 32px; }
@media (max-width: 700px) { .site-why-grid { grid-template-columns: 1fr; } }
.site-why-item { display: flex; gap: 14px; align-items: flex-start; }
.site-why-item .dot { flex: 0 0 auto; width: 12px; height: 12px; border-radius: 50%; background: var(--cb-red); margin-top: 7px; }
.site-why-item h3 { margin: 0 0 4px; font-size: 16px; font-family: var(--site-label); text-transform: uppercase; font-weight: 600; letter-spacing: 0.08em; }
.site-why-item p { margin: 0; font-size: 15px; }

/* Hero on color sections */
.site-hero--pink { background: var(--cb-pink); color: var(--cb-ink); }
.site-hero--cream { background: var(--cb-cream); color: var(--cb-ink); }
.site-hero--pink::after, .site-hero--cream::after { display: none; }
.site-hero--pink h1, .site-hero--cream h1 { color: var(--cb-ink); }
.site-hero--pink .site-hero-sub, .site-hero--cream .site-hero-sub { color: rgba(29,29,27,0.82); }
.site-hero--pink .site-eyebrow, .site-hero--cream .site-eyebrow { color: var(--cb-red); }
.site-hero--pink .site-rich, .site-hero--cream .site-rich, .site-hero--lime .site-rich { color: var(--cb-ink); }
.site-hero--pink .site-rich a, .site-hero--cream .site-rich a, .site-hero--lime .site-rich a { color: var(--cb-red); }

/* Artist mini-cards used on service pages */
.site-artist-mini { text-align: center; }
.site-artist-mini img {
    display: inline-block; width: 160px; height: auto; max-width: 100%;
    border-radius: 0; object-fit: contain; margin: 0 auto 14px;
    filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.32));
}
.site-artist-mini h3 { margin: 0 0 2px; font-size: 18px; font-family: var(--site-display); text-transform: uppercase; font-weight: var(--fw-display-medium); letter-spacing: -0.02em; line-height: 0.95; overflow-wrap: break-word; }
.site-artist-mini .pronouns { font-family: var(--site-body); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.75; margin: 0 0 8px; }
.site-artist-mini .specs { font-size: 13px; opacity: 0.8; }
.site-artists-row { display: flex; flex-wrap: wrap; gap: 36px; justify-content: center; }
.site-artists-row .site-artist-mini { width: 180px; }

/* Service-page photo / type galleries */
.site-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 16px; }
.site-gallery-item { margin: 0; }
.site-gallery-item img {
    width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: var(--book-radius-md);
    background: var(--book-dark-elevated); border: 1px solid var(--book-dark-border-soft); display: block;
}
.site-gallery-item figcaption {
    margin-top: 8px; text-align: center; font-family: var(--site-label); text-transform: uppercase;
    font-weight: 600; letter-spacing: 0.1em; font-size: 13px; color: var(--cb-pink);
}
@media (max-width: 540px) { .site-gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

/* Click-to-enlarge lightbox (artist portfolio) */
.js-lightbox { cursor: zoom-in; transition: opacity 0.15s ease; }
.js-lightbox:hover { opacity: 0.88; }
.site-lightbox {
    position: fixed; inset: 0; z-index: 2000; display: none; align-items: center; justify-content: center;
    background: rgba(0, 0, 0, 0.92); padding: 4vmin; box-sizing: border-box;
}
.site-lightbox.is-open { display: flex; }
.site-lightbox figure { margin: 0; max-width: 100%; max-height: 100%; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.site-lightbox img { max-width: 100%; max-height: 86vh; object-fit: contain; border-radius: var(--book-radius-md); cursor: default; }
.site-lightbox figcaption { color: #fff; font-family: var(--site-body); font-size: 14px; text-align: center; max-width: 60ch; }
.site-lightbox-close {
    position: absolute; top: 16px; right: 20px; width: 44px; height: 44px; border: none; border-radius: 50%;
    background: rgba(255, 255, 255, 0.12); color: #fff; font-size: 30px; line-height: 1; cursor: pointer; z-index: 2;
}
.site-lightbox-close:hover { background: var(--cb-red); }
.site-lightbox-nav {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
    width: 52px; height: 52px; border: none; border-radius: 50%;
    background: rgba(255, 255, 255, 0.12); color: #fff; font-size: 32px; line-height: 1; cursor: pointer;
    display: flex; align-items: center; justify-content: center; padding: 0 0 4px;
    transition: background 0.15s ease;
}
.site-lightbox-nav:hover { background: var(--cb-pink); color: var(--cb-ink); }
.site-lightbox-prev { left: 16px; }
.site-lightbox-next { right: 16px; }
@media (max-width: 600px) { .site-lightbox-nav { width: 44px; height: 44px; font-size: 26px; } .site-lightbox-prev { left: 8px; } .site-lightbox-next { right: 8px; } }

/* ============================================================
   PUNK / GRUNGE LAYER - cute pink-goth, edgy but glossy.
   1) Site-wide film grain
   2) Sawtooth section edges (each section's colour spikes UP
      into whatever sits above it - works over any neighbour)
   3) Grungy gradient + sheen on the brand-colour sections
   ============================================================ */

:root {
    /* Upward-pointing teeth, tiled horizontally. Used as a mask so the band
       only shows where the triangles are. */
    --saw-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='16'%3E%3Cpath d='M0 16 L17 0 L34 16 Z' fill='%23fff'/%3E%3C/svg%3E");
    /* Subtle fractal-noise tile for the film-grain overlay. */
    --grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* 1) Film grain - a fixed, faint texture over the whole page. Sits below the
   mobile drawer (z 100) and lightbox (z 2000) so those stay crisp. */
body.site-page::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 3;
    pointer-events: none;
    background-image: var(--grain);
    background-size: 180px 180px;
    opacity: 0.07;
    mix-blend-mode: soft-light;
}

/* 2) Sawtooth tops. Each section carries its own colour so its background
   "bites" upward into the previous block - reads as torn/spiky punk edges. */
.site-section { --saw-color: var(--cb-ink); position: relative; }
.site-section--pink { --saw-color: var(--cb-pink); }
.site-section--lime { --saw-color: var(--cb-lime); }
.site-section--cream { --saw-color: var(--cb-cream); }
.site-section--ink { --saw-color: var(--cb-ink); }

.site-section::before {
    content: "";
    position: absolute;
    left: 0; right: 0;
    top: -17px;
    height: 17px;
    background: var(--saw-color);
    -webkit-mask: var(--saw-mask) repeat-x bottom / 34px 16px;
            mask: var(--saw-mask) repeat-x bottom / 34px 16px;
    pointer-events: none;
    z-index: 2;
    transform: translateZ(0);
}

/* 3) Grungy gradient + faint top sheen on the brand-colour fields so they feel
   printed/screen-grunge rather than flat fills. */
/* IMPORTANT: each gradient must START (0%) at exactly the sawtooth tooth color
   (--saw-color) so the spikes match the section's top edge. Grunge comes from
   deepening toward the bottom - never a top-anchored sheen, which would make the
   top edge a different colour than the teeth. */
.site-section--pink, .site-hero--pink {
    background-image: linear-gradient(180deg, var(--cb-pink) 0%, var(--cb-pink) 18%, var(--cb-pink-deep) 100%);
}
.site-section--lime {
    background-image: linear-gradient(180deg, var(--cb-lime) 0%, var(--cb-lime) 18%, #8fe61f 100%);
}
.site-section--ink {
    /* Green grunge glow anchored low so the top edge blends seamlessly into
       whatever sits above (no hard seam against flat dark sections). */
    background-image: radial-gradient(130% 110% at 50% 130%, rgba(166,255,52,0.06), transparent 60%),
        linear-gradient(180deg, var(--cb-ink) 0%, #191917 100%);
}

/* Punky eyebrow: a little kicked tag with a leading slash. */
.site-eyebrow::before { content: "// "; opacity: 0.6; }

@media (prefers-reduced-motion: reduce) {
    body.site-page::after { opacity: 0.05; }
}

/* ============================================================
   RESPONSIVE TYPE - keep the display loud but readable, and pull
   the section rhythm in so the big margins don't dwarf phones.
   Display fonts wrap aggressively (overflow-wrap on the headings),
   so these mins keep long single words from blowing out the row.
   ============================================================ */
@media (max-width: 900px) {
    .site-section { padding: 80px 0; }
    .site-hero { padding: 100px 0 76px; }
}
@media (max-width: 600px) {
    .site-section { padding: 60px 0; }
    .site-hero { padding: 80px 0 60px; }
    /* Slightly smaller floor than the desktop clamp so wide Obviously caps
       don't overflow narrow viewports, while still feeling poster-big. */
    .site-hero h1 { font-size: clamp(36px, 11vw, 60px); margin-bottom: 22px; }
    .site-section h2, .site-cta-band h2 { font-size: clamp(28px, 8vw, 46px); margin-bottom: 20px; }
    .site-artist-head .meta h1 { font-size: clamp(28px, 8vw, 40px); }
    .site-card--crew .site-card-body h3 { font-size: clamp(20px, 6vw, 28px); }
    body.site-page { font-size: 17px; }
    /* Extra side room so the tilted crew polaroids don't kiss the screen edges. */
    .site-grid--crew { padding: 0 22px; }
}

/* Homepage hero hugs the header so more of the page lands above the fold.
   Scoped to .page-home so other pages keep their roomier hero. Specificity
   (0,2,0) + late source order beats the base/.has-photo padding. */
.page-home .site-hero { padding-top: 50px; }
@media (max-width: 600px) {
    .page-home .site-hero { padding-top: 28px; }
}

/* FAQ hero has long words ("FREQUENTLY", "QUESTIONS") - pull the headline down
   so they don't fracture awkwardly at the full hero scale. */
.page-faqs .site-hero h1 { font-size: clamp(34px, 5vw, 56px); }
@media (max-width: 600px) {
    .page-faqs .site-hero h1 { font-size: clamp(30px, 8vw, 42px); }
}
