/* ============================================================
   Sukoon Studio — design system v2
   Apple Method + Craft Layer (Emil Kowalski · Impeccable · Taste)
   Concept: Sukoon = stillness. "Be seen, without the rush."
   ============================================================ */
:root{
  /* ---- color: OKLCH, one accent locked, tinted-warm neutrals ---- */
  --cream:    oklch(97.6% 0.009 82);   /* warm off-white base */
  --cream-2:  oklch(95.2% 0.014 80);   /* alt surface */
  --paper:    oklch(99.2% 0.006 84);
  --ink:      oklch(26% 0.018 64);     /* warm near-black text */
  --ink-2:    oklch(48% 0.018 66);     /* secondary */
  --ink-3:    oklch(63% 0.016 68);     /* tertiary */
  --gold:     oklch(80% 0.128 80);     /* brand amber #F8B048 (accent fill) */
  --gold-ink: oklch(50% 0.105 72);     /* darker amber for text on light (AA) */
  --gold-soft:oklch(92% 0.06 82);
  --dark:     oklch(20% 0.014 62);     /* warm near-black surface */
  --dark-2:   oklch(25% 0.015 62);     /* elevation +1 (lighter=higher) */
  --on-dark:  oklch(94% 0.012 80);
  --on-dark-2:oklch(78% 0.012 76);
  --line:     oklch(26% 0.018 64 / .12);
  --line-2:   oklch(26% 0.018 64 / .07);
  --shadow:   0 1px 2px oklch(26% 0.02 64 / .05), 0 12px 32px -14px oklch(26% 0.03 64 / .20);
  --shadow-lg:0 2px 8px oklch(26% 0.02 64 / .07), 0 40px 70px -28px oklch(26% 0.04 64 / .34);
  --ring:     0 0 0 2px var(--cream), 0 0 0 4px var(--gold);

  /* ---- type ---- */
  --serif: ui-serif, "New York", "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
  --sans: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", system-ui, "Helvetica Neue", sans-serif;
  --arabic: "SF Arabic", -apple-system, "Geeza Pro", "Noto Naskh Arabic", serif;

  /* ---- space (4pt scale) ---- */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s6:24px; --s8:32px; --s12:48px; --s16:64px; --s24:96px;
  --gutter:clamp(20px, 5vw, 60px);
  --wide:1220px; --mid:760px; --read:62ch;
  --r:12px; --r-2:18px; --r-3:26px; --r-pill:999px;

  /* ---- motion (Emil/Impeccable) ---- */
  --ease-out-expo:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-drawer:    cubic-bezier(0.32, 0.72, 0, 1);
  --d-fast:140ms; --d-mid:260ms; --d-slow:440ms;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--sans); color:var(--ink); background:var(--cream);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold-soft);color:var(--ink)}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--r)}

/* ---- layout ---- */
.wrap{max-width:var(--wide);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(72px,10vw,128px)}
.bg-cream2{background:var(--cream-2)}
.bg-paper{background:var(--paper)}
.bg-dark{background:var(--dark);color:var(--on-dark)}
.bg-dark .dim{color:var(--on-dark-2)}
.dim{color:var(--ink-2)}
.maxmid{max-width:var(--mid)}

/* ---- type scale ---- */
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-ink)}
.bg-dark .eyebrow{color:var(--gold)}
h1,h2,h3,.display{font-family:var(--serif);font-weight:500;line-height:1.07;letter-spacing:-.02em;color:inherit}
h1,.h1{font-size:clamp(44px,7vw,84px);line-height:1.0;letter-spacing:-.028em}
h2,.h2{font-size:clamp(32px,4.6vw,54px);letter-spacing:-.022em}
h3,.h3{font-size:clamp(21px,2.4vw,27px);letter-spacing:-.014em}
em.gold{font-style:italic;color:var(--gold-ink)}
.bg-dark em.gold{color:var(--gold)}
.lede{font-size:clamp(18px,2vw,22px);line-height:1.5;color:var(--ink-2);font-weight:400;max-width:54ch}
.bg-dark .lede{color:var(--on-dark-2)}
.ksmall{font-size:13.5px;color:var(--ink-3);letter-spacing:.01em}

/* ---- buttons (8 states) ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;position:relative;
  font-family:var(--sans);font-size:16px;font-weight:600;letter-spacing:-.01em;
  padding:14px 26px;min-height:48px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer;
  transition:transform var(--d-fast) var(--ease-out-quint), background var(--d-mid) var(--ease-out-quart),
             box-shadow var(--d-mid) var(--ease-out-quart), border-color var(--d-mid), color var(--d-mid);white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn--gold{background:var(--gold);color:oklch(28% 0.05 66)}
.btn--wa{background:oklch(64% 0.16 150);color:#fff}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.bg-dark .btn--ghost{border-color:oklch(94% 0.012 80 / .26);color:var(--on-dark)}
.btn--lg{padding:17px 32px;font-size:17px;min-height:54px}
@media (hover:hover) and (pointer:fine){
  .btn--gold:hover{background:oklch(84% 0.12 82);box-shadow:0 12px 28px -10px oklch(80% 0.13 80 / .9)}
  .btn--wa:hover{background:oklch(68% 0.16 150)}
  .btn--ghost:hover{border-color:var(--ink);background:oklch(26% 0.018 64 / .04)}
  .bg-dark .btn--ghost:hover{border-color:var(--on-dark);background:oklch(94% 0.012 80 / .07)}
}
.icon{width:18px;height:18px;flex:none}
.stars{color:var(--gold);letter-spacing:.06em}

/* ---- OO mark ---- */
.oo{display:inline-block;color:var(--gold);line-height:0}
.oo svg{width:100%;height:100%;display:block}

/* ---- header ---- */
.head{position:sticky;top:0;z-index:60;transition:background var(--d-mid),border-color var(--d-mid)}
.head.glass{background:oklch(97.6% 0.009 82 / .8);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--line-2)}
.head__in{display:flex;align-items:center;gap:28px;height:70px}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto}
.brand__logo{height:24px;width:auto;display:block}
.brand__studio{font-size:11.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);
  line-height:1;align-self:center;padding-left:11px;border-left:1px solid var(--line)}
.nav{display:flex;gap:28px}
.nav a{font-size:15px;font-weight:500;color:var(--ink-2);transition:color var(--d-fast)}
@media (hover:hover){.nav a:hover{color:var(--ink)}}
.head__cta{display:flex;align-items:center;gap:14px}
.head__star{font-size:13.5px;font-weight:600;color:var(--ink-2);display:inline-flex;gap:.4em;align-items:center}
/* burger + mobile nav panel */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:0;border:0;background:transparent;cursor:pointer;border-radius:var(--r);order:9}
.burger span{display:block;width:22px;height:2px;margin-inline:auto;background:var(--ink);border-radius:2px;
  transition:transform var(--d-mid) var(--ease-out-quart),opacity var(--d-fast) var(--ease-out-quart)}
.head.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.head.nav-open .burger span:nth-child(2){opacity:0}
.head.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:920px){
  .head__star{display:none}
  .burger{display:flex}
  .nav{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:oklch(97.6% 0.009 82 / .97);backdrop-filter:saturate(180%) blur(20px);
    border-bottom:1px solid var(--line);padding:6px var(--gutter) 14px;
    opacity:0;visibility:hidden;transform:translateY(-10px);pointer-events:none;
    transition:opacity var(--d-mid) var(--ease-out-quart),transform var(--d-mid) var(--ease-out-quart),visibility 0s linear var(--d-mid)}
  .head.nav-open .nav{opacity:1;visibility:visible;transform:none;pointer-events:auto;transition-delay:0s}
  .nav a{font-size:17px;font-weight:500;color:var(--ink);padding:14px 2px;border-bottom:1px solid var(--line-2)}
  .nav a:last-child{border-bottom:0}
}
@media(max-width:520px){.brand__studio{display:none}.brand__logo{height:23px}.head__in{gap:14px}.head__cta .btn--wa{padding:12px 18px}}

/* ============ HERO ============ */
.hero{position:relative;padding-top:clamp(40px,7vw,92px);padding-bottom:clamp(28px,4vw,48px)}
.hero .ar-mark{font-family:var(--arabic);font-size:15px;color:var(--gold-ink);letter-spacing:.02em;display:block;margin-bottom:18px}
.hero h1{max-width:14ch;margin-bottom:.34em}
.hero .lede{margin-bottom:34px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__proof{display:flex;align-items:center;gap:22px;margin-top:30px;flex-wrap:wrap;color:var(--ink-2);font-size:14px}
.hero__proof .sep{width:1px;height:15px;background:var(--line);display:inline-block}
.hero__proof b{color:var(--ink)}

/* ===== re-envisioned conversion hero (split: copy + hero visual / video slot) ===== */
.hero--split{padding-top:clamp(24px,4vw,56px);padding-bottom:clamp(14px,2.4vw,30px)}
.hero__grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,5vw,60px);align-items:center}
.hero--split .ar-mark{margin-bottom:16px}
.hero__copy h1{max-width:13ch;margin:.14em 0 .3em}
.hero__copy .lede{margin-bottom:26px}
.hero__media{position:relative;border-radius:var(--r-3);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/4.7;background:var(--cream-2)}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.hero__media .ar{position:absolute;right:16px;bottom:13px;font-family:var(--arabic);font-size:40px;color:oklch(94% 0.012 80 / .92);text-shadow:0 2px 16px oklch(20% 0.02 60 / .6)}
.hero__media .play{position:absolute;inset:0;margin:auto;width:66px;height:66px;border-radius:50%;display:grid;place-items:center;background:oklch(99% 0 0 / .9);box-shadow:var(--shadow-lg);color:var(--ink)}
.hero__media .play svg{width:24px;height:24px;margin-left:3px}
.hero__vbadge{position:absolute;left:14px;top:13px;background:oklch(20% 0.02 60 / .5);backdrop-filter:blur(6px);color:#fff;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:var(--r-pill)}
@media(max-width:820px){.hero__grid{grid-template-columns:1fr}.hero__media{order:-1;aspect-ratio:4/3}.hero__media .ar{font-size:32px}}

/* ===== trust bar ===== */
.trustbar{border-block:1px solid var(--line);background:var(--paper)}
.trustbar__in{display:flex;flex-wrap:wrap;gap:10px 26px;justify-content:center;align-items:center;padding-block:13px}
.trustbar__in span{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink-2)}
.trustbar__in svg{width:15px;height:15px;color:var(--gold-ink);flex:none}

/* ===== guarantee band (risk reversal) ===== */
.guarantee{background:var(--gold-soft)}
.guarantee__in{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(16px,3vw,34px);align-items:center;padding-block:clamp(26px,4vw,42px)}
.guarantee__icon{width:54px;height:54px;border-radius:50%;background:var(--paper);display:grid;place-items:center;color:var(--gold-ink);box-shadow:var(--shadow);flex:none}
.guarantee__icon svg{width:28px;height:28px}
.guarantee h3{font-size:clamp(20px,2.5vw,28px);letter-spacing:-.012em}
.guarantee p{color:var(--ink-2);font-size:15px;line-height:1.5;margin-top:6px;max-width:62ch}
@media(max-width:760px){.guarantee__in{grid-template-columns:auto 1fr;gap:14px 18px}.guarantee__in .btn{grid-column:1 / -1;justify-self:start}}

/* ===== forms / lead capture ===== */
.formcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-3);box-shadow:var(--shadow-lg);padding:clamp(22px,3vw,34px)}
.form{display:grid;gap:17px}
.field{display:grid;gap:7px;position:relative}
.field>label{font-size:13.5px;font-weight:600;color:var(--ink)}
.field .req{color:var(--gold-ink)}
.input,.select,.textarea{font-family:var(--sans);font-size:16px;color:var(--ink);background:var(--cream);
  border:1px solid var(--line);border-radius:var(--r);padding:13px 14px;width:100%;
  transition:border-color var(--d-fast) var(--ease-out-quart),box-shadow var(--d-fast) var(--ease-out-quart),background var(--d-fast);
  -webkit-appearance:none;appearance:none}
.textarea{min-height:104px;resize:vertical;line-height:1.5}
.input::placeholder,.textarea::placeholder{color:var(--ink-3)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft);background:var(--paper)}
.select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a08a6a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
.field[data-error] .input,.field[data-error] .select,.field[data-error] .textarea{border-color:oklch(58% 0.16 25)}
.field__err{font-size:12.5px;font-weight:500;color:oklch(52% 0.17 25);display:none}
.field[data-error] .field__err{display:block}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:17px}
@media(max-width:560px){.form__row{grid-template-columns:1fr}}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form__foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:3px}
.form__note{font-size:13px;color:var(--ink-3);max-width:34ch}
.form__fail{display:none;font-size:14px;color:oklch(52% 0.17 25);background:oklch(58% 0.16 25 / .08);border:1px solid oklch(58% 0.16 25 / .25);border-radius:var(--r);padding:11px 14px}
.formsuccess{display:none;text-align:center;padding:20px 4px}
.formsuccess svg{width:46px;height:46px;color:oklch(64% 0.16 150);margin:0 auto 12px}
.formsuccess h3{font-size:clamp(22px,2.6vw,28px);margin-bottom:.3em}
.formsuccess p{color:var(--ink-2);font-size:15.5px;max-width:46ch;margin:0 auto}
.form.is-sent{display:none}
.formsuccess.is-shown{display:block}

/* ---- portfolio marquee (brand register, slow drift) ---- */
.marquee{margin-top:clamp(36px,6vw,72px);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee__track{display:flex;gap:16px;width:max-content;animation:drift 64s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee figure{position:relative;width:clamp(210px,26vw,300px);aspect-ratio:4/5;border-radius:var(--r-2);overflow:hidden;flex:none;background:var(--cream-2);box-shadow:var(--shadow)}
.marquee img{width:100%;height:100%;object-fit:cover}
.marquee figcaption{position:absolute;left:14px;bottom:12px;color:#fff;font-size:12.5px;font-weight:600;letter-spacing:.04em;text-shadow:0 1px 8px oklch(20% 0.02 60 / .7)}
@keyframes drift{to{transform:translateX(-50%)}}

/* ============ INTENT LANES (lead device, all four visible) ============ */
.router{position:relative}
.router__head{max-width:var(--mid);margin-bottom:8px}
.lanes{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px}
.lane{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-3);
  overflow:hidden;box-shadow:var(--shadow);
  transition:transform var(--d-mid) var(--ease-out-quart),box-shadow var(--d-mid) var(--ease-out-quart),border-color var(--d-mid)}
@media (hover:hover) and (pointer:fine){.lane:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}}
.lane__media{aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.lane__media img{width:100%;height:100%;object-fit:cover;object-position:center 26%;transition:transform var(--d-slow) var(--ease-out-quart)}
@media (hover:hover) and (pointer:fine){.lane:hover .lane__media img{transform:scale(1.04)}}
.lane__body{display:flex;flex-direction:column;gap:11px;padding:20px;flex:1}
.lane__title{font-family:var(--serif);font-size:21px;font-weight:500;letter-spacing:-.012em;line-height:1.1}
.lane__promise{font-size:14px;color:var(--ink-2);line-height:1.45}
.lane__lines{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin-top:1px}
.lane__lines li{font-size:12px;font-weight:600;color:var(--ink-2);background:var(--cream-2);border-radius:var(--r-pill);padding:5px 10px}
.lane__cta{margin-top:auto;padding-top:8px}
.lane__cta .btn{width:100%}
.lane--quick{border-color:var(--gold-soft);background:linear-gradient(180deg,var(--gold-soft) 0%,var(--paper) 40%)}
.lane--quick .lane__lines li{background:var(--paper);color:var(--gold-ink)}
@media(max-width:980px){.lanes{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.lanes{grid-template-columns:1fr}}
@keyframes panelin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ============ DIFFERENCE / KHALIL ============ */
.diff{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.diff__media{position:relative;border-radius:var(--r-3);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/4.5}
.diff__media img{width:100%;height:100%;object-fit:cover}
.diff__media .ar{position:absolute;right:18px;bottom:14px;font-family:var(--arabic);font-size:54px;color:oklch(94% 0.012 80 / .9);text-shadow:0 2px 18px oklch(20% 0.02 60 / .6)}
.stats{display:flex;gap:40px;margin-top:32px;flex-wrap:wrap}
.stat b{font-family:var(--sans);font-size:42px;font-weight:600;display:block;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.stat span{font-size:13px;color:var(--ink-2);margin-top:4px;display:block}
@media(max-width:820px){.diff{grid-template-columns:1fr}.diff__media{order:-1;aspect-ratio:4/3}}

/* ============ WORK GRID ============ */
.work__head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:38px;flex-wrap:wrap}
.grid-work{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tile{position:relative;display:block;border-radius:var(--r-2);overflow:hidden;background:var(--cream-2);box-shadow:var(--shadow);
  aspect-ratio:4/5;transition:transform var(--d-fast) var(--ease-out-quint)}
.tile img{width:100%;height:100%;object-fit:cover;object-position:center 28%;transition:transform var(--d-slow) var(--ease-out-quart)}
@media (hover:hover) and (pointer:fine){.tile:hover img{transform:scale(1.03)}}
.tile:active{transform:scale(.99)}
.tile figcaption,.tile .tcap{position:absolute;left:0;right:0;bottom:0;padding:32px 15px 13px;color:#fff;font-size:12.5px;font-weight:600;
  letter-spacing:.04em;background:linear-gradient(transparent,oklch(20% 0.02 60 / .72))}
@media(max-width:880px){.grid-work{grid-template-columns:repeat(2,1fr)}}

/* ============ TESTIMONIAL (featured + supporting, not 3 equal) ============ */
.tlead{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
.tlead blockquote{font-family:var(--serif);font-size:clamp(24px,3vw,34px);line-height:1.28;letter-spacing:-.014em;font-weight:500}
.tlead .who{display:flex;align-items:center;gap:13px;margin-top:26px}
.tlead .who img{width:46px;height:46px;border-radius:50%;object-fit:cover}
.tlead .who b{font-size:15px}.tlead .who span{font-size:13px;color:var(--ink-3);display:block}
.tmini{display:flex;flex-direction:column;gap:14px}
.tmini .q{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-2);padding:20px 22px;box-shadow:var(--shadow)}
.tmini .q p{font-size:14.5px;line-height:1.5;margin-bottom:12px}
.tmini .q .who{display:flex;align-items:center;gap:10px}
.tmini .q .who img{width:34px;height:34px;border-radius:50%;object-fit:cover}
.tmini .q .who b{font-size:13px}
@media(max-width:820px){.tlead{grid-template-columns:1fr}}

/* ============ B2B ============ */
.b2b{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:42px}
.b2b__card{border:1px solid oklch(94% 0.012 80 / .14);border-radius:var(--r-3);padding:34px 32px;background:oklch(94% 0.012 80 / .03)}
.b2b__card h3{margin-bottom:.4em}
.b2b__card p{color:var(--on-dark-2);font-size:15px;margin-bottom:22px}
@media(max-width:760px){.b2b{grid-template-columns:1fr}}

/* ============ VISIT ============ */
.visit{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,60px);align-items:center}
.visit__map{aspect-ratio:16/12;border-radius:var(--r-3);overflow:hidden;box-shadow:var(--shadow);position:relative;
  background:linear-gradient(135deg,oklch(92% 0.02 82),oklch(86% 0.03 78));display:grid;place-items:center}
.visit__map .pin{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--gold-ink);font-size:13px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.visit dl{display:grid;grid-template-columns:auto 1fr;gap:12px 20px;margin:24px 0 28px}
.visit dt{font-size:12.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-3);padding-top:2px}
.visit dd{font-size:16px}
.visit a.link{color:var(--gold-ink);font-weight:600}
@media(max-width:760px){.visit{grid-template-columns:1fr}.visit__map{order:-1}}

/* ============ FOOTER ============ */
.foot{background:var(--dark);color:var(--on-dark-2);padding-block:60px calc(120px + env(safe-area-inset-bottom))}
.foot__top{display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap}
.foot__mark{height:40px;width:auto;display:block}
.foot__brand b{font-family:var(--serif);color:var(--on-dark);font-size:22px;display:block;margin-top:14px}
.foot__cols{display:flex;gap:56px;flex-wrap:wrap}
.foot__cols h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-weight:700}
.foot__cols a{display:block;font-size:14px;padding:5px 0;transition:color var(--d-fast)}
@media(hover:hover){.foot__cols a:hover{color:var(--on-dark)}}
.foot__legal{margin-top:46px;padding-top:24px;border-top:1px solid oklch(94% 0.012 80 / .1);font-size:12.5px;color:oklch(70% 0.012 76);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ============ MOBILE STICKY BAR ============ */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;gap:10px;padding:12px var(--gutter);
  padding-bottom:calc(12px + env(safe-area-inset-bottom));
  background:oklch(97.6% 0.009 82 / .9);backdrop-filter:saturate(180%) blur(20px);border-top:1px solid var(--line)}
.mbar .btn{flex:1}
@media(max-width:920px){.mbar{display:flex}body{padding-bottom:80px}}

/* ============ LANDING-PAGE COMPONENTS (reused across service LPs) ============ */
.lp-hero{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,5vw,68px);align-items:center;padding-top:clamp(28px,5vw,64px)}
.lp-hero h1{max-width:13ch;margin:.1em 0 .35em}
.lp-hero .lede{margin-bottom:30px}
.lp-hero__cta{display:flex;gap:13px;flex-wrap:wrap}
.lp-hero__proof{display:flex;align-items:center;gap:18px;margin-top:26px;flex-wrap:wrap;color:var(--ink-2);font-size:14px}
.lp-hero__proof b{color:var(--ink)}
@media(max-width:820px){.lp-hero{grid-template-columns:1fr}.lp-hero__media{order:-1}}

/* passport-photo "deliverable" card */
.passcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-3);box-shadow:var(--shadow-lg);padding:26px;display:grid;gap:18px;max-width:420px;margin-inline:auto}
.passcard__frame{position:relative;aspect-ratio:35/45;border-radius:14px;overflow:hidden;background:#fff;outline:2px dashed var(--gold);outline-offset:6px}
.passcard__frame img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.passcard__dim{position:absolute;top:10px;right:10px;background:oklch(20% 0.02 60 / .72);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px}
.passcard__checks{display:grid;gap:9px}
.passcard__checks li{list-style:none;display:flex;align-items:center;gap:10px;font-size:14.5px;font-weight:500;color:var(--ink)}
.passcard__checks svg{width:19px;height:19px;color:oklch(64% 0.16 150);flex:none}

/* quick-facts row */
.factrow{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:46px}
.fact{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-2);padding:22px 20px;box-shadow:var(--shadow)}
.fact b{font-family:var(--sans);font-size:30px;font-weight:600;display:block;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.fact span{font-size:13.5px;color:var(--ink-2);margin-top:6px;display:block;line-height:1.35}
@media(max-width:760px){.factrow{grid-template-columns:repeat(2,minmax(0,1fr))}.fact b{font-size:25px}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px;counter-reset:step}
.step{position:relative;padding:28px 24px;border-radius:var(--r-2);background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow)}
.step::before{counter-increment:step;content:counter(step);display:grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:var(--gold-soft);color:var(--gold-ink);font-weight:700;font-size:17px;margin-bottom:16px;font-variant-numeric:tabular-nums}
.step h3{font-size:19px;margin-bottom:.35em}
.step p{font-size:15px;color:var(--ink-2);line-height:1.5}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* spec chips */
.speclist{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.speclist span{font-size:14.5px;font-weight:600;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:var(--r-pill);padding:9px 16px}

/* FAQ (native disclosure) */
.faq{max-width:var(--mid);margin-top:36px;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-family:var(--serif);font-size:clamp(18px,2vw,21px);font-weight:500;color:var(--ink);transition:color var(--d-fast)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";width:13px;height:13px;flex:none;border-right:2px solid var(--ink-3);border-bottom:2px solid var(--ink-3);
  transform:rotate(45deg);transition:transform var(--d-mid) var(--ease-out-quart);margin-top:-4px}
.faq details[open] summary::after{transform:rotate(-135deg);margin-top:4px}
.faq details[open] summary{color:var(--gold-ink)}
.faq__a{padding:0 0 22px;color:var(--ink-2);font-size:16px;line-height:1.6;max-width:62ch;animation:panelin var(--d-mid) var(--ease-out-quart)}
@media (hover:hover){.faq summary:hover{color:var(--gold-ink)}}

/* CTA band */
.ctaband{text-align:center}
.ctaband h2{margin-bottom:.4em}
.ctaband .lp-hero__cta{justify-content:center}

/* ============ REVEAL (cards/groups only, never whole sections) ============ */
.reveal{opacity:0;transform:translateY(8px);filter:blur(6px)}
.reveal.in{opacity:1;transform:none;filter:none;
  transition:opacity var(--d-slow) var(--ease-out-expo), transform var(--d-slow) var(--ease-out-expo), filter var(--d-slow) var(--ease-out-expo);
  transition-delay:calc(var(--i,0) * 55ms)}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .reveal{opacity:1;transform:none;filter:none}
  .marquee__track{animation:none}
}
