/* =====================================================
   IV Solutions Spa & Wellness — site.css
   Real brand palette: dark mode + champagne gold.
   ===================================================== */

:root {
  /* Real brand colors from logo */
  --c-primary: #D4B58A;             /* champagne gold from logo */
  --c-primary-hover: #E8D4B0;
  --c-primary-glow: rgba(212,181,138,.32);
  --c-primary-soft: rgba(212,181,138,.10);
  --c-secondary: #B89868;            /* deeper bronze */
  --c-accent: #E8D4B0;               /* light cream gold */
  --c-accent-hover: #F4E5C8;

  /* Dark mode text on warm-black bg */
  --c-text: #F5F0E5;                  /* warm cream */
  --c-text-soft: #C5BFB0;
  --c-text-mute: #A09889;            /* AAA-compliant on bg #0A0807 (7.4:1) */

  /* Backgrounds — warm near-black */
  --c-bg: #0A0807;                    /* deep warm black */
  --c-surface: #14110D;               /* slightly elevated */
  --c-surface-2: #1F1B14;             /* cards */
  --c-surface-3: #2A241B;             /* highest elevation */
  --c-border: #2D2820;
  --c-border-strong: #4A4032;

  --c-success: #7FB287;
  --c-warning: #E8B86C;
  --c-danger: #D67560;
  --c-overlay: rgba(10,8,7,.78);

  /* Typography — classical to match the art-deco logo */
  --font-heading: 'Cinzel', 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
  --font-display: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --font-body: 'Inter', 'Lato', system-ui, -apple-system, sans-serif;

  --fs-h1: clamp(2.25rem, 5.4vw, 4.5rem);
  --fs-h2: clamp(1.875rem, 4vw, 3rem);
  --fs-h3: clamp(1.375rem, 2.6vw, 2rem);
  --fs-h4: clamp(1.125rem, 1.8vw, 1.5rem);
  --fs-body: clamp(1rem, 1.05vw, 1.125rem);
  --fs-small: .875rem;
  --fs-eyebrow: .72rem;

  --lh-tight: 1.1;
  --lh-snug: 1.25;
  --lh-normal: 1.65;
  --lh-relaxed: 1.8;
  --ls-tight: -0.02em;
  --ls-wide: .18em;       /* wider for the Cinzel feel */

  --sp-xs: .25rem;
  --sp-sm: .5rem;
  --sp-md: 1rem;
  --sp-lg: 1.5rem;
  --sp-xl: 2rem;
  --sp-2xl: 3rem;
  --sp-3xl: 4rem;
  --sp-4xl: 6rem;
  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 14px;
  --r-xl: 22px;
  --r-pill: 999px;

  --sh-sm: 0 1px 2px rgba(0,0,0,.4);
  --sh-md: 0 6px 24px rgba(0,0,0,.45);
  --sh-lg: 0 20px 60px rgba(0,0,0,.6);
  --sh-glow: 0 14px 40px var(--c-primary-glow);
  --sh-accent-glow: 0 14px 40px rgba(232,212,176,.30);

  --container-w: 1240px;
  --header-h: 88px;
}

@font-face {
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: local('Cinzel'), url(https://fonts.gstatic.com/s/cinzel/v23/8vIU7ww63mVu7gtR-kwKxNvkNOjw-tbnTYrvDE5dxc8.woff2) format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300 700;
  font-display: swap;
  src: local('Cormorant Garamond Italic'), url(https://fonts.gstatic.com/s/cormorantgaramond/v16/64cE-IuIqyDsJP19eHqV5UheGRWUO_qd2hY.woff2) format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: local('Cormorant Garamond'), url(https://fonts.gstatic.com/s/cormorantgaramond/v16/co3YmX5slCNuHLi8bLeY9MK7whWMhyjQAllvuQ.woff2) format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: local('Inter'), url(https://fonts.gstatic.com/s/inter/v18/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2) format('woff2');
}

/* Icon system */
.ico { flex-shrink: 0; vertical-align: middle; }
.ico-wrap { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: var(--r-md); background: var(--c-primary-soft); color: var(--c-primary); border: 1px solid rgba(212,181,138,.18); transition: background .35s, color .35s, transform .4s cubic-bezier(.34,1.56,.64,1), border-color .35s; }
.ico-wrap--sm { width: 42px; height: 42px; }
.ico-wrap--lg { width: 64px; height: 64px; }
.ico-wrap--round { border-radius: 50%; }
.card:hover .ico-wrap { background: var(--c-primary); color: var(--c-bg); transform: translateY(-4px) rotate(-4deg); border-color: var(--c-primary); }
.card--featured .ico-wrap { background: rgba(10,8,7,.18); color: var(--c-bg); border-color: rgba(10,8,7,.2); }
.card:hover.card--featured .ico-wrap { background: var(--c-bg); color: var(--c-primary); }

/* Reset */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: 100px; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body { margin: 0; font-family: var(--font-body); color: var(--c-text); background: var(--c-bg); font-size: var(--fs-body); line-height: var(--lh-normal); -webkit-font-smoothing: antialiased; }
img, svg, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
a { color: var(--c-primary); text-decoration: none; cursor: pointer; }
a:hover { color: var(--c-primary-hover); }
ul, ol { padding-left: 1.25rem; }
address { font-style: normal; }
hr { border: 0; border-top: 1px solid var(--c-border); margin: var(--sp-2xl) 0; }

/* Strong focus ring for keyboard users — pro-max rule */
:focus-visible { outline: 2px solid var(--c-primary); outline-offset: 3px; border-radius: 4px; box-shadow: 0 0 0 4px rgba(212,181,138,.18); }
button:focus-visible, a:focus-visible, [role="button"]:focus-visible { outline-color: var(--c-primary); }
input:focus-visible, textarea:focus-visible, select:focus-visible { outline: 0; }
.input:focus-visible, .textarea:focus-visible, .select:focus-visible { border-color: var(--c-primary); box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-primary) 22%, transparent); }

::selection { background: var(--c-primary); color: var(--c-bg); }

/* Skip link */
.skip-link { position: absolute; top: -100px; left: 1rem; padding: .5rem 1rem; background: var(--c-primary); color: var(--c-bg); border-radius: var(--r-sm); z-index: 200; font-weight: 600; }
.skip-link:focus { top: 1rem; }

/* Typography */
h1,h2,h3,h4 { font-family: var(--font-heading); font-weight: 500; line-height: var(--lh-tight); letter-spacing: var(--ls-tight); color: var(--c-text); margin: 0 0 var(--sp-md); }
h1 { font-size: var(--fs-h1); font-weight: 500; letter-spacing: -.01em; }
h2 { font-size: var(--fs-h2); letter-spacing: -.005em; }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); }
p { margin: 0 0 var(--sp-md); color: var(--c-text-soft); }
em.script, .script { font-family: var(--font-display); font-style: italic; font-weight: 400; color: var(--c-primary); }
.eyebrow { display: inline-block; font-family: var(--font-body); font-size: var(--fs-eyebrow); font-weight: 600; text-transform: uppercase; letter-spacing: var(--ls-wide); color: var(--c-primary); padding: .4rem 1rem; background: var(--c-primary-soft); border: 1px solid var(--c-primary-soft); border-radius: var(--r-pill); margin-bottom: var(--sp-md); }
.eyebrow--accent { color: var(--c-accent); border-color: rgba(232,212,176,.2); background: rgba(232,212,176,.06); }
.lede { font-size: clamp(1.125rem, 1.4vw, 1.25rem); color: var(--c-text-soft); max-width: 64ch; line-height: var(--lh-relaxed); font-weight: 400; }
.answer-block { background: var(--c-surface-2); border-left: 3px solid var(--c-primary); padding: 1.25rem 1.5rem; border-radius: 0 var(--r-md) var(--r-md) 0; font-weight: 400; color: var(--c-text); margin: 1rem 0; }

/* Layout */
.container { max-width: var(--container-w); margin: 0 auto; padding: 0 1.5rem; }
.container--narrow { max-width: 880px; }
.container--wide { max-width: 1480px; }
.section { padding: clamp(3rem, 8vw, 6rem) 0; position: relative; }
.section--surface { background: var(--c-surface); }
.section--accent { background: linear-gradient(180deg, var(--c-surface) 0%, var(--c-bg) 100%); }
.section--gold { background: linear-gradient(135deg, var(--c-primary-soft), var(--c-surface)); border-top: 1px solid var(--c-border); border-bottom: 1px solid var(--c-border); }
.section__head { max-width: 760px; margin: 0 auto var(--sp-2xl); text-align: center; }
.section__head--left { text-align: left; margin-left: 0; }

.grid { display: grid; gap: var(--sp-xl); }
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.grid--4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.split { display: grid; gap: clamp(2rem, 5vw, 4rem); grid-template-columns: 1fr; align-items: center; }
@media (min-width: 900px) {
  .split { grid-template-columns: 1.05fr 1fr; }
  .split--reverse { grid-template-columns: 1fr 1.05fr; }
  .split--reverse > :first-child { order: 2; }
}

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .55rem; padding: .9rem 1.6rem; border-radius: var(--r-pill); font-family: var(--font-body); font-weight: 600; font-size: .92rem; line-height: 1; text-align: center; letter-spacing: .05em; text-transform: uppercase; transition: transform .2s, box-shadow .25s, background .25s, color .25s, border-color .25s; will-change: transform; border: 1.5px solid transparent; cursor: pointer; min-height: 44px; }
.btn--primary { background: var(--c-primary); color: var(--c-bg); }
.btn--primary:hover { background: var(--c-primary-hover); color: var(--c-bg); transform: translateY(-2px); box-shadow: var(--sh-glow); }
.btn--accent { background: var(--c-accent); color: var(--c-bg); }
.btn--accent:hover { background: var(--c-accent-hover); color: var(--c-bg); transform: translateY(-2px); box-shadow: var(--sh-accent-glow); }
.btn--ghost { background: transparent; color: var(--c-primary); border-color: var(--c-primary); }
.btn--ghost:hover { background: var(--c-primary); color: var(--c-bg); transform: translateY(-2px); }
.btn--wa { background: #25D366; color: #fff; }
.btn--wa:hover { background: #1FAA52; color: #fff; transform: translateY(-2px); }
.btn--sm { padding: .65rem 1.2rem; font-size: .76rem; min-height: 44px; }
.btn--lg { padding: 1.1rem 2.2rem; font-size: .98rem; }
.btn--block { width: 100%; }
.btn:active { transform: translateY(0); }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none !important; }
.btn-row { display: flex; flex-wrap: wrap; gap: .85rem; }
.btn-row--center { justify-content: center; }

.link-fancy { position: relative; font-weight: 600; }
.link-fancy::after { content: ''; position: absolute; bottom: -3px; left: 0; right: 0; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .35s cubic-bezier(.4,0,.2,1); }
.link-fancy:hover::after { transform: scaleX(1); transform-origin: left; }

/* Header */
.site-header { position: sticky; top: 0; z-index: 80; background: transparent; transition: transform .3s cubic-bezier(.4,0,.2,1), background .25s, box-shadow .25s, backdrop-filter .25s; }
.site-header.is-scrolled { background: rgba(10,8,7,.85); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--c-border); }
.site-header.is-hidden { transform: translateY(-100%); }
.site-header__bar { padding: .85rem 0; }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.logo { display: inline-flex; align-items: center; gap: .65rem; color: var(--c-primary); font-weight: 600; }
.logo__img { display: block; height: 56px; width: auto; }
.logo--header .logo__img { height: 58px; }
.logo--footer .logo__img { height: 70px; }

.site-nav { display: none; }
@media (min-width: 1100px) { .site-nav { display: block; } }
.site-nav__list { display: flex; align-items: center; gap: 1.8rem; list-style: none; margin: 0; padding: 0; }
.site-nav__list > li > a { color: var(--c-text); font-family: var(--font-body); font-size: .82rem; font-weight: 600; padding: .4rem 0; position: relative; text-transform: uppercase; letter-spacing: .12em; transition: color .2s; }
.site-nav__list a.is-active { color: var(--c-primary); }
.site-nav__list a:hover { color: var(--c-primary); }
.site-nav__list .has-sub { position: relative; }
.site-nav__sub { position: absolute; top: 100%; left: -1.25rem; min-width: 340px; padding: .75rem; background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-md); box-shadow: var(--sh-lg); opacity: 0; visibility: hidden; transform: translateY(8px); transition: opacity .2s, transform .2s, visibility .2s; display: grid; gap: .15rem; }
.site-nav__list .has-sub:hover .site-nav__sub,
.site-nav__list .has-sub:focus-within .site-nav__sub { opacity: 1; visibility: visible; transform: translateY(0); }
.site-nav__sub a { display: block; padding: .75rem 1rem; border-radius: var(--r-sm); }
.site-nav__sub a strong { display: block; font-size: .92rem; color: var(--c-text); font-family: var(--font-heading); font-weight: 500; letter-spacing: .02em; }
.site-nav__sub a span { display: block; font-size: .78rem; color: var(--c-text-mute); margin-top: 3px; }
.site-nav__sub a:hover { background: var(--c-surface-3); }
.site-nav__sub a:hover strong { color: var(--c-primary); }

.site-header__cta { display: none; align-items: center; gap: 1rem; }
@media (min-width: 1100px) { .site-header__cta { display: flex; } }
.header-phone { display: inline-flex; align-items: center; gap: .5rem; color: var(--c-text); font-weight: 600; font-size: .85rem; letter-spacing: .04em; transition: color .2s; }
.header-phone:hover { color: var(--c-primary); }
.header-phone .ico { color: var(--c-primary); }
.cart-btn { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: var(--r-pill); border: 1px solid var(--c-border); color: var(--c-text); cursor: pointer; transition: border-color .2s, color .2s, background .2s; }
.cart-btn:hover { border-color: var(--c-primary); color: var(--c-primary); }
.cart-btn__count { position: absolute; top: -4px; right: -4px; background: var(--c-primary); color: var(--c-bg); font-size: .68rem; font-weight: 700; min-width: 18px; height: 18px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; padding: 0 5px; }

.nav-toggle { display: inline-flex; flex-direction: column; gap: 5px; padding: .85rem; min-width: 44px; min-height: 44px; align-items: center; justify-content: center; cursor: pointer; }
@media (min-width: 1100px) { .nav-toggle { display: none; } }
.nav-toggle span { display: block; width: 26px; height: 2px; background: var(--c-text); transition: transform .3s, opacity .3s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); background: var(--c-primary); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); background: var(--c-primary); }

/* Mobile menu */
.site-nav-mobile { position: fixed; inset: 0; background: var(--c-bg); z-index: 70; transform: translateX(100%); transition: transform .35s cubic-bezier(.4,0,.2,1); padding: 5rem 1.5rem 2rem; overflow-y: auto; }
.site-nav-mobile.is-open { transform: translateX(0); }
.site-nav-mobile a { display: block; padding: 1rem 0; border-bottom: 1px solid var(--c-border); color: var(--c-text); font-size: 1.05rem; font-weight: 500; opacity: 0; transform: translateY(12px); transition: opacity .3s, transform .3s, color .2s; }
.site-nav-mobile a:hover { color: var(--c-primary); }
.site-nav-mobile.is-open a { opacity: 1; transform: translateY(0); }
.site-nav-mobile.is-open a:nth-child(1) { transition-delay: 100ms; }
.site-nav-mobile.is-open a:nth-child(2) { transition-delay: 150ms; }
.site-nav-mobile.is-open a:nth-child(3) { transition-delay: 175ms; }
.site-nav-mobile.is-open a:nth-child(4) { transition-delay: 200ms; }
.site-nav-mobile.is-open a:nth-child(5) { transition-delay: 220ms; }
.site-nav-mobile.is-open a:nth-child(n+6) { transition-delay: 250ms; }
.site-nav-mobile__actions { display: grid; gap: .65rem; margin-top: 1.5rem; }
body.nav-locked { overflow: hidden; }

/* Hero */
.hero { position: relative; padding: clamp(3rem, 8vw, 6rem) 0 clamp(3rem, 8vw, 7rem); overflow: hidden; isolation: isolate; }
.hero--with-bg { color: var(--c-text); }
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: .55; animation: kenburns 22s ease-in-out infinite alternate; }
.hero__bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(10,8,7,.86) 0%, rgba(10,8,7,.68) 55%, rgba(10,8,7,.92) 100%); }
.hero__inner { position: relative; max-width: 760px; }
.hero__eyebrow { opacity: 0; transform: translateY(16px); animation: heroIn .6s cubic-bezier(.4,0,.2,1) .1s forwards; }
.hero__title { opacity: 0; transform: translateY(24px); animation: heroIn .7s cubic-bezier(.4,0,.2,1) .2s forwards; }
.hero--with-bg .hero__title { color: var(--c-text); }
.hero__subtitle { opacity: 0; transform: translateY(20px); animation: heroIn .7s cubic-bezier(.4,0,.2,1) .35s forwards; margin-bottom: var(--sp-xl); }
.hero__ctas { opacity: 0; transform: translateY(20px); animation: heroIn .7s cubic-bezier(.4,0,.2,1) .5s forwards; }
.hero__trust { opacity: 0; transform: translateY(20px); animation: heroIn .7s cubic-bezier(.4,0,.2,1) .65s forwards; margin-top: 1.5rem; font-size: var(--fs-small); color: var(--c-text-soft); display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.hero__trust .check { color: var(--c-primary); font-weight: 700; }
.dot { display: inline-block; width: 4px; height: 4px; border-radius: 50%; background: var(--c-text-mute); }

@keyframes heroIn { to { opacity: 1; transform: translateY(0); } }
@keyframes kenburns { from { transform: scale(1) translate(0,0); } to { transform: scale(1.08) translate(-2%, -2%); } }

.hero--light { background: linear-gradient(180deg, var(--c-surface) 0%, var(--c-bg) 100%); color: var(--c-text); }
.hero--light .hero__title { color: var(--c-text); }
.hero--light .hero__subtitle { color: var(--c-text-soft); }
.hero--light .hero__trust { color: var(--c-text-mute); }

/* Trust bar */
.trust-bar { padding: 1.25rem 0; background: var(--c-surface); border-top: 1px solid var(--c-border); border-bottom: 1px solid var(--c-border); overflow: hidden; }
.trust-bar__inner { display: flex; align-items: center; flex-wrap: wrap; gap: 1.5rem 2.5rem; justify-content: center; text-align: center; }
.trust-bar__item { display: inline-flex; align-items: center; gap: .6rem; font-size: .85rem; color: var(--c-text-soft); font-weight: 500; letter-spacing: .04em; }
.trust-bar__item .ico-wrap { color: var(--c-primary); background: rgba(212,181,138,.08); border-color: rgba(212,181,138,.15); }

/* Marquee */
.marquee { overflow: hidden; mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent); }
.marquee__track { display: flex; gap: 4rem; animation: marquee 40s linear infinite; width: max-content; }
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Cards — pro-max: cursor + hover-only-on-pointer-devices */
.card { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.85rem; transition: transform .3s cubic-bezier(.4,0,.2,1), box-shadow .3s, border-color .3s, background .3s; color: var(--c-text); display: flex; flex-direction: column; cursor: pointer; }
a.card, a.product-card, a.drip-card { color: var(--c-text); }
@media (hover: hover) {
  .card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--c-primary); background: var(--c-surface-3); }
}
@media (hover: none) {
  .card:active { transform: translateY(-2px); border-color: var(--c-primary); }
}
.card__icon { width: 52px; height: 52px; border-radius: var(--r-md); background: var(--c-primary-soft); color: var(--c-primary); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1.25rem; font-size: 1.6rem; transition: transform .4s cubic-bezier(.34,1.56,.64,1); border: 1px solid rgba(212,181,138,.18); }
.card:hover .card__icon { transform: translateY(-4px) rotate(-4deg); background: var(--c-primary); color: var(--c-bg); }
.card__title { font-size: 1.25rem; font-weight: 500; font-family: var(--font-heading); color: var(--c-text); margin-bottom: .5rem; letter-spacing: -.01em; }
.card__text { font-size: .96rem; color: var(--c-text-soft); margin-bottom: 1rem; flex-grow: 1; }
.card__link { color: var(--c-primary); font-weight: 600; font-size: .82rem; display: inline-flex; align-items: center; gap: .35rem; text-transform: uppercase; letter-spacing: .12em; margin-top: auto; }
.card__link::after { content: '→'; transition: transform .25s; }
.card:hover .card__link::after { transform: translateX(4px); }
.card--featured { background: linear-gradient(155deg, var(--c-primary) 0%, var(--c-secondary) 100%); color: var(--c-bg); border-color: transparent; }
.card--featured .card__title, .card--featured .card__text { color: var(--c-bg); }
.card--featured .card__text { opacity: .82; }
.card--featured .card__icon { background: rgba(10,8,7,.18); color: var(--c-bg); border-color: rgba(10,8,7,.2); }
.card:hover.card--featured .card__icon { background: var(--c-bg); color: var(--c-primary); }
.card--featured .card__link { color: var(--c-bg); }

/* Process steps */
.process { display: grid; gap: 1.25rem; counter-reset: step; }
@media (min-width: 720px) { .process { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.5rem; } }
.process__step { padding: 2rem 1.5rem 1.75rem; background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); position: relative; }
.process__step::before { counter-increment: step; content: counter(step, decimal-leading-zero); position: absolute; top: 1.4rem; right: 1.4rem; font-family: var(--font-heading); font-size: 2.25rem; color: var(--c-primary); font-weight: 500; line-height: 1; opacity: .8; }
.process__step h3 { font-size: 1.15rem; margin-top: 1.75rem; margin-bottom: .5rem; }
.process__step p { font-size: .95rem; margin: 0; }

/* Testimonials */
.testimonial { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.85rem; display: flex; flex-direction: column; gap: 1rem; }
.testimonial__stars { color: var(--c-primary); letter-spacing: 3px; font-size: 1rem; }
.testimonial__quote { font-family: var(--font-display); font-style: italic; font-size: 1.2rem; font-weight: 400; color: var(--c-text); line-height: 1.45; flex-grow: 1; }
.testimonial__cite { display: flex; align-items: center; gap: .85rem; padding-top: .85rem; border-top: 1px solid var(--c-border); }
.testimonial__avatar { width: 46px; height: 46px; border-radius: 50%; background: var(--c-surface-3); object-fit: cover; }
.testimonial__name { font-weight: 600; font-size: .92rem; color: var(--c-text); }
.testimonial__role { font-size: .82rem; color: var(--c-text-mute); }

/* Stats */
.stats { display: grid; gap: 1.5rem; grid-template-columns: repeat(2, 1fr); text-align: center; }
@media (min-width: 720px) { .stats { grid-template-columns: repeat(4, 1fr); gap: 2rem; } }
.stats__item .num { font-family: var(--font-heading); font-size: clamp(2.25rem, 4vw, 3.25rem); font-weight: 500; color: var(--c-primary); line-height: 1; display: block; letter-spacing: -.02em; }
.stats__item .label { font-size: .78rem; color: var(--c-text-mute); margin-top: .5rem; display: block; letter-spacing: .14em; text-transform: uppercase; }

/* FAQ accordion */
.accordion { border-top: 1px solid var(--c-border); }
.accordion__item { border-bottom: 1px solid var(--c-border); }
.accordion__trigger { width: 100%; padding: 1.5rem 0; display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; text-align: left; font-weight: 500; font-size: 1.1rem; color: var(--c-text); font-family: var(--font-heading); transition: color .2s; letter-spacing: -.005em; }
.accordion__trigger:hover { color: var(--c-primary); }
.accordion__icon { flex-shrink: 0; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--c-border); display: inline-flex; align-items: center; justify-content: center; transition: transform .3s, background .3s, border-color .3s, color .3s; color: var(--c-primary); }
.accordion__item.is-open .accordion__icon { transform: rotate(180deg); background: var(--c-primary); color: var(--c-bg); border-color: var(--c-primary); }
.accordion__content { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s cubic-bezier(.4,0,.2,1); }
.accordion__item.is-open .accordion__content { grid-template-rows: 1fr; }
.accordion__content > div { overflow: hidden; }
.accordion__body { padding: 0 0 1.5rem; color: var(--c-text-soft); }
.accordion__body p:last-child { margin-bottom: 0; }

/* CTA block */
.cta-block { background: linear-gradient(135deg, var(--c-surface-2) 0%, var(--c-surface) 100%); color: var(--c-text); border: 1px solid var(--c-border-strong); border-radius: var(--r-xl); padding: clamp(2.75rem, 5vw, 4.5rem); text-align: center; position: relative; overflow: hidden; }
.cta-block::before { content: ''; position: absolute; top: -50%; left: -10%; width: 60%; height: 200%; background: radial-gradient(circle, var(--c-primary-soft) 0%, transparent 65%); }
.cta-block::after { content: ''; position: absolute; bottom: -50%; right: -10%; width: 60%; height: 200%; background: radial-gradient(circle, rgba(184,152,104,.10) 0%, transparent 65%); }
.cta-block > * { position: relative; }
.cta-block h2 { color: var(--c-text); font-size: clamp(1.875rem, 4vw, 2.75rem); margin-bottom: 1rem; }
.cta-block p { color: var(--c-text-soft); margin-bottom: 2rem; font-size: 1.1rem; }
.cta-block .btn-row { justify-content: center; }

/* Forms */
.form { display: grid; gap: 1.1rem; }
.form__row { display: grid; gap: 1.1rem; }
@media (min-width: 640px) { .form__row--2 { grid-template-columns: 1fr 1fr; } .form__row--3 { grid-template-columns: 2fr 2fr 1fr; } }
.form__field label { display: block; font-weight: 600; font-size: .82rem; margin-bottom: .45rem; color: var(--c-text); text-transform: uppercase; letter-spacing: .08em; }
.form__field .req { color: var(--c-danger); }
.input, .textarea, .select { width: 100%; padding: .9rem 1.1rem; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-md); font: inherit; font-size: 1rem; color: var(--c-text); transition: border-color .2s, box-shadow .2s, background .2s; font-family: var(--font-body); }
.input:focus, .textarea:focus, .select:focus { border-color: var(--c-primary); background: var(--c-surface-2); box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-primary) 18%, transparent); outline: none; }
.textarea { resize: vertical; min-height: 130px; }
.select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--c-primary) 50%), linear-gradient(135deg, var(--c-primary) 50%, transparent 50%); background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: 2.5rem; }
.honeypot { position: absolute; left: -9999px; opacity: 0; pointer-events: none; }
.form-status { margin-top: 1rem; padding: .9rem 1.1rem; border-radius: var(--r-md); display: none; font-size: .92rem; }
.form-status:not(:empty) { display: block; }
.form-status.is-success { background: rgba(127,178,135,.12); color: var(--c-success); border-left: 3px solid var(--c-success); }
.form-status.is-error { background: rgba(214,117,96,.10); color: var(--c-danger); border-left: 3px solid var(--c-danger); }

.contact-card { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.85rem; display: flex; flex-direction: column; gap: .85rem; }
.contact-card__icon { width: 48px; height: 48px; border-radius: var(--r-md); background: var(--c-primary-soft); color: var(--c-primary); display: inline-flex; align-items: center; justify-content: center; font-size: 1.4rem; border: 1px solid rgba(212,181,138,.2); }
.contact-card h3 { font-size: 1.15rem; margin: 0; }
.contact-card p { font-size: .95rem; margin: 0; }
.contact-card a { font-weight: 600; }

/* Feature block */
.feature-block { display: grid; gap: 2.5rem; align-items: center; padding: clamp(2rem, 4vw, 3.5rem); background: var(--c-surface); border-radius: var(--r-xl); border: 1px solid var(--c-border); }
@media (min-width: 880px) { .feature-block { grid-template-columns: 1.05fr 1fr; } .feature-block--reverse { grid-template-columns: 1fr 1.05fr; } .feature-block--reverse > :first-child { order: 2; } }
.feature-block__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--r-lg); }
.feature-block__list { display: grid; gap: .85rem; margin: 1.25rem 0 1.75rem; padding: 0; list-style: none; }
.feature-block__list li { display: flex; gap: .65rem; align-items: flex-start; color: var(--c-text); }
.feature-block__list .check { color: var(--c-primary); font-weight: 700; flex-shrink: 0; }

/* Drip / product menu */
.drip-menu { display: grid; gap: 1.25rem; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.drip-card { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.85rem; display: flex; flex-direction: column; gap: .85rem; transition: transform .3s, box-shadow .3s, border-color .3s; }
@media (hover: hover) {
  .drip-card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--c-primary); }
}
.drip-card__tag { display: inline-block; font-size: .68rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--c-primary); padding: .2rem 0; }
.drip-card__title { font-family: var(--font-heading); font-size: 1.4rem; font-weight: 500; margin: 0; letter-spacing: -.01em; }
.drip-card__ingredients { color: var(--c-text-soft); font-size: .9rem; margin: 0; }
.drip-card__benefits { display: flex; flex-wrap: wrap; gap: .4rem; }
.chip { display: inline-block; font-size: .72rem; padding: .28rem .7rem; background: var(--c-surface-3); color: var(--c-text-soft); border-radius: var(--r-pill); font-weight: 500; border: 1px solid var(--c-border); }
.drip-card__price { font-family: var(--font-heading); font-size: 1.6rem; color: var(--c-primary); font-weight: 500; margin-top: auto; padding-top: .85rem; border-top: 1px solid var(--c-border); display: flex; align-items: baseline; justify-content: space-between; }
.drip-card__price small { font-size: .68rem; color: var(--c-text-mute); font-family: var(--font-body); font-weight: 500; letter-spacing: .12em; text-transform: uppercase; }

/* Team */
.team-card { text-align: center; }
.team-card__photo { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: var(--r-lg); margin-bottom: 1.25rem; filter: brightness(.92) contrast(1.05); }
.team-card__name { font-family: var(--font-heading); font-size: 1.25rem; font-weight: 500; margin: 0; letter-spacing: -.01em; }
.team-card__role { color: var(--c-primary); font-size: .82rem; margin-top: .4rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 600; }
.team-card__bio { font-size: .94rem; color: var(--c-text-soft); margin-top: .85rem; }

.credentials { display: grid; gap: .75rem; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.credential { display: flex; gap: .85rem; align-items: flex-start; padding: 1.1rem 1.35rem; background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-md); transition: border-color .25s; }
.credential:hover { border-color: var(--c-primary); }
.credential .ico { color: var(--c-primary); font-size: 1.3rem; flex-shrink: 0; }
.credential strong { display: block; font-size: .95rem; color: var(--c-text); font-family: var(--font-heading); font-weight: 500; letter-spacing: -.005em; }
.credential span { font-size: .82rem; color: var(--c-text-mute); }

/* Map */
.map-frame { aspect-ratio: 16/9; border-radius: var(--r-lg); border: 1px solid var(--c-border); overflow: hidden; background: var(--c-surface); }
.map-frame iframe { width: 100%; height: 100%; border: 0; filter: invert(.92) hue-rotate(190deg) saturate(.5) brightness(.95) contrast(.9); }

/* Sticky mobile CTA */
.sticky-cta { position: fixed; bottom: 0; left: 0; right: 0; display: none; padding: .75rem; background: rgba(10,8,7,.96); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); box-shadow: 0 -4px 24px rgba(0,0,0,.4); border-top: 1px solid var(--c-border); z-index: 60; gap: .5rem; transform: translateY(110%); transition: transform .35s cubic-bezier(.4,0,.2,1); }
.sticky-cta.is-visible { transform: translateY(0); }
@media (max-width: 900px) { .sticky-cta { display: flex; } body { padding-bottom: 4.5rem; } }
.sticky-cta .btn { flex: 1; padding: .85rem; font-size: .8rem; }

/* Footer */
.site-footer { background: #050403; color: var(--c-text-soft); padding: 4.5rem 0 2rem; border-top: 1px solid var(--c-border); }
.site-footer__grid { display: grid; gap: 2.5rem; grid-template-columns: 1fr; }
@media (min-width: 720px) { .site-footer__grid { grid-template-columns: 1.5fr 1fr 1fr 1fr 1.2fr; } }
.site-footer__brand .logo { color: var(--c-primary); margin-bottom: 1.2rem; }
.footer-tagline { color: var(--c-text-mute); font-size: .92rem; line-height: 1.7; max-width: 38ch; }
.footer-social { display: flex; gap: .75rem; margin-top: 1.5rem; }
.footer-social a { width: 44px; height: 44px; border-radius: 50%; background: var(--c-surface-2); color: var(--c-primary); display: inline-flex; align-items: center; justify-content: center; transition: background .25s, transform .25s, color .25s; border: 1px solid var(--c-border); cursor: pointer; }
.footer-social .ico { width: 18px; height: 18px; }
.footer-social a:hover { background: var(--c-primary); color: var(--c-bg); transform: translateY(-2px); }
.site-footer__col h4 { font-family: var(--font-heading); font-size: 1rem; font-weight: 500; color: var(--c-primary); margin-bottom: 1.1rem; letter-spacing: .04em; text-transform: uppercase; }
.site-footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .65rem; }
.site-footer__col a { color: var(--c-text-mute); font-size: .9rem; transition: color .2s; }
.site-footer__col a:hover { color: var(--c-primary); }
.site-footer address { color: var(--c-text-mute); font-size: .9rem; }
.site-footer address strong { color: var(--c-text); display: block; font-family: var(--font-heading); font-weight: 500; margin-bottom: .35rem; }
.site-footer address a { color: var(--c-text-soft); }
.site-footer address a:hover { color: var(--c-primary); }
.footer-hours { font-size: .88rem; color: var(--c-text-mute); margin-top: 1rem; line-height: 1.65; }
.footer-hours strong { color: var(--c-primary); display: block; margin-bottom: .25rem; }
.site-footer__bottom { margin-top: 3.5rem; padding-top: 1.75rem; border-top: 1px solid var(--c-border); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; font-size: .82rem; color: var(--c-text-mute); }
.site-footer__bottom ul { display: flex; gap: 1.5rem; list-style: none; padding: 0; margin: 0; }
.site-footer__bottom a { color: var(--c-text-mute); }
.site-footer__bottom a:hover { color: var(--c-primary); }

/* Fade-in */
[data-fade] { opacity: 0; transform: translateY(28px); transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1); }
[data-fade].is-visible { opacity: 1; transform: translateY(0); }
[data-fade-delay="100"] { transition-delay: 100ms; }
[data-fade-delay="200"] { transition-delay: 200ms; }
[data-fade-delay="300"] { transition-delay: 300ms; }
[data-fade-delay="400"] { transition-delay: 400ms; }

img[loading="lazy"] { transition: opacity .4s; }

/* Article */
.article-body { font-size: 1.05rem; line-height: var(--lh-relaxed); color: var(--c-text); max-width: 72ch; margin: 0 auto; }
.article-body h2, .article-body h3 { margin-top: 2.25rem; color: var(--c-text); }
.article-body p { color: var(--c-text-soft); }
.article-body strong { color: var(--c-text); }
.article-body img { border-radius: var(--r-md); margin: 1.5rem 0; }
.article-body blockquote { border-left: 2px solid var(--c-primary); padding: .25rem 1.5rem; margin: 1.5rem 0; font-family: var(--font-display); font-style: italic; font-size: 1.25rem; color: var(--c-text); }
.article-body ul li, .article-body ol li { color: var(--c-text-soft); }

.tag-list { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }
.legal h2 { margin-top: 2rem; font-size: 1.45rem; }

.area-list { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }
.area-list .chip { background: var(--c-surface-2); border: 1px solid var(--c-border); color: var(--c-text-soft); padding: .35rem .85rem; }
.area-list a.chip:hover { background: var(--c-primary); color: var(--c-bg); border-color: var(--c-primary); }

.pull-quote { font-family: var(--font-display); font-style: italic; font-size: clamp(1.5rem, 2.6vw, 2.2rem); font-weight: 400; line-height: 1.4; color: var(--c-text); padding: 1.5rem 0 1.5rem 1.75rem; border-left: 2px solid var(--c-primary); max-width: 52ch; }

/* ============================================
   SHOP — product grid, detail, cart, checkout
   ============================================ */

.product-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }

.product-card { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform .3s cubic-bezier(.4,0,.2,1), box-shadow .3s, border-color .3s; cursor: pointer; }
.product-card__media { aspect-ratio: 4/3; overflow: hidden; background: var(--c-surface-3); position: relative; }
.product-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s cubic-bezier(.4,0,.2,1); }
@media (hover: hover) {
  .product-card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--c-primary); }
  .product-card:hover .product-card__media img { transform: scale(1.05); }
}
.product-card__badge { position: absolute; top: 12px; left: 12px; padding: .25rem .65rem; background: var(--c-primary); color: var(--c-bg); border-radius: var(--r-pill); font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.product-card__body { padding: 1.4rem; flex-grow: 1; display: flex; flex-direction: column; gap: .55rem; }
.product-card__category { font-size: .68rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--c-primary); }
.product-card__title { font-family: var(--font-heading); font-size: 1.25rem; font-weight: 500; margin: 0; color: var(--c-text); letter-spacing: -.01em; }
.product-card__excerpt { font-size: .9rem; color: var(--c-text-soft); margin: 0; flex-grow: 1; }
.product-card__foot { display: flex; align-items: center; justify-content: space-between; gap: .5rem; padding-top: .85rem; margin-top: auto; border-top: 1px solid var(--c-border); }
.product-card__price { font-family: var(--font-heading); font-size: 1.5rem; color: var(--c-primary); font-weight: 500; }
.product-card__price s { color: var(--c-text-mute); font-size: .85em; margin-right: .35rem; }

.product-detail { display: grid; gap: 3rem; grid-template-columns: 1fr; }
@media (min-width: 880px) { .product-detail { grid-template-columns: 1fr 1fr; } }
.product-detail__media { aspect-ratio: 1; border-radius: var(--r-xl); overflow: hidden; background: var(--c-surface-2); border: 1px solid var(--c-border); }
.product-detail__media img { width: 100%; height: 100%; object-fit: cover; }
.product-detail__body h1 { font-size: clamp(2rem, 4vw, 3rem); }
.product-detail__category { font-size: .75rem; letter-spacing: .14em; text-transform: uppercase; color: var(--c-primary); font-weight: 700; margin-bottom: .5rem; display: block; }
.product-detail__price { font-family: var(--font-heading); font-size: 2.2rem; color: var(--c-primary); font-weight: 500; margin: 1rem 0 1.5rem; }
.product-detail__price s { color: var(--c-text-mute); font-size: .65em; margin-right: .5rem; }
.product-detail__qty { display: inline-flex; align-items: center; border: 1px solid var(--c-border); border-radius: var(--r-pill); overflow: hidden; }
.product-detail__qty button { width: 44px; height: 44px; color: var(--c-text); font-size: 1.1rem; cursor: pointer; transition: background .2s, color .2s; }
.product-detail__qty button:hover { background: var(--c-surface-3); color: var(--c-primary); }
.product-detail__qty input { width: 60px; height: 44px; background: var(--c-surface); border: 0; border-left: 1px solid var(--c-border); border-right: 1px solid var(--c-border); color: var(--c-text); text-align: center; font: inherit; font-weight: 600; }
.product-detail__qty input:focus { outline: 0; background: var(--c-surface-2); }

.product-spec { display: grid; gap: 1rem; margin: 2rem 0; padding: 1.5rem; background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-md); }
.product-spec dt { font-family: var(--font-body); font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--c-primary); }
.product-spec dd { margin: .3rem 0 0; color: var(--c-text-soft); font-size: .96rem; }

/* Cart */
.cart-table { width: 100%; border-collapse: collapse; }
.cart-table th { text-align: left; padding: .85rem 1rem; font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--c-text-mute); border-bottom: 1px solid var(--c-border); }
.cart-table td { padding: 1.25rem 1rem; border-bottom: 1px solid var(--c-border); vertical-align: middle; }
.cart-table tr:last-child td { border-bottom: 0; }
.cart-table img { width: 64px; height: 64px; border-radius: var(--r-sm); object-fit: cover; }
.cart-item__name { font-family: var(--font-heading); font-size: 1.05rem; color: var(--c-text); margin: 0 0 .15rem; }
.cart-item__meta { font-size: .82rem; color: var(--c-text-mute); }
.cart-table .qty-mini { display: inline-flex; align-items: center; border: 1px solid var(--c-border); border-radius: var(--r-pill); }
.cart-table .qty-mini button { width: 44px; height: 44px; color: var(--c-text); cursor: pointer; transition: color .2s; }
.cart-table .qty-mini button:hover { color: var(--c-primary); }
.cart-table .qty-mini input { width: 44px; height: 44px; background: transparent; border: 0; border-left: 1px solid var(--c-border); border-right: 1px solid var(--c-border); color: var(--c-text); text-align: center; font: inherit; font-weight: 600; }
.cart-remove { background: none; border: 0; color: var(--c-text-mute); cursor: pointer; transition: color .2s, background .2s; font-size: 1.25rem; min-width: 44px; min-height: 44px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; }
.cart-remove:hover { color: var(--c-danger); background: rgba(214,117,96,.08); }
.cart-summary { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.85rem; }
.cart-summary__row { display: flex; justify-content: space-between; padding: .55rem 0; color: var(--c-text-soft); }
.cart-summary__row strong { color: var(--c-text); }
.cart-summary__row--total { border-top: 1px solid var(--c-border); margin-top: .5rem; padding-top: 1rem; font-family: var(--font-heading); font-size: 1.35rem; color: var(--c-primary); }
.cart-summary__row--total strong { color: var(--c-primary); }
.cart-empty { text-align: center; padding: 4rem 1rem; color: var(--c-text-mute); }
.cart-empty h2 { color: var(--c-text); }

/* Checkout */
.checkout-grid { display: grid; gap: 3rem; grid-template-columns: 1fr; }
@media (min-width: 880px) { .checkout-grid { grid-template-columns: 1.4fr 1fr; align-items: start; } }
.checkout-section { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: 1.85rem; margin-bottom: 1.5rem; }
.checkout-section h2 { font-size: 1.35rem; margin-bottom: 1.25rem; }
.payment-option { display: flex; gap: 1rem; align-items: flex-start; padding: 1.25rem; border: 1.5px solid var(--c-border); border-radius: var(--r-md); cursor: pointer; transition: border-color .25s, background .25s; margin-bottom: .75rem; }
.payment-option:hover { border-color: var(--c-primary); background: var(--c-surface-3); }
.payment-option input { margin-top: .25rem; accent-color: var(--c-primary); }
.payment-option strong { color: var(--c-text); display: block; margin-bottom: .25rem; font-family: var(--font-heading); font-weight: 500; }
.payment-option span { color: var(--c-text-mute); font-size: .88rem; }
.payment-option:has(input:checked) { border-color: var(--c-primary); background: var(--c-primary-soft); }
.payment-details { background: var(--c-surface-3); border: 1px dashed var(--c-primary); border-radius: var(--r-md); padding: 1.5rem; margin-top: 1rem; font-family: 'Courier New', monospace; font-size: .96rem; color: var(--c-text); display: none; }
.payment-details.is-visible { display: block; }
.payment-details strong { color: var(--c-primary); }
.payment-details .copy-btn { display: inline-block; margin-left: .5rem; padding: .2rem .6rem; font-size: .72rem; background: var(--c-primary); color: var(--c-bg); border-radius: var(--r-sm); cursor: pointer; }

/* Admin */
.admin-shell { min-height: 100dvh; min-height: 100vh; display: grid; grid-template-columns: 240px 1fr; background: var(--c-bg); }
@media (max-width: 880px) { .admin-shell { grid-template-columns: 1fr; } }
.admin-side { background: #050403; border-right: 1px solid var(--c-border); padding: 1.5rem; position: sticky; top: 0; height: 100dvh; max-height: 100vh; overflow-y: auto; }
@media (max-width: 880px) { .admin-side { position: static; height: auto; } }
.admin-side .logo { color: var(--c-primary); margin-bottom: 2rem; }
.admin-nav { display: grid; gap: .35rem; }
.admin-nav a { display: flex; align-items: center; gap: .85rem; padding: .8rem 1rem; border-radius: var(--r-md); color: var(--c-text-soft); font-size: .9rem; font-weight: 500; transition: background .2s, color .2s; letter-spacing: .01em; }
.admin-nav a:hover { background: var(--c-surface-2); color: var(--c-text); }
.admin-nav a:hover .ico { color: var(--c-primary); }
.admin-nav a.is-active { background: var(--c-primary); color: var(--c-bg); }
.admin-nav a.is-active .ico { color: var(--c-bg); }
.admin-nav .ico { width: 18px; height: 18px; color: var(--c-text-mute); transition: color .2s; flex-shrink: 0; }
.admin-side__bottom { position: absolute; bottom: 1.5rem; left: 1.5rem; right: 1.5rem; }
@media (max-width: 880px) { .admin-side__bottom { position: static; margin-top: 1.5rem; } }

.admin-main { padding: 2rem; min-width: 0; }
@media (min-width: 880px) { .admin-main { padding: 2.5rem 3rem; } }
.admin-page-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 2rem; flex-wrap: wrap; }
.admin-page-head h1 { font-size: clamp(1.5rem, 2.4vw, 2rem); margin: 0; }
.admin-page-head__actions { display: flex; gap: .65rem; }

.admin-grid { display: grid; gap: 1.25rem; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
.admin-stat { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: 1.5rem; }
.admin-stat__label { font-size: .72rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--c-text-mute); }
.admin-stat__value { font-family: var(--font-heading); font-size: clamp(1.75rem, 3vw, 2.25rem); color: var(--c-primary); font-weight: 500; margin-top: .5rem; }
.admin-stat__hint { font-size: .82rem; color: var(--c-text-soft); margin-top: .35rem; }

.admin-table { width: 100%; border-collapse: collapse; background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-md); overflow: hidden; }
.admin-table th, .admin-table td { padding: .85rem 1rem; text-align: left; border-bottom: 1px solid var(--c-border); }
.admin-table th { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--c-primary); background: var(--c-surface); }
.admin-table tr:last-child td { border-bottom: 0; }
.admin-table tr:hover td { background: var(--c-surface); }
.admin-table img { width: 44px; height: 44px; border-radius: var(--r-sm); object-fit: cover; }
.admin-table a { color: var(--c-text); font-weight: 500; }
.admin-table a:hover { color: var(--c-primary); }
.admin-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

.badge { display: inline-block; padding: .2rem .6rem; font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; border-radius: var(--r-sm); }
.badge--pending { background: rgba(232,184,108,.12); color: var(--c-warning); border: 1px solid rgba(232,184,108,.3); }
.badge--paid { background: rgba(127,178,135,.12); color: var(--c-success); border: 1px solid rgba(127,178,135,.3); }
.badge--shipped { background: rgba(212,181,138,.12); color: var(--c-primary); border: 1px solid rgba(212,181,138,.3); }
.badge--cancelled { background: rgba(214,117,96,.12); color: var(--c-danger); border: 1px solid rgba(214,117,96,.3); }
.badge--active { background: rgba(127,178,135,.12); color: var(--c-success); border: 1px solid rgba(127,178,135,.3); }
.badge--draft { background: var(--c-surface-3); color: var(--c-text-mute); border: 1px solid var(--c-border); }

.admin-card { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: 1.85rem; margin-bottom: 1.5rem; }
.admin-card h2 { font-size: 1.25rem; margin-bottom: 1.25rem; }

.alert { padding: 1rem 1.25rem; border-radius: var(--r-md); margin-bottom: 1.5rem; font-size: .92rem; }
.alert--success { background: rgba(127,178,135,.12); color: var(--c-success); border-left: 3px solid var(--c-success); }
.alert--error { background: rgba(214,117,96,.10); color: var(--c-danger); border-left: 3px solid var(--c-danger); }
.alert--info { background: rgba(212,181,138,.12); color: var(--c-primary); border-left: 3px solid var(--c-primary); }

.login-shell { min-height: 100dvh; min-height: 100vh; display: grid; place-items: center; padding: 2rem; background: linear-gradient(135deg, var(--c-bg) 0%, var(--c-surface) 100%); }
.login-card { background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-xl); padding: 2.5rem; width: 100%; max-width: 420px; }
.login-card .logo { justify-content: center; margin-bottom: 1.5rem; }

/* Section helpers */
.text-center { text-align: center; }
.mt-lg { margin-top: var(--sp-2xl); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
  .hero__bg img { animation: none !important; }
}

@media print {
  .site-header, .site-nav-mobile, .sticky-cta, .site-footer { display: none !important; }
  body { color: #000; background: #fff; }
}
