/* =========================================================
   BUSHOR'S TREE SURGEONS — Workshop Ledger
   Heritage navy + brushed brass + warm bone
   Family arborists · Jacksonville · Since 1962
   ========================================================= */

:root{
  --navy:#0F2540;
  --navy-deep:#091828;
  --navy-tint:#1B3A5C;
  --brass:#B5894F;
  --brass-bright:#D4A668;
  --brass-deep:#8B6635;
  --bone:#F6F1E7;
  --bone-deep:#ECE3D0;
  --white:#FFFFFF;
  --ink:#0C1620;
  --ink-soft:#2B3744;
  --mute:#5D6873;
  --mute-dark:#A29B89;
  --rule:#E3DBC8;
  --rule-dark:#243A56;
  --leaf:#3E5E3A;
  --leaf-dark:#26401F;
  --red:#C32B1E;          /* Bushor real brand red (logo accent) */
  --red-deep:#9A2114;
  --alert:#C32B1E;

  --font-serif: 'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  --maxw: 1280px;
  --pad: clamp(20px, 4vw, 56px);
  --radius: 8px;
  --radius-lg: 16px;
  --shadow-sm: 0 1px 2px rgba(15,37,64,.06), 0 1px 3px rgba(15,37,64,.05);
  --shadow-md: 0 4px 12px rgba(15,37,64,.08), 0 12px 32px rgba(15,37,64,.10);
  --shadow-lg: 0 14px 36px rgba(15,37,64,.14), 0 36px 90px rgba(15,37,64,.16);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bone);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding: 0 var(--pad); }
.center{ text-align:center; }

/* ---------- TYPE ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono);
  font-size:11px; letter-spacing:.20em; text-transform:uppercase;
  color:var(--brass); font-weight:600;
}
.eyebrow::before{
  content:""; width:28px; height:1px; background:var(--brass);
}
.kicker{
  font-family:var(--font-mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--mute); font-weight:500;
}
.h-display{
  font-family:var(--font-serif);
  font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size: clamp(40px, 6.4vw, 88px);
  line-height:1.02;
  letter-spacing:-.02em;
  color:var(--white);
  margin:0;
}
.h-display em{
  font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100, "wght" 400;
  color:var(--brass-bright);
}
.h-display--ink{ color:var(--ink); }
.h-display--ink em{ color:var(--brass-deep); }
h1,h2,h3,h4{ font-family:var(--font-serif); font-weight:500; letter-spacing:-.015em; margin:0; }
.h-section{
  font-family:var(--font-serif);
  font-weight:500;
  font-variation-settings:"opsz" 144, "SOFT" 60;
  font-size: clamp(30px, 4.2vw, 56px);
  line-height:1.08;
  margin:0 0 16px;
}
.h-section em{ font-style:italic; color:var(--brass); font-variation-settings:"opsz" 144, "SOFT" 100, "wght" 400; }
.h-section--white{ color:var(--white); }
.h-section--white em{ color:var(--brass-bright); }
.lead{
  font-size:18px;
  color:var(--ink-soft);
  max-width:64ch;
  line-height:1.65;
}
.lead--white{ color:rgba(255,255,255,.78); }
.lead--mute{ color:var(--mute); }

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 26px;
  border-radius:6px;
  font-family:var(--font-sans);
  font-weight:600; font-size:15px;
  letter-spacing:.01em;
  border:0; cursor:pointer;
  min-height:54px;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn--brass{ background:var(--brass); color:var(--white); box-shadow: 0 8px 22px rgba(181,137,79,.34); }
.btn--brass:hover{ background:var(--brass-deep); }
.btn--ghost{ background:transparent; color:var(--white); border:1.5px solid rgba(255,255,255,.36); }
.btn--ghost:hover{ border-color:var(--white); background:rgba(255,255,255,.06); }
.btn--ink{ background:var(--navy); color:var(--white); }
.btn--ink:hover{ background:var(--navy-deep); }
.btn--bone{ background:var(--bone); color:var(--navy); border:1.5px solid var(--rule); }
.btn--bone:hover{ background:var(--bone-deep); }
.btn--block{ width:100%; justify-content:center; }
.btn--xl{ padding:20px 32px; font-size:17px; min-height:62px; }

.btn-call{
  display:inline-flex; align-items:center; gap:14px;
  background:var(--brass); color:var(--white);
  padding:16px 28px; border-radius:10px;
  font-weight:700; font-size:18px;
  box-shadow: 0 8px 24px rgba(181,137,79,.36);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  min-height:60px;
}
.btn-call:hover{ background:var(--brass-deep); transform:translateY(-1px); }
.btn-call__icon{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.22);
  display:grid;place-items:center;
  flex:0 0 36px;
}
.btn-call__icon svg{ width:18px; height:18px; fill:var(--white); }
.btn-call__num{ font-family:var(--font-serif); font-weight:500; font-size:22px; letter-spacing:-.01em; }
.btn-call__lab{ font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase; opacity:.92; font-weight:500; }

/* ---------- HEADER ---------- */
.site-header{
  position:sticky; top:0; z-index:80;
  background:rgba(246,241,231,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--rule);
  transition:box-shadow .25s ease, background .25s ease;
}
.site-header--scrolled{ box-shadow:0 6px 24px rgba(15,37,64,.10); background:rgba(246,241,231,.97); }
.hdr{
  display:flex; align-items:center; justify-content:space-between;
  height:78px; gap:24px;
}
.brand{ display:flex; align-items:center; gap:14px; }
.brand__mark{
  width:52px; height:52px;
  display:grid; place-items:center;
}
.brand__mark svg{ width:100%; height:100%; }
/* Real Bushor wordmark logo in header */
.brand__logo{ height:46px; width:auto; display:block; }
@media (max-width:640px){ .brand__logo{ height:38px; } }
.brand__text{ display:flex; flex-direction:column; line-height:1.1; }
.brand__name{
  font-family:var(--font-serif);
  font-weight:500;
  font-variation-settings:"opsz" 72, "SOFT" 50;
  font-size:20px;
  color:var(--navy);
  letter-spacing:-.01em;
}
.brand__sub{
  font-family:var(--font-mono);
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass); font-weight:500;
  margin-top:3px;
}

.hdr-nav{ display:flex; align-items:center; gap:28px; }
.hdr-nav a{
  font-size:14px; font-weight:500; color:var(--ink-soft);
  letter-spacing:.01em;
  position:relative; padding:8px 0;
  transition:color .15s ease;
}
.hdr-nav a:hover{ color:var(--navy); }
.hdr-nav a.active{ color:var(--navy); }
.hdr-nav a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:2px; background:var(--brass);
}
.hdr-cta{ display:flex; align-items:center; gap:14px; }
.hdr-phone{
  display:flex; flex-direction:column; align-items:flex-end; line-height:1.1;
  padding:10px 16px; border-radius:8px; border:1px solid var(--rule);
  background:var(--white);
  transition:border-color .15s ease;
}
.hdr-phone:hover{ border-color:var(--brass); }
.hdr-phone__lab{ font-family:var(--font-mono); font-size:9px; letter-spacing:.20em; text-transform:uppercase; color:var(--brass); font-weight:500;}
.hdr-phone__num{ font-family:var(--font-serif); font-size:17px; font-weight:500; color:var(--navy); margin-top:3px;}
.hdr-burger{
  width:46px; height:46px; border:1px solid var(--rule); background:var(--white); border-radius:8px;
  display:none; place-items:center; padding:0;
}
.hdr-burger span, .hdr-burger span::before, .hdr-burger span::after{
  content:""; display:block; width:18px; height:2px; background:var(--navy); border-radius:2px;
  transition:transform .2s ease;
}
.hdr-burger span{ position:relative; }
.hdr-burger span::before{ position:absolute; top:-6px; left:0; }
.hdr-burger span::after{ position:absolute; top:6px; left:0; }
.mob-menu{
  display:none; flex-direction:column; gap:0;
  padding: 8px var(--pad) 24px;
  border-top:1px solid var(--rule);
  background:var(--bone);
}
.mob-menu.open{ display:flex; }
.mob-menu a{
  padding:16px 0; border-bottom:1px solid var(--rule);
  font-size:16px; font-weight:500; color:var(--navy);
}

/* ---------- HERO ---------- */
.hero{
  position:relative; overflow:hidden;
  background:var(--navy);
  color:var(--white);
  padding: clamp(60px, 9vw, 120px) 0 clamp(80px, 10vw, 140px);
  isolation:isolate;
}
.hero__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(181,137,79,.18), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(62,94,58,.22), transparent 55%),
    linear-gradient(180deg, #0F2540 0%, #091828 100%);
  z-index:-1;
}
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(180deg, transparent 0, transparent 79px, rgba(255,255,255,.04) 79px, rgba(255,255,255,.04) 80px);
  opacity:.6;
}
.hero__inner{ position:relative; z-index:2; max-width:1080px; }
.hero__masthead{
  display:flex; align-items:center; gap:14px;
  padding-bottom:24px; border-bottom:1px solid rgba(255,255,255,.15);
  margin-bottom:36px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.20em; text-transform:uppercase;
  color:rgba(255,255,255,.62);
  flex-wrap:wrap;
}
.hero__masthead span{ display:inline-flex; align-items:center; gap:10px; }
.hero__masthead .sep{ width:6px; height:6px; border-radius:50%; background:var(--brass); padding:0; }

.hero__badge{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 16px; border-radius:999px;
  background:rgba(181,137,79,.16);
  border:1px solid rgba(181,137,79,.32);
  font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass-bright); font-weight:500;
  margin-bottom:28px;
}
.hero__title{ max-width:16ch; }
.hero__lead{
  margin-top:28px; max-width:58ch;
  color:rgba(255,255,255,.78);
  font-size:19px; line-height:1.6;
}
.hero__cta{ margin-top:40px; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero__meta{
  margin-top:64px;
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap:0;
  border-top:1px solid rgba(255,255,255,.18);
  padding-top:32px;
}
.hero__meta-item{
  display:flex; flex-direction:column; gap:8px;
  padding-right:24px;
  border-right:1px solid rgba(255,255,255,.10);
}
.hero__meta-item:last-child{ border-right:0; }
.hero__meta-item small{ font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase; color:var(--brass); font-weight:500; }
.hero__meta-item strong{ font-family:var(--font-serif); font-size:30px; font-weight:500; color:var(--white); font-variation-settings:"opsz" 72, "SOFT" 60; }

/* ---------- STICKY SERVICE BAR ---------- */
.svc-bar{
  position:sticky; top:78px; z-index:60;
  background:var(--navy-deep); color:var(--white);
  border-bottom:1px solid rgba(181,137,79,.30);
}
.svc-bar__inner{
  max-width:var(--maxw); margin:0 auto; padding: 0 var(--pad);
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap:0;
}
.svc-bar__item{
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:16px 12px;
  font-size:14px; font-weight:600;
  border-right:1px solid rgba(255,255,255,.10);
  transition:background .15s ease;
}
.svc-bar__item:last-child{ border-right:0; }
.svc-bar__item:hover{ background:rgba(255,255,255,.06); }
.svc-bar__item .ico{ width:18px; height:18px; display:inline-grid; place-items:center; }
.svc-bar__item .ico svg{ width:100%; height:100%; fill:var(--brass-bright); }
.svc-bar__item--alert{ background:var(--alert); }
.svc-bar__item--alert:hover{ background:#9A2E1A; }
.svc-bar__item--alert .ico svg{ fill:var(--white); }

/* ---------- SECTIONS ---------- */
.section{ padding: clamp(72px, 9vw, 120px) 0; position:relative; }
.section--bone{ background:var(--bone); }
.section--bone-deep{ background:var(--bone-deep); }
.section--white{ background:var(--white); }
.section--navy{ background:var(--navy); color:var(--white); }
.section--navy-deep{ background:var(--navy-deep); color:var(--white); }
.section--leaf{ background:var(--leaf-dark); color:var(--white); }
.section-head{ max-width:760px; margin-bottom:60px; }
.section-head.center{ margin-left:auto; margin-right:auto; }
.section-head .lead{ margin-top:14px; }

/* ---------- BRAND STRIP / CREDENTIALS ---------- */
.cred-strip{
  background:var(--bone-deep);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:32px 0;
}
.cred-strip__inner{
  display:grid; grid-template-columns: repeat(5, 1fr);
  gap:24px; align-items:center;
}
.cred{
  display:flex; flex-direction:column; align-items:center; gap:8px;
  text-align:center;
  border-right:1px solid var(--rule);
  padding:8px 16px;
}
.cred:last-child{ border-right:0; }
.cred__big{
  font-family:var(--font-serif);
  font-size:32px; font-weight:500; color:var(--navy);
  font-variation-settings:"opsz" 72, "SOFT" 60;
  letter-spacing:-.01em;
}
.cred__lab{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase;
  color:var(--mute); font-weight:500;
}

/* ---------- SERVICES GRID ---------- */
.svc-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--rule);
  border-left:1px solid var(--rule);
}
.svc-card{
  background:var(--white);
  padding:40px 32px;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  display:flex; flex-direction:column; gap:14px;
  transition:background .15s ease;
}
.svc-card:hover{ background:var(--bone); }
.svc-card__num{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.20em;
  color:var(--brass); font-weight:500;
}
.svc-card__icon{
  width:48px; height:48px; margin-bottom:8px;
  display:grid; place-items:center;
  color:var(--brass);
}
.svc-card__icon svg{ width:100%; height:100%; fill:currentColor; }
.svc-card__title{
  font-family:var(--font-serif);
  font-size:24px; font-weight:500;
  color:var(--navy);
  letter-spacing:-.01em;
  font-variation-settings:"opsz" 72, "SOFT" 70;
}
.svc-card__blurb{ font-size:15px; line-height:1.6; color:var(--ink-soft); margin:0; }
.svc-card__list{ list-style:none; padding:0; margin:8px 0 0; font-size:14px; color:var(--mute); }
.svc-card__list li{ padding:6px 0; border-top:1px solid var(--rule); display:flex; align-items:center; gap:10px; }
.svc-card__list li::before{ content:"●"; color:var(--brass); font-size:10px; }
.svc-card__cta{
  margin-top:auto; padding-top:18px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.20em; text-transform:uppercase;
  color:var(--navy); font-weight:600;
  display:inline-flex; align-items:center; gap:8px;
  border-top:1px solid var(--rule);
}
.svc-card__cta:hover{ color:var(--brass); }

/* ---------- STORY / 3-GEN TIMELINE ---------- */
.story{
  display:grid; grid-template-columns: 1.05fr 1fr;
  gap:80px; align-items:start;
}
.story__img{
  position:relative;
  aspect-ratio: 4/5;
  background:var(--bone-deep);
  overflow:hidden;
  border-radius: var(--radius);
}
.story__img img{ width:100%; height:100%; object-fit:cover; }
.story__img-badge{
  position:absolute; bottom:20px; left:20px; right:20px;
  background:var(--navy); color:var(--white);
  padding:16px 20px; border-radius:6px;
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:500;
}
.story__img-badge span{ color:var(--brass-bright); font-size:14px; }
.story__intro{ padding-top:8px; }
.story__pillars{
  margin-top:36px;
  display:grid; grid-template-columns: repeat(2,1fr); gap:0;
  border-top:1px solid var(--rule);
  border-left:1px solid var(--rule);
}
.pillar{
  padding:20px 24px;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.pillar__lab{ font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase; color:var(--brass); font-weight:500;}
.pillar__val{ font-family:var(--font-serif); font-size:30px; font-weight:500; color:var(--navy); margin-top:8px; font-variation-settings:"opsz" 72, "SOFT" 60; }

/* ---------- 3 GENERATIONS BAND ---------- */
.gens{ display:grid; grid-template-columns: repeat(3,1fr); gap:0; }
.gen-card{
  background:var(--white);
  padding:48px 36px;
  border:1px solid var(--rule);
  border-right:0;
}
.gen-card:last-child{ border-right:1px solid var(--rule); }
.gen-card__year{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.22em;
  color:var(--brass); font-weight:600;
}
.gen-card__name{
  font-family:var(--font-serif); font-size:30px; font-weight:500;
  color:var(--navy); margin-top:12px;
  font-variation-settings:"opsz" 96, "SOFT" 70;
  letter-spacing:-.01em;
}
.gen-card__role{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--mute); font-weight:500;
  margin-top:6px;
}
.gen-card__credo{
  font-family:var(--font-serif); font-style:italic;
  font-size:17px; line-height:1.55; color:var(--ink-soft);
  margin-top:20px;
  font-variation-settings:"opsz" 14, "SOFT" 100, "wght" 400;
}
.gen-card__cert{
  margin-top:24px; padding-top:18px;
  border-top:1px solid var(--rule);
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft); font-weight:500;
  display:flex; flex-direction:column; gap:6px;
}
.gen-card__cert span{ color:var(--brass); }

/* ---------- SERVICE AREAS GRID ---------- */
.areas{
  display:grid; grid-template-columns: 1fr 1.3fr;
  gap:64px; align-items:start;
}
.areas-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:0;
  border-top:1px solid rgba(255,255,255,.15);
  border-left:1px solid rgba(255,255,255,.15);
}
.area-tile{
  padding:24px 22px;
  border-right:1px solid rgba(255,255,255,.15);
  border-bottom:1px solid rgba(255,255,255,.15);
  background:transparent;
}
.area-tile__name{
  display:block;
  font-family:var(--font-serif); font-size:20px; font-weight:500;
  color:var(--white); letter-spacing:-.01em;
  font-variation-settings:"opsz" 48, "SOFT" 60;
}
.area-tile__note{
  display:block; margin-top:6px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass-bright); font-weight:500;
}
.area-tile--home{ background:rgba(181,137,79,.14); }

/* ---------- REVIEWS ---------- */
.reviews{ display:grid; grid-template-columns: repeat(3, 1fr); gap:24px; }
.review{
  background:var(--white);
  padding:32px 28px;
  border:1px solid var(--rule);
  border-radius:var(--radius);
  display:flex; flex-direction:column; gap:18px;
}
.review__stars{ color:var(--brass); font-size:18px; letter-spacing:2px; }
.review__quote{
  font-family:var(--font-serif); font-style:italic; font-size:18px; line-height:1.5;
  color:var(--ink); margin:0;
  font-variation-settings:"opsz" 14, "SOFT" 100, "wght" 400;
}
.review__author{ display:flex; align-items:center; gap:14px; margin-top:auto; padding-top:18px; border-top:1px solid var(--rule); }
.review__avatar{
  width:42px; height:42px; border-radius:50%;
  background:var(--navy); color:var(--brass-bright);
  display:grid; place-items:center;
  font-family:var(--font-serif); font-weight:500; font-size:15px;
}
.review__name{ font-size:13px; font-weight:600; color:var(--navy); }
.review__src{ font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); margin-top:2px;}
.reviews-strip{
  margin-top:48px;
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
  border-top:1px solid var(--rule);
}
.reviews-strip__item{
  padding:28px 16px; text-align:center;
  border-right:1px solid var(--rule);
}
.reviews-strip__item:last-child{ border-right:0; }
.reviews-strip__rating{
  font-family:var(--font-serif); font-size:26px; font-weight:500; color:var(--navy);
  font-variation-settings:"opsz" 48, "SOFT" 60;
}
.reviews-strip__src{ font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); margin-top:6px; }

/* ---------- QUOTE FORM ---------- */
.quote{
  display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap:64px; align-items:start;
}
.quote__why{ list-style:none; padding:0; margin:20px 0 0; }
.quote__why li{
  padding:12px 0; border-bottom:1px solid var(--rule);
  display:flex; align-items:center; gap:12px;
  font-size:15px; color:var(--ink-soft);
}
.quote__why li::before{ content:"●"; color:var(--brass); font-size:10px; }
.form{
  background:var(--white);
  padding:36px;
  border:1px solid var(--rule);
  border-radius:var(--radius);
}
.form__row{ display:grid; gap:18px; margin-bottom:18px; }
.form__row--2{ grid-template-columns:1fr 1fr; }
.field{ display:flex; flex-direction:column; gap:6px; min-width:0; }
.field label{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass); font-weight:600;
}
.field input, .field select, .field textarea{
  width:100%; min-width:0; max-width:100%;
  padding:14px 14px;
  border:1px solid var(--rule);
  border-radius:6px;
  background:var(--bone);
  font-family:var(--font-sans); font-size:15px; color:var(--ink);
  transition:border-color .15s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--brass); background:var(--white);
}
.field textarea{ resize:vertical; min-height:120px; }
.form__note{
  margin-top:14px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.14em;
  color:var(--mute); text-transform:uppercase;
}

/* ---------- CTA BAND ---------- */
.cta-band{
  background:var(--navy-deep); color:var(--white);
  padding: clamp(60px, 8vw, 96px) 0;
  text-align:center;
  position:relative; overflow:hidden;
}
.cta-band::before{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(90deg, transparent 0, transparent 79px, rgba(255,255,255,.04) 79px, rgba(255,255,255,.04) 80px);
  opacity:.5;
}
.cta-band .wrap{ position:relative; z-index:2; }
.cta-band__title{
  font-family:var(--font-serif); font-weight:500;
  font-size:clamp(32px, 4.4vw, 56px);
  color:var(--white);
  font-variation-settings:"opsz" 144, "SOFT" 60;
  letter-spacing:-.02em;
  margin:0 0 16px;
}
.cta-band__title em{ font-style:italic; color:var(--brass-bright); font-variation-settings:"opsz" 144, "SOFT" 100, "wght" 400; }
.cta-band__lead{ color:rgba(255,255,255,.78); font-size:18px; margin:0 auto 32px; max-width:64ch; }

/* ---------- FOOTER ---------- */
.foot{
  background:var(--navy-deep); color:rgba(255,255,255,.62);
  padding: 72px 0 32px;
  border-top:6px solid var(--brass);
}
.foot__grid{
  display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.foot__brand{ display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.foot__logo-chip{
  background:var(--bone); border-radius:10px;
  padding:10px 14px; display:inline-grid; place-items:center;
  box-shadow:0 4px 14px rgba(0,0,0,.25);
}
.foot__logo-chip img{ height:42px; width:auto; display:block; }
.foot__brand .brand__name{ color:var(--white); font-size:18px; }
.foot__brand .brand__sub{ color:var(--brass-bright); }
.foot__about{ font-size:14px; line-height:1.6; max-width:42ch; color:rgba(255,255,255,.62); }
.foot__phone{
  display:flex; flex-direction:column; gap:4px;
  background:rgba(181,137,79,.12);
  border:1px solid rgba(181,137,79,.32);
  padding:14px 18px; border-radius:8px;
  margin-top:18px; max-width:280px;
}
.foot__phone .lab{ font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase; color:var(--brass-bright); font-weight:500; }
.foot__phone .num{ font-family:var(--font-serif); font-size:20px; color:var(--white); font-weight:500; }
.foot h4{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--brass); font-weight:600;
  margin:0 0 18px;
}
.foot ul{ list-style:none; padding:0; margin:0; }
.foot ul li{ padding:6px 0; font-size:14px; line-height:1.5; }
.foot ul li a{ color:rgba(255,255,255,.7); transition:color .15s ease; }
.foot ul li a:hover{ color:var(--brass-bright); }
.foot__bottom{
  padding-top:28px; display:flex; justify-content:space-between; gap:24px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.42);
  flex-wrap:wrap;
}
.foot__credit a{ color:var(--brass-bright); }

/* ---------- INNER PAGE HERO ---------- */
.page-hero{
  background:var(--navy);
  color:var(--white);
  padding: clamp(80px, 8vw, 120px) 0 clamp(60px, 6vw, 96px);
  border-bottom:1px solid var(--rule-dark);
  position:relative; overflow:hidden;
}
.page-hero__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 70% 30%, rgba(181,137,79,.16), transparent 50%),
    linear-gradient(180deg, #0F2540 0%, #091828 100%);
  z-index:0;
}
.page-hero .wrap{ position:relative; z-index:2; }
.page-hero__crumbs{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.20em; text-transform:uppercase;
  color:var(--brass-bright); margin-bottom:24px;
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
}
.page-hero__crumbs a{ color:var(--brass-bright); }
.page-hero__crumbs .sep{ opacity:.5; }
.page-hero__title{
  font-family:var(--font-serif); font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 60;
  font-size:clamp(40px, 6vw, 80px);
  line-height:1.04; letter-spacing:-.02em;
  color:var(--white);
  max-width:18ch;
  margin:0;
}
.page-hero__title em{ font-style:italic; color:var(--brass-bright); font-variation-settings:"opsz" 144, "SOFT" 100, "wght" 400; }
.page-hero__lead{
  margin-top:24px; max-width:60ch;
  color:rgba(255,255,255,.78);
  font-size:18px; line-height:1.6;
}

/* ---------- LONG SERVICES PAGE ---------- */
.svc-long{ display:flex; flex-direction:column; gap:0; }
.svc-long__row{
  display:grid; grid-template-columns: 1fr 1fr;
  gap:60px; align-items:center;
  padding: 60px 0;
  border-bottom:1px solid var(--rule);
}
.svc-long__row:last-child{ border-bottom:0; }
.svc-long__row--rev{ direction:rtl; }
.svc-long__row--rev > *{ direction:ltr; }
.svc-long__copy h3{
  font-family:var(--font-serif); font-weight:500;
  font-variation-settings:"opsz" 144, "SOFT" 70;
  font-size:clamp(28px, 3.6vw, 42px);
  color:var(--navy); margin:8px 0 12px;
  letter-spacing:-.01em;
}
.svc-long__copy h3 em{ font-style:italic; color:var(--brass); }
.svc-long__copy .lead{ margin-bottom:18px; }
.svc-long__copy ul{ list-style:none; padding:0; margin:0; }
.svc-long__copy ul li{
  padding:10px 0; border-top:1px solid var(--rule);
  display:flex; align-items:flex-start; gap:14px;
  font-size:15px; color:var(--ink-soft);
}
.svc-long__copy ul li::before{
  content:"●"; color:var(--brass); font-size:9px; padding-top:8px;
}
.svc-long__visual{
  aspect-ratio: 4/3; background:var(--bone-deep);
  border-radius:var(--radius); overflow:hidden; position:relative;
}
.svc-long__visual img{ width:100%; height:100%; object-fit:cover; }
.svc-long__badge{
  position:absolute; top:18px; left:18px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase;
  color:var(--white); background:rgba(15,37,64,.86);
  padding:8px 12px; border-radius:4px; font-weight:600;
}

/* ---------- ABOUT TIMELINE ---------- */
.timeline{
  display:flex; flex-direction:column; gap:0;
  border-top:1px solid var(--rule);
}
.tl-row{
  display:grid; grid-template-columns: 180px 1fr;
  gap:48px; padding:36px 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
}
.tl-year{
  font-family:var(--font-serif); font-weight:500;
  font-size:44px; color:var(--brass);
  font-variation-settings:"opsz" 96, "SOFT" 60;
  letter-spacing:-.01em;
  line-height:1;
}
.tl-tag{
  display:block; margin-top:8px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase;
  color:var(--mute); font-weight:500;
}
.tl-body h4{
  font-family:var(--font-serif); font-size:24px; font-weight:500; color:var(--navy);
  font-variation-settings:"opsz" 72, "SOFT" 70;
  margin:0 0 10px;
}
.tl-body p{ font-size:16px; line-height:1.6; color:var(--ink-soft); margin:0; max-width:64ch; }

/* ---------- AREA PAGE GRID ---------- */
.area-page-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:0;
  border-top:1px solid var(--rule);
  border-left:1px solid var(--rule);
}
.area-page-tile{
  background:var(--white);
  padding:32px 28px;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  display:flex; flex-direction:column; gap:10px;
}
.area-page-tile__name{
  font-family:var(--font-serif); font-size:26px; font-weight:500; color:var(--navy);
  font-variation-settings:"opsz" 72, "SOFT" 70;
  letter-spacing:-.01em;
}
.area-page-tile__county{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.20em; text-transform:uppercase;
  color:var(--brass); font-weight:500;
}
.area-page-tile__copy{ font-size:14px; color:var(--ink-soft); line-height:1.55; margin:8px 0 0; }
.area-page-tile--home{
  background:var(--navy); color:var(--white);
}
.area-page-tile--home .area-page-tile__name{ color:var(--white); }
.area-page-tile--home .area-page-tile__copy{ color:rgba(255,255,255,.78); }
.area-page-tile--home .area-page-tile__county{ color:var(--brass-bright); }

/* ---------- CONTACT PAGE ---------- */
.contact-grid{
  display:grid; grid-template-columns: 1fr 1fr;
  gap:60px;
}
.contact-card{
  background:var(--white);
  border:1px solid var(--rule);
  border-radius:var(--radius);
  padding:32px;
}
.contact-card h4{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--brass); font-weight:600;
  margin:0 0 16px;
}
.contact-card .big{
  font-family:var(--font-serif); font-size:24px; font-weight:500; color:var(--navy);
  font-variation-settings:"opsz" 72, "SOFT" 70;
  letter-spacing:-.01em;
  margin:0 0 8px;
}
.contact-card p{ font-size:15px; line-height:1.6; color:var(--ink-soft); margin:0 0 12px; }
.contact-stack{ display:flex; flex-direction:column; gap:24px; }
.map-frame{
  width:100%; aspect-ratio:1/1;
  border:1px solid var(--rule);
  border-radius:var(--radius); overflow:hidden;
}
.map-frame iframe{ width:100%; height:100%; border:0; }

/* ---------- DIVIDER (TREE-RING SVG) ---------- */
.divider{
  display:flex; justify-content:center; align-items:center; gap:14px;
  padding: 28px 0;
}
.divider__line{ flex:1; height:1px; background:var(--rule); max-width:200px; }
.divider__mark{ width:24px; height:24px; color:var(--brass); }
.divider--white .divider__line{ background:rgba(255,255,255,.20); }
.divider--white .divider__mark{ color:var(--brass-bright); }

/* ============================================================
   PREMIUM ADD-ONS — real-photo hero, gallery, ISA badge, seals
   ============================================================ */

/* ---------- SPLIT HERO (text left · real climber photo right) ---------- */
.hero--split .hero__inner{ max-width:var(--maxw); }
.hero__grid{
  display:grid; grid-template-columns: 1.05fr .95fr;
  gap:64px; align-items:center;
}
.hero__photo{
  position:relative;
  aspect-ratio: 4/5;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid rgba(181,137,79,.4);
  box-shadow: 0 30px 80px rgba(0,0,0,.45);
}
.hero__photo img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1.04);
  will-change:transform;
}
.hero__photo::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(9,24,40,.55) 100%);
}
/* Brass "Since 1962" seal on the hero photo */
.hero__seal{
  position:absolute; bottom:18px; left:18px; z-index:3;
  width:96px; height:96px; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, #14304D 0%, #0B2138 100%);
  border:2px solid var(--brass);
  display:grid; place-items:center; text-align:center;
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
}
.hero__seal-inner{
  border:1px solid rgba(181,137,79,.5);
  border-radius:50%; width:80px; height:80px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1px;
}
.hero__seal-est{ font-family:var(--font-mono); font-size:8px; letter-spacing:.22em; color:var(--brass-bright); text-transform:uppercase; }
.hero__seal-yr{ font-family:var(--font-serif); font-size:26px; color:#fff; font-weight:500; line-height:1; font-variation-settings:"opsz" 48, "SOFT" 60; }
.hero__seal-sub{ font-family:var(--font-mono); font-size:7px; letter-spacing:.16em; color:var(--brass-bright); text-transform:uppercase; }
.hero__photo-cap{
  position:absolute; bottom:16px; right:16px; z-index:3;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.82); background:rgba(9,24,40,.6);
  padding:6px 10px; border-radius:4px; backdrop-filter:blur(4px);
}

/* ---------- COUNT-UP STAT (hero meta uses .num) ---------- */
.hero__meta-item strong .num{ font-variant-numeric:tabular-nums; }

/* ---------- REAL-PHOTO GALLERY (masonry) ---------- */
.gallery-note{
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass); font-weight:500; margin-top:18px;
}
.gallery-note::before{ content:"●"; color:var(--red); }
.gallery{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
  grid-auto-flow: dense;
  gap:14px;
  margin-top:8px;
}
.gallery__item{
  position:relative; overflow:hidden;
  border-radius:var(--radius);
  background:var(--bone-deep);
}
.gallery__item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s cubic-bezier(.2,.7,.3,1);
}
.gallery__item:hover img{ transform:scale(1.07); }
.gallery__item::after{
  content:attr(data-cap);
  position:absolute; left:0; right:0; bottom:0;
  padding:24px 14px 12px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:#fff;
  background:linear-gradient(180deg, transparent, rgba(9,24,40,.82));
  opacity:0; transform:translateY(8px);
  transition:opacity .3s ease, transform .3s ease;
}
.gallery__item:hover::after{ opacity:1; transform:translateY(0); }
.gallery__item--wide{ grid-column:span 2; }
.gallery__item--tall{ grid-row:span 2; }
.gallery__item--big{ grid-column:span 2; grid-row:span 2; }

/* ---------- ISA BADGE / CRED LOGOS ---------- */
.isa-badge{ height:120px; width:auto; display:block; }
.cred-logos{
  display:flex; align-items:center; gap:28px; flex-wrap:wrap;
}
.cred-logos img{ display:block; }
.isa-inline{ height:64px; width:auto; }
.badges-inline{ height:54px; width:auto; opacity:.9; }

/* story photo: use real climber, taller */
.story__img--real{ aspect-ratio: 3/4; }

/* fleet feature band */
.fleet{
  display:grid; grid-template-columns: 1.2fr 1fr; gap:60px; align-items:center;
}
.fleet__img{
  border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--rule);
  box-shadow:var(--shadow-md);
  aspect-ratio: 16/13;
}
.fleet__img img{ width:100%; height:100%; object-fit:cover; }

@media (max-width: 1024px){
  .hero__grid{ grid-template-columns:1fr; gap:40px; }
  .hero__photo{ aspect-ratio:4/3; max-height:440px; order:2; }
  .gallery{ grid-template-columns: repeat(2, 1fr); grid-auto-rows:180px; }
  .gallery__item--big{ grid-column:span 2; grid-row:span 1; }
  .fleet{ grid-template-columns:1fr; gap:32px; }
}
@media (max-width: 640px){
  .gallery{ grid-template-columns: 1fr; grid-auto-rows:220px; }
  .gallery__item--wide, .gallery__item--big{ grid-column:span 1; }
  .hero__seal{ width:78px; height:78px; }
  .hero__seal-inner{ width:64px; height:64px; }
  .hero__seal-yr{ font-size:20px; }
}

/* ---------- RESPONSIVE 2-COL UTILITY (replaces inline grids) ---------- */
.gridx2{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:60px; align-items:center;
}
.badge2x2{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:1px; background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.18);
}
@media (max-width: 900px){
  .gridx2{ grid-template-columns:1fr; gap:36px; }
}

/* ---------- REVEAL ANIMATIONS (FAIL-OPEN) ---------- */
.reveal{ opacity:1; transform:none; }
.reveal--hidden{ opacity:0; transform: translateY(20px); transition: opacity .8s ease, transform .8s ease; }
.reveal--shown{ opacity:1; transform:none; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px){
  .hdr-nav{ display:none; }
  .hdr-burger{ display:grid; }
  .hdr-phone{ display:none; }
  .hero__meta{ grid-template-columns: repeat(2,1fr); gap:20px 0; }
  .hero__meta-item{ padding-right:16px; }
  .hero__meta-item:nth-child(2){ border-right:0; }
  .svc-bar__inner{ grid-template-columns: repeat(2, 1fr); }
  .svc-bar__item{ border-bottom:1px solid rgba(255,255,255,.10); }
  .svc-bar__item:nth-child(2){ border-right:0; }
  .svc-grid{ grid-template-columns: repeat(2, 1fr); }
  .story{ grid-template-columns:1fr; gap:48px; }
  .gens{ grid-template-columns:1fr; }
  .gen-card{ border-right:1px solid var(--rule); border-bottom:0; }
  .gen-card:last-child{ border-bottom:1px solid var(--rule); }
  .areas{ grid-template-columns:1fr; gap:36px; }
  .areas-grid{ grid-template-columns: repeat(2, 1fr); }
  .reviews{ grid-template-columns: 1fr; }
  .reviews-strip{ grid-template-columns:1fr; }
  .reviews-strip__item{ border-right:0; border-bottom:1px solid var(--rule); }
  .reviews-strip__item:last-child{ border-bottom:0; }
  .quote{ grid-template-columns:minmax(0,1fr); gap:40px; }
  .foot__grid{ grid-template-columns: 1fr 1fr; gap:36px; }
  .cred-strip__inner{ grid-template-columns: repeat(3,1fr); }
  .cred{ border-bottom:1px solid var(--rule); padding-bottom:16px; }
  .cred:nth-child(3){ border-right:0; }
  .svc-long__row{ grid-template-columns: 1fr; gap:32px; padding:40px 0; }
  .svc-long__row--rev{ direction:ltr; }
  .tl-row{ grid-template-columns: 1fr; gap:12px; }
  .area-page-grid{ grid-template-columns: repeat(2,1fr); }
  .contact-grid{ grid-template-columns: 1fr; gap:36px; }
}
@media (max-width: 640px){
  .hero__meta{ grid-template-columns: 1fr; }
  .hero__meta-item{ border-right:0; border-bottom:1px solid rgba(255,255,255,.10); padding-bottom:20px; }
  .hero__meta-item:last-child{ border-bottom:0; }
  .svc-bar__inner{ grid-template-columns: 1fr; }
  .svc-bar__item{ border-right:0; }
  .svc-grid{ grid-template-columns: 1fr; }
  .areas-grid{ grid-template-columns: 1fr; }
  .form__row--2{ grid-template-columns: 1fr; }
  .foot__grid{ grid-template-columns: 1fr; }
  .cred-strip__inner{ grid-template-columns: 1fr; }
  .cred{ border-right:0; border-bottom:1px solid var(--rule); padding-bottom:20px; }
  .cred:last-child{ border-bottom:0; }
  .area-page-grid{ grid-template-columns:1fr; }
  .hdr{ height:68px; }
  .brand__name{ font-size:17px; }
  .brand__sub{ font-size:9px; }
  .svc-bar{ top:68px; }
  .pillar__val{ font-size:24px; }
}
