/* =========================================================
   Dillingham Consulting, LLC
   Brand palette: #FBFAF9  #F7F4ED  #D3DBD2  #25393C  #000000
   Brand words:   Empowered . Calm . Leadership . Polished
   ========================================================= */

:root{
  --bg:        #FBFAF9;   /* warm off white   */
  --cream:     #F7F4ED;   /* soft cream       */
  --sage:      #D3DBD2;   /* calm sage        */
  --ink:       #25393C;   /* deep teal ink    */
  --black:     #000000;

  --ink-80: rgba(37,57,60,.80);
  --ink-65: rgba(37,57,60,.65);
  --ink-45: rgba(37,57,60,.45);
  --ink-12: rgba(37,57,60,.12);
  --sage-30: rgba(211,219,210,.45);

  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --maxw: 1160px;
  --pad: clamp(1.25rem, 5vw, 2.5rem);
  --section-y: clamp(4rem, 9vw, 7.5rem);
  --radius: 16px;
  --radius-sm: 10px;

  --shadow: 0 1px 2px rgba(37,57,60,.05), 0 18px 40px -28px rgba(37,57,60,.28);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:430;
  line-height:1.1;
  letter-spacing:-.01em;
  margin:0;
}

p{ margin:0 0 1.1rem; }
p:last-child{ margin-bottom:0; }

.container{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--pad);
}

.section{ padding-block:var(--section-y); }
.section--cream{ background:var(--cream); }
.section--sage{ background:var(--sage); }
.section--ink{ background:var(--ink); color:var(--cream); }
.section--ink h1,.section--ink h2,.section--ink h3{ color:var(--cream); }

/* ---------- Eyebrow ---------- */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.7rem;
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-65);
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:"";
  width:1.9rem;
  height:1px;
  background:var(--ink-45);
}
.section--ink .eyebrow{ color:rgba(247,244,237,.7); }
.section--ink .eyebrow::before{ background:rgba(247,244,237,.5); }

/* ---------- Type scale ---------- */
.display{
  font-size:clamp(2.4rem, 6.2vw, 4.4rem);
  line-height:1.04;
  letter-spacing:-.02em;
}
.h2{ font-size:clamp(1.85rem, 4vw, 2.9rem); }
.h3{ font-size:clamp(1.3rem, 2.4vw, 1.6rem); }
.lead{
  font-size:clamp(1.1rem, 1.8vw, 1.3rem);
  line-height:1.55;
  color:var(--ink-80);
  max-width:46ch;
}
.section--ink .lead{ color:rgba(247,244,237,.86); }
.measure{ max-width:62ch; }
em,.italic{ font-style:italic; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.01em;
  padding:.85rem 1.5rem;
  border-radius:999px;
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--cream);
  cursor:pointer;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 14px 26px -16px rgba(37,57,60,.55); }
.btn .arrow{ transition:transform .25s ease; }
.btn:hover .arrow{ transform:translateX(3px); }

.btn--ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink-45);
}
.btn--ghost:hover{ background:var(--ink); color:var(--cream); border-color:var(--ink); }

.btn--light{ background:var(--cream); color:var(--ink); border-color:var(--cream); }
.btn--light:hover{ background:var(--sage); border-color:var(--sage); }

.btn--lightghost{ background:transparent; color:var(--cream); border-color:rgba(247,244,237,.5); }
.btn--lightghost:hover{ background:var(--cream); color:var(--ink); border-color:var(--cream); }

.btn-row{ display:flex; flex-wrap:wrap; gap:.85rem; margin-top:1.8rem; }

/* =========================================================
   Header
   ========================================================= */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,250,249,.86);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--ink-12);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  min-height:74px;
}
.brand{ display:flex; flex-direction:row; align-items:center; gap:.7rem; line-height:1.05; }
.brand-logo{ height:44px; width:auto; display:block; flex:none; }
.brand-text{ display:flex; flex-direction:column; }
.brand-name{
  font-family:var(--serif);
  font-size:1.32rem;
  font-weight:500;
  letter-spacing:-.01em;
}
.brand-tag{
  font-size:.66rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-65);
  margin-top:.18rem;
}
.site-nav{ display:flex; align-items:center; gap:1.65rem; }
.site-nav a{
  font-size:.95rem;
  font-weight:500;
  color:var(--ink-80);
  position:relative;
  transition:color .2s ease;
}
.site-nav a:not(.nav-cta)::after{
  content:"";
  position:absolute;
  left:0; bottom:-6px;
  width:0; height:1.5px;
  background:var(--ink);
  transition:width .25s ease;
}
.site-nav a:not(.nav-cta):hover{ color:var(--ink); }
.site-nav a:not(.nav-cta):hover::after,
.site-nav a[aria-current="page"]::after{ width:100%; }
.site-nav a[aria-current="page"]{ color:var(--ink); }
.site-nav a.nav-cta{ padding:.6rem 1.15rem; color:var(--cream); }
.site-nav a.nav-cta:hover{ color:var(--cream); }

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  width:44px; height:44px;
  align-items:center; justify-content:center;
  background:transparent; border:none; cursor:pointer;
}
.nav-toggle span{
  width:24px; height:2px; background:var(--ink);
  transition:transform .3s ease, opacity .2s ease;
}

@media (max-width:880px){
  .nav-toggle{ display:flex; }
  .site-nav{
    position:fixed;
    inset:74px 0 auto 0;
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    background:var(--bg);
    border-bottom:1px solid var(--ink-12);
    padding:.5rem var(--pad) 1.6rem;
    transform:translateY(-130%);
    transition:transform .35s cubic-bezier(.4,0,.2,1);
    box-shadow:var(--shadow);
  }
  .site-nav.open{ transform:translateY(0); }
  .site-nav a{ width:100%; padding:.95rem 0; border-bottom:1px solid var(--ink-12); font-size:1.05rem; }
  .site-nav a:not(.nav-cta)::after{ display:none; }
  .nav-cta{ margin-top:1.1rem; border-bottom:none !important; justify-content:center; }
  .nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
}

/* =========================================================
   Hero
   ========================================================= */
.hero{ padding-block:clamp(3rem,7vw,6rem) clamp(3.5rem,8vw,6.5rem); }
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:clamp(2rem,5vw,4.5rem);
  align-items:center;
}
.hero-copy .display{ margin-bottom:1.4rem; }
.hero-copy .display .accent{ font-style:italic; color:var(--ink); }
.hero-figure{ position:relative; }
.hero-photo{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--sage);
  aspect-ratio:4/5;
  box-shadow:var(--shadow);
}
.hero-photo img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.hero-photo::after{
  content:"";
  position:absolute; inset:0;
  box-shadow:inset 0 0 0 1px rgba(37,57,60,.18);
  border-radius:var(--radius);
}
.hero-badge{
  position:absolute;
  left:-14px; bottom:24px;
  background:var(--ink);
  color:var(--cream);
  padding:.85rem 1.1rem;
  border-radius:12px;
  max-width:200px;
  box-shadow:var(--shadow);
}
.hero-badge strong{ font-family:var(--serif); font-size:1.6rem; font-weight:500; display:block; line-height:1; }
.hero-badge span{ font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(247,244,237,.78); }

@media (max-width:780px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-figure{ max-width:380px; }
  .hero-badge{ left:0; }
}

/* ---------- Brand band ---------- */
.brandband{
  border-block:1px solid var(--ink-12);
  background:var(--cream);
}
.brandwords{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:1.4rem;
  padding-block:1.4rem;
  font-family:var(--sans);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:.82rem;
  font-weight:600;
  color:var(--ink);
}
.brandwords i{ color:var(--ink-45); font-style:normal; }
.section--ink .brandwords{ color:var(--cream); }

/* ---------- Stat strip ---------- */
.stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.5rem;
}
.stat{ border-top:1px solid rgba(247,244,237,.25); padding-top:1.1rem; }
.stat .num{ font-family:var(--serif); font-size:clamp(2rem,4vw,2.9rem); line-height:1; display:block; }
.stat .lbl{ font-size:.82rem; letter-spacing:.04em; color:rgba(247,244,237,.78); margin-top:.5rem; display:block; }
@media (max-width:680px){ .stats{ grid-template-columns:repeat(2,1fr); gap:1.4rem 1.5rem; } }

/* ---------- Section heading block ---------- */
.sec-head{ max-width:60ch; margin-bottom:clamp(2rem,4vw,3rem); }
.sec-head .h2{ margin-bottom:.9rem; }

/* ---------- Service cards ---------- */
.card-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}
.card-grid--2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:900px){ .card-grid,.card-grid--2{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .card-grid,.card-grid--2{ grid-template-columns:1fr; } }

.card{
  background:var(--bg);
  border:1px solid var(--ink-12);
  border-radius:var(--radius);
  padding:1.7rem 1.6rem;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  height:100%;
}
.section--cream .card{ background:var(--bg); }
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.card .tag{
  font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-65); font-weight:600; display:block; margin-bottom:.8rem;
}
.card h3{ font-size:1.4rem; margin-bottom:.6rem; }
.card .sub{ font-weight:600; color:var(--ink); font-family:var(--sans); font-size:.92rem; margin-bottom:.85rem; display:block; }
.card ul{ margin:0; padding:0; list-style:none; }
.card ul li{
  position:relative;
  padding-left:1.1rem;
  margin-bottom:.5rem;
  font-size:.96rem;
  color:var(--ink-80);
  line-height:1.45;
}
.card ul li::before{
  content:""; position:absolute; left:0; top:.62em;
  width:6px; height:6px; border-radius:50%; background:var(--sage);
  box-shadow:inset 0 0 0 1px var(--ink-45);
}
.card .more{
  display:inline-flex; align-items:center; gap:.4rem;
  margin-top:1.1rem; font-weight:600; font-size:.92rem; color:var(--ink);
}
.card .more .arrow{ transition:transform .25s ease; }
.card:hover .more .arrow{ transform:translateX(3px); }

/* ---------- Split / feature row ---------- */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:center;
}
.split--media-right{ direction:ltr; }
@media (max-width:820px){ .split{ grid-template-columns:1fr; } }
.media-frame{
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--sage);
  aspect-ratio:5/4;
  box-shadow:var(--shadow);
  position:relative;
}
.media-frame img{ width:100%; height:100%; object-fit:cover; }
.media-frame::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px rgba(37,57,60,.16); }

/* ---------- Testimonials ---------- */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; align-items:start; }
@media (max-width:980px){ .quotes{ grid-template-columns:1fr; } }
.quote{
  background:var(--cream);
  border:1px solid var(--ink-12);
  border-radius:var(--radius);
  padding:2rem 1.9rem;
  position:relative;
}
.quote::before{
  content:"\201C";
  font-family:var(--serif);
  font-size:4.5rem;
  line-height:.6;
  color:var(--sage);
  position:absolute;
  top:1.2rem; left:1.3rem;
}
.quote p{
  font-family:var(--serif);
  font-size:1.22rem;
  line-height:1.5;
  font-style:italic;
  color:var(--ink);
  margin:1.5rem 0 1.4rem;
  position:relative;
}
.quote .who{ font-family:var(--sans); font-weight:600; font-size:.95rem; }
.quote .role{ font-size:.84rem; color:var(--ink-65); }

/* ---------- CTA band ---------- */
.cta-band{ text-align:center; }
.cta-band .h2{ margin-bottom:1rem; max-width:20ch; margin-inline:auto; }
.cta-band .lead{ margin-inline:auto; margin-bottom:0; }
.cta-band .btn-row{ justify-content:center; }

/* ---------- About / bio prose ---------- */
.prose p{ font-size:1.08rem; color:var(--ink-80); margin-bottom:1.25rem; }
.prose p strong{ color:var(--ink); }
.creds{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.6rem; }
.chip{
  font-size:.8rem; font-weight:600; letter-spacing:.04em;
  padding:.5rem .9rem; border-radius:999px;
  background:var(--sage); color:var(--ink);
}

/* ---------- Team ---------- */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
@media (max-width:880px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .team-grid{ grid-template-columns:1fr; } }
.member{
  background:var(--bg);
  border:1px solid var(--ink-12);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease;
}
.member:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.member .photo{ aspect-ratio:1/1; background:var(--sage); overflow:hidden; }
.member .photo img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.member .body{ padding:1.4rem 1.4rem 1.7rem; }
.member h3{ font-size:1.35rem; }
.member .pos{ font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-65); font-weight:600; margin:.4rem 0 .9rem; display:block; }
.member p{ font-size:.95rem; color:var(--ink-80); }

/* ---------- News ---------- */
.feature-post{
  display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(1.5rem,4vw,3rem);
  align-items:center;
  background:var(--cream);
  border:1px solid var(--ink-12);
  border-radius:var(--radius);
  overflow:hidden;
}
.feature-post .media{ background:var(--sage); aspect-ratio:4/3; }
.feature-post .media img{ width:100%; height:100%; object-fit:cover; }
.feature-post .body{ padding:clamp(1.6rem,3vw,2.6rem); }
@media (max-width:760px){ .feature-post{ grid-template-columns:1fr; } }
.post-meta{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-65); font-weight:600; margin-bottom:.7rem; }
.post-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin-top:2rem; }
@media (max-width:880px){ .post-list{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .post-list{ grid-template-columns:1fr;} }
.post-card{
  background:var(--bg); border:1px solid var(--ink-12);
  border-radius:var(--radius); overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease;
}
.post-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.post-card .media{ aspect-ratio:16/10; background:var(--sage); }
.post-card .media img{ width:100%; height:100%; object-fit:cover; }
.post-card .body{ padding:1.4rem; }
.post-card h3{ font-size:1.22rem; margin:.5rem 0 .6rem; }
.post-card p{ font-size:.93rem; color:var(--ink-80); }

/* ---------- Forms ---------- */
.form{ display:grid; gap:1.1rem; max-width:560px; }
.field{ display:grid; gap:.4rem; }
.field label{ font-size:.84rem; font-weight:600; letter-spacing:.03em; color:var(--ink); }
.field input,.field textarea,.field select{
  font-family:var(--sans);
  font-size:1rem;
  color:var(--ink);
  background:var(--bg);
  border:1px solid var(--ink-45);
  border-radius:var(--radius-sm);
  padding:.85rem .95rem;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;
  border-color:var(--ink);
  box-shadow:0 0 0 3px var(--sage-30);
}
.field textarea{ resize:vertical; min-height:130px; }
.inline-form{ display:flex; gap:.6rem; flex-wrap:wrap; max-width:480px; }
.inline-form input{ flex:1 1 220px; }
.section--ink .field label{ color:var(--cream); }
.section--ink .field input,.section--ink .field textarea{
  background:rgba(247,244,237,.06); border-color:rgba(247,244,237,.32); color:var(--cream);
}
.section--ink .field input::placeholder,.section--ink .field textarea::placeholder{ color:rgba(247,244,237,.5); }

/* ---------- Contact info ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); }
@media (max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }
.info-row{ display:flex; gap:.9rem; padding:1.1rem 0; border-bottom:1px solid var(--ink-12); }
.info-row .ico{ width:34px; height:34px; flex:none; border-radius:9px; background:var(--sage); display:grid; place-items:center; color:var(--ink); }
.info-row .k{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-65); font-weight:600; }
.info-row .v{ font-size:1.02rem; color:var(--ink); }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{ background:var(--ink); color:rgba(247,244,237,.78); }
.footer-top{ padding-block:clamp(3rem,6vw,4.5rem) 2.5rem; }
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:clamp(2rem,5vw,3.5rem);
}
@media (max-width:760px){ .footer-grid{ grid-template-columns:1fr; gap:2.2rem; } }
.footer-brand .brand-name{ color:var(--cream); font-size:1.5rem; }
.footer-brand p{ color:rgba(247,244,237,.66); max-width:34ch; margin-top:1rem; font-size:.96rem; }
.footer-col h4{ font-family:var(--sans); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(247,244,237,.6); font-weight:700; margin-bottom:1rem; }
.footer-col a, .footer-col p{ display:block; color:rgba(247,244,237,.82); font-size:.96rem; margin-bottom:.6rem; transition:color .2s ease; }
.footer-col a:hover{ color:var(--cream); }
.footer-bottom{
  border-top:1px solid rgba(247,244,237,.16);
  padding-block:1.5rem;
  display:flex; flex-wrap:wrap; gap:1rem;
  align-items:center; justify-content:space-between;
  font-size:.84rem; color:rgba(247,244,237,.6);
}
.footer-bottom .sig{ font-family:var(--serif); font-style:italic; color:rgba(247,244,237,.8); }

/* ---------- Reveal animation (progressive enhancement) ---------- */
/* Hidden state only applies when JS confirms it can reveal */
.js-reveal .reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease; }
.js-reveal .reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .js-reveal .reveal{ opacity:1; transform:none; }
}

/* ---------- Utilities ---------- */
.center{ text-align:center; }
.mt-s{ margin-top:1rem; }
.mt-m{ margin-top:2rem; }
.hide{ display:none; }
:focus-visible{ outline:2px solid var(--ink); outline-offset:3px; border-radius:4px; }

/* ---------- Footer social ---------- */
.social{ display:flex; gap:.6rem; padding-top:1.4rem; }
.social a{ display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; width:38px; height:38px; border-radius:50%; border:1px solid rgba(247,244,237,.28); color:rgba(247,244,237,.82); transition:background .2s ease,color .2s ease,border-color .2s ease; }
.social a:hover{ background:var(--cream); color:var(--ink); border-color:var(--cream); }
.social svg{ width:18px; height:18px; flex:none; display:block; fill:currentColor; }

/* ---------- Before / after placeholder frames ---------- */
.ba-frame{ position:relative; aspect-ratio:16/10; border-radius:var(--radius); background:var(--sage); box-shadow:var(--shadow); display:flex; align-items:center; justify-content:center; }
.ba-frame span{ font-family:var(--sans); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-65); }
.ba-frame--after{ background:var(--ink); }
.ba-frame--after span{ color:rgba(247,244,237,.7); }

/* ---------- Footer logo ---------- */
.footer-logo{ height:46px; width:auto; display:block; margin-bottom:.9rem; }

/* ---------- Page hero banner (image watermark) ---------- */
.page-hero{ position:relative; min-height:clamp(300px,42vw,480px); display:flex; align-items:flex-end; background-size:cover; background-position:center; isolation:isolate; }
.page-hero::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(37,57,60,.30) 0%, rgba(37,57,60,.82) 100%); }
.page-hero .container{ padding-block:clamp(3rem,8vw,5rem) clamp(2rem,5vw,3.4rem); }
.page-hero .eyebrow{ color:rgba(247,244,237,.82); }
.page-hero .eyebrow::before{ background:rgba(247,244,237,.55); }
.page-hero h1{ color:var(--cream); }
.page-hero p{ color:rgba(247,244,237,.92); }
