/* ============================================================
   KRISTIAN GREY · MAGICIAN — site styles
   Monochrome ink · champagne gold · iridescent specular
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Hanken+Grotesk:wght@300;400;500;600;700&display=swap');

:root{
  /* LIGHT THEME — stark white surfaces (was monochrome ink) */
  --ink:        #ffffff;   /* page background base — pure white */
  --ink-1:      #fbfbfc;   /* raised surface (whisper of tint to lift cards) */
  --ink-2:      #ffffff;   /* raised surface, brightest */
  --ink-3:      #f6f6f7;
  --hair:       rgba(28,24,16,.14);
  --hair-soft:  rgba(28,24,16,.07);

  --bone:       #1d1b17;   /* primary text  (~15:1 on paper) */
  --bone-2:     #423f39;   /* secondary text (~8.5:1) */
  --dim:        #54514a;   /* muted text    (~6.5:1) */
  --faint:      #6a675f;   /* faint labels  (~4.7:1) */

  /* champagne gold — split: accessible bronze for marks/text, metallic for fills */
  --gold-1:#b78a3e;
  --gold-2:#7a5c24;        /* accessible bronze accent — text & small marks (~5.9:1) */
  --gold-3:#8a6526;
  --gold-4:#6f4f1c;
  --gold-grad: linear-gradient(140deg,#8a6526 0%,#7a5c24 45%,#684c1c 100%); /* dark bronze: clipped text & marks */
  --gold-metal: linear-gradient(140deg,#f3dda6 0%,#e6c479 38%,#cfa251 70%,#b07f37 100%); /* light metallic: button & avatar fills */
  --gold-line: linear-gradient(90deg, transparent, var(--gold-3), transparent);

  /* iridescent low-chroma shimmer */
  --irid: linear-gradient(110deg,
      #d9c9ff 0%, #bfe3ff 22%, #c9f3e6 42%,
      #f5e9c5 62%, #f3cfe0 82%, #d9c9ff 100%);

  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 84px);

  --ff-display:'Cormorant Garamond', Georgia, serif;
  --ff-ui:'Hanken Grotesk', system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--ink);
  color:var(--bone);
  font-family:var(--ff-ui);
  font-weight:400;
  line-height:1.6;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; }

/* ---- keyboard focus visibility (WCAG 2.4.7) ---- */
:focus-visible{ outline:2px solid #7a5c24; outline-offset:3px; border-radius:3px; }
.btn:focus-visible{ outline-offset:4px; }
.inp:focus-visible{ outline:2px solid #7a5c24; outline-offset:1px; }

/* ---- global grain + vignette overlays ---- */
body::before{ /* grain */
  content:""; position:fixed; inset:-50%; z-index:9000; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.025; mix-blend-mode:multiply;
}
body::after{ /* very soft neutral vignette */
  content:""; position:fixed; inset:0; z-index:8999; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 16%, transparent 70%, rgba(40,40,44,.035) 100%);
}

/* ============================================================
   Type helpers
   ============================================================ */
.eyebrow{
  font-family:var(--ff-ui); font-weight:600;
  font-size:.72rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--gold-2);
  display:inline-flex; align-items:center; gap:.85em;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--gold-grad); display:inline-block; }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:var(--gold-grad); display:inline-block; }
.eyebrow.center{ justify-content:center; }

h1,h2,h3{ font-family:var(--ff-display); font-weight:400; line-height:1.02; margin:0; letter-spacing:-.01em; }
.display{ font-size:clamp(3.4rem, 9.5vw, 9rem); font-weight:300; }
.h2{ font-size:clamp(2.4rem, 5.4vw, 4.6rem); font-weight:400; }
.lede{ font-size:clamp(1.05rem,1.5vw,1.32rem); color:var(--bone-2); font-weight:300; max-width:54ch; }
.muted{ color:var(--dim); }

.gold-text{
  background:var(--gold-grad); -webkit-background-clip:text; background-clip:text;
  color:transparent; -webkit-text-fill-color:transparent;
}
.italic{ font-style:italic; }

/* gold hairline rule */
.rule{ height:1px; width:100%; background:var(--gold-line); opacity:.5; }

/* ============================================================
   Layout
   ============================================================ */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
section{ position:relative; }
.section-pad{ padding-block:clamp(60px,7vw,104px); }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  --bg:transparent;
  display:inline-flex; align-items:center; gap:.7em;
  padding:1.02em 1.8em; border-radius:999px;
  font-family:var(--ff-ui); font-weight:600; font-size:.82rem;
  letter-spacing:.16em; text-transform:uppercase;
  position:relative; isolation:isolate;
  transition:transform .5s var(--ease), color .4s, box-shadow .5s;
}
.btn .ar{ transition:transform .45s var(--ease); }
.btn:hover .ar{ transform:translateX(4px); }
.btn-gold{ color:#1a140a; background:var(--gold-metal); box-shadow:0 1px 0 rgba(255,255,255,.55) inset, 0 14px 34px -16px rgba(176,127,55,.55); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 1px 0 rgba(255,255,255,.65) inset, 0 22px 50px -16px rgba(176,127,55,.7); }
.btn-ghost{ color:var(--bone); border:1px solid rgba(28,24,16,.22); background:rgba(28,24,16,.015); backdrop-filter:blur(4px); }
.btn-ghost:hover{ transform:translateY(-2px); border-color:rgba(138,101,38,.6); box-shadow:0 18px 40px -24px rgba(60,48,24,.45); }

/* ============================================================
   Playing-card motif (CSS drawn — parallax)
   ============================================================ */
.cards-layer{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:1; }

/* Realistic playing cards (CSS) */
.card{
  position:absolute; width:118px; height:166px; border-radius:9px;
  transform-origin:50% 100%; will-change:transform; backface-visibility:hidden;
  background:linear-gradient(158deg,#ffffff,#f6f1e6 56%,#ece3d2);
  box-shadow:
    0 1px 1px rgba(255,255,255,.9) inset,
    0 0 0 1px rgba(120,108,86,.5),
    0 16px 30px -16px rgba(40,32,16,.4);
  font-family:Georgia,'Times New Roman',serif; color:#16161c; line-height:1;
}
.card::before{ /* glossy specular sheen */
  content:""; position:absolute; inset:0; border-radius:9px; pointer-events:none;
  background:linear-gradient(118deg, rgba(255,255,255,.62), transparent 26%, transparent 72%, rgba(255,255,255,.32));
  opacity:.5; mix-blend-mode:screen;
}
.card .corner{ position:absolute; font-weight:700; font-size:18px; text-align:center; letter-spacing:-.02em; }
.card .corner.tl{ top:9px; left:10px; }
.card .corner.br{ bottom:9px; right:10px; transform:rotate(180deg); }
.card .corner .su{ display:block; font-size:14px; margin-top:1px; }
.card .pip{ position:absolute; inset:0; display:grid; place-items:center; font-size:62px; }
.card.red{ color:#c01f2e; }
.card.glow{ filter:drop-shadow(0 0 22px rgba(230,203,145,.32)); }

/* branded gold card back */
.card.back{
  background:linear-gradient(150deg,#16181f,#0d0f15 58%,#090a0e);
  box-shadow:
    0 0 0 1px rgba(230,203,145,.55) inset,
    0 0 0 5px rgba(7,7,10,.92) inset,
    0 0 0 6px rgba(230,203,145,.30) inset,
    0 22px 40px -16px rgba(0,0,0,.82);
}
.card.back::before{
  inset:9px; border-radius:5px; opacity:1; mix-blend-mode:normal;
  background:
    repeating-linear-gradient(45deg, rgba(230,203,145,.18) 0 1px, transparent 1px 9px),
    repeating-linear-gradient(-45deg, rgba(230,203,145,.18) 0 1px, transparent 1px 9px);
}
.card.back::after{
  content:""; position:absolute; inset:0; margin:auto; width:38px; height:38px;
  rotate:45deg; border-radius:4px;
  background:linear-gradient(140deg,#f8eed6,#e6cb91 40%,#c39a55 72%,#8c6a32);
  box-shadow:0 0 0 4px rgba(7,7,10,.95), 0 0 0 5px rgba(230,203,145,.5), 0 0 18px rgba(230,203,145,.4);
}

/* spring fan — all cards pivot from a shared point */
.card-spring{ position:absolute; left:62%; bottom:5%; width:0; height:0; z-index:2;
  transform-origin:50% 100%; animation:fanSway 8s ease-in-out infinite; }
.card-spring .card{ left:-59px; bottom:0; }
.card.acc{ animation:none; }
.card.acc-a{ animation:floatCardA 6.5s ease-in-out infinite; }
.card.acc-b{ animation:floatCardB 7.5s ease-in-out infinite; }
@keyframes fanSway{ 0%,100%{ transform:rotate(-1.1deg); } 50%{ transform:rotate(1.3deg); } }
@keyframes floatCardA{ 0%,100%{ transform:translateY(-9px) rotate(-12deg); } 50%{ transform:translateY(11px) rotate(-8.5deg); } }
@keyframes floatCardB{ 0%,100%{ transform:translateY(10px) rotate(8deg); } 50%{ transform:translateY(-10px) rotate(11deg); } }
@media (prefers-reduced-motion: reduce){ .card-spring,.card.acc-a,.card.acc-b{ animation:none; } }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:clamp(14px,2vw,22px) var(--pad);
  transition:background .5s, backdrop-filter .5s, padding .5s, border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(250,248,243,.82); backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid var(--hair-soft); padding-block:11px;
}
.nav-mark{ display:flex; align-items:center; gap:.7rem; }
.nav-mark img{ height:34px; width:auto; filter:drop-shadow(0 3px 8px rgba(80,60,20,.22)); }
.nav-mark .nm-txt{ font-family:var(--ff-ui); font-weight:600; letter-spacing:.28em; font-size:.7rem; text-transform:uppercase; color:var(--bone-2); }
.nav-links{ display:flex; align-items:center; gap:clamp(18px,2.4vw,40px); list-style:none; margin:0; padding:0; }
.nav-links a{ font-size:.78rem; letter-spacing:.13em; text-transform:uppercase; font-weight:500; color:var(--bone-2); position:relative; padding:.3em 0; transition:color .35s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--gold-grad); transition:width .4s var(--ease); }
.nav-links a:hover{ color:var(--bone); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-burger{ display:none; width:42px; height:42px; border:1px solid var(--hair); border-radius:50%; background:transparent; place-items:center; }
.nav-burger span{ display:block; width:17px; height:1.5px; background:var(--bone); position:relative; }
.nav-burger span::before,.nav-burger span::after{ content:""; position:absolute; left:0; width:17px; height:1.5px; background:var(--bone); }
.nav-burger span::before{ top:-5px; } .nav-burger span::after{ top:5px; }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:999; background:rgba(248,246,241,.97); backdrop-filter:blur(20px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.4rem;
  opacity:0; pointer-events:none; transition:opacity .5s;
}
.mobile-menu.open{ opacity:1; pointer-events:auto; }
.mobile-menu a{ font-family:var(--ff-display); font-size:2.4rem; color:var(--bone); }
.mobile-menu a:hover{ color:var(--gold-2); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; padding-top:90px;
  background:#ffffff; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ position:absolute; right:-3%; bottom:0; height:104%; width:auto; max-width:none;
  object-fit:contain; object-position:bottom right;
  filter:contrast(1.02) saturate(.98) brightness(1.0);
}
.hero-bg .blend{ position:absolute; inset:0;
  background:linear-gradient(90deg, #ffffff 18%, rgba(255,255,255,.4) 44%, transparent 64%); }
.hero-bg .glow{ position:absolute; inset:0;
  background:
    radial-gradient(58% 58% at 70% 40%, rgba(214,178,120,.1), transparent 64%);
}
.hero-bg .floor{ display:none; }
.hero-inner{ position:relative; z-index:5; width:100%; }
.hero h1{ margin-top:.18em; }
.hero .kicker{ margin-bottom:1.4rem; }
.hero .sub{ margin-top:1.6rem; }
.hero .lede{ max-width:40ch; }
.hero .actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2.4rem; }
.hero-accolade{ display:inline-flex; align-items:center; gap:18px; margin-top:3rem; padding:14px 22px;
  border:1px solid var(--hair); border-radius:999px; background:rgba(255,255,255,.5); backdrop-filter:blur(6px); }
.hero-accolade .laurel{ color:var(--gold-2); font-size:1.1rem; }
.hero-accolade .ha-txt{ font-size:.92rem; letter-spacing:.02em; color:var(--bone); line-height:1.4; white-space:nowrap; }
.hero-accolade .ha-sub{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--dim); }
.hero-name{ display:block; }
.hero-name .ln{ display:block; }
/* the italic gradient "Grey" has a deep descender — give the clip box room so the
   y-tail isn't cut off by background-clip:text + tight heading line-height */
.hero-name .ln.gold-text{ padding-bottom:.16em; line-height:1.12; }
.scrollcue{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:6;
  display:flex; flex-direction:column; align-items:center; gap:9px; color:var(--faint);
  font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; }
.scrollcue .line{ width:1px; height:46px; background:linear-gradient(var(--gold-3), transparent); animation:cue 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%{ transform:scaleY(0); opacity:0;} 35%{ opacity:1;} 100%{ transform:scaleY(1); opacity:0; } }

/* ---- hero award-card fan (twist-in entrance) ---- */
.hero-awards{ position:absolute; left:71%; bottom:12%; z-index:6; width:0; height:0; pointer-events:none; }
.ha-card{
  position:absolute; left:0; bottom:0; max-width:none;
  width:clamp(88px, 9.5vw, 142px); height:auto;
  border-radius:9px; transform-origin:50% 90%; backface-visibility:hidden;
  box-shadow:0 22px 44px -16px rgba(20,16,8,.55), 0 0 0 1px rgba(176,140,60,.4);
}
/* resting (and reduced-motion / no-JS) fan positions */
.ha-1{ transform:translate(-86%, 5%) rotate(-19deg); z-index:20; }
.ha-2{ transform:translate(-50%, -4%) rotate(-2deg);  z-index:30; }
.ha-3{ transform:translate(-14%, 5%) rotate(19deg);   z-index:20; }

@media (prefers-reduced-motion: no-preference){
  .ha-card{ opacity:0; animation-duration:1.15s; animation-timing-function:cubic-bezier(.17,.84,.27,1.06); animation-fill-mode:both; }
  .ha-2{ animation-name:haTwist2; animation-delay:.10s; }
  .ha-1{ animation-name:haTwist1; animation-delay:.30s; }
  .ha-3{ animation-name:haTwist3; animation-delay:.50s; }
  /* gentle idle sway of the whole fan after it lands */
  .hero-awards{ animation:haSway 9s ease-in-out 1.7s infinite; }
}
@keyframes haTwist1{
  0%{   opacity:0; transform:translate(-50%, 90px) rotate(-410deg) scale(.4); }
  55%{  opacity:1; }
  100%{ opacity:1; transform:translate(-86%, 5%) rotate(-19deg) scale(1); }
}
@keyframes haTwist2{
  0%{   opacity:0; transform:translate(-50%, 96px) rotate(375deg) scale(.4); }
  55%{  opacity:1; }
  100%{ opacity:1; transform:translate(-50%, -4%) rotate(-2deg) scale(1); }
}
@keyframes haTwist3{
  0%{   opacity:0; transform:translate(-50%, 90px) rotate(410deg) scale(.4); }
  55%{  opacity:1; }
  100%{ opacity:1; transform:translate(-14%, 5%) rotate(19deg) scale(1); }
}
@keyframes haSway{ 0%,100%{ transform:translateY(0) rotate(-.7deg); } 50%{ transform:translateY(-8px) rotate(.7deg); } }
@media (max-width:860px){
  /* drop the decorative hero fan on phones — awards have their own section, and a
     centred fan would collide with the full-width hero copy */
  .hero-awards{ display:none; }
  .hero .lede{ max-width:38ch; }
  /* hide all floating playing-card decorations on mobile so they can't sit over copy */
  #services .cards-layer, .deco-layer{ display:none; }
}

/* ============================================================
   MARQUEE (trusted by)
   ============================================================ */
.marquee{ border-block:1px solid var(--hair-soft); padding-block:30px; overflow:hidden; position:relative; background:linear-gradient(var(--ink-1),var(--ink)); }
.marquee .label{ text-align:center; margin-bottom:20px; color:var(--faint); font-size:.66rem; letter-spacing:.34em; text-transform:uppercase; }
.marquee-track{ display:flex; gap:clamp(40px,6vw,90px); width:max-content; animation:slide 38s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--ff-display); font-size:clamp(1.3rem,2.2vw,2rem); font-style:italic; color:var(--bone-2); white-space:nowrap; opacity:.62; transition:opacity .4s, color .4s; }
.marquee-track span:hover{ opacity:1; color:var(--gold-2); }
@keyframes slide{ to{ transform:translateX(-50%); } }

/* ============================================================
   LOGO BAND (brands & clients)
   Two rows scroll in opposite directions.
   Logos are rendered greyscale + low-opacity at rest; hover
   reveals full colour. Drop logo files into assets/logos/ and
   swap the placeholder <span> elements for <img> tags.
   ============================================================ */
.logo-band{
  padding-block: clamp(52px,7vw,88px);
  overflow:hidden; position:relative;
  background:linear-gradient(var(--ink),var(--ink-1) 55%, var(--ink));
}
.logo-band::before, .logo-band::after{  /* left + right fade masks */
  content:""; position:absolute; top:0; bottom:0; width:clamp(60px,10vw,140px); z-index:2; pointer-events:none;
}
.logo-band::before{ left:0;  background:linear-gradient(to right, var(--ink), transparent); }
.logo-band::after{  right:0; background:linear-gradient(to left,  var(--ink), transparent); }

.logo-band-label{
  text-align:center; margin-bottom:clamp(28px,4vw,44px);
  font-family:var(--ff-ui); font-weight:600;
  font-size:.7rem; letter-spacing:.32em; text-transform:uppercase; color:var(--faint);
}

.logo-row{ overflow:hidden; position:relative; }
.logo-row + .logo-row{ margin-top:clamp(18px,2.4vw,30px); }

.logo-track{
  display:flex; align-items:center;
  gap:clamp(44px,6vw,84px);
  width:max-content;
  animation:slide 44s linear infinite;
}
.logo-row:nth-child(odd)  .logo-track{ animation-duration:44s; }
.logo-row:nth-child(even) .logo-track{ animation-duration:52s; animation-direction:reverse; }
.logo-band:hover .logo-track{ animation-play-state:paused; }

/* ---------- real logo images ---------- */
.logo-item img{
  height:clamp(28px,3.2vw,42px); width:auto; display:block;
  /* greyscale + dim at rest; hover reveals full colour */
  filter:grayscale(1) opacity(.38) contrast(1.1);
  transition:filter .55s var(--ease), transform .55s var(--ease);
  user-select:none; pointer-events:none;
}
.logo-item:hover img{ filter:grayscale(0) opacity(1) contrast(1); transform:scale(1.04); }

/* Square / stacked logos (AXA, FREE NOW) — cap width so they don't dwarf wordmarks */
.logo-item img[alt="AXA"],
.logo-item img[alt="FREE NOW"]{
  height:clamp(38px,4vw,54px); /* allow a touch taller so they're readable */
  width:auto;
}

/* ---------- text placeholders (remove when real logos land) ---------- */
.logo-ph{
  font-family:var(--ff-display); font-style:italic;
  font-size:clamp(1.05rem,1.6vw,1.5rem); font-weight:400;
  letter-spacing:.04em; white-space:nowrap;
  color:var(--bone-2); opacity:.32;
  transition:opacity .45s var(--ease), color .45s;
  cursor:default; user-select:none;
}
.logo-item:hover .logo-ph{ opacity:.85; color:var(--gold-2); }

/* ---------- dot separator ---------- */
.logo-sep{
  color:var(--gold-3); opacity:.4; font-size:.7rem;
  flex:none; user-select:none; pointer-events:none;
}

@media (prefers-reduced-motion: reduce){ .logo-track{ animation:none; } }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(40px,6vw,96px); align-items:center; }
.about-portrait{ position:relative; }
.about-portrait .frame{ position:relative; border-radius:14px; overflow:hidden; box-shadow:0 40px 80px -50px rgba(40,32,16,.4); }
.about-portrait .frame::after{ content:""; position:absolute; inset:0; box-shadow:0 0 0 1px var(--hair) inset; border-radius:14px;
  background:linear-gradient(160deg, rgba(230,203,145,.08), transparent 40%); }
.about-portrait img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.about-portrait .tag{ position:absolute; bottom:-22px; left:-22px; background:var(--ink-2); border:1px solid var(--hair);
  border-radius:12px; padding:18px 22px; box-shadow:0 24px 50px -30px rgba(40,32,16,.45); }
.about-portrait .tag .n{ font-family:var(--ff-display); font-size:2.2rem; line-height:1; }
.about-portrait .tag .l{ font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--dim); margin-top:6px; }
.about-copy h2{ margin-bottom:1.5rem; }
.about-copy p{ color:var(--bone-2); font-weight:300; margin:0 0 1.15rem; max-width:52ch; }
.about-copy p strong{ color:var(--bone); font-weight:500; }
.sign{ font-family:var(--ff-display); font-style:italic; font-size:1.8rem; color:var(--gold-2); margin-top:1.4rem; }

/* stat row */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--hair-soft); border:1px solid var(--hair-soft); border-radius:14px; overflow:hidden; margin-top:clamp(48px,7vw,86px); }
.stats .s{ background:var(--ink-1); padding:clamp(24px,3vw,38px) 22px; text-align:center; }
.stats .s .num{ font-family:var(--ff-display); font-size:clamp(2.6rem,4.5vw,3.6rem); line-height:1; }
.stats .s .lab{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); margin-top:10px; }

/* ============================================================
   SERVICES (tilt cards)
   ============================================================ */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:clamp(40px,5vw,64px); }
.tilt{ perspective:1100px; display:flex; }
.svc{
  position:relative; border-radius:16px; padding:38px 34px 34px; min-height:380px; width:100%;
  background:linear-gradient(165deg, var(--ink-2), var(--ink-1));
  border:1px solid var(--hair); overflow:hidden;
  transform-style:preserve-3d; transition:box-shadow .5s, border-color .5s;
  display:flex; flex-direction:column;
}
.svc .glare{ position:absolute; inset:0; opacity:0; transition:opacity .4s; pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%), rgba(214,178,120,.16), transparent 45%); }
.svc:hover{ border-color:rgba(138,101,38,.45); box-shadow:0 40px 80px -50px rgba(40,30,12,.4); }
.svc:hover .glare{ opacity:1; }
.svc .num{ font-family:var(--ff-display); font-style:italic; font-size:1.1rem; color:var(--gold-3); transform:translateZ(30px); }
.svc h3{ font-size:2.1rem; margin:.6rem 0 .9rem; transform:translateZ(40px); }
.svc p{ color:var(--dim); font-weight:300; font-size:.96rem; transform:translateZ(20px); flex:1; }
.svc .feat{ list-style:none; padding:0; margin:1.3rem 0 0; transform:translateZ(24px); }
.svc .feat li{ font-size:.85rem; color:var(--bone-2); padding:.42em 0; border-top:1px solid var(--hair-soft); display:flex; align-items:center; gap:.7em; }
.svc .feat li::before{ content:""; width:5px; height:5px; rotate:45deg; background:var(--gold-grad); flex:none; }
.svc .ico{ position:absolute; top:30px; right:30px; font-family:var(--ff-display); font-size:2rem; color:var(--faint); transform:translateZ(30px); }
.svc-link{ display:inline-flex; align-items:center; gap:.55em; margin-top:1.3rem; transform:translateZ(24px);
  font-family:var(--ff-ui); font-weight:600; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-2); transition:gap .4s var(--ease); }
.svc-link .ar{ transition:transform .4s var(--ease); }
.svc-link:hover{ gap:.85em; }
.svc-link:hover .ar{ transform:translateX(3px); }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ columns:3; column-gap:16px; margin-top:clamp(40px,5vw,60px); }
.gitem{ break-inside:avoid; margin-bottom:16px; position:relative; border-radius:12px; overflow:hidden; cursor:pointer;
  box-shadow:0 24px 48px -40px rgba(40,32,16,.5); }
.gitem img{ width:100%; transition:transform .9s var(--ease), filter .6s; filter:grayscale(.12) contrast(1.02); }
.gitem::after{ content:""; position:absolute; inset:0; box-shadow:0 0 0 1px var(--hair) inset; border-radius:12px;
  background:linear-gradient(to top, rgba(30,24,12,.32), transparent 50%); opacity:.7; transition:opacity .5s; }
.gitem .plus{ position:absolute; bottom:16px; right:16px; width:40px; height:40px; border-radius:50%; z-index:2;
  border:1px solid rgba(230,203,145,.5); display:grid; place-items:center; color:var(--gold-1);
  background:rgba(7,7,10,.4); backdrop-filter:blur(6px); opacity:0; transform:translateY(8px) scale(.9); transition:.5s var(--ease); }
.gitem:hover img{ transform:scale(1.06); filter:grayscale(0) contrast(1.05); }
.gitem:hover::after{ opacity:.4; }
.gitem:hover .plus{ opacity:1; transform:translateY(0) scale(1); }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:5000; background:rgba(5,5,8,.94); backdrop-filter:blur(10px);
  display:grid; place-items:center; opacity:0; pointer-events:none; transition:opacity .4s; }
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:90vw; max-height:84vh; border-radius:10px; box-shadow:0 50px 120px -40px #000, 0 0 0 1px var(--hair); }
.lightbox .lb-close{ position:absolute; top:24px; right:28px; width:48px; height:48px; border-radius:50%; border:1px solid var(--hair); background:rgba(255,255,255,.04); display:grid; place-items:center; font-size:1.2rem; }
.lightbox .lb-nav{ position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; border:1px solid var(--hair); background:rgba(255,255,255,.04); display:grid; place-items:center; font-size:1.3rem; transition:.3s; }
.lightbox .lb-nav:hover{ border-color:var(--gold-3); }
.lb-prev{ left:24px; } .lb-next{ right:24px; }

/* ============================================================
   FLIP GALLERY (swivel-to-reveal on scroll)
   ============================================================ */
.flip-hint{ display:flex; align-items:center; gap:.6em; margin-top:clamp(28px,4vw,40px);
  font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-2); font-weight:600; }
.flip-hint .ar{ font-size:1rem; animation:hintBob 2.2s var(--ease) infinite; }
@keyframes hintBob{ 0%,100%{ transform:translateY(-2px); opacity:.5; } 50%{ transform:translateY(3px); opacity:1; } }
@media (prefers-reduced-motion: reduce){ .flip-hint{ display:none; } }

.flip-gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:18px; perspective:1700px; }
.flip-tile{ position:relative; aspect-ratio:4/5; }
.flip-inner{ position:absolute; inset:0; transform-style:preserve-3d; transform:rotateY(0deg); will-change:transform;
  transition:transform .85s cubic-bezier(.55,.08,.25,1); }
.flip-tile .face{ position:absolute; inset:0; margin:0; border-radius:12px; overflow:hidden; cursor:pointer;
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  box-shadow:0 26px 52px -34px rgba(40,32,16,.6), 0 0 0 1px var(--hair); }
.flip-tile .face img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.1) contrast(1.02); transition:filter .5s; }
.flip-tile .face.back{ transform:rotateY(180deg); }
.flip-tile .face::after{ content:""; position:absolute; inset:0; border-radius:12px; pointer-events:none;
  background:linear-gradient(to top, rgba(30,24,12,.28), transparent 46%); opacity:.7; transition:opacity .5s; }
.flip-tile .face:hover img{ filter:grayscale(0) contrast(1.05); }
.flip-tile .face:hover::after{ opacity:.45; }
.flip-tile .plus{ position:absolute; bottom:14px; right:14px; width:38px; height:38px; border-radius:50%; z-index:2;
  border:1px solid rgba(255,255,255,.6); display:grid; place-items:center; color:#fff;
  background:rgba(20,16,8,.32); backdrop-filter:blur(6px); opacity:0; transform:translateY(8px) scale(.9);
  transition:.5s var(--ease); }
.flip-tile .face:hover .plus{ opacity:1; transform:translateY(0) scale(1); }
@media (prefers-reduced-motion: reduce){ .flip-inner{ transition:none; } }
@media (max-width:1024px){ .flip-gallery{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:640px){ .flip-gallery{ grid-template-columns:repeat(2,1fr); gap:12px; }
  /* keep a tidy 3×2 grid on phones — hide the lone 7th tile */
  .flip-tile:nth-child(7){ display:none; } }

/* ============================================================
   AWARDS
   ============================================================ */
.awards{ background:linear-gradient(var(--ink),var(--ink-1) 50%,var(--ink)); }
.award-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,40px); margin-top:clamp(46px,6vw,70px); }
.award{ position:relative; text-align:center; }
.award .pic{ position:relative; border-radius:12px; overflow:hidden; box-shadow:0 30px 64px -44px rgba(40,32,16,.5);
  transition:transform .6s var(--ease), box-shadow .6s; will-change:transform; }
.award .pic::after{ content:""; position:absolute; inset:0; border-radius:12px; box-shadow:0 0 0 1px rgba(230,203,145,.3) inset;
  background:linear-gradient(120deg, rgba(255,255,255,.14), transparent 30%, transparent 70%, rgba(230,203,145,.1)); pointer-events:none; }
.award:hover .pic{ transform:translateY(-8px); box-shadow:0 50px 90px -44px rgba(40,30,12,.42), 0 0 50px -24px rgba(138,101,38,.35); }
.award .pic img{ width:100%; }
.award .cap{ margin-top:18px; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--dim); }
.award .cap b{ color:var(--gold-2); font-weight:600; }

/* ============================================================
   REVIEWS / GOOGLE
   ============================================================ */
.reviews-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:30px; }
.gscore{ display:flex; align-items:center; gap:18px; }
.gscore .gmark{ width:46px; height:46px; flex:none; }
.gscore .num{ font-family:var(--ff-display); font-size:3.2rem; line-height:.9; }
.stars{ display:flex; gap:3px; color:var(--gold-2); font-size:1rem; letter-spacing:2px; }
.gscore .sub{ font-size:.78rem; color:var(--dim); letter-spacing:.04em; }
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:clamp(40px,5vw,60px); }
.review{ background:linear-gradient(165deg,var(--ink-2),var(--ink-1)); border:1px solid var(--hair); border-radius:16px; padding:30px 28px;
  display:flex; flex-direction:column; gap:16px; transition:border-color .5s, transform .5s; }
.review:hover{ border-color:rgba(138,101,38,.4); transform:translateY(-4px); }
.review .qstars{ color:var(--gold-2); font-size:.9rem; letter-spacing:2px; }
.review p{ margin:0; font-family:var(--ff-display); font-size:1.32rem; line-height:1.42; color:var(--bone); font-weight:300; }
.review .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.review .av{ width:40px; height:40px; border-radius:50%; flex:none; display:grid; place-items:center; font-weight:600; font-size:.9rem; color:#1a140a; background:var(--gold-metal); }
.review .who .nm{ font-size:.88rem; font-weight:500; color:var(--bone); }
.review .who .mt{ font-size:.72rem; color:var(--faint); letter-spacing:.04em; }

/* ============================================================
   TIKTOK
   ============================================================ */
.tiktok{ background:linear-gradient(var(--ink-1),var(--ink)); }
.tt-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.tt-phones{ display:flex; gap:18px; justify-content:center; }
.tt-phone{ width:172px; aspect-ratio:9/19; border-radius:26px; background:linear-gradient(160deg,var(--ink-3),var(--ink-1));
  border:1px solid var(--hair); position:relative; overflow:hidden; box-shadow:0 40px 80px -40px #000; }
.tt-phone:nth-child(2){ transform:translateY(26px); }
.tt-phone .scr{ position:absolute; inset:8px; border-radius:18px; overflow:hidden; background:#000; }
.tt-phone .scr img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.2) contrast(1.04); }
.tt-phone .play{ position:absolute; inset:0; display:grid; place-items:center; z-index:2; }
.tt-phone .play span{ width:52px; height:52px; border-radius:50%; background:rgba(7,7,10,.5); backdrop-filter:blur(6px);
  border:1px solid rgba(230,203,145,.5); display:grid; place-items:center; color:var(--gold-1); padding-left:3px; }
.tt-phone .grad{ position:absolute; inset:0; background:linear-gradient(to top, rgba(7,7,10,.7), transparent 55%); z-index:1; }
.tt-phone .hd{ position:absolute; bottom:12px; left:12px; right:12px; z-index:3; font-size:.7rem; color:var(--bone-2); letter-spacing:.04em; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{ margin-top:clamp(36px,4vw,52px); border-top:1px solid var(--hair); max-width:880px; }
.faq{ border-bottom:1px solid var(--hair); }
.faq-q{ width:100%; text-align:left; background:none; border:0; padding:26px 0; display:flex; align-items:center; justify-content:space-between; gap:24px;
  font-family:var(--ff-display); font-size:clamp(1.3rem,2vw,1.7rem); color:var(--bone); transition:color .4s; }
.faq-q:hover{ color:var(--gold-2); }
.faq-q .pm{ position:relative; width:18px; height:18px; flex:none; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; inset:0; margin:auto; background:var(--gold-2); transition:transform .4s var(--ease); }
.faq-q .pm::before{ width:18px; height:1.5px; }
.faq-q .pm::after{ width:1.5px; height:18px; }
.faq.open .pm::after{ transform:scaleY(0); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .55s var(--ease); }
.faq-a p{ color:var(--dim); font-weight:300; margin:0; padding:0 0 28px; max-width:64ch; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ background:linear-gradient(var(--ink),var(--ink-1)); }
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(40px,6vw,88px); }
.contact-aside h2{ margin-bottom:1.4rem; }
.contact-aside .lede{ margin-bottom:2.4rem; }
.cinfo{ display:flex; flex-direction:column; gap:4px; }
.cinfo a, .cinfo .ci{ display:flex; align-items:center; gap:16px; padding:18px 0; border-top:1px solid var(--hair); transition:color .4s; }
.cinfo a:hover{ color:var(--gold-2); }
.cinfo .k{ font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--faint); width:96px; flex:none; }
.cinfo .v{ font-size:1.05rem; }

.form{ background:linear-gradient(165deg,var(--ink-2),var(--ink-1)); border:1px solid var(--hair); border-radius:18px; padding:clamp(28px,3.4vw,44px); position:relative; overflow:hidden; }
.form::before{ content:""; position:absolute; top:-1px; left:0; right:0; height:1px; background:var(--gold-line); }
.field{ margin-bottom:20px; }
.field.row2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field.row2 .field{ margin:0; }
label{ display:block; font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); margin-bottom:9px; }
.inp{ width:100%; background:rgba(28,24,16,.03); border:1px solid var(--hair); border-radius:10px;
  padding:14px 16px; color:var(--bone); font-family:var(--ff-ui); font-size:.96rem; transition:border-color .35s, background .35s; }
.inp::placeholder{ color:var(--faint); }
.inp:focus{ outline:none; border-color:rgba(138,101,38,.6); background:rgba(28,24,16,.05); }
select.inp{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a5c24' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; }
textarea.inp{ resize:vertical; min-height:120px; }
.form .btn{ width:100%; justify-content:center; margin-top:6px; }
.form-note{ font-size:.74rem; color:var(--faint); margin-top:14px; text-align:center; }
.form-success{ display:none; text-align:center; padding:30px 10px; }
.form-success.show{ display:block; }
.form-success .tick{ width:64px; height:64px; border-radius:50%; border:1px solid var(--gold-3); display:grid; place-items:center; margin:0 auto 20px; color:var(--gold-1); font-size:1.6rem; }
.form-success h3{ font-size:2rem; margin-bottom:.5rem; }
.form-success p{ color:var(--dim); }
.form.sent .form-body{ display:none; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ border-top:1px solid var(--hair); padding-block:clamp(48px,6vw,80px) 40px; }
.footer-top{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:40px; align-items:flex-start; }
.footer .flogo{ display:inline-flex; align-items:center; gap:14px; margin-bottom:18px; }
.footer .flogo img{ height:48px; width:auto; filter:drop-shadow(0 3px 8px rgba(80,60,20,.2)); }
.footer .flogo-txt{ display:flex; flex-direction:column; line-height:1.1; }
.footer .flogo-txt b{ font-family:var(--ff-ui); font-weight:600; letter-spacing:.18em; font-size:.92rem; text-transform:uppercase; color:var(--bone); }
.footer .flogo-txt i{ font-style:normal; font-size:.64rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-2); margin-top:5px; }
.footer .tag{ color:var(--dim); font-weight:300; max-width:34ch; }
.footer-links{ display:flex; gap:clamp(30px,5vw,80px); flex-wrap:wrap; }
.footer-col h4{ font-family:var(--ff-ui); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--faint); margin:0 0 16px; }
.footer-col a{ display:block; color:var(--bone-2); font-size:.92rem; padding:6px 0; transition:color .3s; }
.footer-col a:hover{ color:var(--gold-2); }
.footer-press{
  display:flex; flex-wrap:wrap; align-items:center; gap:8px 20px;
  margin-top:clamp(32px,4vw,48px); padding-top:24px;
  border-top:1px solid var(--hair-soft);
}
.footer-press-label{
  font-size:.68rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--faint); font-weight:600; flex-shrink:0;
}
.footer-press a{
  font-size:.76rem; color:var(--dim); text-decoration:none;
  transition:color .2s;
}
.footer-press a::before{ content:"↗ "; font-size:.7rem; }
.footer-press a:hover{ color:var(--gold-3); }

.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:16px; margin-top:20px; padding-top:20px; border-top:1px solid var(--hair-soft);
  color:var(--faint); font-size:.76rem; letter-spacing:.04em; }

/* ============================================================
   Reveal animations
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

/* Award cards swivel in on scroll — rotateY instead of plain translateY */
.award.reveal{
  opacity:0;
  transform:perspective(700px) rotateY(-52deg) scale(.92);
}
.award.reveal.in{
  opacity:1;
  transform:perspective(700px) rotateY(0deg) scale(1);
}

@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } .award.reveal{ transform:none; } .card-spring{ opacity:.85; } .marquee-track,.scrollcue .line{ animation:none; } }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .gallery{ columns:2; }
  .stats{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .nav-links{ display:none; }
  .card-spring{ animation:none; transform:scale(.66); left:68%; bottom:3%; }
  .card.acc{ display:none; }
  .nav-cta .btn{ display:none; }
  .nav-burger{ display:grid; }
  .about-grid{ grid-template-columns:1fr; gap:60px; }
  .about-portrait .frame{ max-width:440px; }
  .svc-grid{ grid-template-columns:1fr; }
  .award-row{ grid-template-columns:1fr; max-width:420px; margin-inline:auto; }
  .rev-grid{ grid-template-columns:1fr; }
  .tt-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .hero-bg img{ opacity:.4; right:-30%; }
}
@media (max-width:560px){
  .gallery{ columns:1; }
  .card-spring{ transform:scale(.5); left:64%; bottom:1%; }
  .field.row2{ grid-template-columns:1fr; }
  .hero .badges img{ height:46px; }
  .footer-top{ flex-direction:column; }
  /* compact accolade pill on phones (no flanking flourishes, smaller type) */
  .hero-accolade{ flex-wrap:wrap; gap:4px 10px; padding:10px 16px; max-width:100%; }
  .hero-accolade .laurel{ display:none; }
  .hero-accolade .ha-txt{ white-space:normal; font-size:.76rem; line-height:1.3; }
  .hero-accolade .ha-sub{ font-size:.58rem; }
  /* two TikTok phones fit side by side instead of overflowing */
  .tt-phones{ gap:14px; justify-content:center; }
  .tt-phone{ width:calc(50% - 7px); }
  .tt-phone:nth-child(2){ transform:translateY(16px); }
}

/* ============================================================
   WEDDINGS PAGE
   ============================================================ */
.subnav-active{ color:var(--bone) !important; }
.subnav-active::after{ width:100% !important; }

.wed-hero{ position:relative; padding-top:clamp(132px,16vw,196px); padding-bottom:clamp(56px,8vw,104px);
  background:linear-gradient(180deg,#ffffff,#faf8f3); overflow:hidden; }
.wed-hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,6vw,84px); align-items:center; }
.wed-hero h1{ font-family:var(--ff-display); font-weight:300; font-size:clamp(2.9rem,6vw,5.6rem); line-height:1.08; letter-spacing:-.01em; padding-bottom:.04em; }
.wed-hero .lede{ margin-top:1.5rem; }
.wed-hero .actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2.2rem; }
.wed-hero-media{ position:relative; border-radius:16px; overflow:hidden; aspect-ratio:5/6;
  box-shadow:0 50px 90px -54px rgba(40,32,16,.5); }
.wed-hero-media img{ width:100%; height:100%; object-fit:cover; }
.wed-hero-media .badge{ position:absolute; left:-16px; bottom:-16px; background:#fff; border:1px solid var(--hair);
  border-radius:14px; padding:14px 20px; box-shadow:0 26px 54px -30px rgba(40,32,16,.5); }
.wed-hero-media .badge .n{ font-family:var(--ff-display); font-size:1.9rem; line-height:1; }
.wed-hero-media .badge .l{ font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); margin-top:6px; }

.pkg-list{ margin-top:clamp(40px,5vw,72px); display:flex; flex-direction:column; gap:clamp(52px,8vw,116px); }
.pkg{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,76px); align-items:center; }
.pkg:nth-child(even) .pkg-media{ order:2; }
.pkg-media{ border-radius:16px; overflow:hidden; aspect-ratio:4/3;
  box-shadow:0 44px 84px -54px rgba(40,32,16,.5); }
.pkg-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); filter:grayscale(.08) contrast(1.02); }
.pkg-media:hover img{ transform:scale(1.045); filter:grayscale(0); }
.pkg-num{ font-family:var(--ff-display); font-style:italic; font-size:1.15rem; color:var(--gold-3); }
.pkg h3{ font-size:clamp(2.1rem,3.4vw,3.2rem); margin:.45rem 0 1rem; }
.pkg p{ color:var(--dim); font-weight:300; max-width:50ch; }
.pkg .feat{ list-style:none; padding:0; margin:1.5rem 0 0; max-width:42ch; }
.pkg .feat li{ font-size:.92rem; color:var(--bone-2); padding:.52em 0; border-top:1px solid var(--hair-soft); display:flex; align-items:center; gap:.7em; }
.pkg .feat li::before{ content:""; width:5px; height:5px; rotate:45deg; background:var(--gold-grad); flex:none; }

.timeline{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3vw,44px); margin-top:clamp(40px,5vw,64px); }
.tl-step{ position:relative; padding-top:30px; }
.tl-step::before{ content:""; position:absolute; top:0; left:0; width:100%; height:1px; background:var(--gold-line); }
.tl-step .tl-time{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-2); font-weight:600; }
.tl-step h4{ font-family:var(--ff-display); font-size:1.7rem; margin:.55rem 0 .6rem; color:var(--bone); font-weight:400; }
.tl-step p{ color:var(--dim); font-weight:300; font-size:.95rem; margin:0; max-width:34ch; }

.wed-trust{ background:linear-gradient(var(--ink),var(--ink-1) 50%,var(--ink)); }
.wed-cta-band{ text-align:center; }
.wed-cta-band .h2{ margin:1rem auto 0; }
.wed-cta-band .actions{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:2rem; }

@media (max-width:860px){
  .wed-hero-grid{ grid-template-columns:1fr; gap:44px; }
  .wed-hero-media{ max-width:460px; }
  .pkg{ grid-template-columns:1fr; gap:26px; }
  .pkg:nth-child(even) .pkg-media{ order:0; }
  .timeline{ grid-template-columns:1fr; gap:28px; }
}

/* ============================================================
   STUDIO NINJA EMBED (contact form iframe wrapper)
   The form itself is rendered cross-origin and cannot be styled
   from here — only this surrounding card/frame can. Match the
   form's *internal* colours inside Studio Ninja's form designer.
   ============================================================ */
.form.sn-card{ padding:clamp(8px,1.4vw,16px); }
.sn-embed{ width:100%; text-align:center; }
.sn-embed iframe{
  width:100% !important; min-width:100% !important; max-width:100% !important;
  border:0; border-radius:12px; display:block; background:#fff;
  /* iframeResizer sets the real height; this floor avoids a short-height flash */
  min-height:1040px;
}
.sn-loading{ color:var(--faint); font-size:.78rem; letter-spacing:.04em; padding:18px 0; text-align:center; }

/* ============================================================
   BACK TO TOP
   ============================================================ */
.btt{
  position:fixed;
  bottom:clamp(20px,4vw,36px);
  right:clamp(20px,4vw,36px);
  z-index:900;
  width:46px; height:46px;
  border-radius:50%;
  border:1px solid rgba(138,101,38,.35);
  background:var(--gold-metal);
  color:#1d1b17;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 18px rgba(0,0,0,.18);
  /* hidden by default */
  opacity:0;
  transform:translateY(12px);
  pointer-events:none;
  transition:opacity .35s var(--ease), transform .35s var(--ease), box-shadow .2s;
}
.btt:hover{
  box-shadow:0 6px 26px rgba(138,101,38,.45);
  transform:translateY(-2px);
}
.btt.visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
@media (prefers-reduced-motion:reduce){
  .btt{ transition:opacity .2s; transform:none !important; }
}
