/* ============================================================
   MALONE—CO STUDIO — Concept Landing System  v1
   "your brand deserves soul, not shortcuts."
   Warm cream editorial, lowercase serif voice, courier mono accents.
   Palette from maloneco.au: cream #fbf4e2 / #f7f0e9, clay #7f5038,
   maroon #56002b, plum-black #28001e.
   Type: Fraunces (freight-big-pro stand-in) + Figtree (sans)
         + Courier Prime (their courier-std nav/mono voice).
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;1,9..144,300;1,9..144,400&family=Figtree:wght@400;500;600;700&family=Courier+Prime:wght@400;700&display=swap');

:root{
  --bg:#fbf4e2; --bg-2:#f7f0e9;
  --glass:rgba(251,244,226,.62); --glass-strong:rgba(251,244,226,.85);
  --ink:#28001e; --ink-soft:rgba(40,0,30,.66); --ink-mute:rgba(40,0,30,.42);
  --clay:#7f5038; --maroon:#56002b;
  --line:rgba(40,0,30,.14); --line-soft:rgba(40,0,30,.07);
  --hi:rgba(255,255,255,.6);
  --blur:blur(26px) saturate(1.4);
  --r:26px; --r-sm:18px;
  --shadow:0 30px 80px -38px rgba(40,0,30,.45);
  --maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:90px}
section[id]{scroll-margin-top:90px}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:'Figtree',-apple-system,system-ui,Arial,sans-serif;
  font-weight:400; line-height:1.7; letter-spacing:.005em;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
body::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(70% 50% at 50% -10%, rgba(127,80,56,.07), transparent 60%),
             radial-gradient(50% 40% at 90% 110%, rgba(86,0,43,.05), transparent 60%),
             linear-gradient(180deg, var(--bg), var(--bg-2));
}

/* Type — lowercase serif, their voice */
h1,h2,h3,.display{font-family:'Fraunces',Georgia,serif; font-weight:400; line-height:1.04;
  letter-spacing:-.01em; margin:0; text-transform:lowercase}
h1{font-size:clamp(2.6rem,7vw,5.6rem); font-weight:300}
h2{font-size:clamp(1.8rem,4vw,3rem); font-weight:300}
h3{font-size:clamp(1.1rem,1.8vw,1.4rem); font-weight:500}
p{margin:0 0 1rem}
.lead{font-size:clamp(1rem,1.4vw,1.16rem); color:var(--ink-soft); font-weight:400; text-transform:none}
.serif{font-family:'Fraunces',Georgia,serif; font-style:italic; font-weight:300;
  text-transform:none; letter-spacing:0; line-height:1.45}
.eyebrow{font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.22em;
  font-weight:400; font-size:.78rem; color:var(--clay)}
.eyebrow.line{display:inline-block; padding-bottom:10px; position:relative}
.eyebrow.line::after{content:""; position:absolute; left:0; bottom:0; height:1px; width:44px; background:var(--clay)}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
section{padding:clamp(60px,9vw,130px) 0}
.num{font-family:'Fraunces',serif; font-weight:300; font-style:italic; color:var(--clay);
  font-size:clamp(2.4rem,5vw,3.6rem); line-height:1}
.wordmark{font-family:'Fraunces',serif; font-weight:400; letter-spacing:.02em; text-transform:lowercase}
.wordmark em{font-style:normal; color:var(--clay)}

/* Panels — warm cream glass */
.panel{background:var(--glass); border:1px solid var(--line);
  -webkit-backdrop-filter:var(--blur); backdrop-filter:var(--blur);
  border-radius:var(--r); box-shadow:var(--shadow);
  position:relative; transition:transform .35s cubic-bezier(.2,.7,.2,1), border-color .3s, box-shadow .4s}
.panel::before{content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  background:linear-gradient(180deg, rgba(255,255,255,.55), transparent 28%);
  mask:linear-gradient(180deg,#000 0%,transparent 45%); -webkit-mask:linear-gradient(180deg,#000 0%,transparent 45%)}
.panel:hover{border-color:rgba(127,80,56,.4)}
.panel-soft{background:rgba(255,255,255,.32); border:1px solid var(--line-soft); border-radius:var(--r)}

/* Buttons — soft pills */
.btn{display:inline-flex; align-items:center; gap:.6em; cursor:pointer;
  font-family:'Courier Prime',monospace; font-weight:700; text-transform:lowercase; letter-spacing:.12em;
  font-size:.88rem; padding:1rem 1.9rem; border:1px solid rgba(40,0,30,.3); text-decoration:none;
  border-radius:999px; -webkit-backdrop-filter:var(--blur); backdrop-filter:var(--blur);
  transition:background .25s, color .25s, transform .2s, border-color .25s, box-shadow .3s;
  background:rgba(255,255,255,.4); color:var(--ink)}
.btn:hover{transform:translateY(-2px); border-color:var(--ink)}
.btn-solid{background:var(--ink); color:var(--bg); border-color:var(--ink);
  box-shadow:0 14px 40px -14px rgba(40,0,30,.5)}
.btn-solid:hover{background:var(--maroon); border-color:var(--maroon)}
.btn-ghost:hover{background:rgba(255,255,255,.7)}
.btn svg{width:1.05em; height:1.05em}
.btn-row{display:flex; flex-wrap:wrap; gap:14px; align-items:center}

/* Topbar */
.topbar{position:sticky; top:0; z-index:50; -webkit-backdrop-filter:var(--blur); backdrop-filter:var(--blur);
  background:rgba(251,244,226,.6); border-bottom:1px solid var(--line-soft);
  transition:background .35s, box-shadow .35s}
.topbar.scrolled{background:rgba(251,244,226,.88); box-shadow:0 18px 50px -28px rgba(40,0,30,.3)}
.topbar .wrap{display:flex; align-items:center; justify-content:space-between; padding-top:16px; padding-bottom:16px}
.brand-logo{display:flex; align-items:center; text-decoration:none; color:var(--ink); font-size:1.25rem}
.nav-links{display:flex; align-items:center; gap:30px}
.nav-links a{color:var(--ink-soft); text-decoration:none; font-size:.85rem;
  font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.14em; transition:color .18s}
.nav-links a:hover{color:var(--ink)}
.topbar .btn{padding:.65rem 1.2rem; font-size:.78rem}
@media(max-width:820px){ .nav-links{display:none} }

/* HERO */
.hero{position:relative; min-height:88vh; display:flex; align-items:flex-end; padding:0 0 clamp(50px,7vw,90px)}
.hero-bg{position:absolute; inset:0; overflow:hidden}
.hero-bg img{width:100%; height:100%; object-fit:cover; display:block;
  filter:contrast(1.02) brightness(.96); transform:scale(1.08)}
.hero-bg::after{content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(251,244,226,.32) 0%, rgba(251,244,226,0) 30%, rgba(40,0,30,.42) 62%, rgba(40,0,30,.8) 100%)}
.hero .wrap{position:relative; z-index:2; width:100%}
.hero h1{color:#fbf4e2; text-shadow:0 2px 30px rgba(40,0,30,.55)}
.hero h1 span{display:block}
.hero .eyebrow{color:rgba(251,244,226,.85)}
.hero .eyebrow.line::after{background:rgba(251,244,226,.85)}
.hero .sub{font-size:clamp(1.05rem,1.7vw,1.35rem); color:rgba(251,244,226,.92); text-shadow:0 1px 18px rgba(40,0,30,.5); max-width:600px; margin-top:22px}
.badges{display:flex; flex-wrap:wrap; gap:10px; margin-top:28px}
.chip{display:inline-flex; align-items:center; gap:.5em; font-size:.78rem; color:rgba(251,244,226,.92);
  font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.1em; border-radius:999px;
  padding:.5rem 1.05rem; background:rgba(40,0,30,.32); border:1px solid rgba(251,244,226,.3);
  -webkit-backdrop-filter:var(--blur); backdrop-filter:var(--blur)}
.hero .btn-ghost{color:#fbf4e2; border-color:rgba(251,244,226,.55); background:rgba(40,0,30,.2)}
.hero .btn-ghost:hover{background:rgba(40,0,30,.4)}
.hero .btn-solid{background:#fbf4e2; color:var(--ink); border-color:#fbf4e2}
.hero .btn-solid:hover{background:#fff; border-color:#fff}
.cue{display:inline-flex; flex-direction:column; align-items:center; gap:8px; margin-top:42px;
  color:rgba(251,244,226,.7); font-size:10px; letter-spacing:.2em; text-transform:lowercase;
  font-family:'Courier Prime',monospace; text-decoration:none}
.cue .bar{width:1px; height:44px; background:linear-gradient(180deg,#fbf4e2,transparent);
  animation:cuedrop 1.8s ease-in-out infinite}
@keyframes cuedrop{0%{transform:scaleY(0); transform-origin:top} 50%{transform:scaleY(1)} 100%{transform:scaleY(0); transform-origin:bottom}}

/* Marquee */
.marquee{overflow:hidden; -webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); padding:18px 0}
.marquee-track{display:flex; gap:54px; width:max-content; animation:scrollx 34s linear infinite; align-items:center}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{color:var(--ink-mute); font-family:'Fraunces',serif; font-style:italic; font-weight:300;
  letter-spacing:.04em; font-size:1rem; white-space:nowrap; display:inline-flex; align-items:center; gap:.7rem}
.marquee span::before{content:""; width:5px; height:5px; border-radius:50%; background:var(--clay); display:inline-block}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* Section heads */
.shead{max-width:820px; margin:0 auto clamp(36px,5vw,64px); text-align:center}
.shead p{margin-top:16px}
.shead-l{max-width:720px; margin-bottom:clamp(36px,5vw,64px)}
.shead-l p{margin-top:16px}

/* Folio index rows */
.pindex{border-top:1px solid var(--line)}
.prow{display:grid; grid-template-columns:80px 1fr auto auto; gap:18px; align-items:center;
  padding:24px 10px; border-bottom:1px solid var(--line); text-decoration:none; color:var(--ink);
  position:relative; transition:background .25s, padding-left .3s}
.prow:hover{background:rgba(255,255,255,.45); padding-left:22px}
.prow .pn{font-family:'Courier Prime',monospace; font-size:.9rem; color:var(--ink-mute); letter-spacing:.1em}
.prow .pt{font-family:'Fraunces',serif; font-weight:300; text-transform:lowercase; font-size:clamp(1.3rem,2.6vw,2rem)}
.prow .pa{font-family:'Fraunces',serif; font-style:italic; font-weight:300; color:var(--ink-soft); font-size:.95rem}
.prow .ps{font-size:.74rem; font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.12em; color:var(--clay)}
.prow .pimg{position:absolute; right:8%; top:50%; transform:translateY(-50%) scale(.94) rotate(-1deg); width:300px; aspect-ratio:4/3;
  object-fit:cover; opacity:0; pointer-events:none; transition:opacity .3s, transform .4s; z-index:3;
  box-shadow:var(--shadow); border:1px solid var(--hi); border-radius:var(--r-sm)}
.prow:hover .pimg{opacity:1; transform:translateY(-50%) scale(1) rotate(0deg)}
@media(max-width:820px){ .prow{grid-template-columns:44px 1fr; grid-auto-rows:auto} .prow .ps{display:none}
  .prow .pimg{display:none} }

/* Gallery band */
.gband{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:14px}
.gband figure{margin:0; position:relative; overflow:hidden; border:1px solid var(--line-soft);
  aspect-ratio:4/3; border-radius:var(--r-sm); box-shadow:0 18px 50px -30px rgba(40,0,30,.4)}
.gband figure.tall{grid-row:span 2; aspect-ratio:auto}
.gband img{width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gband figure:hover img{transform:scale(1.05)}
.gband figcaption{position:absolute; left:0; right:0; bottom:0; padding:14px 16px;
  font-size:.74rem; font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.12em; color:#fbf4e2;
  background:linear-gradient(180deg, transparent, rgba(40,0,30,.78))}
@media(max-width:820px){ .gband{grid-template-columns:1fr 1fr} }

/* Editorial band */
.eband{display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,64px); align-items:center}
.eband + .eband{margin-top:clamp(50px,7vw,100px)}
.eband .eimg{margin:0; position:relative; overflow:hidden; border-radius:var(--r);
  border:1px solid var(--line-soft); box-shadow:var(--shadow); aspect-ratio:4/5}
.eband .eimg.wide{aspect-ratio:4/3}
.eband .eimg img{width:100%; height:100%; object-fit:cover; display:block;
  transition:transform 1s cubic-bezier(.2,.7,.2,1)}
.eband:hover .eimg img{transform:scale(1.04)}
.eband .etext .eyebrow{display:block; margin-bottom:14px}
.eband .etext h3{font-size:clamp(1.5rem,3vw,2.3rem); margin-bottom:18px; font-weight:300}
.eband .etext .serif{font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--ink-soft); margin-bottom:14px}
.eband .etext p:not(.serif){color:var(--ink-soft); font-size:.97rem}
.eband.flip .eimg{order:2}
@media(max-width:820px){ .eband{grid-template-columns:1fr} .eband.flip .eimg{order:0} .eband .eimg{aspect-ratio:4/3} }

/* Filmstrip */
.strip-outer{overflow:hidden}
.strip{display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding:6px max(24px, calc((100vw - var(--maxw)) / 2 + 24px)) 22px;
  -webkit-overflow-scrolling:touch; scrollbar-width:none}
.strip::-webkit-scrollbar{display:none}
.strip figure{margin:0; flex:0 0 auto; width:min(300px,72vw); aspect-ratio:3/4; position:relative;
  overflow:hidden; border-radius:var(--r-sm); border:1px solid var(--line-soft); scroll-snap-align:start;
  box-shadow:0 18px 50px -30px rgba(40,0,30,.4)}
.strip img{width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.strip figure:hover img{transform:scale(1.05)}
.strip figcaption{position:absolute; left:0; right:0; bottom:0; padding:14px 16px;
  font-size:.72rem; font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.12em; color:#fbf4e2;
  background:linear-gradient(180deg, transparent, rgba(40,0,30,.78))}
.strip-hint{text-align:center; color:var(--ink-mute); font-size:.74rem; letter-spacing:.18em;
  text-transform:lowercase; font-family:'Courier Prime',monospace; margin-top:4px}

/* Wallquote — full-bleed image, maroon wash, cream glass card */
.wallquote{position:relative; min-height:68vh; display:flex; align-items:center; overflow:hidden; padding:clamp(60px,9vw,130px) 0}
.wallquote .wq-bg{position:absolute; inset:0}
.wallquote .wq-bg img{width:100%; height:100%; object-fit:cover; display:block}
.wallquote .wq-bg::after{content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(86,0,43,.66), rgba(86,0,43,.3) 35%, rgba(86,0,43,.3) 65%, rgba(86,0,43,.78))}
.wallquote .wrap{position:relative; z-index:2}
.wallquote .wq-card{max-width:760px; margin:0 auto; text-align:center; padding:clamp(34px,5vw,60px);
  background:rgba(251,244,226,.78); border:1px solid rgba(251,244,226,.6); border-radius:var(--r);
  -webkit-backdrop-filter:var(--blur); backdrop-filter:var(--blur); box-shadow:var(--shadow)}
.wallquote .serif{font-size:clamp(1.3rem,2.6vw,1.95rem); color:var(--ink); margin:0}
.wallquote cite{display:block; margin-top:20px; font-style:normal; font-size:.74rem;
  font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.18em; color:var(--clay)}

/* Steps */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.step{padding:34px 30px}
.step h3{margin:.8rem 0 .6rem}
.step p{color:var(--ink-soft); margin:0; font-size:.95rem; text-transform:none}
@media(max-width:820px){ .steps{grid-template-columns:1fr} }

/* Quote */
.bigquote{max-width:880px; margin:0 auto; text-align:center}
.bigquote .serif{font-size:clamp(1.5rem,3.2vw,2.4rem); color:var(--ink)}
.bigquote cite{display:block; margin-top:22px; font-style:normal; font-size:.76rem;
  font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.18em; color:var(--clay)}

/* CTA + forms */
.cta{position:relative; text-align:center; padding:clamp(48px,7vw,90px) 30px; overflow:hidden}
.cta h2{max-width:820px; margin:0 auto 16px}
.cta .lead{max-width:600px; margin:0 auto 30px}
.lead-form{max-width:480px; margin:0 auto; text-align:left}
.lead-form .field{margin-bottom:16px}
.lead-form label{display:block; font-size:.76rem; color:var(--clay); margin-bottom:7px;
  font-family:'Courier Prime',monospace; text-transform:lowercase; letter-spacing:.14em}
.lead-form input, .lead-form select, .lead-form textarea{width:100%; padding:1rem 1.15rem; font:inherit; font-size:.96rem;
  background:rgba(255,255,255,.55); border:1px solid var(--line); color:var(--ink); outline:none;
  transition:border-color .2s, background .2s; border-radius:16px; appearance:none}
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus{border-color:var(--clay); background:#fff}
.lead-form input::placeholder, .lead-form textarea::placeholder{color:var(--ink-mute)}
.lead-form select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%237f5038' viewBox='0 0 16 16'%3E%3Cpath d='M8 11 3 6h10z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center}
.lead-form .btn{width:100%; justify-content:center; margin-top:8px}
.form-note{text-align:center; font-size:.76rem; color:var(--ink-mute); margin-top:16px}
.thanks{text-align:center; padding:34px}
.thanks .seal{width:60px; height:60px; border-radius:50%; display:grid; place-items:center; margin:0 auto 18px;
  background:var(--ink); color:var(--bg)}
.thanks .seal svg{width:28px; height:28px}

/* QUIZ */
.quiz{max-width:640px; margin:0 auto}
.quiz-card{padding:clamp(30px,4vw,46px); position:relative; overflow:hidden; background:var(--glass-strong)}
.progress{height:3px; border-radius:99px; background:rgba(40,0,30,.12); overflow:hidden; margin-bottom:30px}
.progress > i{display:block; height:100%; width:20%; border-radius:99px; background:var(--clay); transition:width .4s cubic-bezier(.2,.7,.2,1)}
.q-step{display:none; animation:qin .45s ease both}
.q-step.active{display:block}
@keyframes qin{from{opacity:0; transform:translateX(16px)} to{opacity:1; transform:none}}
.q-kicker{font-size:.74rem; letter-spacing:.2em; font-family:'Courier Prime',monospace; text-transform:lowercase; color:var(--clay)}
.q-step h3{font-size:clamp(1.3rem,2.7vw,1.85rem); margin:.6rem 0 1.5rem; text-transform:none; font-family:'Fraunces',serif; font-weight:400}
.opts{display:grid; gap:10px}
.opt{display:flex; align-items:center; gap:.9rem; width:100%; text-align:left; cursor:pointer;
  padding:1.05rem 1.25rem; background:rgba(255,255,255,.5); border:1px solid var(--line);
  color:var(--ink); font:inherit; font-size:1rem; transition:border-color .18s, background .18s, transform .12s;
  border-radius:18px}
.opt:hover{border-color:var(--clay); background:#fff; transform:translateY(-1px)}
.opt .dot{flex:none; width:20px; height:20px; border-radius:50%; border:1.5px solid var(--ink-mute); display:grid; place-items:center; transition:.18s}
.opt .dot svg{width:11px; height:11px; color:var(--bg); opacity:0; transition:.18s}
.opt.sel{border-color:var(--ink); background:#fff}
.opt.sel .dot{background:var(--ink); border-color:var(--ink)} .opt.sel .dot svg{opacity:1}
.q-nav{display:flex; justify-content:space-between; align-items:center; margin-top:26px}
.q-back{background:none; border:0; color:var(--ink-mute); font:inherit; cursor:pointer; font-size:.9rem; padding:.4rem}
.q-back:hover{color:var(--ink-soft)}
.q-back[disabled]{opacity:0; pointer-events:none}

footer{padding:54px 0 44px; border-top:1px solid var(--line); color:var(--ink-mute); font-size:.86rem; text-align:center;
  background:var(--ink); color:rgba(251,244,226,.6)}
footer a{color:#fbf4e2; text-decoration:none}
footer .flogo{font-family:'Fraunces',serif; font-size:1.5rem; color:#fbf4e2; margin-bottom:14px; display:block; text-transform:lowercase}
.disclaimer{max-width:720px; margin:16px auto 0; font-size:.72rem; color:rgba(251,244,226,.4)}

/* Reveal system */
.reveal{opacity:1; transform:none}
.js-anim .reveal{opacity:0; transform:translateY(36px) scale(.985); filter:blur(9px);
  transition:opacity .95s cubic-bezier(.16,.84,.3,1), transform .95s cubic-bezier(.16,.84,.3,1), filter .9s ease;
  transition-delay:var(--rd,0s); will-change:opacity,transform,filter}
.js-anim .reveal.in{opacity:1; transform:none; filter:none}

/* Hero word-cascade */
.js-anim .h-word{display:inline-block; opacity:0; transform:translateY(.55em); filter:blur(8px);
  animation:wordin .85s cubic-bezier(.16,.84,.3,1) forwards; animation-delay:var(--wd,0s)}
@keyframes wordin{to{opacity:1; transform:none; filter:none}}

/* Scroll progress */
.scroll-progress{position:fixed; top:0; left:0; height:2px; width:0; z-index:140;
  background:var(--clay); box-shadow:0 0 12px rgba(127,80,56,.5)}

.grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:16px}
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
@media(max-width:900px){ .grid2,.grid3{grid-template-columns:1fr} }

/* drifting warm motes */
.dust{position:fixed; inset:0; z-index:-1; pointer-events:none}
.dust i{position:absolute; bottom:-2vh; width:3px; height:3px; border-radius:50%; background:rgba(127,80,56,.35);
  filter:blur(.5px); opacity:0; animation:drift var(--dur,24s) linear var(--del,0s) infinite}
@keyframes drift{0%{opacity:0; transform:translate(0,0)} 12%{opacity:.5}
  60%{opacity:.25; transform:translate(var(--sway,20px),-58vh)} 100%{opacity:0; transform:translate(calc(var(--sway,20px)*-.5),-112vh)}}

/* picker cards */
.pick{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:44px}
.pcard{padding:0; text-decoration:none; color:var(--ink); display:flex; flex-direction:column; overflow:hidden}
.pcard .pimg-top{aspect-ratio:16/10; overflow:hidden; border-bottom:1px solid var(--line-soft)}
.pcard .pimg-top img{width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.pcard:hover .pimg-top img{transform:scale(1.06)}
.pcard .pbody{padding:24px 26px 28px; display:flex; flex-direction:column; gap:10px; flex:1}
.pcard .tag{font-family:'Courier Prime',monospace; font-size:.72rem; letter-spacing:.2em; text-transform:lowercase; color:var(--clay)}
.pcard h3{font-size:1.35rem}
.pcard p{color:var(--ink-soft); font-size:.92rem; margin:0; flex:1; text-transform:none}
.pcard .go{font-family:'Courier Prime',monospace; font-weight:700; font-size:.82rem; letter-spacing:.14em; text-transform:lowercase;
  display:inline-flex; align-items:center; gap:.5em; margin-top:6px}
.pcard .best{align-self:flex-start; font-family:'Courier Prime',monospace; font-size:.66rem; letter-spacing:.16em; text-transform:lowercase;
  color:var(--bg); background:var(--maroon); padding:.45rem .8rem; border-radius:999px}
@media(max-width:860px){ .pick{grid-template-columns:1fr} }

/* testimonial cards */
.tcard{padding:30px 28px}
.tcard .serif{font-size:1.02rem; color:var(--ink-soft); margin-bottom:18px}
.tcard cite{font-style:normal; font-size:.74rem; font-family:'Courier Prime',monospace;
  text-transform:lowercase; letter-spacing:.14em; color:var(--clay)}

/* pricing / audit inclusions */
.inc-list{list-style:none; margin:0; padding:0; display:grid; gap:0}
.inc-list li{display:flex; gap:14px; align-items:flex-start; padding:16px 4px; border-bottom:1px solid var(--line-soft); color:var(--ink-soft)}
.inc-list li b{color:var(--ink); font-weight:600}
.inc-list .tick{flex:none; width:22px; height:22px; border-radius:50%; background:var(--clay); color:var(--bg);
  display:grid; place-items:center; margin-top:3px}
.inc-list .tick svg{width:12px; height:12px}
.price-tag{display:inline-flex; align-items:baseline; gap:.4em; font-family:'Fraunces',serif; font-weight:300;
  font-size:clamp(2.4rem,5vw,3.6rem); color:var(--ink)}
.price-tag small{font-size:.95rem; font-family:'Courier Prime',monospace; color:var(--clay); letter-spacing:.1em}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important; transition:none!important; scroll-behavior:auto!important}
  .reveal{opacity:1; transform:none}
}

/* Lenis (desktop only — see mc.js) */
html.lenis, html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-smooth iframe{pointer-events:none}

/* ---- built by Scalus footer badge ---- */
.built-by{display:inline-flex; align-items:center; gap:.55em; margin-top:26px;
  font-size:.7rem; font-weight:600; line-height:1; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(251,244,226,.45); text-decoration:none; opacity:.85; transition:opacity .3s}
.built-by img{height:13px; width:auto; display:block}
.built-by b{color:rgba(251,244,226,.75); font-weight:700; letter-spacing:.22em}
.built-by:hover{opacity:1}
