/* =========================================================
   Overland Media — Expedition theme
   One stylesheet, all pages. No frameworks.
   ========================================================= */

:root{
  /* Palette — deep pine night + warm paper + trail amber */
  --night:      #0E1311;
  --night-soft: #141B18;
  --bark:       #1C2520;
  --bark-line:  #2A352F;
  --paper:      #F5F1E8;
  --paper-soft: #EAE4D6;
  --stone:      #A6A294;
  --stone-dim:  #7E7C70;
  --pine:       #2F5D50;
  --pine-soft:  #3E7A69;
  --amber:      #E0793B;
  --amber-soft: #F2A05E;
  --sage:       #93A892;

  /* Type */
  --display: "Fraunces", Georgia, serif;
  --body:    "Hanken Grotesk", "Segoe UI", sans-serif;
  --mono:    "Spline Sans Mono", ui-monospace, monospace;

  /* Spacing rhythm */
  --container: 1180px;
  --pad: clamp(1.25rem, 4vw, 3rem);
  --radius: 14px;
  --section: clamp(4.5rem, 9vw, 8.5rem);

  --shadow: 0 24px 60px -28px rgba(0,0,0,.55);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--body);
  background:var(--paper);
  color:var(--night);
  font-size:clamp(1rem,.6vw + .9rem,1.075rem);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:560;
  font-optical-sizing:auto;
  line-height:1.04;
  letter-spacing:-.02em;
  margin:0;
  font-variation-settings:"SOFT" 30,"WONK" 0;
}
h1{ font-size:clamp(2.7rem,6.5vw,5.2rem); }
h2{ font-size:clamp(2rem,4.2vw,3.3rem); }
h3{ font-size:clamp(1.3rem,2vw,1.7rem); font-weight:600; }
p{ margin:0 0 1.1rem; }

.container{ width:min(100% - 2*var(--pad), var(--container)); margin-inline:auto; }
.section{ padding-block:var(--section); }
.lead{ font-size:clamp(1.15rem,1.6vw,1.45rem); color:#33403a; line-height:1.55; }

/* Eyebrow / coordinate label */
.eyebrow{
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:500;
  color:var(--amber);
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  margin:0 0 1.2rem;
}
.eyebrow::before{
  content:"";
  width:26px;height:1px;background:var(--amber);display:inline-block;
}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--amber); --fg:#1a120b;
  display:inline-flex; align-items:center; gap:.6em;
  background:var(--bg); color:var(--fg);
  font-family:var(--body); font-weight:650;
  font-size:.98rem; letter-spacing:.01em;
  padding:.92em 1.5em; border-radius:999px;
  text-decoration:none; border:1px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  box-shadow:0 10px 24px -12px rgba(224,121,59,.7);
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(224,121,59,.8); }
.btn .arrow{ transition:transform .25s ease; }
.btn:hover .arrow{ transform:translateX(4px); }
.btn--ghost{
  background:transparent; color:var(--paper);
  border:1px solid rgba(245,241,232,.35); box-shadow:none;
}
.btn--ghost:hover{ background:rgba(245,241,232,.08); border-color:rgba(245,241,232,.6); }
.btn--dark{ --bg:var(--night); --fg:var(--paper); box-shadow:0 10px 24px -14px rgba(0,0,0,.6); }

/* ---------- Topographic backdrop ---------- */
.topo{ position:relative; }
.topo::before{
  content:""; position:absolute; inset:0; z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='760' height='760' viewBox='0 0 760 760'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.05' stroke-width='1.4'%3E%3Cpath d='M380 380m-40 0a40 40 0 1 0 80 0a40 40 0 1 0 -80 0'/%3E%3Cpath d='M380 380m-90 0a90 90 0 1 0 180 0a90 90 0 1 0 -180 0'/%3E%3Cpath d='M380 380m-150 0a150 150 0 1 0 300 0a150 150 0 1 0 -300 0'/%3E%3Cpath d='M380 380m-220 0a220 220 0 1 0 440 0a220 220 0 1 0 -440 0'/%3E%3Cpath d='M380 380m-300 0a300 300 0 1 0 600 0a300 300 0 1 0 -600 0'/%3E%3Cpath d='M380 380m-390 0a390 390 0 1 0 780 0a390 390 0 1 0 -780 0'/%3E%3C/g%3E%3C/svg%3E");
  background-position:center; background-size:880px;
  pointer-events:none;
}
.topo > *{ position:relative; z-index:1; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(14,19,17,.78);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:2rem; padding-block:1rem;
}
.brand{ display:flex; align-items:center; gap:.7rem; text-decoration:none; color:var(--paper); }
.brand svg{ width:34px; height:34px; }
.brand-name{ font-family:var(--display); font-weight:600; font-size:1.18rem; letter-spacing:-.01em; }
.brand-name span{ color:var(--amber); }
.nav-links{ display:flex; align-items:center; gap:2rem; list-style:none; margin:0; padding:0; }
.nav-links a{
  color:var(--paper); text-decoration:none; font-size:.95rem; font-weight:500;
  opacity:.85; position:relative; padding-block:.3rem;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0;
  background:var(--amber); transition:width .3s ease;
}
.nav-links a:hover{ opacity:1; }
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{ width:100%; }
.nav-links a[aria-current="page"]{ opacity:1; }
.nav-cta{ display:flex; align-items:center; gap:1rem; }
.menu-toggle{ display:none; background:none; border:0; cursor:pointer; padding:.4rem; }
.menu-toggle svg{ width:26px; height:26px; stroke:var(--paper); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  background:radial-gradient(120% 130% at 80% -10%, #1c2a24 0%, var(--night) 55%);
  color:var(--paper);
  overflow:hidden;
}
.hero-inner{ padding-block:clamp(4.5rem,10vw,8rem) clamp(4rem,8vw,7rem); }
.hero h1{ max-width:16ch; }
.hero h1 em{ font-style:italic; color:var(--amber-soft); font-variation-settings:"SOFT" 60; }
.hero .lead{ color:var(--stone); max-width:46ch; margin-top:1.6rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.4rem; }
.hero-meta{
  margin-top:3.5rem; display:flex; flex-wrap:wrap; gap:2.4rem;
  border-top:1px solid rgba(255,255,255,.1); padding-top:1.8rem;
}
.hero-meta div{ display:flex; flex-direction:column; }
.hero-meta dt{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--stone-dim); }
.hero-meta dd{ margin:.2rem 0 0; font-family:var(--display); font-size:1.9rem; color:var(--paper); }

/* staggered entrance */
.reveal{ opacity:0; transform:translateY(22px); animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards; }
.reveal.d1{ animation-delay:.08s } .reveal.d2{ animation-delay:.18s }
.reveal.d3{ animation-delay:.30s } .reveal.d4{ animation-delay:.44s }
@keyframes rise{ to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .reveal{ animation:none; opacity:1; transform:none; } }

/* =========================================================
   GENERIC SECTIONS
   ========================================================= */
.section-head{ max-width:62ch; margin-bottom:clamp(2.5rem,5vw,3.5rem); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head p{ color:#3a463f; margin-top:1rem; }

.dark{ background:var(--night); color:var(--paper); }
.dark .section-head p,.dark p{ color:var(--stone); }
.dark h1,.dark h2,.dark h3{ color:var(--paper); }
.pine{ background:linear-gradient(160deg,#21433a,#152a24); color:var(--paper); }
.pine p{ color:#cfe0d9; }

/* Two-column intro */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
@media (max-width:820px){ .split{ grid-template-columns:1fr; } }

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

.card{
  background:var(--paper); border:1px solid #e2dccd; border-radius:var(--radius);
  padding:1.8rem; transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.card:hover{ transform:translateY(-4px); box-shadow:0 22px 40px -28px rgba(0,0,0,.4); border-color:var(--amber); }
.card .ic{ width:46px; height:46px; margin-bottom:1.1rem; color:var(--pine); }
.card h3{ margin-bottom:.5rem; }
.card p{ color:#46524b; font-size:.98rem; margin:0; }
.dark .card{ background:var(--night-soft); border-color:var(--bark-line); }
.dark .card p{ color:var(--stone); }
.dark .card .ic{ color:var(--amber-soft); }

/* link list */
.card-link{ display:inline-flex; align-items:center; gap:.4em; margin-top:1rem;
  font-weight:650; font-size:.92rem; color:var(--pine); text-decoration:none; }
.card-link .arrow{ transition:transform .25s ease; }
.card-link:hover .arrow{ transform:translateX(4px); }

/* ---------- Stats band ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; text-align:center; }
@media (max-width:780px){ .stats{ grid-template-columns:1fr 1fr; gap:2.5rem; } }
.stat .num{ font-family:var(--display); font-size:clamp(2.6rem,5vw,3.6rem); color:var(--amber-soft); line-height:1; }
.stat .lbl{ display:block; margin-top:.6rem; color:var(--stone); font-size:.92rem; }

/* ---------- Detailed service blocks ---------- */
.service{ padding-block:clamp(3rem,6vw,5rem); border-top:1px solid #e2dccd; }
.service:first-of-type{ border-top:0; }
.service-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
@media (max-width:860px){ .service-grid{ grid-template-columns:1fr; gap:1.5rem; } }
.service h2{ display:flex; align-items:baseline; gap:1rem; }
.service h2 .idx{ font-family:var(--mono); font-size:.95rem; color:var(--amber); letter-spacing:.1em; }
.service ul{ margin:1.2rem 0 0; padding:0; list-style:none; display:grid; gap:.7rem; }
.service ul li{ position:relative; padding-left:1.7rem; color:#46524b; }
.service ul li::before{
  content:""; position:absolute; left:0; top:.55em; width:9px; height:9px;
  border:1.5px solid var(--amber); border-radius:2px; transform:rotate(45deg);
}

/* ---------- Testimonials ---------- */
.quotes{ columns:2; column-gap:1.5rem; }
@media (max-width:760px){ .quotes{ columns:1; } }
.quote{
  break-inside:avoid; background:var(--night-soft); border:1px solid var(--bark-line);
  border-radius:var(--radius); padding:1.8rem; margin-bottom:1.5rem;
}
.quote p{ color:var(--paper); font-size:1.05rem; line-height:1.6; }
.quote .mark{ font-family:var(--display); font-size:2.6rem; color:var(--amber); line-height:.4; display:block; height:.7em; }
.quote cite{ color:var(--amber-soft); font-style:normal; font-weight:600; font-size:.92rem; }

/* ---------- Case study ---------- */
.cs-hero{ background:linear-gradient(160deg,#1c2a24,#0E1311); color:var(--paper); }
.cs-meta{ display:flex; flex-wrap:wrap; gap:1.5rem 2.5rem; margin-top:2rem;
  border-top:1px solid rgba(255,255,255,.12); padding-top:1.6rem; }
.cs-meta div dt{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--stone-dim); }
.cs-meta div dd{ margin:.25rem 0 0; font-weight:600; }
.phase{ border-left:2px solid var(--bark-line); padding:0 0 2.4rem 2rem; position:relative; }
.phase::before{ content:""; position:absolute; left:-7px; top:.4rem; width:12px; height:12px;
  background:var(--amber); border-radius:50%; box-shadow:0 0 0 4px rgba(224,121,59,.15); }
.phase .ph-no{ font-family:var(--mono); color:var(--amber); font-size:.8rem; letter-spacing:.12em; }
.phase h3{ margin:.3rem 0 .8rem; }
.phase ul{ margin:0; padding-left:1.1rem; color:#46524b; }
.phase ul li{ margin-bottom:.4rem; }

/* ---------- Contact ---------- */
.form-wrap{ background:var(--night-soft); border:1px solid var(--bark-line); border-radius:18px; padding:clamp(1.6rem,4vw,2.6rem); }
.field{ margin-bottom:1.2rem; }
.field label{ display:block; font-family:var(--mono); text-transform:uppercase; letter-spacing:.12em; font-size:.7rem; color:var(--stone); margin-bottom:.5rem; }
.field input,.field textarea,.field select{
  width:100%; background:var(--night); border:1px solid var(--bark-line); border-radius:10px;
  padding:.85rem 1rem; color:var(--paper); font-family:var(--body); font-size:1rem;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none; border-color:var(--amber); box-shadow:0 0 0 3px rgba(224,121,59,.18);
}
.field textarea{ min-height:140px; resize:vertical; }
.contact-aside dl{ margin:0; display:grid; gap:1.5rem; }
.contact-aside dt{ font-family:var(--mono); text-transform:uppercase; letter-spacing:.14em; font-size:.7rem; color:var(--amber); margin-bottom:.3rem; }
.contact-aside dd{ margin:0; color:var(--stone); }
.contact-aside dd a{ color:var(--paper); text-decoration:none; border-bottom:1px solid var(--bark-line); }
.contact-aside dd a:hover{ border-color:var(--amber); }

/* ---------- CTA band ---------- */
.cta{ text-align:center; }
.cta h2{ max-width:18ch; margin-inline:auto; }
.cta p{ max-width:48ch; margin:1.2rem auto 2rem; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:#0a0e0c; color:var(--stone); padding-block:clamp(3.5rem,6vw,5rem) 2rem; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; }
@media (max-width:760px){ .footer-top{ grid-template-columns:1fr; gap:2rem; } }
.footer-top .brand{ margin-bottom:1rem; }
.site-footer h4{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--stone-dim); font-weight:500; margin:0 0 1rem; }
.site-footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.site-footer a{ color:var(--stone); text-decoration:none; }
.site-footer a:hover{ color:var(--amber-soft); }
.footer-blurb{ max-width:34ch; font-size:.95rem; }
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem;
  border-top:1px solid rgba(255,255,255,.08); margin-top:3rem; padding-top:1.5rem; font-size:.85rem; }

/* ---------- Mobile nav ---------- */
@media (max-width:860px){
  .menu-toggle{ display:inline-flex; }
  .nav-links{
    position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:var(--night); padding:1rem var(--pad) 2rem; align-items:flex-start;
    border-bottom:1px solid rgba(255,255,255,.1);
    transform:translateY(-120%); transition:transform .35s ease; z-index:40;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ width:100%; padding:1rem 0; border-bottom:1px solid rgba(255,255,255,.07); font-size:1.05rem; }
  .nav .nav-cta .btn{ display:none; }
}

/* =========================================================
   JAZZ PASS — photographic hero, film grain, detail polish
   ========================================================= */

/* Photographic hero (homepage) */
.hero--photo{
  position:relative;
  min-height:90vh;
  display:flex;
  align-items:center;
  background:var(--night);
  isolation:isolate;
  overflow:hidden;
}
.hero--photo .hero-photo{ position:absolute; inset:0; z-index:-2; }
.hero--photo .hero-photo img{
  width:100%; height:100%; object-fit:cover; object-position:74% center;
  filter:saturate(1.06) contrast(1.03);
}
/* legibility scrim: dark on the left, clearing over the subject on the right */
.hero--photo::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(90deg, rgba(9,14,11,.94) 0%, rgba(11,18,14,.74) 30%, rgba(11,18,14,.20) 60%, rgba(11,18,14,0) 82%),
    linear-gradient(0deg, rgba(8,12,10,.80) 0%, rgba(8,12,10,0) 42%);
}
/* faint amber contour motif drifting across the seam */
.hero--photo::after{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='760' height='760' viewBox='0 0 760 760'%3E%3Cg fill='none' stroke='%23E0793B' stroke-opacity='0.10' stroke-width='1.2'%3E%3Cpath d='M380 380m-90 0a90 90 0 1 0 180 0a90 90 0 1 0 -180 0'/%3E%3Cpath d='M380 380m-150 0a150 150 0 1 0 300 0a150 150 0 1 0 -300 0'/%3E%3Cpath d='M380 380m-220 0a220 220 0 1 0 440 0a440 440 0 1 0 -440 0'/%3E%3Cpath d='M380 380m-300 0a300 300 0 1 0 600 0a300 300 0 1 0 -600 0'/%3E%3C/g%3E%3C/svg%3E");
  background-position:left center; background-size:760px;
}
.hero--photo .hero-inner{ padding-block:clamp(4.5rem,11vh,8rem); }
@media (max-width:680px){
  .hero--photo{ min-height:82vh; }
  .hero--photo .hero-photo img{ object-position:68% center; }
  .hero--photo::before{
    background:linear-gradient(0deg, rgba(8,12,10,.92) 0%, rgba(9,14,11,.55) 45%, rgba(9,14,11,.35) 100%);
  }
}

/* Film grain — site-wide, very subtle, adds analog texture */
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:9998;
  opacity:.05; mix-blend-mode:soft-light;
  background-size:200px 200px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Gradient stat numerals */
.stat .num{
  background:linear-gradient(180deg,var(--amber-soft) 0%, var(--amber) 90%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Slow drift for the hero contour motif */
@media (prefers-reduced-motion:no-preference){
  .hero--photo::after{ animation:drift 26s ease-in-out infinite alternate; }
  @keyframes drift{ from{ transform:translate3d(0,0,0) } to{ transform:translate3d(28px,-18px,0) } }
}

/* =========================================================
   CASE STUDY — B-Quiet brand integration
   ========================================================= */
.cs-hero.hero--photo{ min-height:66vh; }
.cs-hero.hero--photo .hero-photo img{ object-position:center 38%; }
.cs-hero.hero--photo::before{
  background:
    linear-gradient(90deg, rgba(8,12,10,.95) 0%, rgba(10,16,13,.86) 40%, rgba(10,16,13,.42) 68%, rgba(10,16,13,0) 90%),
    linear-gradient(0deg, rgba(8,12,10,.85) 0%, rgba(8,12,10,0) 46%);
}
.cs-hero .lead{ color:#dcd8cc; max-width:42ch; }
.cs-meta dd a{ color:var(--amber-soft); text-decoration:none; border-bottom:1px solid rgba(242,160,94,.45); }
.cs-meta dd a:hover{ border-color:var(--amber-soft); }

/* client logo chip (logo art is dark, so it sits on a light plate) */
.bq-badge{
  display:inline-flex; align-items:center; background:var(--paper);
  padding:.6rem 1rem; border-radius:12px; margin-bottom:1.5rem;
  box-shadow:0 10px 26px -14px rgba(0,0,0,.55);
}
.bq-badge img{ height:34px; width:auto; display:block; }

/* product cards using B-Quiet's real product photography */
.bq-prod img{
  width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:10px;
  margin-bottom:1.2rem; background:#fff;
}
.bq-prod h3{ margin-bottom:.4rem; }

/* B-Quiet brand-red button for the outbound link */
.btn--bq{ --bg:#ca2d39; --fg:#fff; box-shadow:0 10px 24px -14px rgba(202,45,57,.75); }
