/* Dune — shared site design system (used by all standalone pages: about, services, portfolio, process, contact, faq) */
:root{
  --navy:#12122A; --navy2:#1b1b3d; --navy3:#26264f;
  --gold:#D3A64B; --gold2:#E7C877;
  --ink:#14142b; --muted:#5c5c74; --line:#e7e6ef;
  --cream:#faf9f6; --soft:#f7f6f2; --white:#fff; --green:#1f9d6b;
  --radius:16px; --maxw:1160px;
  --sh-1:0 1px 3px rgba(16,24,40,.06),0 1px 2px rgba(16,24,40,.04);
  --sh-2:0 4px 12px -4px rgba(16,24,40,.10),0 2px 6px -2px rgba(16,24,40,.06);
  --sh-3:0 20px 48px -14px rgba(16,24,40,.22),0 8px 20px -8px rgba(16,24,40,.12);
  --s2:8px;--s3:12px;--s4:16px;--s6:24px;--s8:32px;--s12:48px;--s16:64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Sora',sans-serif;line-height:1.14;letter-spacing:-.02em;color:var(--navy)}
h1{font-size:clamp(32px,5.2vw,52px)}
h2{font-size:clamp(26px,3.6vw,38px)}
h3{font-size:20px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:'Sora',sans-serif;font-weight:600;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.muted{color:var(--muted)}
.lead{font-size:clamp(16px,2vw,19px);color:var(--muted);max-width:640px}
section.pad{padding:clamp(56px,8vw,96px) 0}
.center{text-align:center}.mx-auto{margin-left:auto;margin-right:auto}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Sora',sans-serif;font-weight:600;font-size:15px;padding:13px 24px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.2s;min-height:46px}
.btn svg{width:17px;height:17px}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--navy)}
.btn-gold:hover{filter:brightness(1.05);box-shadow:var(--sh-2);transform:translateY(-1px)}
.btn-dark{background:var(--navy);color:#fff}.btn-dark:hover{background:var(--navy2);transform:translateY(-1px)}
.btn-ghost{border-color:var(--line);color:var(--navy)}.btn-ghost:hover{border-color:var(--gold)}
.btn:active{transform:translateY(0)}

/* header / nav */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:saturate(1.3) blur(10px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Sora',sans-serif;font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--navy)}
.brand img{width:30px;height:30px;border-radius:8px}
.brand b{color:var(--gold)}
.navlinks{display:flex;align-items:center;gap:26px}
.navlinks a{font-weight:500;font-size:14.5px;color:var(--navy);transition:.15s}
.navlinks a:hover,.navlinks a[aria-current="page"]{color:var(--gold)}
.navcta{display:flex;align-items:center;gap:12px}
.navcta .btn{padding:9px 18px;font-size:14px;min-height:40px}
.menu-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:11px;background:#fff;cursor:pointer}
.menu-toggle svg{width:22px;height:22px;stroke:var(--navy)}

/* page hero band */
.phero{background:linear-gradient(180deg,var(--soft),#fff);border-bottom:1px solid var(--line)}
.phero .wrap{padding-top:clamp(48px,7vw,84px);padding-bottom:clamp(40px,6vw,72px)}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:14px}
.crumbs a:hover{color:var(--gold)}

/* cards / grid */
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--sh-1);transition:.2s}
.card:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.icon-chip{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(211,166,75,.14);color:var(--gold);margin-bottom:14px}
.icon-chip svg{width:22px;height:22px}

/* footer */
footer.site{background:var(--navy);color:#c9c9de;padding:56px 0 28px}
footer.site .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
footer.site .fbrand{color:#fff}
footer.site h4{color:#fff;font-size:14px;margin-bottom:14px;font-family:'Sora',sans-serif}
footer.site a{display:block;padding:6px 0;color:#b4b4cd;font-size:14px;min-height:34px}
footer.site a:hover{color:var(--gold2)}
.fbottom{border-top:1px solid rgba(255,255,255,.1);margin-top:36px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#8a8aa6}

/* accessibility + motion */
a:focus-visible,button:focus-visible,.btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:8px}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}html{scroll-behavior:auto}}

/* mobile */
@media(max-width:860px){
  .navlinks,.navcta .btn-ghost{display:none}
  .menu-toggle{display:flex}
  header.site .wrap{height:60px}
  .g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:1fr}.g2{grid-template-columns:1fr}
  footer.site .wrap{grid-template-columns:1fr 1fr}
  .mobile-nav{display:none;flex-direction:column;padding:8px 24px 18px;border-bottom:1px solid var(--line);background:#fff}
  .mobile-nav.open{display:flex}
  .mobile-nav a{padding:12px 0;font-weight:600;color:var(--navy);border-bottom:1px solid var(--line);min-height:44px;display:flex;align-items:center}
  .mobile-nav .btn{margin-top:12px;width:100%;justify-content:center}
}
@media(min-width:861px){.mobile-nav{display:none}}
@media(max-width:520px){footer.site .wrap{grid-template-columns:1fr}}

/* ===== motion / "alive" layer (Wix-inspired scroll + live movement) ===== */
.reveal-init{opacity:0;transform:translateY(22px);will-change:opacity,transform}
.reveal-in{opacity:1!important;transform:none!important;transition:opacity .6s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.float{animation:floaty 4.5s ease-in-out infinite}
.float.d1{animation-delay:.6s}.float.d2{animation-delay:1.2s}
.marquee{overflow:hidden;position:relative;-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:22px;width:max-content;animation:marq 46s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}
.card,.pf-card{transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s}
.card:hover,.pf-card:hover{transform:translateY(-6px)}
@media(prefers-reduced-motion:reduce){.reveal-init{opacity:1;transform:none}.float,.marquee-track{animation:none}}
