/* =====================================================================
   California Concrete & Design — site.css
   Shared design system across all pages.
   Mobile-first. Industrial / honest-trade aesthetic.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* Surfaces — true cool concrete with subtle warm fleck */
  --bg:#E8E6DD;            /* cured concrete, faint warm */
  --bg-alt:#D9D6CB;        /* steel-trowel band */
  --bg-deep:#C6C3B5;       /* exposed aggregate */
  --paper:#F8F6EE;         /* fresh slab */
  --dark:#13161A;          /* glossy epoxy black, blue undertone */
  --dark-soft:#1D2024;
  --cream:#F2EFE5;

  /* Ink — neutral slate, reads on warm concrete */
  --ink:#13161A;
  --ink-mid:#41433F;
  --ink-soft:#75766F;

  /* Lines & shadows */
  --line:#BEBBAE;
  --line-soft:#D2CFC2;
  --shadow-sm:0 1px 0 rgba(15,20,15,.04);
  --shadow-md:0 8px 28px rgba(20,25,15,.09);

  /* Accents — wet-turf green (saturated, premium) */
  --accent:#2F6B36;        /* deep turf */
  --accent-dark:#1E4923;
  --accent-soft:#A8C9A4;
  --accent-faint:#D5E4D0;
  --rust:#B85B2A;          /* secondary, dark surfaces only */

  /* Sizing */
  --r:6px;                 /* base radius — small, industrial */
  --r-lg:10px;
  --r-pill:999px;
  --maxw:1280px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{
  -webkit-text-size-adjust:100%;text-size-adjust:100%;
  scroll-behavior:smooth;
  -webkit-tap-highlight-color:rgba(47,107,54,.15);
  /* iOS Safari < 16 ignores `overflow-x:clip`, so use `hidden` as the
     primary value and let `clip` enhance on browsers that support it. */
  overflow-x:hidden;overflow-x:clip;
  width:100%;max-width:100%;
  position:relative;
}
body{
  font-family:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:16px;line-height:1.55;font-weight:400;
  color:var(--ink-mid);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;overflow-x:clip;
  width:100%;max-width:100%;
  position:relative;
  font-feature-settings:'ss01';
  overscroll-behavior:none;
}
a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
a{-webkit-touch-callout:none}

h1,h2,h3,h4{
  font-family:'Archivo','DM Sans',sans-serif;
  color:var(--ink);font-weight:800;
  letter-spacing:-0.02em;line-height:1.05;
}
h1{font-size:2.25rem;letter-spacing:-0.035em;line-height:1;font-weight:900}
h2{font-size:1.75rem;letter-spacing:-0.03em;font-weight:800}
h3{font-size:1.25rem;letter-spacing:-0.02em;font-weight:700}
h4{font-size:1rem;font-weight:700;letter-spacing:-0.005em}

p{color:var(--ink-mid)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul,ol{list-style:none}
button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}

/* Display utility — used for section heads that need extra weight */
.display{font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;letter-spacing:-0.035em;line-height:.98}

/* ---------- Container ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ---------- Eyebrow ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'DM Sans',sans-serif;font-size:.6875rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
}
.eyebrow::before{content:'';width:22px;height:2px;background:currentColor}
.eyebrow.solo::before{display:none}
.eyebrow.dim{color:var(--ink-soft)}
.eyebrow.cream{color:var(--accent-soft)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 22px;min-height:50px;
  font-family:'DM Sans',sans-serif;font-size:.9375rem;font-weight:700;
  letter-spacing:.005em;
  border:1.5px solid transparent;border-radius:var(--r-pill);cursor:pointer;
  transition:transform .12s ease,background .15s ease,color .15s ease,border-color .15s ease;
  white-space:nowrap;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:var(--cream);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.btn-dark{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-dark:hover{background:var(--accent);border-color:var(--accent)}
.btn-light{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-light:hover{background:var(--accent);color:var(--cream);border-color:var(--accent)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn-outline-light{background:transparent;color:var(--cream);border-color:rgba(246,242,232,.4)}
.btn-outline-light:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-block{width:100%}
.arrow::after{content:'\2192';transition:transform .2s;display:inline-block}
.arrow:hover::after{transform:translateX(3px)}

/* ---------- Text link ---------- */
.tlink{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'DM Sans',sans-serif;font-size:.8125rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink);
  padding-bottom:3px;border-bottom:2px solid var(--ink);
}
.tlink::after{content:'\2192';transition:transform .2s}
.tlink:hover::after{transform:translateX(3px)}
.tlink-light{color:var(--cream);border-bottom-color:var(--accent-soft)}

/* =====================================================================
   TOP RIBBON
   ===================================================================== */
.ribbon{
  background:var(--dark);color:var(--cream);
  font-family:'DM Sans',sans-serif;font-size:.6875rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;text-align:center;
  padding:9px 22px;
}
.ribbon b{font-weight:700;color:var(--accent-soft)}
.ribbon .dot{display:inline-block;margin:0 8px;opacity:.4}

/* =====================================================================
   HEADER
   ===================================================================== */
.header{
  background:var(--bg);
  position:sticky;top:0;z-index:60;
  border-bottom:1px solid var(--line-soft);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;gap:12px;
}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink);min-width:0;flex:1 1 auto;overflow:hidden}
.brand-mark{
  width:42px;height:42px;flex-shrink:0;
  background:var(--ink);color:var(--cream);
  display:grid;place-items:center;
  font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;font-size:1rem;
  letter-spacing:.02em;
  border-radius:var(--r);
}
.brand-text{
  font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;
  font-size:.9375rem;letter-spacing:-0.025em;
  color:var(--ink);line-height:1.05;
  text-transform:uppercase;
  min-width:0;overflow:hidden;
}
.brand-text .name{
  display:block;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;
}
.brand-text small{
  display:block;font-family:'DM Sans',sans-serif;font-size:.625rem;
  font-weight:600;color:var(--ink-soft);letter-spacing:.12em;
  text-transform:uppercase;margin-top:2px;
}

.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.call-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 16px;min-height:42px;
  background:var(--accent);color:var(--cream);border-radius:var(--r-pill);
  font-family:'DM Sans',sans-serif;font-size:.8125rem;font-weight:700;
  letter-spacing:.005em;flex-shrink:0;
}
.call-pill svg{width:14px;height:14px;flex-shrink:0}
.call-pill:hover{background:var(--accent-dark)}
.menu-btn{
  display:inline-flex;align-items:center;gap:8px;
  height:42px;padding:0 16px 0 14px;
  background:transparent;border:1.5px solid var(--ink);
  border-radius:var(--r-pill);cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:.8125rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink);
}
.menu-btn .bars{display:inline-flex;flex-direction:column;gap:3px;width:14px}
.menu-btn .bars span{display:block;height:2px;background:currentColor;transition:transform .2s,opacity .2s}
.menu-btn .bars span:nth-child(2){width:10px}
.menu-btn:hover{background:var(--ink);color:var(--cream)}
.menu-btn:hover .bars span{background:var(--cream)}
.menu-btn .lbl{display:inline}
.menu-btn.open .bars span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.menu-btn.open .bars span:nth-child(2){opacity:0}
.menu-btn.open .bars span:nth-child(3){transform:translateY(-5px) rotate(-45deg);width:14px}

/* Desktop horizontal nav (visible ≥1000px) */
.nav-bar{display:none}

/* Full-screen mobile drawer */
.nav{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:var(--bg);z-index:55;
  padding:86px 24px 32px;flex-direction:column;overflow-y:auto;
}
.nav.open{display:flex}
.nav-links{display:flex;flex-direction:column;border-top:1px solid var(--line-soft);max-width:560px;width:100%;margin:0 auto}
.nav-links a{
  padding:18px 0;border-bottom:1px solid var(--line-soft);
  font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;
  font-size:1.5rem;letter-spacing:-0.03em;color:var(--ink);
  text-transform:uppercase;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-links a::after{
  content:'\2192';font-family:'DM Sans',sans-serif;color:var(--ink-soft);
  font-size:1rem;font-weight:400;
}
.nav-links a.active{color:var(--accent)}
.nav-cta{margin:28px auto 0;display:flex;flex-direction:column;gap:10px;max-width:560px;width:100%}
.nav-meta{
  margin-top:auto;padding-top:32px;max-width:560px;width:100%;margin-left:auto;margin-right:auto;
  font-family:'DM Sans',sans-serif;
  font-size:.75rem;color:var(--ink-soft);letter-spacing:.04em;line-height:1.7;
}
.nav-meta b{
  display:block;font-family:'Archivo Black','Archivo',sans-serif;
  color:var(--ink);font-weight:900;font-size:.6875rem;
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px;
}

/* =====================================================================
   HERO (shared structure across pages)
   ===================================================================== */
.hero{padding:20px 0 0;background:var(--bg)}
.hero-frame{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:1/1;background:#2A2D29 center/cover no-repeat;
}
.hero-frame::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(15,17,13,0) 35%,
    rgba(15,17,13,.4) 70%,
    rgba(15,17,13,.85) 100%);
}
.hero-frame-tag{
  position:absolute;top:16px;left:16px;z-index:2;
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(15,17,13,.7);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  padding:7px 12px;border-radius:var(--r-pill);
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--cream);
}
.hero-frame-tag::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);
}
.hero-frame-caption{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:18px 18px 16px;color:var(--cream);
  display:flex;justify-content:space-between;align-items:flex-end;gap:12px;
}
.hero-frame-caption .where{
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(246,242,232,.7);
}
.hero-frame-caption .what{
  font-family:'Archivo','DM Sans',sans-serif;font-weight:700;font-size:1rem;
  letter-spacing:-0.015em;line-height:1.15;color:var(--cream);
  max-width:200px;text-align:right;
}

.hero-copy{padding:22px 0 0}
.crumbs{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'DM Sans',sans-serif;font-size:.6875rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);
  margin-bottom:14px;
}
.crumbs a{color:var(--ink-soft)}
.crumbs a:hover{color:var(--accent)}
.crumbs .sep{opacity:.4}
.hero-copy h1{margin-bottom:16px;font-family:'Archivo Black','Archivo',sans-serif}
.hero-copy h1 .accent{color:var(--accent)}
.hero-lead{
  font-family:'DM Sans',sans-serif;
  font-size:1rem;line-height:1.5;color:var(--ink-mid);
  margin-bottom:20px;max-width:46ch;
}
.hero-cta{display:flex;flex-direction:column;gap:10px}

/* Trust chips inside hero */
.trust-row{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  margin-top:28px;border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.trust-chip{
  padding:14px 4px 14px 14px;
  display:flex;flex-direction:column;gap:2px;
  border-right:1px solid var(--line-soft);
}
.trust-chip:nth-child(2n){border-right:0}
.trust-chip:nth-child(1),.trust-chip:nth-child(2){border-bottom:1px solid var(--line-soft)}
.trust-chip .k{
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);
}
.trust-chip .v{
  font-family:'Archivo','DM Sans',sans-serif;font-weight:800;font-size:.9375rem;
  color:var(--ink);letter-spacing:-0.015em;line-height:1.1;
  font-feature-settings:'tnum';
}

/* =====================================================================
   SECTION SCAFFOLDING
   ===================================================================== */
.section{padding:52px 0}
.section-alt{background:var(--bg-alt)}
.section-paper{background:var(--paper)}
.section-dark{background:var(--ink);color:var(--cream)}
.section-dark h2,.section-dark h3,.section-dark h4{color:var(--cream)}
.section-dark p{color:rgba(246,242,232,.72)}

.shead{margin-bottom:28px;display:flex;flex-direction:column;gap:14px}
.shead h2{max-width:18ch}
.shead p{font-size:1rem;line-height:1.55;max-width:42ch}

/* =====================================================================
   IMAGE / SHOWCASE BLOCKS
   ===================================================================== */
.shot{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:#2A241D center/cover no-repeat;
  aspect-ratio:16/10;
}
.shot.tall{aspect-ratio:4/5}
.shot.square{aspect-ratio:1}
.shot.cinema{aspect-ratio:21/9}
.shot-meta{
  margin-top:14px;display:grid;gap:14px;
  grid-template-columns:1fr;
}
.shot-meta .row{display:flex;flex-direction:column;gap:2px}
.shot-meta .k{
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);
}
.shot-meta .v{
  font-family:'Archivo','DM Sans',sans-serif;font-weight:700;font-size:1rem;
  color:var(--ink);letter-spacing:-0.015em;line-height:1.2;
}

/* =====================================================================
   CARD GRIDS — types/finishes/patterns/systems/uses
   ===================================================================== */
.cards{display:grid;grid-template-columns:1fr;gap:24px}
.card{
  background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--r-lg);overflow:hidden;
  display:flex;flex-direction:column;
}
.card-img{
  aspect-ratio:4/3;background:#2A241D center/cover no-repeat;
}
.card-body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:8px}
.card-num{
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);
}
.card h3{margin-bottom:4px}
.card-body p{font-size:.9375rem;line-height:1.5}

/* Text-only "also offered" cells */
.cells{display:grid;grid-template-columns:1fr;gap:0}
.cell{
  padding:24px 0;border-top:1px solid var(--line);
}
.cell:first-child{border-top:0;padding-top:8px}
.cell h4{
  font-family:'Archivo Black','Archivo',sans-serif;
  font-size:1.25rem;font-weight:900;letter-spacing:-0.02em;
  color:var(--ink);margin-bottom:8px;text-transform:none;
}
.cell p{font-size:.9375rem;line-height:1.55}

/* =====================================================================
   FEATURED INSTALL — image with metadata strip below
   ===================================================================== */
.feature{margin:32px 0 0}
.feature .shot{aspect-ratio:4/5}
.feature-meta{
  margin-top:18px;padding-top:18px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
}
.feature-meta .row{display:flex;flex-direction:column;gap:2px}
.feature-meta .k{
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);
}
.feature-meta .v{
  font-family:'Archivo','DM Sans',sans-serif;font-weight:800;font-size:1rem;
  color:var(--ink);letter-spacing:-0.015em;line-height:1.2;
}

/* =====================================================================
   PROCESS — numbered steps (dark band)
   ===================================================================== */
.process{
  padding:56px 0;color:var(--cream);
  position:relative;overflow:hidden;
  /* Dark base + accent-tinted radial blob painted as a background image
     so it can never widen the section's intrinsic width on iOS Safari. */
  background-color:var(--ink);
  background-image:radial-gradient(circle 150px at calc(100% + 30px) -30px,
    rgba(47,107,54,.32) 0%,
    rgba(47,107,54,.12) 40%,
    transparent 70%);
  background-repeat:no-repeat;
}
.process h2{color:var(--cream);margin-bottom:12px}
.process .lead{color:rgba(246,242,232,.7);font-size:1rem;line-height:1.55;margin-bottom:28px;max-width:42ch}
.steps{display:flex;flex-direction:column;gap:0;margin-bottom:28px}
.step{
  display:grid;grid-template-columns:auto 1fr;gap:14px;
  padding:18px 0;border-bottom:1px solid rgba(246,242,232,.14);
}
.step:last-child{border-bottom:0}
.step .n{
  font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;
  font-size:1.5rem;color:var(--accent-soft);letter-spacing:-0.02em;
  flex-shrink:0;min-width:32px;line-height:1;
  font-feature-settings:'tnum';
}
.step .body b{
  display:block;font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;
  font-size:1.0625rem;color:var(--cream);letter-spacing:-0.02em;
  margin-bottom:4px;text-transform:none;
}
.step .body span{font-size:.875rem;color:rgba(246,242,232,.7);line-height:1.5}

/* =====================================================================
   AREA / SERVICE COVERAGE
   ===================================================================== */
.area{padding:60px 0;background:var(--bg-alt)}
.area-list{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:var(--paper);border-radius:var(--r-lg);
  border:1px solid var(--line-soft);overflow:hidden;
}
.area-list li{
  font-family:'Archivo','DM Sans',sans-serif;font-weight:700;
  font-size:.9375rem;color:var(--ink);letter-spacing:-0.01em;
  padding:13px 16px;
  border-bottom:1px solid var(--line-soft);
  border-right:1px solid var(--line-soft);
  display:flex;align-items:center;gap:8px;
}
.area-list li::before{
  content:'';width:5px;height:5px;border-radius:50%;background:var(--accent);
  flex-shrink:0;
}
.area-list li:nth-child(2n){border-right:0}
.area-list li:nth-last-child(-n+2){border-bottom:0}
.area-note{
  margin-top:18px;text-align:center;
  font-size:.875rem;color:var(--ink-soft);line-height:1.5;
}
.area-note a{color:var(--ink);font-weight:600;border-bottom:1px solid var(--ink)}

/* =====================================================================
   QUOTE FORM
   ===================================================================== */
.quote{padding:60px 0 56px;background:var(--bg)}
.quote-card{
  background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--r-lg);padding:26px 22px 30px;
  box-shadow:var(--shadow-sm),var(--shadow-md);
}
.quote-card h2{margin:14px 0 10px;font-size:1.75rem}
.quote-card>p{font-size:.9375rem;line-height:1.5;color:var(--ink-mid);margin-bottom:22px;max-width:42ch}
.quote-card>p a{color:var(--ink);font-weight:700;border-bottom:1.5px solid var(--ink)}
.field{margin-bottom:14px}
.field label{
  display:block;font-family:'DM Sans',sans-serif;font-size:.6875rem;
  font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:6px;
}
.field input,.field textarea,.field select{
  width:100%;padding:14px 14px;
  border:1.5px solid var(--line);border-radius:var(--r);
  background:#fff;font-family:'DM Sans',sans-serif;
  font-size:16px;font-weight:500;color:var(--ink);
  -webkit-appearance:none;appearance:none;
  transition:border-color .15s,box-shadow .15s;
  min-height:48px;
}
.field textarea{min-height:96px}
.field select{
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23161310' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:0;border-color:var(--ink);box-shadow:0 0 0 3px rgba(20,15,8,.08);
}
.field textarea{resize:vertical;line-height:1.45}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.submit-row{margin-top:18px}
.submit-row .btn{width:100%}
.fine{font-size:.75rem;color:var(--ink-soft);margin-top:12px;line-height:1.5;text-align:center}

/* =====================================================================
   FINAL CTA BAND
   ===================================================================== */
.final{
  padding:64px 22px;background:var(--ink);color:var(--cream);
  text-align:center;position:relative;overflow:hidden;
  contain:paint;
}
.final-img{position:absolute;inset:0;background:center/cover no-repeat;opacity:.2}
.final-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(21,19,15,.55) 0%,rgba(21,19,15,.95) 100%);
}
.final-inner{position:relative;z-index:2;max-width:520px;margin:0 auto}
.final .eyebrow{color:var(--accent-soft);margin-bottom:16px}
.final h2{color:var(--cream);font-size:1.9375rem;line-height:1;margin-bottom:14px;letter-spacing:-0.035em;font-family:'Archivo Black','Archivo',sans-serif;font-weight:900}
.final h2 .accent{color:var(--accent-soft)}
.final p{color:rgba(246,242,232,.75);font-size:1rem;line-height:1.5;margin-bottom:26px}
.final-cta{display:flex;flex-direction:column;gap:10px}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:#0E0C09;color:rgba(246,242,232,.7);padding:48px 0 24px;font-size:.875rem}
.footer-brand{display:flex;align-items:center;gap:10px;color:var(--cream);margin-bottom:14px}
.footer-brand .brand-mark{background:var(--cream);color:var(--ink)}
.footer-brand .brand-text{color:var(--cream);font-size:.9375rem}
.footer-brand .brand-text small{color:rgba(246,242,232,.5)}
.footer-tag{color:rgba(246,242,232,.55);font-size:.875rem;line-height:1.55;margin-bottom:24px;max-width:34ch}
.footer-cols{
  display:grid;grid-template-columns:1fr 1fr;gap:28px 18px;
  padding-top:28px;border-top:1px solid rgba(246,242,232,.12);
  margin-bottom:28px;
}
.footer h4{
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(246,242,232,.5);margin-bottom:12px;
}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a,.footer-links li{color:rgba(246,242,232,.82);font-size:.875rem}
.footer-links a:hover{color:var(--accent-soft)}
.footer-call{
  padding:18px;background:rgba(246,242,232,.04);border-radius:var(--r-lg);
  margin-bottom:24px;display:flex;flex-direction:column;gap:4px;
}
.footer-call small{
  font-family:'DM Sans',sans-serif;font-size:.6875rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent-soft);
}
.footer-call a{
  font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;font-size:1.5rem;
  color:var(--cream);letter-spacing:-0.025em;
  font-feature-settings:'tnum';
}
.footer-call span{font-size:.8125rem;color:rgba(246,242,232,.5);margin-top:2px}
.footer-bottom{
  padding-top:20px;border-top:1px solid rgba(246,242,232,.12);
  display:flex;flex-direction:column;gap:6px;
  font-size:.6875rem;color:rgba(246,242,232,.4);letter-spacing:.04em;
}
.footer-bottom a{color:rgba(246,242,232,.55);border-bottom:1px solid rgba(246,242,232,.12)}

/* =====================================================================
   STICKY MOBILE BAR
   ===================================================================== */
.stickybar{
  position:fixed;left:8px;right:8px;
  bottom:calc(8px + env(safe-area-inset-bottom,0));z-index:50;
  display:flex;gap:5px;
  background:rgba(19,22,26,.96);backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
  padding:5px;border-radius:var(--r-pill);
  box-shadow:0 14px 36px rgba(0,0,0,.36),0 0 0 1px rgba(246,242,232,.06);
}
.stickybar a{
  flex:1 1 0;display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:14px 6px;border-radius:var(--r-pill);
  font-family:'DM Sans',sans-serif;font-size:.8125rem;font-weight:700;
  letter-spacing:.005em;min-height:46px;line-height:1;
  transition:background .12s ease;
}
.stickybar a.call{background:var(--accent);color:var(--cream)}
.stickybar a.call:active{background:var(--accent-dark);transform:translateY(1px)}
.stickybar a.text{background:rgba(246,242,232,.12);color:var(--cream)}
.stickybar a.text:active{background:rgba(246,242,232,.22);transform:translateY(1px)}
.stickybar a.quote{background:transparent;color:var(--cream);border:1.5px solid rgba(246,242,232,.22)}
.stickybar a.quote:active{background:rgba(246,242,232,.08);transform:translateY(1px)}
.stickybar svg{width:15px;height:15px;flex-shrink:0}
@media (max-width:380px){
  .stickybar{gap:4px;padding:4px}
  .stickybar a{font-size:.75rem;padding:12px 4px;gap:5px;min-height:44px}
  .stickybar svg{width:14px;height:14px}
}
body{padding-bottom:calc(72px + env(safe-area-inset-bottom,0))}

/* =====================================================================
   RELATED / OTHER SERVICES
   ===================================================================== */
.related{padding:60px 0;background:var(--bg)}
.related-grid{display:grid;grid-template-columns:1fr;gap:16px}
.related-card{
  display:block;background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--r-lg);overflow:hidden;
  transition:transform .15s ease,border-color .15s ease;
}
.related-card:hover{border-color:var(--ink)}
.related-card-img{aspect-ratio:16/10;background:#2A241D center/cover no-repeat}
.related-card-body{padding:18px 18px 22px}
.related-card .num{
  font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent);
}
.related-card h3{margin:8px 0 6px}
.related-card p{font-size:.9375rem;line-height:1.5;margin-bottom:14px}

/* =====================================================================
   MEDIA — Tablet ≥ 720
   ===================================================================== */
@media (min-width:720px){
  .container{padding:0 32px}
  h1{font-size:3.125rem}
  h2{font-size:2.5rem}
  h3{font-size:1.5rem}

  .brand-text{font-size:1rem}
  .brand-text small{display:block}

  .hero-frame{aspect-ratio:21/10}
  .hero-frame-caption .what{font-size:1.1875rem;max-width:280px}

  .cards{grid-template-columns:repeat(2,1fr);gap:20px}
  .feature-meta{grid-template-columns:repeat(3,1fr)}
  .area-list{grid-template-columns:repeat(3,1fr)}
  .area-list li:nth-child(2n){border-right:1px solid var(--line-soft)}
  .area-list li:nth-child(3n){border-right:0}
  .area-list li:nth-last-child(-n+2){border-bottom:1px solid var(--line-soft)}
  .area-list li:nth-last-child(-n+3){border-bottom:0}
  .field-row{gap:14px}
  .related-grid{grid-template-columns:1fr 1fr}
  .stickybar{display:none}
  body{padding-bottom:0}
  .cells{grid-template-columns:1fr 1fr;column-gap:48px}
}

/* =====================================================================
   MEDIA — Laptop ≥ 920 (hero 2-col, section heads grid, larger type)
   ===================================================================== */
@media (min-width:920px){
  .hero{padding:36px 0 0}
  .hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:40px;align-items:center}
  .hero-frame{aspect-ratio:4/5;order:2;max-height:580px}
  .hero-copy{padding:0;order:1;min-width:0}
  .hero-copy h1{font-size:2.875rem;margin-bottom:18px;line-height:.95}
  .hero-lead{font-size:1.0625rem;margin-bottom:24px}
  .hero-cta{flex-direction:row;flex-wrap:wrap}
  .hero-cta .btn{flex:0 1 auto;width:auto;min-width:0}
  .trust-row{grid-template-columns:repeat(4,1fr);margin-top:36px}
  .trust-chip{padding:14px 14px;border-right:1px solid var(--line-soft) !important;border-bottom:0 !important}
  .trust-chip:last-child{border-right:0 !important}
  .trust-chip .v{font-size:.9375rem}
  .section{padding:88px 0}
  .shead{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:44px}
  .shead h2{font-size:2.375rem;max-width:14ch}
  .shead .body{padding-bottom:6px}
  .shead p{font-size:1.0625rem;max-width:48ch}
  .cards{grid-template-columns:repeat(3,1fr);gap:20px}
  .cells{grid-template-columns:repeat(3,1fr);column-gap:40px}
  .process{padding:88px 0}
  .process-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:start}
  .process h2{font-size:2.375rem}
  .area{padding:88px 0}
  .area-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:56px;align-items:start}
  .quote{padding:88px 0}
  .quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
  .quote-image{aspect-ratio:4/5;background:center/cover no-repeat;border-radius:var(--r-lg);display:block !important}
  .quote-card{padding:36px}
  .quote-card h2{font-size:2rem}
  .related{padding:88px 0}
  .final{padding:112px 0}
  .final h2{font-size:2.75rem}
  .footer{padding:72px 0 28px}
  .footer-top{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start;margin-bottom:44px}
  .footer-cols{grid-template-columns:repeat(4,1fr);border:0;padding:0;margin:0;gap:28px}
  .footer-call{margin:0;align-items:flex-start}
  .footer-bottom{flex-direction:row;justify-content:space-between;font-size:.75rem}
  .gallery{grid-auto-flow:row;grid-auto-columns:auto;grid-template-columns:repeat(3,1fr);overflow:visible;padding:0 40px;max-width:1280px;margin:0 auto;gap:20px;scroll-snap-type:none}
  .work-card{scroll-snap-align:none}
  .feature{margin:36px 0 0}
  .feature .shot{aspect-ratio:21/9}
  .feature-meta{grid-template-columns:repeat(4,1fr);gap:24px}
}

/* =====================================================================
   MEDIA — Desktop ≥ 1200 (inline nav with all services)
   ===================================================================== */
@media (min-width:1200px){
  .container{padding:0 40px}
  h1{font-size:4rem;letter-spacing:-0.04em}
  h2{font-size:2.625rem}
  h3{font-size:1.5rem}

  .header-inner{padding:18px 0;gap:24px}
  .brand-mark{width:46px;height:46px;font-size:1rem;border-radius:8px}
  .brand-text{font-size:1rem}
  .brand-text small{font-size:.6875rem;letter-spacing:.14em;margin-top:3px}
  .call-pill{padding:11px 18px;font-size:.875rem;min-height:44px}
  .call-pill svg{width:14px;height:14px}
  .menu-btn{display:none}

  /* Inline desktop nav */
  .nav-bar{
    display:flex;align-items:center;gap:26px;
    flex:1 1 auto;justify-content:flex-end;
    padding-right:6px;
  }
  .nav-bar a{
    position:relative;
    font-family:'DM Sans',sans-serif;font-weight:600;font-size:.8125rem;
    color:var(--ink-mid);letter-spacing:.1em;text-transform:uppercase;
    padding:6px 0;
    transition:color .15s;
  }
  .nav-bar a:hover{color:var(--ink)}
  .nav-bar a.active{color:var(--accent)}
  .nav-bar a.active::after{
    content:'';position:absolute;left:0;right:0;bottom:-2px;height:2px;
    background:var(--accent);
  }
  .nav-bar .quote-cta{
    padding:10px 16px;border:1.5px solid var(--ink);border-radius:var(--r-pill);
    color:var(--ink);letter-spacing:.04em;font-size:.8125rem;
    transition:background .15s,color .15s;
    margin-left:4px;
  }
  .nav-bar .quote-cta:hover{background:var(--ink);color:var(--cream)}
  .nav-bar .quote-cta::after{display:none}

  .hero{padding:48px 0 0}
  .hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
  .hero-frame{aspect-ratio:4/5;order:2;max-height:640px}
  .hero-copy{padding:0;order:1;min-width:0}
  .hero-copy h1{font-size:3.5rem;margin-bottom:22px;line-height:.95}
  .hero-lead{font-size:1.0625rem;margin-bottom:28px}
  .hero-cta{flex-direction:row;flex-wrap:wrap}
  .hero-cta .btn{flex:0 1 auto;width:auto;min-width:0}
  .trust-row{grid-template-columns:repeat(4,1fr);margin-top:40px}
  .trust-chip{padding:16px 14px;border-right:1px solid var(--line-soft) !important;border-bottom:0 !important}
  .trust-chip:last-child{border-right:0 !important}
  .trust-chip .v{font-size:1rem}

  .section{padding:96px 0}
  .shead{
    display:grid;grid-template-columns:1fr 1fr;gap:48px;
    align-items:end;margin-bottom:48px;
  }
  .shead h2{font-size:2.75rem;max-width:14ch}
  .shead .body{padding-bottom:6px}
  .shead p{font-size:1.0625rem;max-width:48ch}

  .cards{grid-template-columns:repeat(3,1fr);gap:24px}
  .cards.four{grid-template-columns:repeat(4,1fr)}
  .cells{grid-template-columns:repeat(3,1fr);column-gap:48px}

  .feature{margin:48px 0 0}
  .feature .shot{aspect-ratio:21/9}
  .feature-meta{grid-template-columns:repeat(4,1fr);gap:32px}

  .process{padding:104px 0}
  .process-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
  .process h2{font-size:2.75rem}
  .step{grid-template-columns:auto 1fr;gap:22px;padding:24px 0}
  .step .n{font-size:1.875rem;min-width:48px}
  .step .body b{font-size:1.1875rem}

  .area{padding:104px 0}
  .area-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}
  .area-list{grid-template-columns:repeat(3,1fr)}
  .area-list li{font-size:1rem;padding:16px 18px}

  .quote{padding:104px 0}
  .quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
  .quote-image{aspect-ratio:4/5;background:center/cover no-repeat;border-radius:var(--r-lg);display:block !important}
  .quote-card{padding:40px}
  .quote-card h2{font-size:2.125rem}

  .related{padding:104px 0}
  .related-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .related-card-body{padding:22px 24px 26px}

  .final{padding:128px 0}
  .final h2{font-size:3.5rem}
  .final p{font-size:1.125rem}
  .final-cta{flex-direction:row;justify-content:center}

  .footer{padding:80px 0 32px}
  .footer-top{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start;margin-bottom:48px}
  .footer-cols{grid-template-columns:repeat(4,1fr);border:0;padding:0;margin:0;gap:32px}
  .footer-call{margin:0;align-items:flex-start}
  .footer-bottom{flex-direction:row;justify-content:space-between;font-size:.75rem}
}

/* ===== larger desktops ===== */
@media (min-width:1240px){
  h1{font-size:4.5rem}
  .hero-copy h1{font-size:4.5rem}
  .nav-bar{gap:32px}
}
@media (min-width:1440px){
  h1{font-size:5rem}
  .hero-copy h1{font-size:5rem}
  .brand-text{font-size:1.0625rem}
  .brand-mark{width:48px;height:48px}
}

/* =====================================================================
   NARROW PHONE polish
   ===================================================================== */
@media (max-width:719px){
  .brand-text .name{max-width:none}
}
@media (max-width:480px){
  .hero-frame{aspect-ratio:4/3}
  .svcgrid{gap:8px}
}
@media (max-width:480px){
  .header-inner{gap:8px;padding:10px 0}
  .brand{gap:9px}
  .brand-mark{width:34px;height:34px;font-size:.875rem;border-radius:5px}
  .brand-text{font-size:.75rem;letter-spacing:-0.02em}
  .brand-text small{display:none}
  .header-actions{flex-shrink:0;gap:6px}
  .call-pill{padding:8px 12px;font-size:.75rem;gap:6px;min-height:36px;flex-shrink:0}
  .call-pill svg{width:13px;height:13px}
  .menu-btn{padding:0 11px;height:36px;font-size:.75rem;gap:7px;flex-shrink:0}
  .menu-btn .lbl{display:none}
  .menu-btn .bars{width:14px}
}
@media (max-width:420px){
  h1{font-size:2.0625rem}
  h2{font-size:1.625rem}
  .shead h2{max-width:none}
  .hero-cta .btn,.final-cta .btn{padding:14px 18px}
  .svc-inner{padding:12px 12px 14px}
  .svc-name{font-size:.9375rem}
  .svc-num{font-size:.5625rem}
  .svc-arrow{width:28px;height:28px;top:9px;right:9px}
}
@media (max-width:380px){
  .container{padding:0 16px}
  h1{font-size:1.9375rem}
  .call-pill .num{display:none}
  .call-pill{padding:9px;min-width:38px;justify-content:center;gap:0}
  .stickybar a{font-size:.8125rem;padding:11px 8px;gap:6px}
  .area-list{grid-template-columns:1fr}
  .area-list li{border-right:0 !important}
}
@media (max-width:340px){
  .brand-text{display:none}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important}
  html{scroll-behavior:auto}
}

/* =====================================================================
   HOMEPAGE-SPECIFIC (services 2x2, promise, gallery)
   ===================================================================== */
.svcgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.svc{
  position:relative;display:block;
  background:var(--ink) center/cover no-repeat;
  border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:1/1;color:var(--cream);
  transition:transform .15s ease;
}
.svc:active{transform:scale(.98)}
.svc::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,17,13,0) 35%,rgba(15,17,13,.85) 100%);
}
.svc-inner{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px 14px 16px;display:flex;flex-direction:column;gap:4px}
.svc-num{font-family:'DM Sans',sans-serif;font-size:.625rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(246,242,232,.65)}
.svc-name{font-family:'Archivo Black','Archivo',sans-serif;font-weight:900;font-size:1rem;letter-spacing:-0.025em;line-height:1.05;color:var(--cream);text-transform:uppercase}
.svc-arrow{
  position:absolute;top:11px;right:11px;z-index:2;
  width:30px;height:30px;border-radius:50%;
  background:rgba(246,242,232,.18);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:grid;place-items:center;color:var(--cream);font-size:.8125rem;
}
.svc-arrow::before{content:'\2197'}

.gallery{
  display:grid;grid-auto-flow:column;grid-auto-columns:78%;
  gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:0 22px 6px;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;
}
.gallery::-webkit-scrollbar{display:none}
.work-card{scroll-snap-align:start}
.work-img{aspect-ratio:4/5;background:#2A241D center/cover no-repeat;border-radius:var(--r-lg)}
.work-meta{padding:14px 4px 0;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.work-meta h4{font-family:'Archivo','DM Sans',sans-serif;font-weight:800;font-size:1rem;color:var(--ink);letter-spacing:-0.015em;line-height:1.2}
.work-meta .small{font-family:'DM Sans',sans-serif;font-size:.625rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;flex-shrink:0}

@media (min-width:640px){
  .svcgrid{grid-template-columns:repeat(2,1fr);gap:14px}
  .svc{aspect-ratio:1}
  .gallery{grid-auto-columns:55%}
}
@media (min-width:920px){
  .gallery{
    display:grid;grid-auto-flow:row;grid-auto-columns:auto;
    grid-template-columns:repeat(3,1fr);
    overflow:visible;padding:0 40px;max-width:1280px;margin:0 auto;
    gap:20px;scroll-snap-type:none;
  }
  .work-card{scroll-snap-align:none}
  .svcgrid{grid-template-columns:repeat(4,1fr);gap:18px}
  .svc{aspect-ratio:3/4}
  .svc-name{font-size:1.125rem}
  .svc-inner{padding:16px}
}
@media (min-width:1200px){
  .svc-name{font-size:1.25rem}
  .svc-inner{padding:18px}
  .gallery{padding:0;gap:24px}
}
