/* ============================================================
   PACIFIC EDGE — design tokens
   Each value is a CSS custom property so the whole theme can be
   re-skinned from one place (and maps cleanly to WP theme.json).
   ============================================================ */
:root{
  /* Palette — grounded in the Columbia River + high-desert sunset */
  --ink:        #0E2025;   /* deep river slate (near-black) */
  --ink-soft:   #16323a;
  --river:      #0E8587;   /* confluence teal — primary accent */
  --river-deep: #0A6B6D;
  --river-bright:#37C2BE;
  --sunset:     #E07A43;   /* golden-hour amber — warm/local accent */
  --sunset-soft:#F6E4D7;
  --paper:      #FCFCFB;   /* main background (cool near-white) */
  --sand:       #F3EEE3;   /* warm alt-section background */
  --mist:       #E4EBE9;   /* hairlines / card borders */
  --stone:      #54625F;   /* muted body text */
  --stone-soft: #7E8C89;

  /* Type */
  --display: "Bricolage Grotesque", system-ui, sans-serif;
  --body:    "Hanken Grotesk", system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, monospace;

  /* Scale & rhythm */
  --maxw: 1180px;
  --pad: clamp(20px, 5vw, 64px);
  --radius: 18px;
  --radius-sm: 12px;
  --shadow: 0 1px 2px rgba(14,32,37,.04), 0 12px 32px -12px rgba(14,32,37,.14);
  --shadow-lift: 0 1px 2px rgba(14,32,37,.05), 0 24px 48px -16px rgba(14,32,37,.22);
}

/* ============================================================ Reset */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);line-height:1.04;letter-spacing:-.02em;font-weight:700}

/* ============================================================ Layout utils */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,128px)}
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--river-deep);font-weight:600;
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--river)}
.lede{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--stone);max-width:60ch}

/* ============================================================ Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--body);font-weight:600;font-size:.98rem;
  padding:.85em 1.4em;border-radius:999px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  cursor:pointer;border:1px solid transparent;white-space:nowrap;
}
.btn-primary{background:var(--river);color:#fff;box-shadow:0 8px 20px -8px rgba(14,133,135,.6)}
.btn-primary:hover{transform:translateY(-2px);background:var(--river-deep);box-shadow:0 14px 28px -10px rgba(14,133,135,.7)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--mist)}
.btn-ghost:hover{border-color:var(--river);color:var(--river-deep);transform:translateY(-2px)}
.btn-lg{padding:1.05em 1.8em;font-size:1.05rem}

/* ============================================================ Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(252,252,251,.82);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s;
}
.site-header.scrolled{border-bottom-color:var(--mist);box-shadow:0 4px 20px -16px rgba(14,32,37,.4)}
.nav{display:flex;align-items:center;gap:2rem;height:72px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--display);font-weight:800;font-size:1.18rem;letter-spacing:-.03em}
.brand .mark{flex:0 0 auto}
.nav-links{display:flex;gap:1.6rem;margin-left:auto;align-items:center}
.nav-links a{font-size:.94rem;font-weight:500;color:var(--ink);position:relative;padding:.2em 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--river);transition:width .22s ease}
.nav-links a:hover{color:var(--river-deep)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-phone{font-family:var(--mono);font-weight:600;font-size:.92rem;color:var(--ink);display:flex;align-items:center;gap:.4rem;white-space:nowrap}
.nav-phone:hover{color:var(--river-deep)}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--ink)}

/* ============================================================ Hero */
.hero{position:relative;overflow:hidden;padding-top:clamp(40px,6vw,72px);padding-bottom:clamp(40px,6vw,80px)}
.hero h1{
  font-size:clamp(2.5rem,5.6vw,4.4rem);font-weight:800;letter-spacing:-.035em;
  margin:.5em 0 .55em;
}
.hero h1 em{font-style:normal;color:var(--river)}
.hero .lede{margin-bottom:2rem}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;align-items:center}
.hero-trust{margin-top:2.2rem;display:flex;gap:1.6rem;flex-wrap:wrap}
.hero-trust .ht{display:flex;flex-direction:column;gap:.1rem}
.hero-trust .num{font-family:var(--display);font-weight:700;font-size:1.7rem;letter-spacing:-.02em}
.hero-trust .lbl{font-size:.8rem;color:var(--stone);font-weight:500}

/* Hero illustration — bleeds in behind the copy, edges gradiented into the page */
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-bg img{position:absolute;top:50%;right:-3%;transform:translateY(-50%);
  width:clamp(640px,70%,1100px);height:auto;max-width:none;
  opacity:0;animation:heroImg 1.1s ease .25s forwards;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 48%,#000 100%),linear-gradient(180deg,transparent 0%,#000 15%,#000 85%,transparent 100%);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(90deg,transparent 0%,#000 48%,#000 100%),linear-gradient(180deg,transparent 0%,#000 15%,#000 85%,transparent 100%);
  mask-composite:intersect}
@keyframes heroImg{to{opacity:1}}
/* paper scrim keeps the headline crisp; the bridge emerges to the right */
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,var(--paper) 0%,var(--paper) 24%,rgba(252,252,251,0) 58%)}
.hero-inner{position:relative;z-index:1}
.hero-copy{max-width:560px}

/* ============================================================ Local roots */
.roots{background:var(--ink);color:#EAF2F0;position:relative;overflow:hidden}
.roots::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 85% -10%, rgba(224,122,67,.16), transparent 55%),
             radial-gradient(90% 70% at 0% 110%, rgba(55,194,190,.14), transparent 55%)}
.roots .wrap{position:relative}
.roots .eyebrow{color:var(--river-bright)}
.roots .eyebrow::before{background:var(--river-bright)}
.roots h2{font-size:clamp(2rem,4vw,3.1rem);font-weight:700;color:#fff;margin:.6rem 0 1.1rem;max-width:18ch}
.roots .lede{color:#B9CCC8;max-width:54ch}
.roots-body{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,64px);align-items:start}
.roots-cards{display:grid;gap:1rem;margin-top:1rem}
.root-card{display:flex;gap:1rem;padding:1.2rem 1.3rem;border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-sm);background:rgba(255,255,255,.03);transition:background .2s,border-color .2s}
.root-card:hover{background:rgba(255,255,255,.06);border-color:rgba(55,194,190,.4)}
.root-card .ic{flex:0 0 auto;color:var(--river-bright);margin-top:.15rem}
.root-card h3{font-size:1.05rem;color:#fff;margin-bottom:.25rem;font-weight:600;font-family:var(--body);letter-spacing:0}
.root-card p{font-size:.92rem;color:#A9BDB9;line-height:1.5}
.editable{outline:1px dashed rgba(224,122,67,.5);outline-offset:3px}

/* ============================================================ Services */
.services .head{display:flex;justify-content:space-between;align-items:end;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}
.services h2{font-size:clamp(2rem,4vw,3rem);font-weight:700;max-width:14ch}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.svc{
  border:1px solid var(--mist);border-radius:var(--radius);padding:1.6rem;background:#fff;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;position:relative;
}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);border-color:transparent}
.svc .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--sunset-soft);color:var(--sunset);margin-bottom:1.1rem}
.svc:nth-child(3n+2) .ic{background:#DFF1F0;color:var(--river-deep)}
.svc:nth-child(3n) .ic{background:#E7EDEB;color:var(--ink-soft)}
.svc h3{font-size:1.18rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.01em}
.svc p{font-size:.93rem;color:var(--stone);line-height:1.55}

/* ============================================================ Compare */
.compare{background:var(--sand)}
.compare h2{font-size:clamp(2rem,4vw,3rem);font-weight:700;text-align:center;max-width:20ch;margin:0 auto 3rem}
.compare h2 em{font-style:normal;color:var(--river)}
.cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;max-width:920px;margin-inline:auto}
.cmp-col{background:#fff;border-radius:var(--radius);padding:2rem;border:1px solid var(--mist)}
.cmp-col.them{background:transparent;border-style:dashed}
.cmp-col.us{border:1px solid var(--river);box-shadow:var(--shadow)}
.cmp-col h3{font-size:1.25rem;display:flex;align-items:center;gap:.6rem;margin-bottom:1.3rem;font-weight:700}
.cmp-col.us h3{color:var(--river-deep)}
.cmp-list{list-style:none;display:grid;gap:.8rem}
.cmp-list li{display:flex;gap:.7rem;font-size:.95rem;align-items:flex-start;line-height:1.45}
.cmp-list .x{color:var(--stone-soft);flex:0 0 auto;margin-top:.15rem}
.cmp-list.them li{color:var(--stone)}
.cmp-list .c{color:var(--river);flex:0 0 auto;margin-top:.15rem}

/* ============================================================ Proof / testimonials */
.proof .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:4rem;
  border-block:1px solid var(--mist);padding-block:2.4rem}
.stat{text-align:center}
.stat .n{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,4.5vw,3.4rem);
  color:var(--ink);letter-spacing:-.03em;line-height:1}
.stat .n span{color:var(--river)}
.stat .l{font-size:.85rem;color:var(--stone);margin-top:.4rem;font-weight:500}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.quote{background:#fff;border:1px solid var(--mist);border-radius:var(--radius);padding:1.7rem;
  display:flex;flex-direction:column;gap:1rem}
.quote .stars{color:var(--sunset);letter-spacing:2px;font-size:.95rem}
.quote p{font-size:.97rem;color:var(--ink-soft);line-height:1.55}
.quote .who{font-family:var(--mono);font-size:.78rem;color:var(--stone);letter-spacing:.04em;text-transform:uppercase}

/* ============================================================ Team */
.team{background:var(--ink);color:#EAF2F0}
.team .eyebrow{color:var(--river-bright)}
.team .eyebrow::before{background:var(--river-bright)}
.team h2{color:#fff;font-size:clamp(2rem,4vw,3rem);font-weight:700;margin:.6rem 0 .8rem}
.team .lede{color:#B9CCC8}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem}
.member{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);
  padding:1.3rem;transition:background .2s,transform .2s}
.member:hover{background:rgba(255,255,255,.07);transform:translateY(-3px)}
.member .av{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--river),var(--river-bright));
  display:grid;place-items:center;font-family:var(--display);font-weight:700;color:#fff;font-size:1.2rem;margin-bottom:.9rem}
.member:nth-child(even) .av{background:linear-gradient(135deg,var(--sunset),#EFA877)}
.member h3{font-size:1.02rem;color:#fff;font-weight:600;font-family:var(--body);letter-spacing:0}
.member p{font-size:.82rem;color:#9FB4B0;margin-top:.15rem}

/* ============================================================ CTA */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--river-deep),var(--river));color:#fff}
.cta-band::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(75% 90% at 88% 12%, rgba(224,122,67,.42), transparent 60%)}
.cta-inner{position:relative;display:grid;grid-template-columns:1.3fr .7fr;gap:3rem;align-items:center}
.cta-band h2{font-size:clamp(2rem,4vw,3.1rem);font-weight:800;color:#fff;max-width:16ch;line-height:1.05}
.cta-band p{color:rgba(255,255,255,.9);margin:1rem 0 1.8rem;max-width:46ch}
.cta-band .btn-primary{background:#fff;color:var(--river-deep)}
.cta-band .btn-primary:hover{background:var(--sand)}
.cta-pill{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;
  background:rgba(255,255,255,.15);padding:.5em 1em;border-radius:999px;margin-bottom:1.2rem}
.cta-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);
  padding:1.6rem;backdrop-filter:blur(6px)}
.cta-card .big{font-family:var(--display);font-size:2.4rem;font-weight:800;line-height:1}
.cta-card ul{list-style:none;margin-top:1rem;display:grid;gap:.6rem}
.cta-card li{display:flex;gap:.5rem;font-size:.9rem;align-items:center}

/* ============================================================ Footer */
.site-footer{background:var(--ink);color:#9FB4B0;padding-block:clamp(48px,6vw,80px) 2rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2.5rem;margin-bottom:3rem}
.foot-brand{display:flex;align-items:center;gap:.6rem;color:#fff;font-family:var(--display);font-weight:800;font-size:1.2rem;margin-bottom:1rem}
.site-footer p{font-size:.9rem;line-height:1.6}
.foot-col h4{color:#fff;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-family:var(--mono);font-weight:600;margin-bottom:1rem}
.foot-col a{display:block;font-size:.92rem;padding:.25rem 0;color:#9FB4B0}
.foot-col a:hover{color:var(--river-bright)}
.foot-contact .row{display:flex;gap:.6rem;margin-bottom:.8rem;font-size:.92rem;align-items:flex-start}
.foot-contact .ic{color:var(--river-bright);flex:0 0 auto;margin-top:.15rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.6rem;display:flex;
  justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem}
.foot-bottom .lic{font-family:var(--mono);color:var(--stone-soft)}
.socials{display:flex;gap:.7rem}
.socials a{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.18);
  display:grid;place-items:center;color:#9FB4B0;transition:.2s}
.socials a:hover{color:#fff;border-color:var(--river-bright);background:rgba(55,194,190,.12)}

/* ============================================================ Reveal animation */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================ Responsive */
@media(max-width:900px){
  .hero-copy{max-width:none}
  .hero-bg img{right:50%;left:auto;transform:translateX(50%);top:auto;bottom:-2%;width:128%;opacity:.9;
    -webkit-mask-image:linear-gradient(180deg,transparent 0%,#000 52%,#000 88%,transparent 100%);
    mask-image:linear-gradient(180deg,transparent 0%,#000 52%,#000 88%,transparent 100%);
    -webkit-mask-composite:source-over;mask-composite:add}
  .hero-bg::after{background:linear-gradient(180deg,var(--paper) 0%,var(--paper) 30%,rgba(252,252,251,0) 64%)}
  .hero{padding-bottom:clamp(120px,40vw,200px)}
  .roots-body{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .cmp-grid{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr}
  .proof .stats{grid-template-columns:repeat(2,1fr);gap:2rem 1rem}
  .cta-inner{grid-template-columns:1fr;gap:2rem}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;
    background:var(--paper);padding:1rem var(--pad) 1.5rem;border-bottom:1px solid var(--mist);gap:.4rem;box-shadow:var(--shadow)}
  .nav-links.open a{padding:.7rem 0;border-bottom:1px solid var(--mist)}
  .menu-toggle{display:block;margin-left:auto}
  .nav-cta .btn{display:none}
  .svc-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero-trust{gap:1.2rem}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{justify-content:center;white-space:normal}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
:focus-visible{outline:3px solid var(--river);outline-offset:3px;border-radius:4px}