/* Mark Edge - design system. Gold #F2C14E · Orange #F2931E · Ember #D9641A · Ink #0D0D0C */

:root{
  --ink:#0D0D0C; --ink-2:#16140F; --ink-soft:#211D15;
  --gold:#F2C14E; --gold-deep:#E7A92C; --orange:#F2931E; --ember:#D9641A;
  --cream:#F7F3EC; --bone:#FBF9F4; --sand:#EFE7D8; --slate:#1A1714;
  --muted:#6F675B; --line:#E3DACB; --line-dark:rgba(247,243,236,.14);
  --bg:var(--cream); --fg:var(--slate);

  --f-display:'Archivo',sans-serif;
  --f-head:'Archivo',sans-serif;
  --f-body:'Hanken Grotesk',sans-serif;

  --container:1280px;
  --gutter:clamp(20px,5vw,72px);
  --radius:18px; --radius-lg:28px;
  --chrome:linear-gradient(135deg,#fff6df 0%,#f2c14e 30%,#f2931e 58%,#d9641a 80%,#7a3d0e 100%);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--fg);
  font-family:var(--f-body); font-size:18px; line-height:1.62; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--orange); color:#fff; }

.wrap{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,11vw,150px); position:relative; }
.section--tight{ padding-block:clamp(48px,7vw,90px); }
.dark{ background:var(--ink); color:var(--cream); }
.dark .muted-fg{ color:#a89e8c; }
.cream{ background:var(--cream); } .bone{ background:var(--bone); } .sand{ background:var(--sand); }

/* type */
.display{ font-family:var(--f-display); font-weight:900; line-height:.98; letter-spacing:-.025em; }
h1,h2,h3,h4{ font-family:var(--f-head); font-weight:800; line-height:1.04; letter-spacing:-.02em; margin:0; }
.h-mega{ font-family:var(--f-display); font-weight:900; line-height:.98; letter-spacing:-.035em; font-size:clamp(50px,8.8vw,128px); }
.h1{ font-size:clamp(38px,6vw,84px); }
.h2{ font-size:clamp(30px,4.4vw,60px); }
.h3{ font-size:clamp(22px,2.6vw,32px); }
.lead{ font-size:clamp(18px,2vw,24px); line-height:1.5; font-weight:400; }
p{ margin:0 0 1.1em; }
.measure{ max-width:62ch; } .measure-sm{ max-width:46ch; }

.eyebrow{ font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.2em;
  font-size:12.5px; color:var(--ember); display:inline-flex; align-items:center; gap:12px; }
.eyebrow::before{ content:""; width:24px; height:2px; background:currentColor; display:inline-block; }
.dark .eyebrow{ color:var(--gold); }
.grad-text{ background:var(--chrome); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* buttons */
.btn{ --bg:var(--ink); --c:var(--cream); display:inline-flex; align-items:center; gap:11px; cursor:pointer;
  font-family:var(--f-head); font-weight:700; font-size:15px; letter-spacing:-.01em; padding:15px 26px;
  border-radius:100px; border:0; background:var(--bg); color:var(--c); white-space:nowrap;
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s, background .25s, color .25s; }
.btn svg{ width:17px; height:17px; transition:transform .25s; }
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 30px -12px rgba(0,0,0,.45); }
.btn:hover svg{ transform:translate(3px,-3px); }
.btn--gold{ --bg:var(--gold); --c:var(--ink); }
.btn--gold:hover{ box-shadow:0 14px 34px -12px var(--gold-deep); }
.btn--ghost{ --bg:transparent; --c:currentColor; border:1.5px solid currentColor; }
.btn--ghost:hover{ background:currentColor; }
.btn--ghost:hover span{ color:var(--bg); }
.btn--chrome{ background:var(--chrome); --c:var(--ink); }
.btn--lg{ padding:18px 32px; font-size:16px; }

.tlink{ font-family:var(--f-head); font-weight:700; font-size:15px; display:inline-flex; gap:9px; align-items:center;
  border-bottom:2px solid transparent; padding-bottom:3px; transition:.25s; }
.tlink:hover{ border-color:currentColor; gap:13px; }

/* nav */
.nav{ position:fixed; inset:0 0 auto 0; z-index:60; height:78px; display:flex; align-items:center;
  transition:background .35s, box-shadow .35s, height .35s; }
.nav__inner{ width:100%; max-width:1480px; margin-inline:auto; padding-inline:var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav__logo{ display:flex; align-items:center; height:46px; }
.nav__logo img{ height:42px; width:auto; }
.nav__links{ display:flex; align-items:center; gap:34px; }
.nav__links a{ font-family:var(--f-head); font-weight:600; font-size:15px; opacity:.82; position:relative; transition:opacity .2s; }
.nav__links a:hover,.nav__links a.active{ opacity:1; }
.nav__links a.active::after{ content:""; position:absolute; left:0; right:0; bottom:-7px; height:2px; background:var(--orange); }
.nav__cta{ display:flex; align-items:center; gap:14px; }
.nav--solid{ background:rgba(247,243,236,.86); backdrop-filter:blur(14px) saturate(1.3); box-shadow:0 1px 0 var(--line); height:68px; color:var(--slate); }
.nav--ondark{ color:var(--cream); }
.nav--ondark.nav--solid{ background:rgba(13,13,12,.7); box-shadow:0 1px 0 var(--line-dark); color:var(--cream); }

.burger{ display:none; width:44px; height:44px; border:0; background:transparent; cursor:pointer; color:inherit; }
.burger span{ display:block; height:2px; background:currentColor; margin:5px auto; width:26px; transition:.3s; }

.mobile-menu{ position:fixed; inset:0; z-index:70; background:var(--ink); color:var(--cream);
  transform:translateY(-100%); transition:transform .5s cubic-bezier(.7,0,.2,1); display:flex; flex-direction:column; }
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu__top{ height:78px; display:flex; align-items:center; justify-content:space-between; padding-inline:var(--gutter); }
.mobile-menu__top img{ height:38px; }
.mobile-menu nav{ flex:1; display:flex; flex-direction:column; justify-content:center; gap:4px; padding-inline:var(--gutter); }
.mobile-menu nav a{ font-family:var(--f-display); font-weight:800; font-size:clamp(34px,9vw,56px); line-height:1.08; letter-spacing:-.025em; color:var(--cream); transition:color .2s, padding .25s; }
.mobile-menu nav a:hover,.mobile-menu nav a:active{ color:var(--gold); padding-left:12px; }
.mobile-menu__foot{ padding:var(--gutter); color:#a89e8c; font-size:14px; border-top:1px solid var(--line-dark); display:flex; flex-wrap:wrap; gap:6px 22px; }
.mobile-menu__foot a{ color:var(--gold); }
.x-close{ width:46px; height:46px; border:0; background:transparent; color:inherit; cursor:pointer; font-size:30px; line-height:1; }

/* hero - minimal */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; background:var(--ink); }
.hero__canvas{ position:absolute; inset:0; width:100%; height:100%; display:block; z-index:0; }
.hero__canvas.chrome-fallback{ background:radial-gradient(120% 100% at 60% 40%, #2a200f 0%, #14110b 45%, #0d0d0c 100%); }
.hero__scrim{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(8,6,2,.7) 0%, rgba(8,6,2,.3) 45%, rgba(8,6,2,0) 80%),
            linear-gradient(180deg, rgba(8,6,2,.5) 0%, rgba(8,6,2,0) 30%, rgba(8,6,2,.45) 100%); }
.hero__inner{ position:relative; z-index:2; width:100%; padding-top:96px; padding-bottom:96px; color:var(--cream); }
.hero__inner .eyebrow{ color:var(--gold); }
.hero__title{ color:var(--cream); margin:22px 0 0; max-width:16ch; font-size:clamp(40px, min(7.4vw, 11vh), 98px); line-height:1.0; }
.hero__sub{ color:#ece4d6; max-width:46ch; margin-top:clamp(30px,4.5vh,46px); }
.hero__meta{ position:absolute; left:var(--gutter); right:var(--gutter); bottom:34px; z-index:2;
  display:flex; justify-content:space-between; gap:14px; color:#9a917f; font-family:var(--f-head); font-weight:600;
  font-size:12px; letter-spacing:.12em; text-transform:uppercase; }
@media (max-width:700px){ .hero__meta{ display:none; } }

/* sub-hero (interior pages) */
.subhero{ position:relative; background:var(--ink); color:var(--cream); overflow:hidden;
  padding-top:clamp(132px,18vh,200px); padding-bottom:clamp(56px,8vw,96px); }
.subhero__canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.subhero__canvas.chrome-fallback{ background:radial-gradient(120% 120% at 80% 0%, #2a200f, #14110b 50%, #0d0d0c 100%); }
.subhero::after{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(8,6,2,.9) 0%, rgba(8,6,2,.6) 48%, rgba(8,6,2,.2) 100%); }
.subhero__inner{ position:relative; z-index:2; }
.subhero .eyebrow{ color:var(--gold); }
.subhero h1{ color:var(--cream); margin-top:18px; }
.subhero p{ color:#ece4d6; margin-top:20px; }
.crumb{ font-family:var(--f-head); font-weight:600; font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:#9a917f; }
.crumb a{ color:#9a917f; } .crumb a:hover{ color:var(--gold); }

/* grids + cards */
.grid{ display:grid; gap:clamp(16px,2vw,26px); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.card{ background:var(--bone); border:1px solid var(--line); border-radius:var(--radius); padding:30px;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, border-color .3s; }
.card:hover{ transform:translateY(-5px); box-shadow:0 24px 50px -28px rgba(60,40,10,.4); border-color:var(--gold); }

.svc{ position:relative; padding:30px 28px 28px; border-radius:var(--radius); background:var(--bone);
  border:1px solid var(--line); overflow:hidden; transition:.35s cubic-bezier(.2,.7,.2,1); display:block; }
.svc__num{ font-family:var(--f-head); font-weight:800; font-size:13px; letter-spacing:.1em; color:var(--ember); opacity:.8; }
.svc h3{ margin:16px 0 9px; font-size:22px; }
.svc p{ font-size:15.5px; color:var(--muted); margin:0; }
.svc__icon{ width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:var(--ink); color:var(--gold); margin-bottom:6px; }
.svc__icon svg{ width:23px; height:23px; }
.svc::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:3px; background:var(--chrome); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.svc:hover{ transform:translateY(-6px); box-shadow:0 28px 56px -30px rgba(60,40,10,.45); border-color:var(--gold-deep); }
.svc:hover::after{ transform:scaleX(1); }

.svc-lg{ display:grid; gap:18px; padding:clamp(28px,3vw,42px); border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--bone); transition:.35s; }
.svc-lg:hover{ border-color:var(--gold-deep); box-shadow:0 28px 60px -34px rgba(60,40,10,.45); transform:translateY(-4px); }
.svc-lg__top{ display:flex; align-items:center; justify-content:space-between; }
.svc-lg__top .svc__icon{ width:54px; height:54px; }
.svc-lg__idx{ font-family:var(--f-display); font-weight:900; font-size:40px; color:transparent; -webkit-text-stroke:1.3px var(--line); line-height:1; }
.svc-lg h3{ font-size:clamp(23px,2.4vw,29px); }
.svc-lg p{ color:var(--muted); font-size:16.5px; margin:0; }
.svc-lg__note{ font-size:14.5px; line-height:1.5; color:var(--slate); border-top:1px dashed var(--line); padding-top:15px; margin:2px 0 0; }
.svc-lg__note b{ color:var(--ember); font-family:var(--f-head); font-weight:700; }

.stat__n{ font-family:var(--f-display); font-weight:900; font-size:clamp(50px,7.5vw,98px); line-height:.96; letter-spacing:-.035em; }
.stat__l{ font-family:var(--f-head); font-weight:600; font-size:14.5px; text-transform:uppercase; letter-spacing:.1em; opacity:.7; margin-top:8px; }

.step{ display:grid; grid-template-columns:auto 1fr; gap:26px; padding:34px 0; border-top:1px solid var(--line); align-items:start; }
.dark .step{ border-color:var(--line-dark); }
.step__n{ font-family:var(--f-display); font-weight:900; font-size:clamp(38px,5vw,68px); line-height:.9; letter-spacing:-.03em; color:transparent; -webkit-text-stroke:1.4px var(--ember); }
.dark .step__n{ -webkit-text-stroke:1.4px var(--gold); }
.step h3{ font-size:clamp(23px,3vw,36px); margin-bottom:8px; }

.work{ border-radius:var(--radius-lg); overflow:hidden; position:relative; background:var(--ink-2); aspect-ratio:4/3; display:flex; align-items:flex-end; transition:.4s; }
.work__media{ position:absolute; inset:0; }
.work__media canvas{ width:100%; height:100%; display:block; }
.work__body{ position:relative; z-index:2; padding:26px; color:#fff; width:100%; background:linear-gradient(to top,rgba(8,6,2,.82),transparent); }
.work__tag{ font-family:var(--f-head); font-weight:700; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); }
.work h3{ font-size:clamp(21px,2.4vw,29px); margin-top:6px; color:#fff; }
.work:hover{ transform:translateY(-5px); }

.quote{ background:var(--bone); border:1px solid var(--line); border-radius:var(--radius-lg); padding:38px 34px; }
.quote p{ font-family:var(--f-head); font-weight:600; font-size:clamp(18px,1.6vw,22px); line-height:1.42; letter-spacing:-.01em; }
.quote__by{ display:flex; align-items:center; gap:13px; margin-top:20px; }
.quote__av{ width:46px; height:46px; border-radius:50%; background:var(--chrome); }
.quote__by b{ font-family:var(--f-head); display:block; font-size:15px; }
.quote__by span{ font-size:13.5px; color:var(--muted); }

.marquee{ overflow:hidden; border-block:1px solid var(--line-dark); }
.marquee__t{ display:inline-flex; gap:44px; padding-block:20px; white-space:nowrap; animation:scrollx 32s linear infinite; }
.marquee__t span{ font-family:var(--f-display); font-weight:900; font-size:clamp(20px,2.7vw,34px); letter-spacing:-.02em; color:var(--cream); opacity:.9; display:inline-flex; gap:44px; align-items:center; }
.marquee__t span::after{ content:"✦"; color:var(--gold); font-size:.55em; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }

.pills{ display:flex; flex-wrap:wrap; gap:10px; }
.pill{ font-family:var(--f-head); font-weight:600; font-size:13.5px; padding:8px 16px; border-radius:100px; border:1px solid var(--line); background:var(--bone); }
.dark .pill{ border-color:var(--line-dark); background:rgba(247,243,236,.05); color:var(--cream); }

.head-block{ display:grid; gap:18px; margin-bottom:clamp(36px,5vw,64px); }

/* faq */
.faq details{ border-top:1px solid var(--line); }
.faq details:last-child{ border-bottom:1px solid var(--line); }
.faq summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:20px; padding:26px 0; font-family:var(--f-head); font-weight:700; font-size:clamp(18px,2vw,24px); letter-spacing:-.01em; color:var(--slate); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .ico{ width:32px; height:32px; flex-shrink:0; border-radius:50%; border:1.5px solid var(--line); position:relative; transition:.3s; }
.faq summary .ico::before,.faq summary .ico::after{ content:""; position:absolute; inset:0; margin:auto; background:currentColor; }
.faq summary .ico::before{ width:13px; height:2px; }
.faq summary .ico::after{ width:2px; height:13px; transition:.3s; }
.faq details[open] summary .ico{ background:var(--ink); color:var(--gold); border-color:var(--ink); }
.faq details[open] summary .ico::after{ transform:scaleY(0); }
.faq p{ color:var(--muted); margin:0 0 26px; max-width:72ch; font-size:16.5px; }

.field{ display:grid; gap:8px; margin-bottom:20px; }
.field label{ font-family:var(--f-head); font-weight:600; font-size:14px; }
.field input,.field textarea,.field select{ font-family:var(--f-body); font-size:16px; padding:14px 16px; border-radius:12px; border:1.5px solid var(--line); background:var(--bone); color:var(--slate); transition:.2s; width:100%; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--orange); box-shadow:0 0 0 4px rgba(242,147,30,.14); }
.field textarea{ resize:vertical; min-height:130px; }

.info-tile{ display:grid; gap:6px; padding:24px; border-radius:var(--radius); border:1px solid var(--line-dark); background:rgba(247,243,236,.04); }
.info-tile h4{ font-family:var(--f-head); font-weight:700; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.info-tile a,.info-tile p{ color:var(--cream); margin:0; font-size:16px; }

.value{ padding:28px 0; border-top:1px solid var(--line); }
.value h3{ font-size:clamp(21px,2.4vw,29px); margin-bottom:10px; }
.value p{ color:var(--muted); margin:0; }

/* footer */
.footer{ background:var(--ink); color:var(--cream); padding-block:clamp(60px,8vw,100px) 34px; }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.footer h4{ font-family:var(--f-head); font-weight:700; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.footer a{ color:#cfc6b6; display:block; padding:6px 0; transition:color .2s, padding .2s; font-size:15.5px; }
.footer a:hover{ color:var(--cream); padding-left:5px; }
.footer__logo img{ height:46px; margin-bottom:20px; }
.footer__bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; margin-top:54px; padding-top:26px; border-top:1px solid var(--line-dark); font-size:13.5px; color:#8d8474; }
.footer__cta{ font-family:var(--f-display); font-weight:900; font-size:clamp(40px,6.5vw,100px); line-height:.98; letter-spacing:-.035em; margin-bottom:30px; }
.cta-band{ text-align:center; }
.cta-band .display{ font-size:clamp(40px,8vw,120px); }

/* reveal - progressive enhancement: visible by default, hidden only once JS arms it */
.reveal{ transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal-enabled .reveal{ opacity:0; transform:translateY(26px); }
.reveal-enabled .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; }
@media (prefers-reduced-motion:reduce){ .reveal-enabled .reveal{ opacity:1; transform:none; } *{ scroll-behavior:auto; } }

/* responsive */
@media (max-width:1080px){ .footer__grid{ grid-template-columns:1fr 1fr; gap:34px; } }
@media (max-width:880px){
  .nav__links{ display:none; } .nav__cta .btn{ display:none; } .burger{ display:block; }
  .cols-4,.cols-3{ grid-template-columns:repeat(2,1fr); }
  #contact-grid{ grid-template-columns:1fr !important; }
  #faq-grid{ grid-template-columns:1fr !important; }
}
@media (max-width:620px){
  body{ font-size:17px; }
  .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .step{ grid-template-columns:1fr; gap:8px; }
  .section{ padding-block:clamp(60px,16vw,90px); }
}

.center{ text-align:center; } .mx-auto{ margin-inline:auto; }
.mt-s{ margin-top:14px; } .mt-m{ margin-top:26px; } .mt-l{ margin-top:44px; }
.row{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.between{ justify-content:space-between; }
.gold{ color:var(--gold); } .orange{ color:var(--orange); } .ember{ color:var(--ember); }
.op70{ opacity:.7; } .op60{ opacity:.6; }
