/* =========================================================================
   Ozark Fence Co. — Design System
   Brand: blue (lighter than navy) + white, cedar accent. Rogers, Arkansas.
   Authored hand-coded; no framework. WCAG 2.2 AA targeted.
   ========================================================================= */

/* ---------- Tokens ---------- */
:root {
  /* Brand blue (lighter than navy) */
  --blue-900:#0f2c52;
  --blue-800:#143a6b;
  --blue-700:#1d5fae;   /* primary */
  --blue-600:#2570c6;
  --blue-500:#2f80d6;   /* links / accent */
  --blue-300:#9cc0ef;
  --blue-200:#bcd4f2;
  --blue-100:#dbe8f8;
  --blue-50:#eef4fc;
  /* Cedar (natural wood accent) */
  --cedar-700:#8f5326;
  --cedar-600:#a9622f;
  --cedar-500:#b9763f;
  --cedar-100:#f3e7d8;
  /* Neutrals */
  --ink:#13212f;
  --slate:#3f5468;
  --muted:#667085;
  --line:#e4e9f0;
  --line-2:#eef2f7;
  --mist:#f5f8fc;
  --paper:#ffffff;
  --ok:#1c8a4e;

  --container:1180px;
  --container-narrow:820px;
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:22px;
  --radius-pill:999px;

  --shadow-sm:0 1px 2px rgba(16,32,55,.06), 0 1px 3px rgba(16,32,55,.08);
  --shadow:0 8px 24px -10px rgba(16,40,82,.22);
  --shadow-lg:0 26px 60px -22px rgba(13,33,68,.38);

  --font-display:"Archivo","Archivo Fallback",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-body:"Inter","Inter Fallback",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  --step--1:clamp(.82rem,.79rem + .12vw,.9rem);
  --step-0:clamp(1rem,.96rem + .2vw,1.075rem);
  --step-1:clamp(1.18rem,1.1rem + .35vw,1.35rem);
  --step-2:clamp(1.42rem,1.28rem + .6vw,1.75rem);
  --step-3:clamp(1.7rem,1.45rem + 1.1vw,2.35rem);
  --step-4:clamp(2.05rem,1.6rem + 2vw,3.15rem);
  --step-5:clamp(2.05rem,1.5rem + 2.9vw,4.1rem);

  --gap:clamp(1rem,.7rem + 1.4vw,1.6rem);
  --section-y:clamp(3.2rem,2.4rem + 3.6vw,6rem);
}

/* Fallback metric adjust to reduce CLS before webfont loads */
@font-face{font-family:"Inter Fallback";src:local("Arial");size-adjust:107%;ascent-override:90%;descent-override:22%;line-gap-override:0%;}
@font-face{font-family:"Archivo Fallback";src:local("Arial");size-adjust:104%;ascent-override:88%;descent-override:22%;line-gap-override:0%;}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:7.5rem}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}
body{margin:0;font-family:var(--font-body);font-size:var(--step-0);line-height:1.65;color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,picture,svg,video{display:block;max-width:100%;height:auto}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.1;letter-spacing:-.018em;color:var(--ink);margin:0 0 .5em;font-weight:800;overflow-wrap:break-word}
h1{font-size:var(--step-5);letter-spacing:-.03em}
h2{font-size:var(--step-4);letter-spacing:-.025em}
h3{font-size:var(--step-2)}
h4{font-size:var(--step-1)}
p{margin:0 0 1em}
a{color:var(--blue-600);text-decoration-color:color-mix(in srgb,var(--blue-600) 35%,transparent);text-underline-offset:3px}
a:hover{color:var(--blue-700)}
ul,ol{margin:0 0 1em;padding-left:1.2em}
strong{font-weight:700}
hr{border:0;border-top:1px solid var(--line);margin:2rem 0}
:focus-visible{outline:3px solid var(--blue-500);outline-offset:2px;border-radius:4px}
::selection{background:var(--blue-100)}

/* ---------- Layout ---------- */
.container{width:min(100% - 2.4rem,var(--container));margin-inline:auto}
.container-narrow{width:min(100% - 2.4rem,var(--container-narrow));margin-inline:auto}
.section{padding-block:var(--section-y)}
.section--mist{background:var(--mist)}
.section--ink{background:var(--blue-900);color:#dfe8f4}
.section--ink h2,.section--ink h3{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:700;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-700)}
.section--ink .eyebrow{color:var(--blue-200)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--cedar-500);display:inline-block}
.lede{font-size:var(--step-1);color:var(--slate);line-height:1.55}
.center{text-align:center}
.measure{max-width:62ch}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--blue-700);color:#fff;padding:.7rem 1.1rem;
  border-radius:0 0 var(--radius-sm) 0;z-index:200;font-weight:700}
.skip-link:focus{left:0}

.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- Buttons ---------- */
.btn{--btn-bg:var(--blue-700);--btn-fg:#fff;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-display);font-weight:700;font-size:1rem;line-height:1;text-decoration:none;cursor:pointer;
  padding:.95rem 1.5rem;min-height:48px;border-radius:var(--radius-pill);border:2px solid transparent;
  background:var(--btn-bg);color:var(--btn-fg);transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  box-shadow:0 10px 22px -12px rgba(29,95,174,.85)}
.btn:hover{transform:translateY(-2px);color:#fff;background:var(--blue-600)}
.btn:active{transform:translateY(0)}
.btn--cedar{--btn-bg:var(--cedar-600);box-shadow:0 10px 22px -12px rgba(169,98,47,.9)}
.btn--cedar:hover{background:var(--cedar-700)}
.btn--ghost{background:transparent;color:var(--blue-700);border-color:var(--blue-200);box-shadow:none}
.btn--ghost:hover{background:var(--blue-50);color:var(--blue-700)}
.btn--light{background:#fff;color:var(--blue-800);box-shadow:none}
.btn--light:hover{background:var(--blue-50);color:var(--blue-800)}
.btn--lg{font-size:1.08rem;padding:1.1rem 1.9rem;min-height:54px}
.btn--block{display:flex;width:100%}
.btn .ico{width:20px;height:20px;flex:none}

.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.topbar{background:var(--blue-900);color:#cfe0f4}
.topbar .container{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;align-items:center;justify-content:center;
  padding-block:.45rem;font-size:.82rem}
.topbar a{color:#eaf2fd;text-decoration:none;font-weight:600}
.topbar a:hover{color:#fff;text-decoration:underline}
.topbar .dot{width:5px;height:5px;border-radius:50%;background:var(--cedar-500)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.7rem}
.brand{display:inline-flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand svg{width:46px;height:46px;flex:none}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:1.28rem;letter-spacing:-.02em;line-height:1}
.brand-sub{display:block;font-family:var(--font-body);font-weight:500;font-size:.72rem;letter-spacing:.02em;color:var(--muted);margin-top:2px}
.nav-links{display:flex;align-items:center;gap:.2rem;list-style:none;margin:0;padding:0}
/* Links are inline-block so vertical padding participates in layout (no paint bleed),
   and the current-page underline is an absolutely-positioned ::after so it can never
   fragment the box or shift layout. Hover animates the same underline (scaleX 0->1);
   the global prefers-reduced-motion rule zeroes the transition. */
.nav-links a{position:relative;display:inline-block;font-family:var(--font-display);font-weight:600;font-size:.97rem;
  color:var(--slate);text-decoration:none;line-height:1.2;padding:.6rem .8rem;border-radius:var(--radius-sm);
  white-space:nowrap;transition:color .15s ease,background-color .15s ease}
.nav-links a:hover{color:var(--blue-700);background:var(--blue-50)}
.nav-links a::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.3rem;height:2px;border-radius:2px;
  background:var(--cedar-500);transform:scaleX(0);transform-origin:left center;transition:transform .18s ease}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a[aria-current="page"],.nav-links a[aria-current="true"]{color:var(--blue-700)}
.nav-links a[aria-current="page"]::after,.nav-links a[aria-current="true"]::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.nav-phone{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-display);font-weight:800;
  color:var(--blue-800);text-decoration:none;font-size:1.02rem;white-space:nowrap}
.nav-phone:hover{color:var(--blue-700)}
.nav-phone .ico{width:18px;height:18px}
.nav-toggle{display:none;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--line);
  background:#fff;border-radius:var(--radius-sm);cursor:pointer}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;height:2px;
  background:var(--ink);border-radius:2px;position:relative;transition:.2s}
.nav-toggle span::before{position:absolute;top:-6px}.nav-toggle span::after{position:absolute;top:6px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{transform:rotate(45deg);top:0}
.nav-toggle[aria-expanded="true"] span::after{transform:rotate(-45deg);top:0}

/* Mid-range: keep all links + CTA on one row before the drawer kicks in */
@media (max-width:1120px) and (min-width:921px){
  .nav-phone .label{display:none}
  .nav-links a{padding:.6rem .62rem}
}
@media (max-width:920px){
  .nav-toggle{display:inline-flex}
  .nav-links{position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:.5rem;
    max-height:0;overflow:hidden;transition:max-height .28s ease;visibility:hidden}
  .nav-links.open{max-height:80vh;visibility:visible}
  .nav-links a{display:block;padding:.95rem .9rem;border-radius:var(--radius-sm);font-size:1.05rem}
  .nav-links a::after{display:none}
  .nav-links a[aria-current="page"],.nav-links a[aria-current="true"]{background:var(--blue-50)}
  .nav{position:relative}
  .nav-phone .label{display:none}
  .nav-cta{gap:.35rem}
}
@media (max-width:560px){
  .hero h1{max-width:none}
  .nav-cta .btn--cedar{display:none}
  .brand-sub{display:none}
  /* Collapse the 3-row topbar to a single call line on small phones */
  .topbar .container span{display:none}
}

/* ---------- Nav dropdown (Services) ----------
   Desktop: panel opens on hover / focus-within (pure CSS) or via the chevron
   button (.open class from JS — covers touch). Mobile (<=920px drawer): the
   submenu renders inline and indented under Services, toggled by the button. */
.nav-sub{position:relative;display:flex;align-items:center}
.sub-toggle{display:inline-flex;align-items:center;justify-content:center;background:none;border:0;cursor:pointer;
  padding:.45rem .35rem .45rem .15rem;margin-left:-.5rem;color:var(--slate);border-radius:var(--radius-sm);
  transition:color .15s ease,background-color .15s ease}
.sub-toggle:hover{color:var(--blue-700);background:var(--blue-50)}
.sub-toggle svg{width:14px;height:14px;transition:transform .18s ease}
.nav-sub.open .sub-toggle svg{transform:rotate(180deg)}
.sub-menu{position:absolute;top:calc(100% + .35rem);left:0;min-width:252px;z-index:120;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:.45rem;margin:0;list-style:none;display:none}
/* invisible bridge so the pointer can cross the gap without closing the panel */
.sub-menu::before{content:"";position:absolute;left:0;right:0;top:-.4rem;height:.4rem}
.nav-links .sub-menu a{display:block;padding:.55rem .75rem;border-radius:var(--radius-sm);
  font-size:.93rem;color:var(--slate);white-space:nowrap}
.nav-links .sub-menu a::after{content:none}
.nav-links .sub-menu a:hover{background:var(--blue-50);color:var(--blue-700)}
.nav-links .sub-menu a[aria-current="page"],.nav-links .sub-menu a[aria-current="true"]{background:var(--blue-50);color:var(--blue-700)}
.sub-menu .sub-all{border-bottom:1px solid var(--line-2);margin-bottom:.4rem;padding-bottom:.4rem}
.nav-links .sub-menu .sub-all a{font-family:var(--font-display);font-weight:700;font-size:.78rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--blue-700)}
.nav-sub.open .sub-menu{display:block}
@media (min-width:921px){
  .nav-sub:hover .sub-menu,.nav-sub:focus-within .sub-menu{display:block}
  .nav-sub:hover .sub-toggle svg,.nav-sub:focus-within .sub-toggle svg{transform:rotate(180deg)}
}
@media (max-width:920px){
  /* the drawer caps at 80vh; let the longer list (with submenu open) scroll */
  .nav-links.open{overflow-y:auto}
  .nav-sub{flex-wrap:wrap;align-items:stretch}
  .nav-sub>a{flex:1}
  .sub-toggle{flex:none;width:48px;min-height:48px;margin:0;padding:0;justify-content:center}
  .sub-toggle[aria-expanded="true"]{background:var(--blue-50);color:var(--blue-700)}
  .sub-menu{position:static;width:100%;min-width:0;border:0;border-radius:0;box-shadow:none;
    border-left:2px solid var(--blue-100);margin:.15rem 0 .45rem .9rem;padding:0 0 0 .25rem}
  .sub-menu::before{content:none}
  .nav-links .sub-menu a{white-space:normal;padding:.65rem .9rem;font-size:.98rem}
}

/* ---------- Hero ---------- */
.hero{position:relative;isolation:isolate;background:var(--blue-900);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,22,44,.78) 0%,rgba(10,26,52,.62) 45%,rgba(12,30,58,.72) 100%)}
.hero-bg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover}
.hero-inner{padding-block:clamp(3.4rem,2.4rem + 6vw,7.5rem)}
.hero h1{color:#fff;max-width:16ch}
.hero .lede{color:#dbe7f6;max-width:54ch}
.hero-badges{display:flex;flex-wrap:wrap;gap:.5rem .55rem;margin:1.4rem 0 1.7rem}
.pill{display:inline-flex;align-items:center;gap:.45rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  color:#eaf2fd;font-family:var(--font-display);font-weight:600;font-size:.83rem;padding:.42rem .8rem;border-radius:var(--radius-pill)}
.pill .ico{width:15px;height:15px;color:var(--blue-200)}
.hero-meta{margin-top:1.6rem;display:flex;flex-wrap:wrap;gap:.5rem 1.6rem;color:#bcd0ea;font-size:.92rem}
.hero-meta b{color:#fff}

/* ---------- Stat / trust band ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.statband .stat{background:#fff;padding:1.5rem 1.2rem;text-align:center}
.stat .num{font-family:var(--font-display);font-weight:800;font-size:var(--step-3);color:var(--blue-700);line-height:1;letter-spacing:-.02em}
.stat .lab{display:block;margin-top:.4rem;font-size:.86rem;color:var(--muted);font-weight:500}
@media (max-width:680px){.statband{grid-template-columns:repeat(2,1fr)}}

/* ---------- Cards / services ---------- */
.grid{display:grid;gap:var(--gap)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .25s ease,border-color .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue-200)}
.card-media{aspect-ratio:16/11;overflow:hidden;background:var(--mist)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card-media img{transform:scale(1.05)}
.card-body{padding:1.3rem 1.35rem 1.45rem;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:var(--step-1);margin-bottom:.35rem}
.card-body p{color:var(--slate);font-size:.97rem;margin-bottom:1rem}
.card-link{margin-top:auto;font-family:var(--font-display);font-weight:700;font-size:.92rem;color:var(--blue-600);
  text-decoration:none;display:inline-flex;align-items:center;gap:.35rem}
.card-link:hover{gap:.6rem;color:var(--blue-700)}
.card-icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--blue-50);color:var(--blue-700);margin-bottom:.9rem}
.card-icon svg{width:24px;height:24px}

.feature{display:flex;gap:1rem;align-items:flex-start}
.feature .fi{flex:none;width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--cedar-100);color:var(--cedar-700)}
.feature .fi svg{width:23px;height:23px}
.feature h3{font-size:var(--step-1);margin-bottom:.25rem}
.feature p{color:var(--slate);font-size:.96rem;margin:0}

/* ---------- Split / media rows ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,1rem + 3vw,4rem);align-items:center}
.split.reverse{direction:rtl}.split.reverse>*{direction:ltr}
@media (max-width:860px){.split{grid-template-columns:1fr}.split.reverse{direction:ltr}}
.media-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);
  border:1px solid var(--line)}
.media-frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.media-frame.tall img{aspect-ratio:3/4}
.media-caption{position:absolute;left:0;right:0;bottom:0;padding:1.1rem 1.1rem .9rem;
  background:linear-gradient(0deg,rgba(9,22,44,.82),transparent);color:#fff;font-size:.85rem}

/* ---------- Checklist / bullets ---------- */
.checks{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
/* block + absolute bullet (not flex) so inline links and text flow on one line */
.checks li{display:block;position:relative;padding-left:calc(22px + .7rem);color:var(--slate)}
.checks li::before{content:"";position:absolute;left:0;top:1px;width:22px;height:22px;border-radius:50%;
  background:var(--blue-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231d5fae' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/14px no-repeat}
.checks.on-dark li{color:#cfe0f4}
.checks.on-dark li::before{background-color:rgba(255,255,255,.12)}

/* ---------- Gallery ---------- */
.gallery{columns:3 280px;column-gap:14px}
.gallery .shot{break-inside:avoid;margin:0 0 14px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line);
  position:relative;background:var(--mist);cursor:zoom-in;display:block;width:100%;padding:0}
.gallery .shot img{width:100%;height:auto;display:block;transition:transform .4s ease}
.gallery .shot:hover img{transform:scale(1.04)}
.gallery .shot .cap{position:absolute;left:0;right:0;bottom:0;display:block;padding:.8rem .8rem .65rem;color:#fff;font-size:.8rem;
  background:linear-gradient(0deg,rgba(9,22,44,.85),transparent);opacity:0;transition:opacity .2s;text-align:left}
.gallery .shot:hover .cap,.gallery .shot:focus-visible .cap{opacity:1}
.gallery-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.6rem}
.chip{font-family:var(--font-display);font-weight:600;font-size:.9rem;padding:.5rem 1rem;border-radius:var(--radius-pill);
  border:1px solid var(--line);background:#fff;color:var(--slate);cursor:pointer}
.chip[aria-pressed="true"]{background:var(--blue-700);color:#fff;border-color:var(--blue-700)}
.chip:hover{border-color:var(--blue-300)}
.is-hidden{display:none!important}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(8,18,36,.92);display:none;align-items:center;justify-content:center;padding:1.2rem}
.lightbox.open{display:flex}
.lightbox img{max-width:min(1100px,94vw);max-height:86vh;border-radius:10px;box-shadow:var(--shadow-lg)}
.lightbox .lb-cap{position:absolute;bottom:1.4rem;left:0;right:0;margin:0;text-align:center;color:#dbe7f6;font-size:.9rem;padding:0 1rem}
.lightbox .lb-close,.lightbox .lb-nav{position:absolute;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);
  color:#fff;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;cursor:pointer;font-size:1.4rem}
.lightbox .lb-close{top:1.1rem;right:1.1rem}
.lightbox .lb-nav{top:50%;transform:translateY(-50%)}
.lb-prev{left:1.1rem}.lb-next{right:1.1rem}
@media (max-width:620px){.lightbox .lb-nav{top:auto;bottom:1.2rem;transform:none}.lb-prev{left:25%}.lb-next{right:25%}}

/* ---------- Service area ---------- */
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}
.area-grid li{list-style:none}
.area-tag{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:.7rem .9rem;font-weight:600;color:var(--slate);font-size:.95rem}
.area-tag svg{width:16px;height:16px;color:var(--blue-600);flex:none}
/* When an area tag is a link (city pages), give it hover/focus affordance */
a.area-tag{text-decoration:none;transition:transform .15s ease,border-color .15s ease,color .15s ease,box-shadow .2s ease}
a.area-tag:hover{transform:translateY(-2px);border-color:var(--blue-300);color:var(--blue-700);box-shadow:var(--shadow-sm)}
a.area-tag:focus-visible{border-color:var(--blue-300);color:var(--blue-700)}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem}
.faq details{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:1.1rem 1.3rem;font-family:var(--font-display);font-weight:700;
  font-size:1.05rem;display:flex;justify-content:space-between;gap:1rem;align-items:center;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--blue-600);transition:transform .2s;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq summary:hover{color:var(--blue-700)}
.faq .faq-body{padding:0 1.3rem 1.2rem;color:var(--slate)}
.faq .faq-body p:last-child{margin-bottom:0}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--blue-800),var(--blue-700));color:#fff;border-radius:var(--radius-lg);
  padding:clamp(2rem,1.4rem + 3vw,3.4rem);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;right:-40px;top:-40px;width:240px;height:240px;border-radius:50%;
  background:rgba(255,255,255,.07)}
.cta-band h2{color:#fff}
.cta-band p{color:#d7e6f8}

/* ---------- Forms ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.4rem,1rem + 2vw,2.4rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.05rem}
.field label{display:block;font-family:var(--font-display);font-weight:600;font-size:.92rem;margin-bottom:.4rem;color:var(--ink)}
.field .req{color:var(--cedar-600)}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:1rem;color:var(--ink);background:#fff;
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:.8rem .9rem;min-height:48px;transition:border-color .15s,box-shadow .15s}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-500);
  box-shadow:0 0 0 3px var(--blue-100)}
.field .hint{font-size:.82rem;color:var(--muted);margin-top:.35rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.05rem}
@media (max-width:560px){.field-row{grid-template-columns:1fr}}
.consent{font-size:.82rem;color:var(--muted);line-height:1.5}
.honey{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{display:flex;gap:.6rem;align-items:flex-start;background:var(--blue-50);border:1px solid var(--blue-100);
  border-radius:var(--radius-sm);padding:.85rem 1rem;font-size:.88rem;color:var(--blue-800);margin-top:.4rem}
.form-note svg{flex:none;width:18px;height:18px;color:var(--blue-600);margin-top:2px}

/* contact info list */
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:1.1rem}
.contact-list li{display:flex;gap:.85rem;align-items:flex-start}
.contact-list .ci{flex:none;width:44px;height:44px;border-radius:12px;background:var(--blue-50);color:var(--blue-700);display:grid;place-items:center}
.contact-list .ci svg{width:21px;height:21px}
.contact-list .k{font-family:var(--font-display);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.contact-list a{font-weight:600;text-decoration:none;color:var(--ink);font-size:1.05rem}
.contact-list a:hover{color:var(--blue-700)}

/* ---------- Breadcrumb ---------- */
.crumbs{font-size:.85rem;color:var(--muted);padding-top:1.2rem}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;padding:0;margin:0}
.crumbs a{color:var(--muted);text-decoration:none}.crumbs a:hover{color:var(--blue-600)}
.crumbs li::after{content:"/";margin-left:.4rem;color:var(--line)}
.crumbs li:last-child::after{content:""}
.crumbs [aria-current="page"]{color:var(--slate)}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:var(--blue-900);color:#fff;position:relative;isolation:isolate;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,24,48,.8),rgba(12,30,58,.86))}
.page-hero-bg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;opacity:.55}
.page-hero .inner{padding-block:clamp(2.6rem,2rem + 3vw,4.6rem)}
.page-hero h1{color:#fff;margin-bottom:.4rem;max-width:18ch}
.page-hero p{color:#cfe0f4;max-width:60ch;margin:0}

/* ---------- Prose ---------- */
.prose h2{margin-top:2.2rem}.prose h3{margin-top:1.6rem}
.prose>p{color:var(--slate)}
.prose ul li{margin-bottom:.4rem;color:var(--slate)}

/* ---------- Footer ---------- */
.site-footer{background:var(--blue-900);color:#b9cbe4;padding-block:clamp(2.6rem,2rem + 3vw,4rem) 1.6rem;font-size:.94rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2rem}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer h2{color:#fff;font-size:.84rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.site-footer a{color:#c4d6ef;text-decoration:none}
.site-footer a:hover{color:#fff;text-decoration:underline}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.55rem}
.footer-brand .brand-name{color:#fff}.footer-brand .brand-sub{color:#88a4cb}
.footer-brand p{color:#a9c0e0;max-width:34ch;margin-top:.9rem}
.footer-brand .brand svg{width:40px;height:40px}
.footer-contact li{display:flex;gap:.55rem;align-items:flex-start}
.footer-contact svg{width:17px;height:17px;color:var(--blue-200);flex:none;margin-top:3px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.4rem;padding-top:1.4rem;
  display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;align-items:center;font-size:.84rem;color:#88a4cb}
.footer-bottom a{color:#9fb8da}
.badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  color:#dce8f8;border-radius:var(--radius-pill);padding:.35rem .75rem;font-size:.78rem;font-weight:600}
.badge svg{width:14px;height:14px;color:var(--blue-200)}

/* ---------- Utility ---------- */
/* Reveal-on-scroll is progressive enhancement: only hides when JS is active. */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none}}
.tag-row{display:flex;flex-wrap:wrap;gap:.5rem}
.tag{background:var(--blue-50);color:var(--blue-700);font-weight:600;font-size:.82rem;padding:.3rem .7rem;border-radius:var(--radius-pill)}
.divider-cedar{height:4px;width:64px;background:var(--cedar-500);border-radius:4px;margin:1.1rem 0}
.note-flag{background:#fffaf0;border:1px dashed var(--cedar-500);border-radius:var(--radius-sm);padding:.7rem .9rem;font-size:.85rem;color:var(--cedar-700)}

/* ---------- OZF roundel logo ---------- */
.brand .logo{color:var(--blue-500)}
.site-footer .brand .logo{color:var(--blue-200)}
/* Brand mark on the about-page story (bio) */
.bio-logo{width:64px;height:64px;color:var(--blue-500);display:block;margin-bottom:14px}

/* ---------- Brand badge on job photos ---------- */
.gallery .shot::after,.media-frame::after{
  content:"";position:absolute;right:9px;bottom:9px;width:30px;height:30px;z-index:2;
  background:url('../img/favicon.svg') center/contain no-repeat;
  border-radius:8px;box-shadow:0 1px 5px rgba(0,0,0,.3);opacity:.95;pointer-events:none;
}
.gallery .shot:hover .cap,.gallery .shot:focus-visible .cap{padding-right:48px;}

/* ==========================================================================
   "More of our work" photo slider (service pages)
   Horizontal, swipe-on-mobile / buttons-on-desktop carousel.
   ========================================================================== */
.work-slider{position:relative}
.work-slider .ws-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:1rem 1.5rem;
  flex-wrap:wrap;margin-bottom:1.6rem;
}
.work-slider .ws-head h2{margin:0}
.work-slider .ws-all{
  font-family:var(--font-display);font-weight:700;white-space:nowrap;
  color:var(--blue-600);text-decoration:none;
}
.work-slider .ws-all:hover{color:var(--blue-700);text-decoration:underline}

/* The scroll track */
.work-slider .ws-track{
  display:flex;gap:1rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scroll-behavior:smooth;
  padding:4px 2px 1.2rem;          /* room for hover lift + focus ring */
  scrollbar-width:none;            /* Firefox */
}
.work-slider .ws-track::-webkit-scrollbar{display:none} /* WebKit */

/* Each card */
.work-slider .ws-card{
  flex:0 0 auto;
  width:clamp(220px,60vw,300px);
  scroll-snap-align:start;
  display:flex;flex-direction:column;
  text-decoration:none;color:var(--ink);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.work-slider .ws-card:focus-visible{
  outline:3px solid var(--blue-500);outline-offset:2px;
}
@media (hover:hover){
  .work-slider .ws-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow);
    border-color:var(--blue-200);
  }
}
.work-slider .ws-frame{
  position:relative;margin:0;
  aspect-ratio:4 / 3;
  background:var(--mist);
  overflow:hidden;
}
/* Absolute-fill so a portrait/pano source can't stretch the frame past 4:3 */
.work-slider .ws-frame img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;display:block;
}
/* Text body fills the rest of the card so there's no empty white space */
.work-slider .ws-body{
  display:flex;flex-direction:column;gap:.3rem;
  padding:.7rem .85rem .9rem;
  flex:1 1 auto;
}
.work-slider .ws-cap{
  display:block;
  font-family:var(--font-display);font-weight:700;font-size:.92rem;
  color:var(--ink);line-height:1.25;
}
.work-slider .ws-detail{
  margin:0;font-size:.84rem;line-height:1.45;color:var(--slate);
}

/* Prev / next buttons */
.work-slider .ws-btn{
  position:absolute;top:calc(50% + .9rem);transform:translateY(-50%);
  z-index:3;
  width:44px;height:44px;border-radius:var(--radius-pill);
  display:grid;place-items:center;
  border:1px solid var(--blue-700);
  background:var(--blue-700);color:#fff;
  cursor:pointer;
  box-shadow:var(--shadow);
  transition:background .15s ease,transform .15s ease;
}
.work-slider .ws-btn:hover{background:var(--blue-800)}
.work-slider .ws-btn:active{transform:translateY(-50%) scale(.94)}
.work-slider .ws-btn:focus-visible{outline:3px solid var(--blue-300);outline-offset:2px}
.work-slider .ws-btn svg{width:22px;height:22px}
.work-slider .ws-btn.prev{left:-8px}
.work-slider .ws-btn.next{right:-8px}
@media (max-width:560px){
  .work-slider .ws-btn{display:none} /* swipe-only on small screens */
}
