/* ============================================================
   PLINTH STUDIO - Component & Layout Styles
   ============================================================ */

::selection { background: var(--accent); color: #fff; }

::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: var(--bg-0); }
::-webkit-scrollbar-thumb { background: #26262e; border-radius: 99px; border: 3px solid var(--bg-0); }
::-webkit-scrollbar-thumb:hover { background: #34343e; }

#root { overflow-x: clip; }

.container {
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container.narrow { max-width: var(--maxw-narrow); }

section { position: relative; }

/* ---- Scroll reveal primitive ---- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
  will-change: opacity, transform;
}
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 0.08s; }
.reveal.d2 { transition-delay: 0.16s; }
.reveal.d3 { transition-delay: 0.24s; }
.reveal.d4 { transition-delay: 0.32s; }
.reveal.d5 { transition-delay: 0.40s; }
body.no-motion .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }

/* ---- Section heading block ---- */
.sec-head { display: flex; flex-direction: column; gap: 1.1rem; max-width: 760px; }
.sec-head.center { margin-inline: auto; align-items: center; text-align: center; }
.sec-label {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-family: var(--font-mono); font-size: var(--t-eyebrow);
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2);
}
.sec-label::before {
  content: ""; width: 26px; height: 1px; background: var(--accent);
}
.sec-head.center .sec-label { justify-content: center; }
.sec-title { font-size: var(--t-h2); }
.sec-sub { font-size: var(--t-lead); color: var(--fg-1); line-height: 1.5; font-weight: var(--w-reg); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.55rem;
  font-family: var(--font-sans); font-size: var(--t-sm); font-weight: var(--w-med);
  letter-spacing: -0.01em; line-height: 1;
  padding: 0.95rem 1.6rem; border-radius: var(--r-pill);
  border: 1px solid transparent; cursor: pointer; white-space: nowrap;
  transition: transform var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out), opacity var(--dur-fast);
  user-select: none;
}
.btn svg { width: 16px; height: 16px; }
.btn-primary { background: var(--accent); color: var(--accent-ink); box-shadow: var(--sh-glow); }
.btn-primary:hover { background: var(--accent-hi); transform: translateY(-2px); box-shadow: 0 22px 64px -16px var(--accent-glow); }
.btn-primary:active { transform: translateY(0) scale(0.985); background: var(--accent-lo); }
.btn-ghost { background: transparent; color: var(--fg-0); border-color: var(--line-2); }
.btn-ghost:hover { background: rgba(255,255,255,0.05); border-color: var(--fg-2); transform: translateY(-2px); }
.btn-ghost:active { transform: translateY(0) scale(0.985); }
.btn-light { background: var(--fg-0); color: var(--bg-0); }
.btn-light:hover { transform: translateY(-2px); box-shadow: var(--sh-md); }
.btn-lg { padding: 1.1rem 2rem; font-size: var(--t-body); }
.btn-sm { padding: 0.7rem 1.15rem; font-size: var(--t-xs); }
.btn-block { width: 100%; }

/* arrow shift on hover */
.btn .arr { transition: transform var(--dur-fast) var(--ease-out); }
.btn:hover .arr { transform: translateX(3px); }

/* ============================================================
   NAVBAR
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 80;
  transition: background var(--dur) var(--ease-out), border-color var(--dur), box-shadow var(--dur);
  background: #ffffff;
  border-bottom: 1px solid var(--line-1, rgba(0,0,0,0.08));
}
.nav.scrolled {
  background: #ffffff;
  border-bottom-color: var(--line-1, rgba(0,0,0,0.08));
  box-shadow: 0 6px 24px -16px rgba(0,0,0,0.35);
}
/* White bar at all times - keep contents dark & legible regardless of theme */
.nav .nav-link { color: #14141a; }
/* nav logo uses the .rh-logo dark defaults (box #14141a / ink #f6f5f2) */
.nav .nav-burger { color: #14141a; }
.nav-inner {
  width: 100%; padding: 0.3rem var(--gutter);
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
}
.brand { display: flex; align-items: center; gap: 0.62rem; cursor: pointer; text-decoration: none; }
.nav .brand { transform: none; }

/* ---- Boxed logo: refined two-zone badge - icon panel | rule | wordmark ---- */
.rh-logo {
  --rh-box: #14141a; --rh-ink: #f6f5f2;
  display: inline-flex; align-items: stretch; gap: 0;
  flex: none;
  /* tactile nameplate: subtle top-lit gradient off the --rh-box base */
  background:
    linear-gradient(176deg,
      color-mix(in srgb, var(--rh-box) 84%, #fff) 0%,
      var(--rh-box) 52%,
      color-mix(in srgb, var(--rh-box) 90%, #000) 100%);
  color: var(--rh-ink);
  font-size: var(--rh-size, 18px);
  border-radius: 9px;
  box-shadow:
    0 1px 1px rgba(18,18,24,0.16),
    0 7px 18px -7px rgba(18,18,24,0.30),
    inset 0 0 0 1px color-mix(in srgb, currentColor 12%, transparent),
    inset 0 1px 0 color-mix(in srgb, currentColor 24%, transparent);
  text-decoration: none; overflow: hidden;
  transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
}
/* Icon panel: a clean square zone with the house mark enlarged & centered */
.rh-logo .rh-logo-ic {
  width: 2.55em; height: 2.55em; display: block; flex: none;
  margin: 0.36em 0.34em 0.36em 0.4em;
}
/* Wordmark zone with a scored divider and two-tone "Render House" */
.rh-logo .rh-logo-text {
  display: flex; align-items: center; gap: 0.26em;
  padding: 0 0.86em 0 0.7em;
  border-left: 1px solid color-mix(in srgb, currentColor 22%, transparent);
  box-shadow: inset 1px 0 0 rgba(0,0,0,0.18);
  font-family: "Space Grotesk", var(--font-sans);
  font-weight: 500; font-size: 1.0em; letter-spacing: -0.01em; line-height: 1;
  white-space: nowrap;
  color: color-mix(in srgb, currentColor 72%, transparent);
}
.rh-logo .rh-logo-text b {
  font-weight: 700; font-style: normal; letter-spacing: -0.012em;
  color: var(--rh-ink);
}
.brand:hover .rh-logo {
  transform: translateY(-2px);
  box-shadow:
    0 6px 16px rgba(20,20,26,0.26),
    inset 0 0 0 1px color-mix(in srgb, currentColor 18%, transparent),
    inset 0 1px 0 color-mix(in srgb, currentColor 20%, transparent);
}
/* ---- Nav logo: clean single-line lockup (no plaque) - echoes the splash mark ---- */
.nav .rh-logo {
  background: none;
  box-shadow: none;
  border-radius: 0;
  color: #14141a;
  font-size: 25px;
  align-items: center;
  gap: 0.26em;            /* tuck the wordmark in close to the house mark */
  overflow: visible;
}
.nav .rh-logo .rh-logo-ic {
  width: 1.96em; height: 1.96em;
  margin: 0;
}
.nav .rh-logo .rh-logo-ic .lg-house { stroke-width: 2.7px; }
.nav .rh-logo .rh-logo-ic .lg-iris  { stroke-width: 2.2px; }
.nav .rh-logo .rh-logo-text {
  display: inline-flex;
  flex-direction: row;           /* one horizontal line, never stacked */
  flex-wrap: nowrap;
  border-left: none;
  box-shadow: none;
  padding: 0;
  align-items: baseline;
  gap: 0.26em;                   /* clear word-space between the two words */
  line-height: 1;
  white-space: nowrap;
  font-family: "Fraunces", Georgia, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-size: 1.06em;
  letter-spacing: 0;
  text-transform: none;          /* not all-caps */
  color: #14141a;                /* same ink as the house mark */
}
.nav .rh-logo .rh-logo-text b {
  color: #14141a;                /* same color, no two-tone */
  font-weight: 400;              /* match "Render" exactly */
  font-style: normal;            /* no italic - identical to "Render" */
  font-size: 1em; letter-spacing: 0;
}
.nav .brand:hover .rh-logo {
  transform: none;
  box-shadow: none;
}
.nav .brand:hover .rh-logo .rh-logo-ic { transform: none; }
.nav .rh-logo .rh-logo-ic { transition: transform 0.5s var(--ease-out); transform-origin: 50% 56%; }

.nav-links { display: flex; align-items: center; gap: 0.35rem; }
.nav-link {
  font-size: var(--t-sm); color: var(--fg-1); padding: 0.5rem 0.85rem; border-radius: var(--r-sm);
  transition: color var(--dur-fast), background var(--dur-fast); position: relative;
}
.nav-link:hover { color: #14141a; background: rgba(0,0,0,0.05); }
.nav-cta { display: flex; align-items: center; gap: 0.7rem; }
.nav-burger { display: none; background: none; border: 0; color: var(--fg-0); cursor: pointer; padding: 0.4rem; }
.nav-burger svg { width: 26px; height: 26px; }

.mobile-menu {
  position: fixed; inset: 0; z-index: 90; background: var(--bg-0);
  display: flex; flex-direction: column; padding: 1.5rem var(--gutter);
  transform: translateX(100%); transition: transform var(--dur) var(--ease-out);
}
.mobile-menu.open { transform: none; }
.mobile-menu-top { display: flex; align-items: center; justify-content: space-between; }
.mobile-links { display: flex; flex-direction: column; gap: 0.4rem; margin-top: 3rem; }
.mobile-links a { font-size: 2rem; font-weight: var(--w-semi); color: var(--fg-0); padding: 0.5rem 0; letter-spacing: -0.03em; }
.mobile-links a:active { color: var(--accent); }

/* ============================================================
   HERO - Editorial (collage + centered card)
   ============================================================ */
.hero-editorial {
  min-height: 100vh; min-height: 100svh;
  padding: 7rem clamp(1.5rem, 5vw, 4rem) 6rem;
  display: grid; place-items: center;
  position: relative; overflow: hidden;
  background: var(--bg-1);
}

/* ---- Two horizontally scrolling rows of image slots ---- */
.hero-rows {
  position: absolute; inset: 0; z-index: 0;
  display: flex; flex-direction: column;
  gap: 8px; padding: 8px;
  overflow: hidden;
  opacity: 0.5;
}
.hero-row {
  flex: 1; min-height: 0;
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
}
.hero-row-track {
  display: flex; gap: 10px; align-items: stretch;
  height: 100%; width: max-content;
  animation: hero-marquee 120s linear infinite;
  will-change: transform;
}
.hero-row-track.reverse { animation: hero-marquee-rev 138s linear infinite; }
.hero-row:hover .hero-row-track { animation-play-state: paused; }
.hr-tile {
  flex: none;
  width: calc((100vw - 56px) / 5);
  height: 100%;
  position: relative;
  overflow: hidden;
  background: var(--bg-inset);
  border-radius: 2px;
}
.hr-tile image-slot {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border-radius: 0 !important;
}
@keyframes hero-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes hero-marquee-rev {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}
/* Subtle dim so the centered card stays legible while tiles fill */
.hero-rows::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(20,20,26,0.22) 0%, transparent 70%);
}

/* ---- Centered, card-less composition on a soft frosted halo ---- */
.hero-card {
  position: relative; z-index: 2;
  width: min(720px, 100%);
  margin: 0 auto;
  background: transparent;
  padding: clamp(2rem, 3.6vw, 3.1rem) clamp(1.5rem, 4vw, 3.4rem);
  text-align: center;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 1.1rem;
}
.hero-card::before {
  /* soft frosted halo behind the type - keeps it legible over imagery, no hard box */
  content: "";
  position: absolute; z-index: -1;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 128%; height: 142%;
  border-radius: 50%;
  background: radial-gradient(ellipse 50% 50% at 50% 50%,
    rgba(248,247,244,0.94) 0%,
    rgba(248,247,244,0.78) 42%,
    rgba(248,247,244,0.32) 66%,
    transparent 80%);
  -webkit-backdrop-filter: blur(7px);
  backdrop-filter: blur(7px);
  -webkit-mask-image: radial-gradient(ellipse 50% 50% at 50% 50%, #000 55%, transparent 78%);
  mask-image: radial-gradient(ellipse 50% 50% at 50% 50%, #000 55%, transparent 78%);
}
.hero-eyebrow-mini {
  display: inline-flex; align-items: center; gap: 0.9rem;
  font-family: var(--font-mono);
  font-size: 0.92rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
  color: var(--fg-1);
}
.hero-eyebrow-mini .he-rule {
  display: inline-block; width: clamp(12px, 2.5vw, 22px); height: 1px;
  background: rgba(20,20,26,0.28);
}
.hero-editorial .hero-serif {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3.9rem);
  line-height: 1.06;
  letter-spacing: -0.025em;
  color: var(--fg-0);
  margin: 0;
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
.hero-editorial .hero-serif em {
  font-style: italic;
  font-weight: 300;
  color: var(--fg-0);
  display: block;
  margin-top: 0.06em;
  white-space: nowrap;
}
.hero-card-lead {
  font-size: var(--t-lead);
  color: var(--fg-1);
  max-width: 46ch;
  line-height: 1.55;
  margin: 0;
}
.hero-card-actions {
  display: flex; align-items: center; gap: 1.4rem;
  flex-wrap: wrap; justify-content: center;
  margin-top: 0.6rem;
}
.btn-dark {
  background: var(--fg-0);
  color: var(--bg-1);
  border: 1px solid var(--fg-0);
}
.btn-dark:hover {
  background: var(--fg-1);
  border-color: var(--fg-1);
  transform: translateY(-2px);
  box-shadow: var(--sh-md);
}
.btn-dark:active { transform: translateY(0) scale(0.985); }
.hero-card-price {
  display: inline-flex; align-items: center; gap: 0.55rem;
  font-size: var(--t-sm);
  color: var(--fg-1);
}
.hero-card-price b { color: var(--fg-0); font-weight: var(--w-semi); }
.dot-ok {
  width: 8px; height: 8px; border-radius: 50%;
  background: #28b265;
  box-shadow: 0 0 0 4px rgba(40,178,101,0.18);
}

/* Nav "from $10" pill (light theme) */
body.theme-light .nav-from-pill {
  background: var(--fg-0); color: var(--bg-1);
  font-family: var(--font-mono); font-size: 0.65rem;
  letter-spacing: 0.12em; padding: 0.45rem 0.7rem;
  border-radius: 2px; text-transform: uppercase;
}

/* Responsive */
@media (max-width: 900px) {
  .hr-tile { width: calc((100vw - 34px) / 3); }
}
@media (max-width: 560px) {
  .hr-tile { width: calc((100vw - 24px) / 2); }
  .hero-card { padding: 1.6rem 1.2rem; }
  .hero-card::before { width: 150%; height: 132%; }
  .hero-card-actions { flex-direction: column; gap: 1rem; }
}

/* ============================================================
   HERO - Legacy (kept for any references; not used by editorial)
   ============================================================ */
.hero {
  min-height: 100vh; min-height: 100svh; display: flex; align-items: center;
  padding-top: 7rem; padding-bottom: 4rem; overflow: hidden; position: relative;
  background: var(--bg-0);
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(37,99,255,0.16), transparent 55%),
    radial-gradient(90% 60% at 0% 110%, rgba(37,99,255,0.07), transparent 60%),
    var(--bg-0);
}
.hero-bg image-slot {
  position: absolute; inset: 0; width: 100%; height: 100%; display: block;
  border-radius: 0 !important;
}
.hero-overlay {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(8,8,10,0.55) 0%, rgba(8,8,10,0.25) 35%, rgba(8,8,10,0.55) 70%, rgba(8,8,10,0.9) 100%),
    linear-gradient(90deg, rgba(8,8,10,0.78) 0%, rgba(8,8,10,0.45) 45%, rgba(8,8,10,0.1) 85%);
}
.hero-inner { position: relative; z-index: 2; width: 100%; }
.hero-content { max-width: 720px; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 0.7rem; margin-bottom: 1.8rem;
  padding: 0.5rem 0.95rem; border: 1px solid var(--line-1); border-radius: var(--r-pill);
  font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.04em; color: var(--fg-1);
  background: rgba(255,255,255,0.02);
}
.hero-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); animation: pulse 2.4s var(--ease-in-out) infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
.hero h1 {
  font-size: var(--t-display); font-weight: var(--w-semi); letter-spacing: -0.045em; line-height: 0.95;
  max-width: 16ch;
}
.hero h1 .grad {
  background: linear-gradient(100deg, var(--accent-hi), #9cb8ff 60%, var(--fg-0));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.hero h1 em { font-style: normal; color: var(--fg-2); }
.hero-lead { font-size: var(--t-lead); color: var(--fg-1); max-width: 48ch; margin-top: 1.8rem; line-height: 1.55; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 0.9rem; margin-top: 2.4rem; }
.hero-meta { display: flex; flex-wrap: wrap; gap: 2.2rem; margin-top: 3.5rem; }
.hero-meta-item { display: flex; flex-direction: column; gap: 0.25rem; }
.hero-meta-num { font-size: 1.7rem; font-weight: var(--w-semi); color: var(--fg-0); letter-spacing: -0.03em; }
.hero-meta-num .u { color: var(--accent); }
.hero-meta-label { font-size: var(--t-xs); color: var(--fg-2); }

/* hero visual (floating slot stack) */
.hero-visual { position: relative; }
.hero-stage {
  position: relative; aspect-ratio: 4/5; border-radius: var(--r-lg); overflow: visible;
}
.hero-stage image-slot { position: absolute; border-radius: var(--r-lg); box-shadow: var(--sh-lg); }
.hero-slot-main { inset: 0; z-index: 2; }
.hero-slot-a { width: 42%; aspect-ratio: 1; right: -10%; top: 8%; z-index: 3; box-shadow: var(--sh-lg) !important; }
.hero-slot-b { width: 38%; aspect-ratio: 3/4; left: -12%; bottom: 6%; z-index: 3; }
.float-tag {
  position: absolute; z-index: 4; display: flex; align-items: center; gap: 0.5rem;
  padding: 0.55rem 0.85rem; border-radius: var(--r-pill);
  background: rgba(14,14,17,0.7); backdrop-filter: blur(14px);
  border: 1px solid var(--line-1); font-size: var(--t-xs); color: var(--fg-0); box-shadow: var(--sh-md);
}
.float-tag .pip { width: 8px; height: 8px; border-radius: 50%; background: var(--ok); }

.hero-editorial .scroll-cue { left: 50%; right: auto; transform: translateX(-50%); }
.scroll-cue {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 0.6rem;
  font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--fg-2);
}
.scroll-cue .line { width: 1px; height: 38px; background: linear-gradient(var(--fg-2), transparent); position: relative; overflow: hidden; }
.scroll-cue .line::after { content:""; position:absolute; top:0; left:0; width:100%; height:40%; background: var(--accent); animation: scrolldown 2s var(--ease-in-out) infinite; }
@keyframes scrolldown { 0% { transform: translateY(-100%);} 60%,100% { transform: translateY(280%);} }

/* ---- marquee logos strip ---- */
.marquee { border-block: 1px solid var(--line-0); padding-block: 1.6rem; overflow: hidden; background: var(--bg-1); }
.marquee-label { text-align: center; font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 1.3rem; }
.marquee-track { display: flex; gap: 4.5rem; width: max-content; animation: marquee 32s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee { to { transform: translateX(-50%); } }
.marquee-item { font-size: 1.35rem; font-weight: var(--w-semi); letter-spacing: -0.02em; color: var(--fg-3); white-space: nowrap; transition: color var(--dur-fast); }
.marquee-item:hover { color: var(--fg-1); }

/* ============================================================
   SERVICES
   ============================================================ */
.services { padding-block: var(--space-section); background: var(--bg-1); }
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; margin-top: 3.5rem; }

/* ---- process strip: full-width, centered lead-in to the work ---- */
.process {
  width: 100%; margin-inline: auto;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 1.1rem;
}
.process-label { justify-content: center; color: var(--fg-2); }
.process-title { font-size: var(--t-h2); line-height: 1.1; max-width: 18ch; }
.process-sub { font-size: var(--t-body); color: var(--fg-1); line-height: 1.55; max-width: 56ch; }
.process-rail {
  margin-top: clamp(2rem, 4vw, 3.2rem);
  position: relative; width: 100%; margin-bottom: 0; padding: 0; list-style: none;
  display: flex; justify-content: space-between; gap: 1.5rem;
}
/* connecting hairline behind the dots (spans dot-centers of 4 equal nodes) */
.process-rail::before {
  content: ""; position: absolute; top: 27px; left: 12.5%; right: 12.5%;
  height: 1px; background: var(--line-1);
}
.process-node {
  position: relative; flex: 1 1 0;
  display: flex; flex-direction: column; align-items: center; gap: 0.7rem;
}
.process-dot {
  position: relative; z-index: 1;
  width: 54px; height: 54px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--bg-1); border: 1px solid var(--line-2); color: var(--fg-1);
  transition: border-color var(--dur-fast), color var(--dur-fast);
}
.process-dot svg { width: 21px; height: 21px; }
.process-node.hub .process-dot {
  border-color: var(--accent); color: var(--accent); background: var(--accent-soft);
}
.process-step {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.18em; color: var(--fg-3);
}
.process-k { font-size: var(--t-h4); font-weight: var(--w-semi); color: var(--fg-0); }
.process-d { font-size: var(--t-sm); color: var(--fg-2); max-width: 22ch; line-height: 1.45; }

@media (max-width: 640px) {
  .process-rail { flex-wrap: wrap; gap: 1.8rem 1rem; }
  .process-rail::before { display: none; }
  .process-node { flex: 0 0 calc(50% - 0.5rem); }
}

/* ---- project examples sub-head ---- */
.work-subhead {
  margin-top: clamp(2.4rem, 4.5vw, 3.6rem);
  padding-top: clamp(1.8rem, 3.2vw, 2.6rem);
  border-top: 1px solid var(--line-0);
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: 0.85rem;
}
.work-subhead .sec-label { justify-content: center; }
.work-subhead-title { font-size: var(--t-h3); }
.work-subhead-sub {
  font-family: "Fraunces", var(--font-serif);
  font-optical-sizing: auto;
  font-variation-settings: "opsz" 144, "SOFT" 40;
  font-weight: 700;
  font-size: clamp(1.5rem, 3.4vw, 2.6rem);
  color: var(--fg-0);
  line-height: 1.05;
  letter-spacing: -0.02em;
  white-space: nowrap;
  text-wrap: nowrap;
}

/* ---- collections: compact project showcase ---- */
.collections { margin-top: clamp(2.8rem, 5vw, 4.2rem); display: flex; flex-direction: column; }
.collection {
  display: grid; grid-template-columns: 0.52fr 2.4fr; gap: clamp(1.8rem, 4vw, 3.8rem);
  align-items: start; padding-block: clamp(2.8rem, 5.5vw, 4.6rem); border-top: 1px solid var(--line-1);
}
.collection:first-child { border-top: none; padding-top: 0; }
.collection:last-child { padding-bottom: 0; }

.col-info { position: sticky; top: 96px; align-self: start; }
.col-index { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2); display: inline-flex; gap: 0.5em; }
.col-index i { font-style: normal; color: var(--fg-3); }
.col-name { font-size: var(--t-h2); line-height: 1.04; letter-spacing: -0.02em; margin-top: 0.85rem; }
.col-desc { color: var(--fg-1); font-size: var(--t-xs); line-height: 1.55; margin-top: 0.85rem; max-width: 30ch; text-wrap: pretty; }
.col-cats { margin-top: 1.5rem; display: flex; flex-direction: column; gap: 0.6rem; }
.col-cats li { display: flex; align-items: center; gap: 0.65rem; font-size: var(--t-sm); color: var(--fg-0); }
.col-cats em { font-style: normal; color: var(--fg-2); }
.col-dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.col-dot.t0 { background: var(--fg-0); }
.col-dot.t1 { background: var(--fg-2); }
.col-dot.t2 { background: var(--fg-3); }
.col-viewall {
  margin-top: 1.7rem; display: inline-block; background: none; border: none; padding: 0 0 0.32rem; cursor: pointer;
  font-family: var(--font-sans); font-size: var(--t-sm); font-weight: var(--w-med); color: var(--fg-0);
  border-bottom: 1px solid var(--fg-0); transition: opacity var(--dur-fast);
}
.col-viewall:hover { opacity: 0.55; }

.col-shots { min-width: 0; }
.col-shots-label { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.22em; text-transform: uppercase; color: var(--fg-2); display: block; margin-bottom: 1rem; }
.col-featured { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.3rem, 2.4vw, 2rem); }
.col-shot {
  position: relative; height: 0; padding-bottom: 132%; overflow: hidden; cursor: pointer;
  border: 1px solid var(--line-1); border-radius: var(--r-md); background: var(--bg-2);
  box-shadow: 0 14px 34px -22px rgba(0,0,0,0.45);
  transition: transform var(--dur-fast) var(--ease-out), border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.col-shot image-slot { position: absolute; inset: 0; display: block; width: 100%; height: 100%; border-radius: 0 !important; }
.col-shot:hover { transform: translateY(-3px); border-color: var(--line-2); box-shadow: 0 18px 40px -22px rgba(0,0,0,0.5); }
.col-shot-meta {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
  padding: 0.72rem 0.8rem; font-size: var(--t-xs); color: #fff;
  background: linear-gradient(to top, rgba(10,10,12,0.82), transparent);
  opacity: 0; transform: translateY(6px); transition: opacity var(--dur-fast), transform var(--dur-fast);
}
.col-shot:hover .col-shot-meta { opacity: 1; transform: none; }
.col-shot-meta svg { flex: none; }

.col-more {
  margin: clamp(1.3rem, 2.5vw, 1.9rem) auto 0; display: block; background: none; border: none; padding: 0 0 0.32rem; cursor: pointer;
  font-family: var(--font-sans); font-size: var(--t-sm); font-weight: var(--w-med); color: var(--fg-1);
  border-bottom: 1px solid var(--line-2); transition: color var(--dur-fast), border-color var(--dur-fast);
}
.col-more:hover { color: var(--fg-0); border-bottom-color: var(--fg-0); }

.col-extra {
  margin-top: clamp(1rem, 2vw, 1.4rem);
  display: grid; grid-template-columns: repeat(6, 1fr); gap: clamp(0.6rem, 1.2vw, 0.95rem);
  animation: col-reveal 0.5s var(--ease-out);
}
.col-shot.sm { aspect-ratio: 1/1; border-radius: var(--r-sm); }
@keyframes col-reveal { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ---- picture tab: a panel that opens with the full shot set inside ---- */
.gallery-tab {
  position: fixed; inset: 0; z-index: 200; display: grid; place-items: center; opacity: 1;
  padding: clamp(1rem, 4vw, 3rem);
  background: rgba(14,14,18,0.55); backdrop-filter: blur(7px);
}
.gallery-card {
  width: min(1180px, 100%); max-height: min(90vh, 880px); display: flex; flex-direction: column;
  opacity: 1; transform: none;
  background: var(--bg-0); border: 1px solid var(--line-1); border-radius: var(--r-lg);
  box-shadow: 0 40px 120px -40px rgba(0,0,0,0.6); overflow: hidden;
}
.gallery-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; flex: none;
  padding: clamp(1.3rem, 3vw, 1.9rem) clamp(1.3rem, 3vw, 2rem) clamp(1rem, 2vw, 1.3rem);
  border-bottom: 1px solid var(--line-1);
}
.gallery-eyebrow { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2); display: inline-flex; gap: 0.5em; }
.gallery-eyebrow i { font-style: normal; color: var(--fg-3); }
.gallery-title { font-size: var(--t-h3); letter-spacing: -0.02em; margin-top: 0.4rem; }
.gallery-head-right { display: flex; align-items: center; gap: 1rem; flex: none; }
.gallery-count { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-2); white-space: nowrap; }
.gallery-close {
  width: 38px; height: 38px; flex: none; display: grid; place-items: center; cursor: pointer;
  background: var(--bg-2); border: 1px solid var(--line-1); border-radius: 50%; color: var(--fg-0);
  transition: background var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast);
}
.gallery-close:hover { background: var(--bg-3); border-color: var(--line-2); transform: rotate(90deg); }
.gallery-grid {
  padding: clamp(1.4rem, 3vw, 2.2rem); overflow-y: auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.4rem, 2.6vw, 2rem);
  align-content: start;
}
.gallery-cell {
  position: relative; height: 0; padding-bottom: 125%; overflow: hidden;
  border: 1px solid var(--line-1); border-radius: var(--r-md); background: var(--bg-2);
  box-shadow: 0 14px 34px -22px rgba(0,0,0,0.45);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast), transform var(--dur-fast) var(--ease-out);
}
.gallery-cell:hover { transform: translateY(-3px); border-color: var(--line-2); box-shadow: 0 22px 46px -22px rgba(0,0,0,0.5); }
.gallery-cell image-slot { position: absolute; inset: 0; display: block; width: 100%; height: 100%; border-radius: 0 !important; }
.gallery-cell-n {
  position: absolute; top: 8px; left: 10px; z-index: 2; pointer-events: none;
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.06em; color: var(--fg-3);
  background: var(--bg-0); padding: 0.12rem 0.4rem; border-radius: var(--r-pill);
}

/* ---- motion tiles (animation deliverables) ---- */
.port-item.motion .ph { align-items: end; padding-bottom: 1.2rem; }
.port-kind {
  position: absolute; top: 1rem; left: 1rem; z-index: 3; font-family: var(--font-mono);
  font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-0);
  background: rgba(10,10,12,0.6); backdrop-filter: blur(8px); border: 1px solid var(--line-1);
  padding: 0.28rem 0.6rem; border-radius: var(--r-pill);
}
.port-play {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 3;
  width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center;
  background: rgba(10,10,12,0.5); border: 1px solid rgba(246,245,242,0.45); color: #fff;
  backdrop-filter: blur(6px); transition: transform var(--dur-fast) var(--ease-out), background var(--dur-fast), border-color var(--dur-fast);
}
.port-play svg { margin-left: 2px; }
.port-item.motion:hover .port-play { transform: translate(-50%, -50%) scale(1.08); background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }
.svc-card {
  position: relative; padding: 2.2rem; border-radius: var(--r-lg);
  background: var(--bg-2); border: 1px solid var(--line-0); overflow: hidden;
  transition: border-color var(--dur) var(--ease-out), transform var(--dur) var(--ease-out), background var(--dur);
  min-height: 320px; display: flex; flex-direction: column;
}
.svc-card::after {
  content:""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background: radial-gradient(120% 120% at var(--mx,80%) 0%, var(--accent-soft), transparent 45%);
  opacity: 0; transition: opacity var(--dur) var(--ease-out);
}
.svc-card:hover { transform: translateY(-4px); border-color: var(--line-2); background: var(--bg-3); }
.svc-card:hover::after { opacity: 1; }
.svc-num { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--accent); letter-spacing: 0.12em; }
.svc-icon { width: 46px; height: 46px; border-radius: var(--r-md); display: grid; place-items: center; background: var(--accent-soft); color: var(--accent-hi); margin-bottom: 1.6rem; }
.svc-icon svg { width: 24px; height: 24px; }
.svc-card h3 { font-size: var(--t-h3); margin-bottom: 0.7rem; }
.svc-card p { color: var(--fg-1); font-size: var(--t-sm); flex: 1; }
.svc-tags { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 1.5rem; }
.svc-tag { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.04em; color: var(--fg-2); padding: 0.3rem 0.65rem; border: 1px solid var(--line-1); border-radius: var(--r-pill); }
.svc-card .svc-arrow { position: absolute; top: 2.2rem; right: 2.2rem; color: var(--fg-3); transition: color var(--dur-fast), transform var(--dur-fast) var(--ease-out); }
.svc-card:hover .svc-arrow { color: var(--accent-hi); transform: translate(3px,-3px); }

/* ============================================================
   ABOUT
   ============================================================ */
.about { padding-block: var(--space-section); background: var(--bg-0); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,5rem); align-items: center; }
.about-copy h2 { font-size: var(--t-h2); margin-bottom: 1.5rem; }
.about-copy p + p { margin-top: 1.1rem; }
.about-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 2.6rem; padding-top: 2.2rem; border-top: 1px solid var(--line-1); }
.about-stat .n { font-size: 2.4rem; font-weight: var(--w-semi); color: var(--fg-0); letter-spacing: -0.03em; }
.about-stat .n .u { color: var(--accent); }
.about-stat .l { font-size: var(--t-xs); color: var(--fg-2); margin-top: 0.2rem; }
.about-visual { position: relative; aspect-ratio: 4/5; }
.about-visual image-slot { position: absolute; box-shadow: var(--sh-lg); border-radius: var(--r-lg); }
.about-slot-1 { inset: 0 20% 18% 0; z-index: 1; }
.about-slot-2 { width: 52%; aspect-ratio: 1; right: 0; bottom: 0; z-index: 2; border: 6px solid var(--bg-0) !important; }

/* ============================================================
   SHOT STYLE SELECTOR
   ============================================================ */
.shotstyle { padding-block: var(--space-section); background: var(--bg-1); }
.shot-layout { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem,4vw,4rem); margin-top: 3.5rem; align-items: start; }
.shot-list { display: flex; flex-direction: column; gap: 0.5rem; }
.shot-opt {
  display: flex; align-items: center; gap: 1.1rem; padding: 1.1rem 1.3rem;
  border: 1px solid var(--line-0); border-radius: var(--r-md); background: var(--bg-2);
  cursor: pointer; text-align: left; width: 100%;
  transition: border-color var(--dur-fast), background var(--dur-fast), transform var(--dur-fast) var(--ease-out);
}
.shot-opt:hover { border-color: var(--line-2); transform: translateX(4px); }
.shot-opt.active { border-color: var(--accent); background: var(--accent-soft); }
.shot-opt-swatch { width: 44px; height: 44px; border-radius: var(--r-sm); flex: none; border: 1px solid var(--line-1); position: relative; overflow: hidden; }
.shot-opt-text { flex: 1; }
.shot-opt-text .t { font-size: var(--t-body); font-weight: var(--w-med); color: var(--fg-0); }
.shot-opt-text .d { font-size: var(--t-xs); color: var(--fg-2); }
.shot-opt .check { width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid var(--line-2); flex: none; display: grid; place-items: center; transition: all var(--dur-fast); }
.shot-opt.active .check { background: var(--accent); border-color: var(--accent); }
.shot-opt .check svg { width: 13px; height: 13px; color: #fff; opacity: 0; transform: scale(0.5); transition: all var(--dur-fast) var(--ease-out); }
.shot-opt.active .check svg { opacity: 1; transform: none; }

.shot-preview { position: relative; border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 4/3; border: 1px solid var(--line-1); background: var(--bg-inset); }
.shot-preview image-slot { position: absolute; inset: 0; }
.shot-preview-overlay { position: absolute; inset: 0; pointer-events: none; transition: background var(--dur-slow) var(--ease-out); }
.shot-preview-meta { position: absolute; left: 1.3rem; bottom: 1.3rem; right: 1.3rem; z-index: 3; display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; }
.shot-preview-meta .label { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-0); background: rgba(10,10,12,0.6); backdrop-filter: blur(10px); padding: 0.5rem 0.85rem; border-radius: var(--r-pill); border: 1px solid var(--line-1); }
.shot-mood-bar { display: flex; gap: 0.4rem; margin-top: 1.4rem; }
.shot-mood-bar .seg { flex: 1; height: 3px; border-radius: 2px; background: var(--line-1); transition: background var(--dur); }
.shot-mood-bar .seg.on { background: var(--accent); }

/* ============================================================
   BEFORE / AFTER
   ============================================================ */
.beforeafter { padding-block: calc(var(--space-section) + 2.5rem) var(--space-section); background: transparent; }
.ba-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1fr);
  gap: clamp(1.5rem, 2.6vw, 3rem);
  align-items: center;
}
.ba-copy { display: flex; flex-direction: column; align-items: flex-start; max-width: 48ch; transform: translateY(-1.25rem); }
.ba-copy .sec-title { margin-top: 1.2rem; }
.ba-copy .sec-sub { margin-top: 1.4rem; }
.ba-legend { display: flex; flex-direction: column; gap: 0.7rem; margin-top: 2rem; }
.ba-legend-row { display: flex; align-items: center; gap: 0.7rem; font-size: var(--t-sm); color: var(--fg-1); }
.ba-legend-row b { color: var(--fg-0); font-weight: var(--w-semi); }
.ba-legend-dot { width: 10px; height: 10px; border-radius: 50%; flex: none; }
.ba-legend-dot.raw { background: var(--fg-3); box-shadow: 0 0 0 4px color-mix(in oklch, var(--fg-3), transparent 80%); }
.ba-legend-dot.done { background: var(--accent); box-shadow: 0 0 0 4px var(--accent-glow, rgba(0,0,0,0.08)); }
.ba-stage-col { display: flex; flex-direction: column; align-items: center; justify-content: center; }
.ba-stage-col .ba-hint { margin-top: 1.6rem; }
.ba-stage {
  position: relative; max-width: 100%; border-radius: var(--r-lg); overflow: hidden;
  border: 1px solid var(--line-1); user-select: none; touch-action: none; cursor: ew-resize;
  background:
    radial-gradient(120% 80% at 50% 0%, color-mix(in oklch, var(--bg-2), transparent 30%), transparent 60%),
    var(--bg-inset);
  box-shadow: 0 1px 0 rgba(255,255,255,0.5) inset, var(--sh-lg, 0 30px 70px -32px rgba(12,12,16,0.45));
  transition: box-shadow var(--dur) var(--ease-out);
}
.ba-stage:hover { box-shadow: 0 1px 0 rgba(255,255,255,0.5) inset, 0 40px 90px -34px rgba(12,12,16,0.55); }
.ba-layer { position: absolute; inset: 0; }
.ba-after { z-index: 1; }
.ba-before { z-index: 2; will-change: clip-path; }
.ba-before image-slot, .ba-after image-slot { position: absolute; inset: 0; width: 100%; height: 100%; }

/* smooth glide when clicking / settling - suppressed while actively dragging */
.ba-before, .ba-handle { transition: clip-path 0.55s var(--ease-out), left 0.55s var(--ease-out); }
.ba-stage.dragging .ba-before, .ba-stage.dragging .ba-handle { transition: none; }

.ba-tag {
  position: absolute; z-index: 4; font-family: var(--font-mono); font-size: var(--t-xs);
  letter-spacing: 0.14em; text-transform: uppercase; padding: 0.5rem 0.9rem; border-radius: var(--r-pill);
  background: rgba(10,10,12,0.6); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,0.14);
  color: #f6f5f2; box-shadow: 0 6px 20px -10px rgba(0,0,0,0.6);
  transition: opacity var(--dur) var(--ease-out);
}
/* placed on opposite diagonal corners so they never collide on portrait stages */
.ba-tag.before { top: 1.1rem; left: 1.1rem; }
.ba-tag.after { bottom: 1.1rem; right: 1.1rem; color: var(--accent-hi); border-color: color-mix(in oklch, var(--accent), transparent 45%); }
/* fade each tag when its side gets squeezed away */
.ba-stage.near-left .ba-tag.before { opacity: 0; }
.ba-stage.near-right .ba-tag.after { opacity: 0; }
.ba-stage.near-right .ba-tag.before { opacity: 0; }
.ba-stage.near-left .ba-tag.after { opacity: 0; }

.ba-handle { position: absolute; top: 0; bottom: 0; width: 2px; z-index: 5; pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.55), #fff 18%, #fff 82%, rgba(255,255,255,0.55));
  box-shadow: 0 0 0 1px rgba(0,0,0,0.06), 0 0 22px rgba(255,255,255,0.55);
}
.ba-knob {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 56px; height: 56px;
  border-radius: 50%; background: #fff; display: grid; place-items: center; color: #14141a;
  box-shadow: 0 8px 24px -6px rgba(0,0,0,0.45), 0 0 0 6px rgba(255,255,255,0.18), 0 0 0 1px rgba(0,0,0,0.05);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}
.ba-stage:hover .ba-knob { transform: translate(-50%,-50%) scale(1.06); }
.ba-stage.dragging .ba-knob { transform: translate(-50%,-50%) scale(1.12); box-shadow: 0 10px 30px -6px rgba(0,0,0,0.5), 0 0 0 8px rgba(255,255,255,0.22), 0 0 0 1px rgba(0,0,0,0.05); }
.ba-knob svg { width: 24px; height: 24px; }
/* drag hint: a slow breathing ring until the user first grabs the knob */
.ba-knob::before {
  content: ""; position: absolute; inset: -7px; border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.75); opacity: 0; animation: ba-pulse 2.4s ease-out infinite;
}
.ba-stage.touched .ba-knob::before { animation: none; opacity: 0; }
@keyframes ba-pulse { 0% { transform: scale(0.7); opacity: 0; } 35% { opacity: 0.7; } 100% { transform: scale(1.5); opacity: 0; } }
body.no-motion .ba-knob::before { animation: none; }

.ba-hint { margin-top: 2.2rem; font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-2); display: inline-flex; align-items: center; gap: 0.6rem; }
.ba-hint::before { content: ""; width: 26px; height: 1px; background: var(--line-2); }

@media (max-width: 880px) {
  .ba-layout { grid-template-columns: 1fr; gap: 2.4rem; }
  .ba-copy { max-width: 56ch; align-items: center; text-align: center; margin-inline: auto; }
  .ba-copy .sec-label { justify-content: center; }
  .ba-legend { align-items: flex-start; }
}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.portfolio { padding-block: var(--space-section); background: var(--bg-1); }
.port-filters { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 2.5rem; }
.port-filter { font-size: var(--t-sm); color: var(--fg-1); padding: 0.55rem 1.1rem; border: 1px solid var(--line-1); border-radius: var(--r-pill); cursor: pointer; background: transparent; transition: all var(--dur-fast); }
.port-filter:hover { border-color: var(--fg-2); color: var(--fg-0); }
.port-filter.active { background: var(--fg-0); color: var(--bg-0); border-color: var(--fg-0); }
.port-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 1.1rem; margin-top: 2rem; }
.port-item { position: relative; border-radius: var(--r-md); overflow: hidden; cursor: pointer; background: var(--bg-2); border: 1px solid var(--line-0); }
.port-item image-slot { position: absolute; inset: 0; width: 100%; height: 100%; }
.port-item .inner { position: relative; width: 100%; height: 100%; }
.port-item .ph { position: absolute; inset: 0; display: grid; place-items: center; color: var(--fg-3); font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.1em; text-transform: uppercase; }
.port-item .meta { position: absolute; inset: auto 0 0 0; z-index: 3; padding: 1.4rem; display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; opacity: 0; transform: translateY(10px); transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); background: linear-gradient(transparent, rgba(8,8,10,0.85)); }
.port-item:hover .meta { opacity: 1; transform: none; }
.port-item .meta .t { font-weight: var(--w-semi); color: var(--fg-0); font-size: var(--t-body); }
.port-item .meta .c { font-size: var(--t-xs); color: var(--fg-1); }
.port-item .meta .expand { width: 36px; height: 36px; border-radius: 50%; background: var(--accent); display: grid; place-items: center; color: #fff; flex: none; }
.port-item .meta .expand svg { width: 16px; height: 16px; }
/* sizes */
.port-item.lg { grid-column: span 8; aspect-ratio: 16/10; }
.port-item.sm { grid-column: span 4; aspect-ratio: 4/5; }
.port-item.md { grid-column: span 6; aspect-ratio: 3/2; }
.port-item.tall { grid-column: span 4; aspect-ratio: 3/4; }
.port-item.wide { grid-column: span 12; aspect-ratio: 21/9; }

/* lightbox */
.lightbox { position: fixed; inset: 0; z-index: 120; background: rgba(6,6,8,0.92); backdrop-filter: blur(8px); display: grid; place-items: center; padding: var(--gutter); opacity: 0; pointer-events: none; transition: opacity var(--dur); }
.lightbox.open { opacity: 1; pointer-events: auto; }
.lightbox-card { width: min(960px, 100%); max-height: 88vh; background: var(--bg-2); border: 1px solid var(--line-1); border-radius: var(--r-lg); overflow: hidden; display: grid; grid-template-columns: 1.4fr 1fr; transform: scale(0.96); transition: transform var(--dur) var(--ease-out); }
.lightbox.open .lightbox-card { transform: none; }
.lightbox-visual { position: relative; background: var(--bg-inset); min-height: 420px; }
.lightbox-visual image-slot { position: absolute; inset: 0; width: 100%; height: 100%; }
.lightbox-body { padding: 2.4rem; display: flex; flex-direction: column; gap: 1rem; overflow-y: auto; }
.lightbox-body .cat { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.lightbox-body h3 { font-size: var(--t-h3); }
.lightbox-body .desc { color: var(--fg-1); font-size: var(--t-sm); }
.lightbox-body .kv { display: flex; justify-content: space-between; padding: 0.7rem 0; border-bottom: 1px solid var(--line-0); font-size: var(--t-sm); }
.lightbox-body .kv span:first-child { color: var(--fg-2); }
.lightbox-body .kv span:last-child { color: var(--fg-0); }
.lightbox-close { position: absolute; top: 1rem; right: 1rem; z-index: 5; width: 40px; height: 40px; border-radius: 50%; background: rgba(10,10,12,0.6); border: 1px solid var(--line-1); color: var(--fg-0); display: grid; place-items: center; cursor: pointer; backdrop-filter: blur(10px); transition: background var(--dur-fast); }
.lightbox-close:hover { background: var(--bg-3); }

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.howitworks { padding-block: var(--space-section); background: var(--bg-0); }
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem; margin-top: 3.5rem; counter-reset: step; }
.step { position: relative; padding: 2rem 1.8rem; border-radius: var(--r-lg); background: var(--bg-2); border: 1px solid var(--line-0); transition: border-color var(--dur), transform var(--dur) var(--ease-out); }
.step:hover { border-color: var(--line-2); transform: translateY(-4px); }
.step-num { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--accent); letter-spacing: 0.12em; }
.step-ico { width: 44px; height: 44px; border-radius: var(--r-md); display: grid; place-items: center; background: var(--accent-soft); color: var(--accent-hi); margin: 1.3rem 0; }
.step-ico svg { width: 22px; height: 22px; }
.step h4 { font-size: var(--t-h4); font-weight: var(--w-semi); color: var(--fg-0); margin-bottom: 0.5rem; }
.step p { font-size: var(--t-sm); color: var(--fg-1); }
.step-line { position: absolute; top: 50%; right: -1.1rem; width: 1.1rem; height: 1px; background: var(--line-2); z-index: 1; }

/* ============================================================
   PRICING
   ============================================================ */
.pricing { padding-block: calc(var(--space-section) * 0.62); background: var(--bg-1); }
.price-toggle { display: inline-flex; gap: 0.25rem; padding: 0.3rem; border: 1px solid var(--line-1); border-radius: var(--r-pill); margin-top: 2rem; background: var(--bg-2); }
.price-toggle button { font-size: var(--t-sm); color: var(--fg-1); padding: 0.55rem 1.2rem; border-radius: var(--r-pill); border: 0; background: transparent; cursor: pointer; transition: all var(--dur-fast); font-family: var(--font-sans); }
.price-toggle button.active { background: var(--fg-0); color: var(--bg-0); }
.price-toggle .save { font-family: var(--font-mono); font-size: 0.62rem; color: var(--accent-hi); margin-left: 0.4rem; }

.price-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.85rem; margin-top: 2.1rem; align-items: stretch; }
.price-card { display: flex; flex-direction: column; padding: 1.5rem 1.35rem; border-radius: var(--r-lg); background: var(--bg-2); border: 1px solid var(--line-0); position: relative; transition: border-color var(--dur), transform var(--dur) var(--ease-out); }
.price-card:hover { transform: translateY(-5px); border-color: var(--line-2); }
.price-card.featured { border-color: var(--accent); background: linear-gradient(180deg, var(--accent-soft), var(--bg-2) 40%); box-shadow: var(--sh-glow); }
.price-badge { position: absolute; top: -11px; left: 1.7rem; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; background: var(--accent); color: #fff; padding: 0.3rem 0.7rem; border-radius: var(--r-pill); }
.price-name { font-size: var(--t-h5, var(--t-body)); font-weight: var(--w-semi); color: var(--fg-0); }
.price-desc { font-size: var(--t-xs); color: var(--fg-2); margin-top: 0.25rem; min-height: 2.4em; }
.price-amt { display: flex; align-items: baseline; gap: 0.2rem; margin: 1rem 0 0.2rem; }
.price-amt .cur { font-size: 1rem; color: var(--fg-1); font-weight: var(--w-med); }
.price-amt .val { font-size: 2.2rem; font-weight: var(--w-bold); color: var(--fg-0); letter-spacing: -0.04em; line-height: 1; }
.price-amt .per { font-size: var(--t-xs); color: var(--fg-2); }
.price-old { font-size: var(--t-sm); color: var(--fg-3); text-decoration: line-through; }
.price-feats { list-style: none; padding: 0; margin: 1.2rem 0; display: flex; flex-direction: column; gap: 0.55rem; flex: 1; }
.price-feats li { display: flex; gap: 0.55rem; font-size: var(--t-xs); color: var(--fg-1); line-height: 1.35; }
.price-feats li svg { width: 15px; height: 15px; color: var(--accent-hi); flex: none; margin-top: 1px; }
.price-feats li.muted { color: var(--fg-3); }
.price-feats li.muted svg { color: var(--fg-3); }
.price-foot { font-size: var(--t-xs); color: var(--fg-2); text-align: center; margin-top: 1.6rem; }

/* ============================================================
   ORDER FLOW (modal)
   ============================================================ */
.order-overlay { position: fixed; inset: 0; z-index: 130; background: rgba(6,6,8,0.86); backdrop-filter: blur(10px); display: grid; place-items: center; padding: clamp(0.5rem,3vw,2rem); opacity: 0; pointer-events: none; transition: opacity var(--dur); }
.order-overlay.open { opacity: 1; pointer-events: auto; }
.order-modal { width: min(900px, 100%); max-height: 92vh; background: var(--bg-1); border: 1px solid var(--line-1); border-radius: var(--r-xl); overflow: hidden; display: flex; flex-direction: column; transform: translateY(20px) scale(0.98); transition: transform var(--dur) var(--ease-out); }
.order-overlay.open .order-modal { transform: none; }
.order-head { display: flex; align-items: center; justify-content: space-between; padding: 1.4rem 1.8rem; border-bottom: 1px solid var(--line-0); }
.order-steps { display: flex; align-items: center; gap: 0.5rem; }
.ostep { display: flex; align-items: center; gap: 0.5rem; }
.ostep .num { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-size: var(--t-xs); font-family: var(--font-mono); border: 1px solid var(--line-2); color: var(--fg-2); transition: all var(--dur-fast); }
.ostep.active .num { background: var(--accent); border-color: var(--accent); color: #fff; }
.ostep.done .num { background: var(--ok); border-color: var(--ok); color: #06140e; }
.ostep .lbl { font-size: var(--t-xs); color: var(--fg-2); }
.ostep.active .lbl { color: var(--fg-0); }
.ostep .bar { width: 26px; height: 1px; background: var(--line-2); }
.order-close { width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--line-1); background: transparent; color: var(--fg-1); cursor: pointer; display: grid; place-items: center; transition: all var(--dur-fast); }
.order-close:hover { background: var(--bg-3); color: var(--fg-0); }
.order-body { padding: 2rem 1.8rem; overflow-y: auto; flex: 1; }
.order-foot { padding: 1.3rem 1.8rem; border-top: 1px solid var(--line-0); display: flex; align-items: center; justify-content: space-between; gap: 1rem; background: var(--bg-2); }
.order-foot .summary { font-size: var(--t-sm); color: var(--fg-1); }
.order-foot .summary b { color: var(--fg-0); }
.order-actions { display: flex; gap: 0.7rem; }
.order-step-title { font-size: var(--t-h3); margin-bottom: 0.4rem; }
.order-step-sub { font-size: var(--t-sm); color: var(--fg-2); margin-bottom: 1.8rem; }

/* dropzone */
.dropzone { border: 1.5px dashed var(--line-2); border-radius: var(--r-lg); padding: 3rem 2rem; text-align: center; transition: all var(--dur-fast); cursor: pointer; background: var(--bg-2); }
.dropzone.drag { border-color: var(--accent); background: var(--accent-soft); }
.dropzone .ico { width: 56px; height: 56px; border-radius: var(--r-md); background: var(--accent-soft); color: var(--accent-hi); display: grid; place-items: center; margin: 0 auto 1.2rem; }
.dropzone .ico svg { width: 28px; height: 28px; }
.dropzone h4 { font-size: var(--t-h4); color: var(--fg-0); margin-bottom: 0.35rem; }
.dropzone p { font-size: var(--t-sm); color: var(--fg-2); }
.dropzone .browse { color: var(--accent-hi); text-decoration: underline; text-underline-offset: 3px; }
.upload-list { display: flex; flex-direction: column; gap: 0.6rem; margin-top: 1.3rem; }
.upload-row { display: flex; align-items: center; gap: 0.9rem; padding: 0.8rem 1rem; border: 1px solid var(--line-1); border-radius: var(--r-md); background: var(--bg-2); }
.upload-row .thumb { width: 42px; height: 42px; border-radius: var(--r-xs); background: var(--bg-3); display: grid; place-items: center; color: var(--fg-2); flex: none; overflow: hidden; }
.upload-row .thumb img { width: 100%; height: 100%; object-fit: cover; }
.upload-row .info { flex: 1; min-width: 0; }
.upload-row .info .n { font-size: var(--t-sm); color: var(--fg-0); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.upload-row .info .s { font-size: var(--t-xs); color: var(--fg-2); }
.upload-row .prog { height: 3px; background: var(--line-1); border-radius: 2px; margin-top: 0.4rem; overflow: hidden; }
.upload-row .prog i { display: block; height: 100%; background: var(--accent); border-radius: 2px; transition: width 0.3s linear; }
.upload-row .del { background: none; border: 0; color: var(--fg-3); cursor: pointer; padding: 0.3rem; transition: color var(--dur-fast); }
.upload-row .del:hover { color: var(--danger); }

/* style/package grids inside order */
.opt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.8rem; }
.opt-tile { border: 1px solid var(--line-1); border-radius: var(--r-md); padding: 1rem; cursor: pointer; background: var(--bg-2); transition: all var(--dur-fast); text-align: left; }
.opt-tile:hover { border-color: var(--line-2); }
.opt-tile.sel { border-color: var(--accent); background: var(--accent-soft); }
.opt-tile .sw { aspect-ratio: 16/10; border-radius: var(--r-sm); margin-bottom: 0.7rem; border: 1px solid var(--line-1); }
.opt-tile .t { font-size: var(--t-sm); font-weight: var(--w-med); color: var(--fg-0); }
.opt-tile .d { font-size: var(--t-xs); color: var(--fg-2); }
.pkg-list { display: flex; flex-direction: column; gap: 0.7rem; }
.pkg-row { display: flex; align-items: center; gap: 1rem; padding: 1.1rem 1.3rem; border: 1px solid var(--line-1); border-radius: var(--r-md); cursor: pointer; background: var(--bg-2); transition: all var(--dur-fast); }
.pkg-row:hover { border-color: var(--line-2); }
.pkg-row.sel { border-color: var(--accent); background: var(--accent-soft); }
.pkg-row .radio { width: 20px; height: 20px; border-radius: 50%; border: 1.5px solid var(--line-2); flex: none; display: grid; place-items: center; transition: all var(--dur-fast); }
.pkg-row.sel .radio { border-color: var(--accent); }
.pkg-row.sel .radio::after { content:""; width: 10px; height: 10px; border-radius: 50%; background: var(--accent); }
.pkg-row .info { flex: 1; }
.pkg-row .info .n { font-size: var(--t-body); font-weight: var(--w-med); color: var(--fg-0); }
.pkg-row .info .d { font-size: var(--t-xs); color: var(--fg-2); }
.pkg-row .price { font-size: var(--t-h4); font-weight: var(--w-semi); color: var(--fg-0); }

/* payment form */
.pay-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.field { display: flex; flex-direction: column; gap: 0.4rem; }
.field label { font-size: var(--t-xs); color: var(--fg-2); font-family: var(--font-mono); letter-spacing: 0.04em; }
.field input, .field textarea, .field select {
  font-family: var(--font-sans); font-size: var(--t-sm); color: var(--fg-0);
  background: var(--bg-2); border: 1px solid var(--line-1); border-radius: var(--r-sm);
  padding: 0.8rem 0.95rem; transition: border-color var(--dur-fast), box-shadow var(--dur-fast); width: 100%;
}
.field input::placeholder, .field textarea::placeholder { color: var(--fg-3); }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }
.card-input { position: relative; }
.card-input .brand-ic { position: absolute; right: 0.9rem; top: 50%; transform: translateY(-50%); color: var(--fg-2); font-family: var(--font-mono); font-size: var(--t-xs); }
.stripe-badge { display: flex; align-items: center; justify-content: center; gap: 0.5rem; font-size: var(--t-xs); color: var(--fg-2); margin-top: 1.2rem; }
.stripe-badge svg { width: 14px; height: 14px; }
.order-success { text-align: center; padding: 1.5rem 0; }
.order-success .check-big { width: 72px; height: 72px; border-radius: 50%; background: var(--accent-soft); color: var(--ok); display: grid; place-items: center; margin: 0 auto 1.5rem; animation: pop 0.5s var(--ease-out); }
.order-success .check-big svg { width: 36px; height: 36px; }
@keyframes pop { 0% { transform: scale(0.4); opacity: 0; } 100% { transform: none; opacity: 1; } }
.order-summary-box { background: var(--bg-2); border: 1px solid var(--line-1); border-radius: var(--r-md); padding: 1.3rem; margin: 1.5rem 0; text-align: left; }
.order-summary-box .kv { display: flex; justify-content: space-between; padding: 0.5rem 0; font-size: var(--t-sm); }
.order-summary-box .kv span:first-child { color: var(--fg-2); }
.order-summary-box .kv span:last-child { color: var(--fg-0); font-weight: var(--w-med); }
.order-summary-box .kv.total { border-top: 1px solid var(--line-1); margin-top: 0.4rem; padding-top: 0.8rem; }
.order-summary-box .kv.total span { font-size: var(--t-body); font-weight: var(--w-semi); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials { padding-block: var(--space-section); background: var(--bg-0); }
.test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; margin-top: 3.5rem; }
.test-card { padding: 2rem; border-radius: var(--r-lg); background: var(--bg-2); border: 1px solid var(--line-0); display: flex; flex-direction: column; gap: 1.4rem; transition: border-color var(--dur), transform var(--dur) var(--ease-out); }
.test-card:hover { border-color: var(--line-2); transform: translateY(-4px); }
.test-stars { display: flex; gap: 0.2rem; color: var(--accent-hi); }
.test-stars svg { width: 16px; height: 16px; }
.test-quote { font-size: var(--t-body); color: var(--fg-0); line-height: 1.55; flex: 1; letter-spacing: -0.01em; }
.test-author { display: flex; align-items: center; gap: 0.8rem; }
.test-avatar { width: 42px; height: 42px; border-radius: 50%; overflow: hidden; flex: none; }
.test-author .n { font-size: var(--t-sm); font-weight: var(--w-med); color: var(--fg-0); }
.test-author .r { font-size: var(--t-xs); color: var(--fg-2); }

/* ============================================================
   FAQ
   ============================================================ */
.faq { padding-block: var(--space-section); background: var(--bg-1); }
.faq-layout { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(2rem,5vw,5rem); margin-top: 2rem; align-items: start; }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-bottom: 1px solid var(--line-1); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 1.4rem 0; background: none; border: 0; cursor: pointer; text-align: left; font-family: var(--font-sans); font-size: var(--t-h4); font-weight: var(--w-med); color: var(--fg-0); transition: color var(--dur-fast); }
.faq-q:hover { color: var(--accent-hi); }
.faq-q .ic { width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--line-2); display: grid; place-items: center; flex: none; transition: all var(--dur-fast); }
.faq-item.open .faq-q .ic { background: var(--accent); border-color: var(--accent); color: #fff; transform: rotate(45deg); }
.faq-q .ic svg { width: 14px; height: 14px; }
.faq-a { overflow: hidden; max-height: 0; transition: max-height var(--dur) var(--ease-out); }
.faq-item.open .faq-a { max-height: 460px; }
.faq-a p { padding: 0 0 1.4rem; color: var(--fg-1); font-size: var(--t-sm); max-width: 56ch; }

/* ============================================================
   CONTACT / CTA
   ============================================================ */
.contact { padding-block: var(--space-section); background: var(--bg-0); }
.contact-card { position: relative; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--line-1); background:
  radial-gradient(120% 130% at 85% 0%, rgba(37,99,255,0.2), transparent 55%), var(--bg-2); padding: clamp(2.5rem,5vw,4.5rem); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: start; position: relative; z-index: 2; }
.contact-left h2 { font-size: var(--t-h2); margin-bottom: 1.2rem; }
.contact-left p { color: var(--fg-1); max-width: 40ch; }
.contact-points { display: flex; flex-direction: column; gap: 1rem; margin-top: 2rem; }
.contact-point { display: flex; align-items: center; gap: 0.9rem; font-size: var(--t-sm); color: var(--fg-1); }
.contact-point .ic { width: 38px; height: 38px; border-radius: var(--r-sm); background: var(--accent-soft); color: var(--accent-hi); display: grid; place-items: center; flex: none; }
.contact-point .ic svg { width: 18px; height: 18px; }
.contact-form { display: flex; flex-direction: column; gap: 1rem; }
.contact-form .field input, .contact-form .field textarea, .contact-form .field select { background: rgba(10,10,12,0.5); }

/* ============================================================
   SELECT SHOTS PAGE
   ============================================================ */
.ss-page { padding-top: 6rem; padding-bottom: 9rem; min-height: 100vh; background: var(--bg-1); }
/* When the Free Sample band is the last thing on the page (step 2), let it
   sit flush against the footer - no cream gap. */
.ss-page:has(.freesample) { padding-bottom: 0; }
.ss-back {
  display: inline-flex; align-items: center; gap: 0.45rem;
  font-family: var(--font-mono); font-size: var(--t-xs);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fg-2); margin-bottom: 2rem;
  transition: color var(--dur-fast);
}
.ss-back:hover { color: var(--fg-0); }
.ss-header { padding-block: clamp(2rem, 5vw, 4rem) clamp(1.6rem, 3vw, 2.4rem); }
.ss-header .sec-label { margin-bottom: 1rem; display: block; }
.ss-title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(2.4rem, 5.5vw, 4.2rem); line-height: 1.04;
  letter-spacing: -0.025em; color: var(--fg-0);
  font-variation-settings: "opsz" 144;
  margin: 0;
}
.ss-title em { font-style: italic; font-weight: 300; color: var(--accent); }
.ss-lead {
  font-size: var(--t-lead); color: var(--fg-1);
  max-width: 64ch; margin-top: 1.2rem; line-height: 1.55;
}

/* ---- Wizard stepper ---- */
.ss-stepper-section { padding-block: 1.6rem 1.4rem; border-bottom: 1px solid var(--line-0); }
.ss-stepper {
  display: flex; align-items: center; gap: 0.4rem;
  list-style: none; margin: 0; padding: 0;
}
.ss-step { display: flex; align-items: center; gap: 0.4rem; }
.ss-step-btn {
  display: inline-flex; align-items: center; gap: 0.7rem;
  background: transparent; border: 0; cursor: pointer;
  font-family: inherit; padding: 0.45rem 0.2rem;
  color: var(--fg-3); text-align: left;
  transition: color var(--dur-fast);
}
.ss-step.done .ss-step-btn { cursor: pointer; }
.ss-step-btn:disabled { cursor: default; }
.ss-step-num {
  width: 36px; height: 36px; flex: none;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 1.5px solid var(--line-1);
  color: var(--fg-3);
  transition: all var(--dur-fast) var(--ease-out);
}
.ss-step-num svg { stroke: currentColor; color: currentColor; }
.ss-step.active .ss-step-num {
  border-color: var(--accent); color: var(--accent);
  background: var(--accent-soft);
}
.ss-step.done .ss-step-num {
  border-color: var(--accent); background: var(--accent); color: var(--accent-ink);
}
.ss-step-txt { display: flex; flex-direction: column; gap: 0.1rem; }
.ss-step-idx {
  font-family: var(--font-mono); font-size: 0.62rem;
  letter-spacing: 0.14em; color: var(--fg-3);
}
.ss-step-label {
  font-size: var(--t-sm); font-weight: var(--w-semi);
  letter-spacing: -0.01em; color: var(--fg-2);
  transition: color var(--dur-fast);
}
.ss-step.active .ss-step-label { color: var(--fg-0); }
.ss-step.active .ss-step-idx { color: var(--accent); }
.ss-step.done .ss-step-label { color: var(--fg-1); }
.ss-step-bar {
  width: clamp(20px, 5vw, 64px); height: 1.5px; flex: none;
  margin: 0 0.4rem;
  background: var(--line-1);
  transition: background var(--dur-fast);
}
.ss-step.done + .ss-step .ss-step-bar,
.ss-step.done .ss-step-bar { background: var(--accent); }

/* ---- Step body ---- */
.ss-body-section { padding-block: 2.4rem 4rem; }

/* ---- Package cards ---- */
.ss-pkg-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem;
  align-items: stretch;
}
.ss-pkg-card {
  position: relative; text-align: left; cursor: pointer;
  display: flex; flex-direction: column; gap: 0.7rem;
  padding: 2rem 1.7rem 2.1rem;
  background: var(--bg-2); border: 1px solid var(--line-0);
  border-radius: var(--r-lg);
  font-family: inherit;
  transition: border-color var(--dur-fast), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast);
}
.ss-pkg-card:hover { border-color: var(--line-2); transform: translateY(-3px); }
.ss-pkg-card.sel {
  border-color: var(--accent);
  box-shadow: 0 0 0 1.5px var(--accent), 0 22px 50px -28px var(--accent-glow);
}
.ss-pkg-flag {
  position: absolute; top: -0.7rem; left: 1.4rem;
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--accent); color: var(--accent-ink);
  padding: 0.3rem 0.6rem; border-radius: 99px;
}
.ss-pkg-radio {
  position: absolute; top: 1.4rem; right: 1.3rem;
  width: 22px; height: 22px; border-radius: 50%;
  border: 1.5px solid var(--line-1);
  display: grid; place-items: center;
  color: var(--accent-ink); transition: all var(--dur-fast);
}
.ss-pkg-card.sel .ss-pkg-radio { background: var(--accent); border-color: var(--accent); }
.ss-pkg-radio svg { stroke: var(--accent-ink); color: var(--accent-ink); }
.ss-pkg-name {
  font-family: var(--font-serif); font-weight: 400;
  font-variation-settings: "opsz" 40;
  font-size: 1.6rem; letter-spacing: -0.02em; color: var(--fg-0);
  padding-right: 1.8rem;
}
.ss-pkg-desc { font-size: var(--t-sm); color: var(--fg-2); line-height: 1.5; min-height: 2.8em; }
.ss-pkg-price { display: flex; align-items: baseline; gap: 0.4rem; margin-top: 0.3rem; }
.ss-pkg-price .cur { font-size: 1rem; color: var(--fg-2); font-weight: var(--w-med); }
.ss-pkg-price .val {
  font-family: var(--font-serif); font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: 2.6rem; letter-spacing: -0.02em; line-height: 1; color: var(--fg-0);
}
.ss-pkg-price .old {
  font-family: var(--font-mono); font-size: 0.8rem;
  color: var(--fg-3); text-decoration: line-through;
}
.ss-pkg-shots {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-family: var(--font-mono); font-size: 0.7rem;
  letter-spacing: 0.04em; color: var(--accent);
  padding: 0.3rem 0; border-top: 1px solid var(--line-0); margin-top: 0.3rem;
}
.ss-pkg-shots svg { stroke: var(--accent); color: var(--accent); }
.ss-pkg-feats { list-style: none; margin: 0.2rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.ss-pkg-feats li {
  display: flex; align-items: center; gap: 0.45rem;
  font-size: var(--t-xs); color: var(--fg-1);
}
.ss-pkg-feats svg { stroke: var(--fg-3); color: var(--fg-3); flex: none; }
.ss-pkg-feats li.muted { color: var(--fg-3); }

/* ---- Product upload ---- */
.ss-upload { max-width: 720px; margin-inline: auto; }
.ss-dropzone {
  border: 1.5px dashed var(--line-2); border-radius: var(--r-lg);
  background: var(--bg-2); cursor: pointer;
  padding: clamp(2.4rem, 6vw, 4rem) 2rem; text-align: center;
  transition: border-color var(--dur-fast), background var(--dur-fast);
}
.ss-dropzone:hover, .ss-dropzone.drag { border-color: var(--accent); background: var(--accent-soft); }
.ss-dz-ico {
  width: 60px; height: 60px; margin: 0 auto 1.1rem;
  display: grid; place-items: center; border-radius: 50%;
  background: var(--bg-3); color: var(--accent);
}
.ss-dz-ico svg { stroke: var(--accent); color: var(--accent); }
.ss-dropzone h4 { font-size: 1.15rem; font-weight: var(--w-semi); color: var(--fg-0); margin: 0 0 0.4rem; letter-spacing: -0.01em; }
.ss-dropzone p { font-size: var(--t-sm); color: var(--fg-2); margin: 0; }
.ss-dropzone .browse { color: var(--accent); font-weight: var(--w-semi); }
.ss-upload-list { display: flex; flex-direction: column; gap: 0.6rem; margin-top: 1.2rem; }
.ss-upload-row {
  display: flex; align-items: center; gap: 0.9rem;
  padding: 0.7rem 0.8rem; background: var(--bg-2);
  border: 1px solid var(--line-0); border-radius: var(--r-sm, 10px);
}
.ss-upload-row .thumb {
  width: 46px; height: 46px; flex: none; border-radius: 8px; overflow: hidden;
  background: var(--bg-3); display: grid; place-items: center; color: var(--fg-3);
}
.ss-upload-row .thumb img { width: 100%; height: 100%; object-fit: cover; }
.ss-upload-row .info { flex: 1; min-width: 0; }
.ss-upload-row .info .n { font-size: var(--t-sm); font-weight: var(--w-med); color: var(--fg-0); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ss-upload-row .info .s { font-family: var(--font-mono); font-size: 0.68rem; color: var(--fg-2); letter-spacing: 0.03em; margin-top: 0.15rem; }
.ss-upload-row .prog { height: 3px; background: var(--line-0); border-radius: 99px; margin-top: 0.4rem; overflow: hidden; }
.ss-upload-row .prog i { display: block; height: 100%; background: var(--accent); transition: width 0.2s; }
.ss-upload-row .del {
  flex: none; width: 32px; height: 32px; border-radius: 8px;
  background: transparent; border: 0; cursor: pointer; color: var(--fg-3);
  display: grid; place-items: center; transition: all var(--dur-fast);
}
.ss-upload-row .del:hover { background: var(--bg-3); color: var(--fg-0); }
.ss-upload-row .del svg { stroke: currentColor; color: currentColor; }

/* ---- Contact + product brief ---- */
.ss-brief {
  margin-top: 2rem; padding-top: 2rem; border-top: 1px solid var(--line-0);
}
.ss-brief.ss-brief-lead-block { margin-top: 0; padding-top: 0; border-top: 0; }
.ss-upload-divider { margin: 2rem 0 1.4rem; padding-top: 1.6rem; border-top: 1px solid var(--line-0); }
.ss-brief-head { margin-bottom: 1.3rem; }
.ss-brief-title { font-size: 1.25rem; font-weight: var(--w-semi); color: var(--fg-0); letter-spacing: -0.01em; margin: 0.7rem 0 0.4rem; }
.ss-brief-lead { font-size: var(--t-sm); color: var(--fg-2); margin: 0; line-height: 1.5; }
.ss-brief-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.ss-brief-grid .fs-field.span-2 { grid-column: span 2; }
.ss-brief-grid .fs-field input.invalid { border-color: oklch(0.62 0.2 25); }
.ss-brief-grid .fs-field input.invalid:focus { box-shadow: 0 0 0 4px oklch(0.62 0.2 25 / 0.14); }
@media (max-width: 520px) {
  .ss-brief-grid { grid-template-columns: 1fr; }
  .ss-brief-grid .fs-field.span-2 { grid-column: span 1; }
}

/* ---- Order placed (confirmation) ---- */
.ss-placed {
  display: flex; flex-direction: column; align-items: center;
  min-height: 70vh; justify-content: center;
  padding-block: clamp(2rem, 6vh, 4.5rem);
}
.ss-placed-card {
  width: 100%; max-width: 600px;
  display: flex; flex-direction: column; align-items: flex-start;
  animation: ssRise 0.7s var(--ease-out) both;
}
@keyframes ssRise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .ss-placed-card { animation: none; } }

.ss-placed-badge {
  display: inline-flex; align-items: center; gap: 0.6rem;
  padding: 0.5rem 0.95rem 0.5rem 0.55rem;
  border: 1px solid var(--line-1); border-radius: var(--r-pill);
  background: var(--bg-2);
  font-family: var(--font-mono); font-size: var(--t-eyebrow); font-weight: var(--w-med);
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-1);
  margin-bottom: 1.8rem;
}
.ss-placed-badge .tick {
  width: 20px; height: 20px; border-radius: var(--r-pill);
  background: var(--accent); display: grid; place-items: center; flex: none;
}
.ss-placed-badge .tick svg { stroke: var(--accent-ink); color: var(--accent-ink); }

.ss-placed-title { margin-bottom: 1.1rem; }
.ss-placed-lead { max-width: 52ch; margin-bottom: 0.5rem; }
.ss-placed-lead b { color: var(--fg-0); font-weight: var(--w-semi); }

/* prominent, stable order-number panel */
.ss-ordernum {
  margin-top: 2rem; width: 100%;
  display: flex; align-items: center; justify-content: space-between; gap: 1.1rem;
  flex-wrap: wrap;
  background: #14141a; color: #f8f7f4;
  border-radius: var(--r-md); padding: 1.25rem 1.5rem;
  box-shadow: var(--sh-md);
}
.ss-ordernum .on-l {
  font-family: var(--font-mono); font-size: var(--t-eyebrow);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(248,247,244,0.6); margin-bottom: 0.4rem;
}
.ss-ordernum .on-v {
  font-family: var(--font-mono); font-size: clamp(1.5rem, 3.4vw, 1.85rem);
  font-weight: var(--w-med); letter-spacing: 0.01em; line-height: 1; white-space: nowrap;
}
.ss-on-copy {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.65rem 1.05rem; border-radius: var(--r-pill);
  background: rgba(248,247,244,0.1); color: #f8f7f4;
  border: 1px solid rgba(248,247,244,0.22); cursor: pointer;
  font-family: var(--font-mono); font-size: var(--t-eyebrow);
  letter-spacing: 0.12em; text-transform: uppercase; white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.ss-on-copy svg { stroke: currentColor; color: currentColor; }
.ss-on-copy:hover { background: rgba(248,247,244,0.2); }
.ss-on-copy.ok { background: #f8f7f4; color: #14141a; border-color: transparent; }
.ss-on-copy.ok svg { stroke: #14141a; color: #14141a; }

.ss-placed-summary {
  margin-top: 1.5rem; width: 100%; max-width: none;
  background: var(--bg-2); border: 1px solid var(--line-1); border-radius: var(--r-md);
  padding: 0.4rem 1.5rem;
}
.ss-placed-summary .kv {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.85rem 0; border-bottom: 1px solid var(--line-0);
  font-size: var(--t-sm); color: var(--fg-2);
}
.ss-placed-summary .kv:last-child { border-bottom: 0; }
.ss-placed-summary .kv span:last-child { color: var(--fg-0); font-weight: var(--w-med); }
.ss-placed-summary .kv.total span { font-weight: var(--w-semi); color: var(--fg-0); }

/* what happens next */
.ss-placed-next {
  margin-top: 1.5rem; width: 100%;
  background: var(--bg-2); border: 1px solid var(--line-1); border-radius: var(--r-md);
  padding: 1.6rem 1.5rem;
}
.ss-placed-next-h {
  font-family: var(--font-mono); font-size: var(--t-eyebrow);
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-2);
  margin-bottom: 1.1rem;
}
.ss-placed-steps { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }
.ss-placed-steps li { display: flex; gap: 0.85rem; align-items: flex-start; }
.ss-placed-steps .dot {
  width: 24px; height: 24px; flex: none; border-radius: var(--r-pill);
  border: 1px solid var(--accent); color: var(--fg-0);
  display: grid; place-items: center; margin-top: 1px;
  font-family: var(--font-mono); font-size: var(--t-xs); font-weight: var(--w-med);
}
.ss-placed-steps .st { display: flex; flex-direction: column; gap: 0.2rem; }
.ss-placed-steps .st-t { font-size: var(--t-sm); color: var(--fg-0); font-weight: var(--w-semi); line-height: 1.3; }
.ss-placed-steps .st-d { font-size: var(--t-sm); color: var(--fg-2); line-height: 1.5; }

.ss-placed-actions { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 2rem; }
.ss-placed-reply { margin-top: 1.75rem; font-size: var(--t-sm); color: var(--fg-2); line-height: 1.6; }
.ss-placed-reply a { color: var(--fg-0); text-decoration: underline; text-underline-offset: 3px; }

/* ---- Grid ---- */
.ss-grid-section { padding-block: 2rem 4rem; }
.ss-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.15rem 1rem;
}
@media (min-width: 1100px) {
  .ss-grid { grid-template-columns: repeat(4, 1fr); gap: 1.2rem 1.05rem; }
}
@media (min-width: 1500px) {
  .ss-grid { grid-template-columns: repeat(5, 1fr); }
}

.ss-tile {
  display: flex; flex-direction: column; gap: 0.55rem;
  position: relative;
}
.ss-tile-visual {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--line-0);
  border-radius: 4px;
  transition: border-color var(--dur-fast), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast);
}
.ss-tile-visual image-slot {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border-radius: 0 !important;
}
/* two showcase images per tile, cross-fading on the shared 5s beat */
.ss-tile-visual .ss-flip-a,
.ss-tile-visual .ss-flip-b {
  transition: opacity 0.8s var(--ease-out);
}
.ss-tile-visual .ss-flip-b { opacity: 0; pointer-events: none; }
.ss-tile-visual.flipped .ss-flip-a { opacity: 0; pointer-events: none; }
.ss-tile-visual.flipped .ss-flip-b { opacity: 1; pointer-events: auto; }
@media (prefers-reduced-motion: reduce) {
  .ss-tile-visual .ss-flip-a,
  .ss-tile-visual .ss-flip-b { transition: none; }
}
.ss-tile:hover .ss-tile-visual {
  border-color: var(--line-2);
  transform: translateY(-2px);
}
.ss-tile.sel .ss-tile-visual {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent), 0 14px 40px -18px var(--accent-glow);
}

/* + / ✓ toggle button (square, top-right) */
.ss-tile-toggle {
  position: absolute; top: 0.55rem; right: 0.55rem;
  width: 30px; height: 30px;
  background: rgba(10,10,12,0.78);
  backdrop-filter: blur(10px);
  border: 0; cursor: pointer;
  color: #fff;
  border-radius: 4px;
  display: grid; place-items: center;
  transition: background var(--dur-fast), transform var(--dur-fast) var(--ease-out);
  z-index: 4;
}
.ss-tile-toggle:hover { background: var(--accent); transform: scale(1.05); }
.ss-tile.sel .ss-tile-toggle { background: var(--accent); }
.ss-tile.sel .ss-tile-toggle:hover { background: var(--accent-hi); }
.ss-tile-toggle svg { stroke: #fff; color: #fff; }

/* sequence number (when selected) - sits opposite the toggle */
.ss-tile-order {
  position: absolute; top: 0.55rem; left: 0.55rem;
  font-family: var(--font-mono); font-size: 0.68rem;
  letter-spacing: 0.1em; color: #fff;
  background: var(--accent); padding: 0.25rem 0.5rem;
  border-radius: 99px;
  animation: ss-pop 0.28s var(--ease-out);
  z-index: 4;
}
@keyframes ss-pop {
  0% { transform: scale(0); opacity: 0; }
  60% { transform: scale(1.15); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

/* bottom overlay with label + price */
.ss-tile-overlay {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 0.7rem 0.8rem;
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 0.5rem;
  background: linear-gradient(transparent, rgba(8,8,10,0.85));
  color: #fff;
  z-index: 3;
}
.ss-tile-label {
  font-size: 0.92rem; font-weight: var(--w-semi);
  letter-spacing: -0.01em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.ss-tile-price {
  font-family: var(--font-mono); font-size: 0.78rem;
  letter-spacing: 0.04em; color: #fff;
  background: rgba(255,255,255,0.16); padding: 0.18rem 0.45rem;
  border-radius: 3px; backdrop-filter: blur(8px);
}
.ss-tile-mood {
  font-size: var(--t-xs);
  color: var(--fg-2);
  padding: 0 0.1rem;
  letter-spacing: -0.005em;
}

/* ---- Sticky action bar ---- */
.ss-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
  background: rgba(14,14,17,0.85);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-top: 1px solid var(--line-1);
  padding: 1rem 0;
  transform: translateY(120%); transition: transform 0.45s var(--ease-out);
}
.ss-bar.visible { transform: none; }
.ss-bar-inner {
  display: flex; align-items: center; gap: 2rem;
}
.ss-bar-summary {
  flex: 1; min-width: 0;
  display: flex; align-items: center; gap: 2.2rem;
}
.ss-bar-totals { flex: none; }
.ss-bar-amount {
  display: flex; align-items: baseline; gap: 0.15rem;
  color: var(--fg-0);
}
.ss-bar-amount .cur {
  font-size: 1rem; color: var(--fg-2); font-weight: var(--w-med);
}
.ss-bar-amount .val {
  font-family: var(--font-serif); font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: 2rem; letter-spacing: -0.02em;
  line-height: 1;
}
.ss-bar-meta {
  font-size: var(--t-xs); color: var(--fg-2);
  font-family: var(--font-mono); letter-spacing: 0.04em;
  margin-top: 0.25rem;
}
.ss-bar-meta strong { color: var(--fg-0); font-weight: var(--w-semi); }
.ss-bar-brands {
  display: flex; gap: 0.45rem; flex-wrap: wrap;
}
.ss-bar-brand {
  display: inline-flex; align-items: center; gap: 0.45rem;
  padding: 0.35rem 0.7rem;
  background: var(--bg-3); border: 1px solid var(--line-0);
  border-radius: 99px;
  font-size: var(--t-xs); color: var(--fg-1);
  transition: all var(--dur-fast);
}
.ss-bar-brand.active {
  background: var(--bg-2); border-color: var(--accent);
  color: var(--fg-0);
}
.ss-bar-brand-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--line-2);
}
.ss-bar-brand.active .ss-bar-brand-dot { background: var(--accent); }
.ss-bar-brand-name { font-weight: var(--w-med); }
.ss-bar-brand-count {
  font-family: var(--font-mono); font-size: 0.7rem;
  color: var(--fg-2); letter-spacing: 0.04em;
}
.ss-bar-brand.active .ss-bar-brand-count { color: var(--accent); }
.ss-bar-actions { display: flex; gap: 0.7rem; flex: none; }

.ss-tile.locked { opacity: 0.5; }
.ss-tile.locked .ss-tile-toggle { background: rgba(10,10,12,0.5); }

/* ---- How it works (step 2 explainer) ---- */
.ss-how {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem;
  margin-bottom: 1.8rem; padding: 1.1rem 1.2rem;
  background: var(--bg-2); border: 1px solid var(--line-0); border-radius: var(--r-md);
}
.ss-how-item { display: flex; gap: 0.7rem; font-size: var(--t-sm); color: var(--fg-1); line-height: 1.45; }
.ss-how-item b { color: var(--fg-0); font-weight: var(--w-semi); }
.ss-how-n {
  flex: none; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.04em;
  color: var(--accent); border: 1px solid var(--accent-soft); background: var(--accent-soft);
  width: 24px; height: 24px; border-radius: 6px; display: grid; place-items: center;
}

/* ---- Compact grid: smaller tiles ---- */
.ss-grid-compact { grid-template-columns: repeat(4, 1fr); gap: 1rem 0.85rem; }
@media (min-width: 1100px) { .ss-grid-compact { grid-template-columns: repeat(5, 1fr); gap: 1rem 0.85rem; } }
@media (min-width: 1500px) { .ss-grid-compact { grid-template-columns: repeat(6, 1fr); } }
@media (max-width: 900px) { .ss-grid-compact { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .ss-grid-compact { grid-template-columns: repeat(2, 1fr); } }

/* ---- Animation note (shown below the grid when the package includes motion) ---- */
.ss-anim-note {
  display: flex; gap: 1rem; align-items: flex-start;
  margin-top: 1.8rem; padding: 1.25rem 1.4rem;
  background: var(--bg-2); border: 1px solid var(--line-0);
  border-left: 3px solid var(--accent);
  border-radius: var(--r-md);
}
.ss-anim-note-ico {
  flex: none; display: grid; place-items: center;
  width: 42px; height: 42px; border-radius: 999px;
  color: var(--accent); background: var(--accent-soft); border: 1px solid var(--accent-soft);
}
.ss-anim-note-body h4 {
  margin: 0.15rem 0 0.35rem; font-size: var(--t-md); font-weight: var(--w-semi);
  letter-spacing: -0.01em; color: var(--fg-0);
}
.ss-anim-note-body p {
  margin: 0; font-size: var(--t-sm); line-height: 1.55; color: var(--fg-1);
  max-width: 60ch; text-wrap: pretty;
}
@media (max-width: 560px) {
  .ss-anim-note { padding: 1.1rem; gap: 0.85rem; }
}

/* price tag, top-right */
.ss-tile-tag {
  position: absolute; top: 0.5rem; right: 0.5rem; z-index: 4;
  font-family: var(--font-mono); font-size: 0.7rem; font-weight: 500; letter-spacing: 0.02em;
  color: #fff; background: rgba(10,10,12,0.62); backdrop-filter: blur(8px);
  padding: 0.16rem 0.42rem; border-radius: 4px; border: 1px solid rgba(255,255,255,0.14);
}
/* quantity badge, top-left */
.ss-tile-qty-badge {
  position: absolute; top: 0.5rem; left: 0.5rem; z-index: 4;
  font-family: var(--font-mono); font-size: 0.7rem; font-weight: 600;
  color: var(--accent-ink); background: var(--accent);
  padding: 0.16rem 0.44rem; border-radius: 4px; box-shadow: 0 2px 10px -2px var(--accent-glow);
}
/* Add button + stepper live in the bottom overlay */
.ss-tile-add {
  display: inline-flex; align-items: center; gap: 0.3rem; margin-top: 0.4rem;
  font-family: var(--font-sans); font-size: 0.76rem; font-weight: var(--w-semi);
  color: #fff; background: rgba(255,255,255,0.16); border: 1px solid rgba(255,255,255,0.24);
  padding: 0.32rem 0.6rem; border-radius: 6px; cursor: pointer; backdrop-filter: blur(8px);
  transition: background var(--dur-fast), border-color var(--dur-fast);
}
.ss-tile-add:hover { background: var(--accent); border-color: var(--accent); }
.ss-tile-add svg { stroke: currentColor; color: currentColor; }
.ss-tile-add:disabled { opacity: 0.45; pointer-events: none; }
.ss-tile-stepper {
  display: inline-flex; align-items: center; gap: 0.1rem; margin-top: 0.4rem;
  background: rgba(10,10,12,0.55); border: 1px solid rgba(255,255,255,0.2);
  border-radius: 7px; padding: 0.12rem; backdrop-filter: blur(8px);
}
.ss-step-btn-q {
  width: 26px; height: 24px; display: grid; place-items: center;
  background: transparent; border: 0; border-radius: 5px; cursor: pointer; color: #fff;
  transition: background var(--dur-fast);
}
.ss-step-btn-q:hover { background: var(--accent); }
.ss-step-btn-q:disabled { opacity: 0.35; pointer-events: none; }
.ss-step-btn-q svg { stroke: #fff; color: #fff; }
.ss-step-q {
  min-width: 20px; text-align: center; font-family: var(--font-mono);
  font-size: 0.8rem; font-weight: 500; color: #fff;
}

@media (max-width: 900px) {
  .ss-grid { grid-template-columns: repeat(3, 1fr); }
  .ss-pkg-grid { grid-template-columns: repeat(2, 1fr); }
  .ss-bar-inner { flex-direction: column; align-items: stretch; gap: 1rem; }
  .ss-bar-summary { flex-direction: column; align-items: flex-start; gap: 0.8rem; }
  .ss-bar-actions { justify-content: space-between; }
  .ss-step-txt { display: none; }
}
@media (max-width: 560px) {
  .ss-grid { grid-template-columns: repeat(2, 1fr); gap: 0.7rem 0.6rem; }
  .ss-pkg-grid { grid-template-columns: 1fr; }
  .ss-tile-label { font-size: 0.82rem; }
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.ab-page { padding-top: 6rem; background: var(--bg-1); }
.ab-hero { padding-block: clamp(3rem, 7vw, 6rem) clamp(3rem, 6vw, 5rem); }
.ab-hero .sec-label, .ab-mission .sec-label, .ab-values .sec-label, .ab-team .sec-label {
  display: block; margin-bottom: 1rem;
}
.ab-title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(2.6rem, 6.5vw, 5rem); line-height: 1.02;
  letter-spacing: -0.03em; color: var(--fg-0);
  font-variation-settings: "opsz" 144; margin: 0;
}
.ab-title em { font-style: italic; font-weight: 300; color: var(--fg-1); display: inline; }
.ab-lead {
  font-size: var(--t-lead); color: var(--fg-1);
  max-width: 56ch; margin-top: 1.8rem; line-height: 1.55;
}

.ab-collage-section { padding-block: 1rem 4rem; }
.ab-collage {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 280px 220px;
  gap: 0.7rem;
}
.ab-c-tile {
  background: linear-gradient(135deg, #efebe1 0%, #e6e1d4 100%);
  border-radius: 2px; overflow: hidden; position: relative;
}
.ab-c-tile image-slot {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border-radius: 0 !important;
}
.ab-c-1 { grid-row: 1 / span 2; }
.ab-c-2 { grid-column: 2; }
.ab-c-3 { grid-column: 3; grid-row: 1 / span 2; }
.ab-c-4 { grid-column: 2; }

.ab-h2 {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(2rem, 4.5vw, 3.3rem); line-height: 1.08;
  letter-spacing: -0.025em; color: var(--fg-0);
  font-variation-settings: "opsz" 144; margin: 0;
}
.ab-h2 em { font-style: italic; font-weight: 300; color: var(--accent); }

.ab-mission { padding-block: clamp(3rem, 6vw, 5rem); border-top: 1px solid var(--line-1); }
.ab-mission-grid {
  display: grid; grid-template-columns: 200px 1fr; gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
.ab-mission-text p {
  font-size: var(--t-lead); color: var(--fg-1);
  line-height: 1.55; max-width: 58ch;
}
.ab-mission-text p + p { margin-top: 1.2rem; }
.ab-mission-text p em { font-style: italic; color: var(--fg-0); }
.ab-mission-text .ab-h2 { margin-bottom: 1.4rem; }

.ab-values { padding-block: clamp(3rem, 6vw, 5rem); border-top: 1px solid var(--line-1); }
.ab-values-list {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 0; margin-top: 1rem;
}
.ab-value {
  display: grid; grid-template-columns: 60px 1fr;
  gap: 1.4rem; padding: 2rem 0;
  border-bottom: 1px solid var(--line-1);
}
.ab-value:nth-last-child(-n+2) { border-bottom: 0; }
.ab-value:nth-child(odd) { padding-right: 2rem; }
.ab-value:nth-child(even) { padding-left: 2rem; border-left: 1px solid var(--line-1); }
.ab-value-num {
  font-family: var(--font-mono); font-size: var(--t-xs);
  letter-spacing: 0.12em; color: var(--fg-2);
}
.ab-value-title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: 1.5rem; letter-spacing: -0.015em;
  color: var(--fg-0); margin: 0 0 0.5rem;
}
.ab-value p {
  font-size: var(--t-sm); color: var(--fg-1); line-height: 1.6;
  max-width: 42ch;
}

.ab-team { padding-block: clamp(3rem, 6vw, 5rem); border-top: 1px solid var(--line-1); }
.ab-team-head { margin-bottom: 3rem; max-width: 720px; }
.ab-team-head .ab-h2 { margin-top: 1rem; }
.ab-team-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem;
}
.ab-team-card { margin: 0; }
.ab-team-photo {
  aspect-ratio: 4/5;
  background: linear-gradient(135deg, #efebe1, #e6e1d4);
  border-radius: 2px; overflow: hidden; position: relative;
}
.ab-team-photo image-slot {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border-radius: 0 !important;
}
.ab-team-card figcaption { margin-top: 0.9rem; }
.ab-team-name { font-size: var(--t-body); font-weight: var(--w-semi); color: var(--fg-0); }
.ab-team-role { font-size: var(--t-xs); color: var(--fg-2); margin-top: 0.2rem; font-family: var(--font-mono); letter-spacing: 0.04em; }

.ab-stats { padding-block: clamp(3rem, 6vw, 5rem); border-top: 1px solid var(--line-1); }
.ab-stats-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.ab-stat { padding-right: 1.5rem; border-right: 1px solid var(--line-1); }
.ab-stat:last-child { border-right: 0; }
.ab-stat-num {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(2rem, 4vw, 3rem); line-height: 1;
  letter-spacing: -0.03em; color: var(--fg-0);
  font-variation-settings: "opsz" 144;
}
.ab-stat-label {
  font-size: var(--t-xs); color: var(--fg-2);
  margin-top: 0.6rem; font-family: var(--font-mono);
  letter-spacing: 0.06em;
}

.ab-cta { padding-block: clamp(3rem, 6vw, 5rem) clamp(4rem, 7vw, 7rem); }
.ab-cta-card {
  background: var(--bg-2); border: 1px solid var(--line-1);
  border-radius: 4px;
  padding: clamp(2.5rem, 5vw, 4.5rem);
  text-align: center; display: flex; flex-direction: column;
  align-items: center; gap: 1.4rem;
  box-shadow: 0 30px 80px -30px rgba(20,20,26,0.20);
}
.ab-cta-card .ab-h2 { max-width: 22ch; }
.ab-cta-card p { font-size: var(--t-lead); color: var(--fg-1); max-width: 52ch; }
.ab-cta-actions { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }

@media (max-width: 900px) {
  .ab-collage { grid-template-columns: 1fr 1fr; grid-template-rows: 220px 180px 180px; }
  .ab-c-1 { grid-column: 1 / span 2; grid-row: 1; }
  .ab-c-2 { grid-column: 1; grid-row: 2; }
  .ab-c-3 { grid-column: 2; grid-row: 2 / span 2; }
  .ab-c-4 { grid-column: 1; grid-row: 3; }
  .ab-mission-grid { grid-template-columns: 1fr; }
  .ab-values-list { grid-template-columns: 1fr; }
  .ab-value:nth-child(even) { padding-left: 0; border-left: 0; }
  .ab-value:nth-child(odd) { padding-right: 0; }
  .ab-value { border-bottom: 1px solid var(--line-1); }
  .ab-team-grid { grid-template-columns: repeat(2, 1fr); }
  .ab-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .ab-stat:nth-child(2) { border-right: 0; }
}
@media (max-width: 560px) {
  .ab-team-grid { grid-template-columns: 1fr 1fr; }
  .ab-stats-grid { grid-template-columns: 1fr 1fr; }
  .ab-stat { border-right: 0; padding-right: 0; }
}

/* ============================================================
   PAGE JUMPS - two big editorial CTA cards to Select Shots + About
   ============================================================ */
.page-jumps { padding-block: clamp(4rem, 8vw, 7rem); background: var(--bg-1); }
.page-jumps-grid {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: 1rem;
}
.page-jump {
  position: relative; overflow: hidden;
  background: var(--bg-2); border: 1px solid var(--line-1);
  border-radius: 4px; padding: clamp(2rem, 4vw, 3rem);
  display: flex; flex-direction: column; gap: 1rem;
  min-height: 360px; cursor: pointer;
  transition: border-color var(--dur) var(--ease-out), transform var(--dur) var(--ease-out);
}
.page-jump:hover { border-color: var(--fg-2); transform: translateY(-3px); }
.page-jump.dark { background: var(--fg-0); color: #f6f3ec; border-color: var(--fg-0); }
.page-jump.dark .page-jump-tag { color: rgba(246,243,236,0.5); }
.page-jump.dark .page-jump-title { color: #f6f3ec; }
.page-jump.dark p { color: rgba(246,243,236,0.7); }
.page-jump.dark .page-jump-cta { color: #f6f3ec; }
.page-jump-tag {
  font-family: var(--font-mono); font-size: var(--t-xs);
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2);
}
.page-jump-title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(2rem, 4vw, 3rem); line-height: 1.04;
  letter-spacing: -0.025em; color: var(--fg-0);
  font-variation-settings: "opsz" 144; margin: 0;
  max-width: 16ch;
}
.page-jump-title em { font-style: italic; font-weight: 300; }
.page-jump p {
  font-size: var(--t-body); color: var(--fg-1);
  max-width: 36ch; line-height: 1.55;
}
.page-jump-cta {
  margin-top: auto; display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: var(--t-sm); font-weight: var(--w-semi); color: var(--fg-0);
  letter-spacing: -0.01em;
}
.page-jump-cta .arr { transition: transform var(--dur-fast) var(--ease-out); }
.page-jump:hover .page-jump-cta .arr { transform: translateX(4px); }

/* Background photo collage for the cards (empty slots) */
.page-jump-bg {
  position: absolute; right: -8%; top: -10%; bottom: -10%;
  width: 45%;
  display: grid;
  grid-template-columns: 1fr 1fr; grid-auto-rows: 1fr; gap: 4px;
  pointer-events: none; opacity: 0.18;
  transition: opacity var(--dur) var(--ease-out);
  transform: rotate(8deg);
}
.page-jump:hover .page-jump-bg { opacity: 0.32; }
.page-jump.dark .page-jump-bg { opacity: 0.14; }
.page-jump.dark:hover .page-jump-bg { opacity: 0.22; }
.page-jump-bg .pj-tile {
  background: linear-gradient(135deg, #efebe1, #c8c0a8);
  border-radius: 2px; overflow: hidden; position: relative;
}
.page-jump.dark .page-jump-bg .pj-tile {
  background: linear-gradient(135deg, #2a2a36, #14141a);
}
.page-jump-bg image-slot {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border-radius: 0 !important;
}

@media (max-width: 900px) {
  .page-jumps-grid { grid-template-columns: 1fr; }
  .page-jump-bg { display: none; }
}

/* ============================================================
   FOOTER - minimal page links (additive)
   ============================================================ */
.footer { background: var(--bg-0); border-top: 1px solid var(--line-0); padding-top: clamp(4rem,7vh,6rem); }
.footer-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; padding-bottom: 3.5rem; }
.footer-brand .brand { margin-bottom: 1.3rem; }
.footer-brand p { color: var(--fg-2); font-size: var(--t-sm); max-width: 32ch; }
.footer-social { display: flex; gap: 0.6rem; margin-top: 1.6rem; }
.footer-social a { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--line-1); display: grid; place-items: center; color: var(--fg-1); transition: all var(--dur-fast); }
.footer-social a:hover { border-color: var(--accent); color: var(--accent-hi); transform: translateY(-2px); }
.footer-social a svg { width: 17px; height: 17px; }
.footer-col h5 { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-2); margin-bottom: 1.2rem; font-weight: var(--w-med); }
.footer-col a { display: block; font-size: var(--t-sm); color: var(--fg-1); padding: 0.4rem 0; transition: color var(--dur-fast); }
.footer-col a:hover { color: var(--fg-0); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.8rem 0; border-top: 1px solid var(--line-0); flex-wrap: wrap; }
.footer-bottom p { font-size: var(--t-xs); color: var(--fg-3); }
.footer-bottom .legal { display: flex; gap: 1.5rem; }
.footer-bottom .legal a { font-size: var(--t-xs); color: var(--fg-2); }
.footer-bottom .legal a:hover { color: var(--fg-0); }
.footer-big { font-size: clamp(3.5rem, 14vw, 13rem); font-weight: var(--w-bold); letter-spacing: -0.045em; line-height: 0.82; color: var(--fg-0); opacity: 0.05; text-align: center; padding-bottom: 2rem; user-select: none; pointer-events: none; display: flex; flex-direction: column; align-items: center; gap: 0; font-family: var(--font-serif); font-variation-settings: "opsz" 144; }
.footer-big span { display: block; }
.footer-big span:nth-child(2) { font-style: normal; font-weight: var(--w-med); letter-spacing: 0.01em; opacity: 0.85; margin-top: -0.05em; }

/* ============================================================
   FOOTER - rich variant (additive)
   ============================================================ */
.footer.footer-rich {
  padding: clamp(2.2rem, 4vh, 3.2rem) 0 1.2rem;
  border-top: 1px solid var(--line-1);
  background: #0a0a0c;
  overflow: hidden;
}

/* ---- black band - flip all foreground tokens to read on dark ---- */
.footer.footer-rich,
.footer.footer-rich * { border-color: rgba(246,245,242,0.12); }
.footer.footer-rich .footer-cta { border-bottom-color: rgba(246,245,242,0.12); }
.footer.footer-rich .footer-cta-title,
.footer.footer-rich .footer-r-brand .brand-name { color: #f6f5f2; }
.footer.footer-rich .footer-cta-copy .sec-label,
.footer.footer-rich .footer-totop,
.footer.footer-rich .footer-r-tagline,
.footer.footer-rich .footer-r-col span,
.footer.footer-rich .footer-r-legal a,
.footer.footer-rich .footer-r-legal a.footer-r-ig { color: rgba(246,245,242,0.62); }
.footer.footer-rich .footer-totop:hover,
.footer.footer-rich .footer-r-col a:hover,
.footer.footer-rich .footer-r-legal a:hover { color: #f6f5f2; }
.footer.footer-rich .footer-r-col h5,
.footer.footer-rich .footer-r-bottom p { color: rgba(246,245,242,0.4); }
.footer.footer-rich .footer-r-col a { color: rgba(246,245,242,0.82); }
.footer.footer-rich .footer-r-social a {
  border-color: rgba(246,245,242,0.18);
  color: rgba(246,245,242,0.72);
}
.footer.footer-rich .footer-r-social a:hover { color: var(--accent-hi); border-color: var(--accent); }
.footer.footer-rich .footer-r-bottom { border-top-color: rgba(246,245,242,0.12); }
.footer.footer-rich .footer-r-wordmark { color: #f6f5f2; opacity: 0.07; }

/* ---- closing CTA band ---- */
.footer-cta {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 2rem; flex-wrap: wrap;
  padding-bottom: clamp(1.6rem, 2.6vh, 2.2rem);
  border-bottom: 1px solid var(--line-0);
}
.footer-cta-copy { display: flex; flex-direction: column; gap: 0.6rem; }
.footer-cta-copy .sec-label { color: var(--fg-2); }
.footer-cta-title {
  font-size: clamp(1.6rem, 2.8vw, 2.3rem);
  font-weight: var(--w-semi); letter-spacing: -0.03em;
  line-height: 1.04; color: var(--fg-0); max-width: 16ch;
}
.footer-cta-actions { display: flex; align-items: center; gap: 1.6rem; flex-wrap: wrap; }
.footer-totop {
  display: inline-flex; align-items: center; gap: 0.45rem;
  font-family: var(--font-mono); font-size: var(--t-xs);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-2); transition: color var(--dur-fast) var(--ease-out);
}
.footer-totop:hover { color: var(--fg-0); }
.footer-totop svg { transition: transform var(--dur-fast) var(--ease-out); }
.footer-totop:hover svg { transform: translate(2px, -2px); }

/* ---- link grid ---- */
.footer-grid {
  display: grid;
  grid-template-columns: 1.7fr 1fr 1fr 1fr;
  gap: 1.6rem 2rem;
  padding-block: clamp(1.6rem, 2.6vh, 2.2rem);
  align-items: start;
}
.footer-r-brand { display: flex; flex-direction: column; gap: 0.9rem; max-width: 38ch; }
.footer-r-brand .brand { gap: 0.62rem; }
/* Logo inversion scope: cream plaque / dark ink (e.g. on the dark footer) */
[data-rh-invert] { --rh-box: #f6f5f2; --rh-ink: #14141a; }
.footer-r-brand .brand-mark { font-size: 15px; }
.footer-r-brand .brand-name { font-size: 1.42rem; }
.footer-r-brand .brand-name b { color: #f6f5f2; }
.footer-r-tagline { color: var(--fg-2); font-size: var(--t-sm); line-height: 1.6; }
.footer-r-social { display: flex; gap: 0.6rem; margin-top: 0.3rem; }
.footer-r-social a {
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid var(--line-1); display: grid; place-items: center;
  color: var(--fg-1);
  transition: color var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast) var(--ease-out);
}
.footer-r-social a:hover { color: var(--accent-hi); border-color: var(--accent); transform: translateY(-2px); }

.footer-r-col h5 {
  font-family: var(--font-mono); font-size: 0.62rem;
  text-transform: uppercase; letter-spacing: 0.22em;
  color: var(--fg-3); font-weight: var(--w-med);
  margin: 0.1rem 0 0.7rem;
}
.footer-r-col a,
.footer-r-col span {
  display: block;
  font-size: var(--t-sm); line-height: 1.7;
  color: var(--fg-1); text-decoration: none;
  transition: color 0.2s var(--ease-out);
}
.footer-r-col a:hover { color: var(--fg-0); }
.footer-r-col span { color: var(--fg-2); }

/* ---- oversized ghosted wordmark ---- */
.footer-r-wordmark {
  font-size: clamp(2.6rem, 12vw, 10rem);
  font-weight: var(--w-bold); letter-spacing: -0.05em;
  line-height: 0.86; color: var(--fg-0); opacity: 0.045;
  text-align: center; white-space: nowrap;
  margin: clamp(0.3rem, 1vh, 0.8rem) 0 clamp(0.6rem, 1.6vh, 1.1rem);
  user-select: none; pointer-events: none;
}

/* ---- bottom bar ---- */
.footer-r-bottom {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
  padding-top: 1.1rem; border-top: 1px solid var(--line-0);
}
.footer-r-bottom p {
  font-family: var(--font-mono); font-size: 0.65rem;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--fg-3); margin: 0;
}
.footer-r-legal { display: flex; align-items: center; gap: 1.6rem; }
.footer-r-legal a.footer-r-ig { display: grid; place-items: center; color: var(--fg-2); }
.footer-r-legal a.footer-r-ig:hover { color: var(--accent-hi); }
.footer-r-legal a {
  font-family: var(--font-mono); font-size: 0.65rem;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--fg-2); transition: color var(--dur-fast);
}
.footer-r-legal a:hover { color: var(--fg-0); }

@media (min-width: 861px) {
  /* keep the Studio column visually aligned to the right edge on desktop */
  .footer-r-col-studio { padding-left: 1.5rem; }
}

@media (max-width: 860px) {
  .footer-grid { grid-template-columns: 1fr 1fr; column-gap: 1.6rem; }
  .footer-r-brand { grid-column: 1 / -1; max-width: none; }
  .footer-r-col-studio { padding-left: 0; }
}
@media (max-width: 560px) {
  .footer-cta { align-items: flex-start; }
  .footer-cta-actions { width: 100%; justify-content: space-between; }
  /* single column so long service labels never break word-by-word */
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer-r-col h5 { margin-bottom: 0.5rem; }
  .footer-r-col a,
  .footer-r-col span { font-size: 0.95rem; line-height: 1.55; overflow-wrap: anywhere; }
  .footer-r-bottom { flex-direction: column; align-items: flex-start; gap: 0.9rem; }
}

/* ============================================================
   TOAST
   ============================================================ */
.toast-wrap { position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%); z-index: 200; display: flex; flex-direction: column; gap: 0.6rem; align-items: center; }
.toast { display: flex; align-items: center; gap: 0.7rem; padding: 0.85rem 1.2rem; background: var(--bg-3); border: 1px solid var(--line-2); border-radius: var(--r-pill); font-size: var(--t-sm); color: var(--fg-0); box-shadow: var(--sh-lg); animation: toastIn 0.4s var(--ease-out); }
.toast svg { width: 17px; height: 17px; color: var(--accent-hi); }
@keyframes toastIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
.hero-layout { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(2rem,5vw,5rem); align-items: center; }

@media (max-width: 1120px) {
  .nav-cta .btn.btn-ghost { display: none; }
  .nav-links { gap: 0.1rem; }
  .nav-link { padding: 0.5rem 0.6rem; }
}
@media (max-width: 1024px) {
  .hero-layout { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .svc-grid { gap: 0.9rem; grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: repeat(2,1fr); }
  .step-line { display: none; }
  .price-grid { grid-template-columns: repeat(2,1fr); }
  .test-grid { grid-template-columns: 1fr 1fr; }
  .about-grid, .shot-layout, .faq-layout, .contact-grid { grid-template-columns: 1fr; }
  .brand-block { grid-template-columns: 1fr; gap: 1.9rem; }
  .brand-info { position: static; }
  .collection { grid-template-columns: 1fr; gap: 1.6rem; }
  .col-info { position: static; }
  .col-extra { grid-template-columns: repeat(4, 1fr); }
  .col-gallery { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-cap { grid-template-columns: 1fr; }
  .svc-cap-tags { justify-content: flex-start; max-width: none; }
  .about-visual { max-width: 460px; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .lightbox-card { grid-template-columns: 1fr; }
}
@media (max-width: 920px) {
  .nav-links { display: none; }
  .nav-cta .btn:not(.nav-order) { display: none; }
  .nav-burger { display: block; }
}
@media (max-width: 720px) {
  .svc-grid { grid-template-columns: 1fr; }
  .price-grid { grid-template-columns: 1fr; }
  .test-grid { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; }
  .port-item.lg, .port-item.sm, .port-item.md, .port-item.tall { grid-column: span 12; aspect-ratio: 4/3; }
  .port-item.wide { grid-column: span 12; aspect-ratio: 16/10; }
  .footer-top { grid-template-columns: 1fr; }
  .order-steps .lbl { display: none; }
  .opt-grid { grid-template-columns: repeat(2,1fr); }
  .field-row { grid-template-columns: 1fr; }
  .hero-meta { gap: 1.5rem; }
}

/* ============================================================
   FREE SAMPLE - editorial form on dramatic dark band
   ============================================================ */
.freesample {
  position: relative;
  padding-block: clamp(3rem, 5.5vh, 4.8rem);
  background: #0a0a0c;
  overflow: hidden;
  isolation: isolate;
}
/* faint blueprint grid, fades toward the edges */
.freesample .fs-bg-grid {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(246,243,236,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(246,243,236,0.045) 1px, transparent 1px);
  background-size: 64px 64px;
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 42%, #000 0%, transparent 78%);
          mask-image: radial-gradient(ellipse 70% 60% at 50% 42%, #000 0%, transparent 78%);
}
.freesample .fs-glow {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(46% 42% at 50% 6%, rgba(246,245,242,0.08), transparent 64%);
}
.freesample .container { position: relative; z-index: 1; }

/* ---- centered head ---- */
.fs-head {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 0.7rem;
  max-width: 600px; margin: 0 auto clamp(1.6rem, 3vh, 2.2rem);
}
.fs-title {
  font-family: var(--font-serif);
  font-variation-settings: "opsz" 144;
  font-size: clamp(2rem, 4vw, 2.9rem);
  font-weight: 400;
  line-height: 1.06;
  letter-spacing: -0.025em;
  color: #f6f5f2;
  text-wrap: balance;
}
.fs-sub {
  font-size: var(--t-lead);
  color: rgba(246,245,242,0.6);
  line-height: 1.55;
  max-width: 52ch;
  text-wrap: pretty;
}

/* ---- card ---- */
.fs-card {
  position: relative;
  max-width: 500px; margin: 0 auto;
  background: linear-gradient(180deg, #ffffff 0%, var(--bg-1) 100%);
  border: 1px solid rgba(246,245,242,0.08);
  border-radius: var(--r-xl);
  padding: clamp(1.4rem, 2.6vw, 1.9rem);
  box-shadow: 0 50px 120px -50px rgba(0,0,0,0.85);
}

.fs-card-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.95rem 1rem;
}

.fs-field { display: flex; flex-direction: column; gap: 0.5rem; }
.fs-field.span-2 { grid-column: span 2; }
.fs-field label {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-2);
  font-weight: 500;
}
.fs-opt {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-left: 0.5em;
}

.fs-field input,
.fs-field textarea {
  font-family: var(--font-sans);
  font-size: var(--t-body);
  color: var(--fg-0);
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: var(--r-sm);
  padding: 0.9rem 1.05rem;
  width: 100%;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), background var(--dur-fast);
  resize: vertical;
}
.fs-field textarea { min-height: 88px; line-height: 1.5; }
.fs-field input::placeholder,
.fs-field textarea::placeholder { color: var(--fg-3); }
.fs-field input:hover,
.fs-field textarea:hover { border-color: var(--line-2); }
.fs-field input:focus,
.fs-field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft);
}

/* ---- drop zone ---- */
.fs-drop {
  display: flex; align-items: center; gap: 0.9rem;
  padding: 1rem 1.15rem;
  border: 1px dashed var(--line-2);
  border-radius: var(--r-md);
  background: var(--bg-2);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast), transform var(--dur-fast) var(--ease-out);
}
.fs-drop:hover { border-color: var(--accent); background: var(--bg-3); }
.fs-drop.over { border-color: var(--accent); background: var(--accent-soft); transform: translateY(-1px); }
.fs-drop.has-files { border-style: solid; border-color: var(--line-1); }
.fs-drop-icon {
  width: 42px; height: 42px; border-radius: var(--r-sm);
  background: var(--accent-soft); color: var(--accent-hi);
  display: grid; place-items: center; flex: none;
}
.fs-drop-copy { flex: 1; min-width: 0; }
.fs-drop-t { font-size: var(--t-sm); color: var(--fg-0); font-weight: var(--w-med); }
.fs-drop-d { font-size: var(--t-xs); color: var(--fg-2); margin-top: 0.15rem; }

.fs-files { display: flex; flex-direction: column; gap: 0.4rem; margin-top: 0.7rem; list-style: none; padding: 0; }
.fs-file {
  display: flex; align-items: center; gap: 0.7rem;
  padding: 0.55rem 0.8rem;
  background: var(--bg-3); border: 1px solid var(--line-0);
  border-radius: var(--r-sm); font-size: var(--t-xs); color: var(--fg-1);
}
.fs-file svg { flex: none; color: var(--fg-2); }
.fs-file-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--fg-0); }
.fs-file-size { color: var(--fg-3); font-family: var(--font-mono); font-size: 0.65rem; }
.fs-file-x {
  background: transparent; border: 0; color: var(--fg-2); cursor: pointer;
  padding: 0.25rem; border-radius: 50%; display: grid; place-items: center;
  transition: color var(--dur-fast), background var(--dur-fast);
}
.fs-file-x:hover { color: var(--fg-0); background: var(--line-1); }

/* ---- submit ---- */
.fs-submit {
  width: 100%; margin-top: 1.2rem;
  border-radius: var(--r-sm);
}
.fs-submit.is-sent { background: var(--accent-hi); }
.fs-fine {
  font-size: var(--t-xs); color: var(--fg-2); text-align: center;
  margin-top: 0.8rem;
}

@media (max-width: 520px) {
  .fs-card-grid { grid-template-columns: 1fr; }
  .fs-field.span-2 { grid-column: span 1; }
}

/* ============================================================
   STICKY CTA - bottom bar, slides up after hero
   ============================================================ */
.sticky-cta {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 70;
  padding: 0;
  pointer-events: none;
  transform: translateY(120%);
  opacity: 0;
  transition: transform 0.6s var(--ease-out), opacity 0.4s var(--ease-out);
}
.sticky-cta.show {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.sticky-cta-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.2rem;
  max-width: none; width: 100%; margin: 0;
  background: rgba(10,10,12,0.88);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  border: 1px solid var(--line-1);
  border-left: none; border-right: none; border-bottom: none;
  border-radius: 0;
  padding: 0.9rem clamp(1rem, 3vw, 1.8rem) max(0.9rem, env(safe-area-inset-bottom));
  box-shadow: 0 -20px 60px -20px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.02) inset;
}
body.theme-light .sticky-cta-inner {
  background: rgba(20,20,26,0.94);
  border-color: rgba(255,255,255,0.06);
  box-shadow: 0 30px 70px -20px rgba(20,20,26,0.35);
}

.sticky-cta-copy { display: flex; align-items: center; gap: 1rem; min-width: 0; }
.sticky-cta-eyebrow {
  display: inline-flex; align-items: center; gap: 0.45rem;
  font-family: var(--font-mono); font-size: 0.62rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: #f6f5f2;
  padding: 0.32rem 0.6rem 0.32rem 0.55rem;
  white-space: nowrap;
  flex: none;
}
.sticky-cta-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #6ee787;
  box-shadow: 0 0 8px rgba(110,231,135,0.7);
  animation: sticky-pulse 1.8s ease-in-out infinite;
}
@keyframes sticky-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.5; transform: scale(0.85); }
}
.sticky-cta-text {
  display: flex; flex-direction: column; line-height: 1.3; min-width: 0;
}
.sticky-cta-text strong {
  color: #f6f5f2; font-size: var(--t-sm); font-weight: var(--w-med);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sticky-cta-sub {
  color: rgba(246,245,242,0.55); font-size: var(--t-xs);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.sticky-cta-actions { display: flex; align-items: center; gap: 0.4rem; flex: none; }
.sticky-cta-btn {
  background: #f6f5f2; color: #14141a;
  font-weight: var(--w-semi);
}
.sticky-cta-btn:hover {
  background: #ffffff; color: #14141a;
  transform: translateY(-1px);
  box-shadow: 0 14px 28px -10px rgba(0,0,0,0.5);
}
.sticky-cta-close {
  width: 36px; height: 36px; border-radius: 50%;
  background: transparent; border: 1px solid rgba(246,245,242,0.14);
  color: rgba(246,245,242,0.55); cursor: pointer;
  display: grid; place-items: center;
  transition: color var(--dur-fast), background var(--dur-fast), border-color var(--dur-fast);
}
.sticky-cta-close:hover {
  color: #f6f5f2;
  background: rgba(246,245,242,0.08);
  border-color: rgba(246,245,242,0.28);
}

body.no-motion .sticky-cta { transition: none; }

@media (max-width: 640px) {
  .sticky-cta { padding-inline: 0; }
  .sticky-cta-inner {
    padding: 0.6rem 0.9rem max(0.6rem, env(safe-area-inset-bottom));
    border-radius: 0;
    gap: 0.6rem;
  }
  .sticky-cta-eyebrow { display: none; }
  .sticky-cta-sub { display: none; }
  .sticky-cta-btn { padding: 0.7rem 1rem; font-size: var(--t-xs); }
  .sticky-cta-close { width: 32px; height: 32px; }
}
