/* Primarch SEO — shared styles */
:root{
  --ink:#0c1322;        /* near-black navy */
  --ink-2:#1a2438;
  --slate:#48566f;
  --mist:#6b7891;
  --line:#e4e8f0;
  --paper:#ffffff;
  --paper-2:#f6f8fc;
  --amber:#e08a2b;      /* warm accent */
  --amber-dk:#b96d18;
  --max:1120px;
  --r:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{font-family:"Space Grotesk","Inter",sans-serif;letter-spacing:-.02em;line-height:1.1}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);
  backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:10px;font-family:"Space Grotesk";font-weight:700;font-size:18px}
.brand .mark{width:26px;height:26px;flex:0 0 auto}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{color:var(--slate);font-size:14.5px;font-weight:500}
.nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--ink);color:#fff!important;padding:9px 18px;border-radius:8px;font-size:14px;font-weight:600}
.nav-cta:hover{background:var(--ink-2)}
.menu-btn{display:none;background:none;border:0;cursor:pointer;font-size:24px;color:var(--ink)}

/* ---- buttons ---- */
.btn{display:inline-block;padding:14px 26px;border-radius:8px;font-weight:600;font-size:15px;cursor:pointer;transition:transform .15s,background .15s}
.btn-amber{background:var(--amber);color:#fff}
.btn-amber:hover{background:var(--amber-dk);transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--line);color:var(--ink);background:#fff}
.btn-ghost:hover{border-color:var(--slate)}
/* ghost button placed on the dark hero */
.hero .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.hero .btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:96px 0 104px}
.hero .grid-bg{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(ellipse 80% 70% at 70% 30%,#000 30%,transparent 75%)}
.hero .pin{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--amber);
  box-shadow:0 0 0 6px rgba(224,138,43,.18)}
.hero-inner{position:relative;max-width:720px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--amber);margin-bottom:22px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--amber)}
.hero h1{font-size:clamp(2.4rem,5.2vw,4rem);font-weight:600;margin-bottom:22px}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero p{font-size:clamp(1.05rem,1.6vw,1.25rem);color:#aeb8cc;max-width:560px;margin-bottom:34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ---- sections ---- */
section{padding:88px 0}
.sec-head{max-width:640px;margin-bottom:54px}
.sec-head .eyebrow{color:var(--amber-dk)}
.sec-head .eyebrow::before{background:var(--amber-dk)}
.sec-head h2{font-size:clamp(1.9rem,3.4vw,2.6rem);font-weight:600;margin-bottom:16px}
.sec-head p{color:var(--slate);font-size:1.08rem}
.alt{background:var(--paper-2)}

/* ---- services ---- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px;
  transition:border-color .18s,transform .18s,box-shadow .18s}
.svc:hover{border-color:var(--amber);transform:translateY(-3px);box-shadow:0 14px 40px -22px rgba(12,19,34,.4)}
.svc .ix{font-family:"Space Grotesk";font-size:13px;font-weight:700;color:var(--amber);letter-spacing:.05em}
.svc h3{font-size:1.4rem;font-weight:600;margin:14px 0 10px}
.svc p{color:var(--slate);font-size:.98rem;margin-bottom:16px}
.svc ul{list-style:none}
.svc li{position:relative;padding-left:22px;color:var(--ink-2);font-size:.93rem;margin-bottom:7px}
.svc li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:2px;background:var(--amber)}

/* ---- process / steps ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step{padding:26px;border-left:2px solid var(--line)}
.step .n{font-family:"Space Grotesk";font-size:30px;font-weight:700;color:var(--amber);line-height:1}
.step h3{font-size:1.15rem;font-weight:600;margin:12px 0 8px}
.step p{color:var(--slate);font-size:.95rem}

/* ---- about ---- */
.about-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:54px;align-items:start}
.about-grid p{color:var(--slate);margin-bottom:18px;font-size:1.05rem}
.about-grid p strong{color:var(--ink)}
.facts{background:var(--ink);color:#fff;border-radius:var(--r);padding:30px}
.facts h3{font-size:1.1rem;margin-bottom:20px;color:#fff}
.facts dl{display:grid;gap:16px}
.facts dt{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--amber)}
.facts dd{font-size:.98rem;color:#cdd5e4;margin-top:2px}

/* ---- contact / calendly ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.contact-card p{color:var(--slate);margin-bottom:22px}
.contact-line{display:flex;align-items:center;gap:12px;margin-bottom:14px;font-size:1rem}
.contact-line a{color:var(--amber-dk);font-weight:600}
.calendly-inline-widget{min-width:320px;height:680px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}

/* ---- faq ---- */
.faq{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 4px;font-family:"Space Grotesk",sans-serif;font-size:1.12rem;
  font-weight:600;color:var(--ink);line-height:1.3}
.faq-q:hover{color:var(--amber-dk)}
.faq-q .ico{flex:0 0 auto;width:22px;height:22px;position:relative;transition:transform .25s}
.faq-q .ico::before,.faq-q .ico::after{content:"";position:absolute;background:var(--amber);
  top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-q .ico::before{width:14px;height:2px}
.faq-q .ico::after{width:2px;height:14px;transition:transform .25s}
.faq-item[open] .faq-q .ico::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{overflow:hidden;color:var(--slate);font-size:1rem;line-height:1.65;
  padding:0 4px 24px;max-width:680px}
.faq-a a{color:var(--amber-dk);font-weight:600}
/* native details marker off */
.faq-item summary{list-style:none}
.faq-item summary::-webkit-details-marker{display:none}

/* ---- cta band ---- */
.band{background:var(--ink);color:#fff;text-align:center;border-radius:16px;padding:60px 32px;position:relative;overflow:hidden}
.band h2{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:600;margin-bottom:14px;position:relative}
.band p{color:#aeb8cc;margin-bottom:28px;position:relative}

/* ---- footer ---- */
footer{border-top:1px solid var(--line);padding:48px 0;color:var(--mist);font-size:14px}
.foot-grid{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.foot-links{display:flex;gap:22px;flex-wrap:wrap}
.foot-links a:hover{color:var(--ink)}

/* ---- legal pages ---- */
.legal{max-width:760px;margin:0 auto;padding:64px 24px}
.legal h1{font-size:2.2rem;margin-bottom:8px}
.legal .updated{color:var(--mist);font-size:14px;margin-bottom:36px}
.legal h2{font-size:1.3rem;margin:34px 0 12px}
.legal h3{font-size:1.05rem;margin:22px 0 8px}
.legal p,.legal li{color:var(--slate);margin-bottom:12px}
.legal ul{padding-left:22px;margin-bottom:12px}
.legal a{color:var(--amber-dk);font-weight:600}

/* ---- responsive ---- */
@media(max-width:820px){
  .nav-links{position:fixed;inset:66px 0 auto 0;flex-direction:column;background:#fff;
    border-bottom:1px solid var(--line);padding:18px 24px;gap:18px;display:none}
  .nav-links.open{display:flex}
  .menu-btn{display:block}
  .svc-grid,.steps,.about-grid,.contact-grid{grid-template-columns:1fr}
  .calendly-inline-widget{height:1000px}
}
