/* Gulf Breeze Fence — v1 design system (proto)
   Anatomy: stump/v8 measured system. Palette: design/TOKENS.md (WCAG-computed).
   Hard edges: 0-3px radius, zero-blur offset shadows, ONE shadowed element per page. */

@font-face{
  font-family:'Archivo';
  src:url('/fonts/archivo-var.woff2') format('woff2');
  font-weight:100 900;font-style:normal;font-display:swap;
}

:root{
  --paper:#f4f1e8; --board:#e9e2d0; --ink:#1c2a23; --pine:#24382e;
  --cedar:#a45a2a; --cedar-press:#7c3f1d; --steel:#5d6b6d;
  --safety:#f5a623; --signal:#e8842c; --seafoam:#9fd6c6;
  --line:#d8cfb8; --line-dark:#3a5145;
  --tide:#0d6a5f; --slate:#51636b;
  --w:1040px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Archivo',system-ui,sans-serif;
  background:var(--paper);color:var(--ink);
  font-size:16px;line-height:1.6;
}
img,svg{max-width:100%;display:block}
a{color:var(--cedar-press)}
.container{max-width:var(--w);margin:0 auto;padding:0 24px}

/* ===== type scale (flat; hierarchy = weight/caps/color) ===== */
h1{font-size:2.15rem;font-weight:800;line-height:1.15;letter-spacing:-.01em;text-wrap:balance}
h2{font-size:1.42rem;font-weight:800;line-height:1.25}
h3{font-size:1.02rem;font-weight:700;line-height:1.3}
.kicker{
  display:inline-block;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;
}
.lead{font-size:1.06rem;line-height:1.65}
.muted{color:var(--steel)}

/* ===== buttons: 2px border + hard offset shadow ===== */
.btn{
  display:inline-block;font-family:inherit;font-size:.85rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;text-decoration:none;
  padding:.85rem 1.5rem;border:2px solid var(--ink);cursor:pointer;
  border-radius:0;box-shadow:4px 4px 0 var(--ink);
  transition:transform .08s ease,box-shadow .08s ease;
}
.btn:active{transform:translate(4px,4px);box-shadow:0 0 0 var(--ink)}
.btn-primary{background:var(--safety);color:var(--ink)}
.btn-primary:hover{background:var(--signal)}
.btn-ghost-dark{background:transparent;color:var(--paper);border-color:var(--paper);box-shadow:4px 4px 0 rgba(244,241,232,.55)}
.btn-ghost-dark:active{box-shadow:0 0 0}

/* ===== masthead: dark block, nav flows into hero ===== */
.masthead{background:var(--ink);color:var(--paper);border-bottom:5px solid var(--cedar)}
.nav{
  display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;
  padding:1.05rem 0;border-bottom:1px solid var(--line-dark);
}
.nav .logo{
  font-weight:800;font-size:1.06rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--paper);text-decoration:none;white-space:nowrap;
}
.nav .logo span{color:var(--safety)}
.nav-menu{display:flex;gap:1.15rem;flex-wrap:wrap;margin-left:auto;align-items:center}
.nav-menu a{
  color:var(--paper);text-decoration:none;font-size:.85rem;font-weight:600;
}
.nav-menu a:hover{color:var(--seafoam)}
.nav-cta{
  background:var(--safety);color:var(--ink)!important;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;font-size:.78rem!important;
  padding:.55rem .95rem;border:2px solid var(--paper);
}
.nav-cta:hover{background:var(--signal);color:var(--ink)!important}

.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;padding:3.4rem 0 3.8rem;align-items:start}
.hero .kicker{color:var(--seafoam)}
.hero h1{color:#fff;margin:.55rem 0 1rem}
.hero .lead{color:var(--paper);opacity:.92;max-width:33rem}
.hero-points{list-style:none;margin:1.3rem 0 0}
.hero-points li{
  padding-left:1.5rem;position:relative;margin-bottom:.55rem;
  color:var(--paper);font-size:.95rem;
}
.hero-points li::before{
  content:"";position:absolute;left:0;top:.42em;width:.7em;height:.7em;
  background:var(--safety);
}

/* THE one shadowed element: the quote form card */
.quote-card{
  background:var(--paper);color:var(--ink);border:2px solid var(--ink);
  box-shadow:8px 8px 0 rgba(0,0,0,.85);padding:1.6rem 1.5rem;
}
.quote-card h2{font-size:1.15rem;margin-bottom:.2rem}
.quote-card .sub{font-size:.85rem;color:var(--steel);margin-bottom:1.1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.field{margin-bottom:.8rem}
.field label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.3rem}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:.95rem;color:var(--ink);
  background:#fff;border:2px solid var(--ink);border-radius:0;padding:.6rem .7rem;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:3px solid var(--safety);outline-offset:0}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.78rem;line-height:1.45;color:var(--steel);margin:.2rem 0 1rem}
.consent input{margin-top:.2rem;width:1rem;height:1rem;accent-color:var(--cedar-press)}
.hp{position:absolute;left:-9999px;opacity:0}
.quote-card .btn{width:100%;text-align:center}

/* ===== paper work sections ===== */
.section{padding:4rem 0}
.section-head{max-width:44rem;margin-bottom:2.2rem}
.section-head .kicker{color:var(--cedar-press)}
.section-head h2{margin-top:.45rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}

/* flat hairline cards (no shadow) */
.card{background:#fff;border:1px solid var(--line);padding:1.4rem 1.3rem;display:flex;flex-direction:column}
.card .kicker{color:var(--cedar-press)}
.card h3{margin:.4rem 0 .5rem}
.card p{font-size:.92rem;line-height:1.55}
.card .learn{margin-top:auto;padding-top:.9rem;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;text-decoration:none;color:var(--cedar-press)}
.card .learn:hover{color:var(--ink)}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:2.1rem;height:2.1rem;background:var(--ink);color:var(--safety);
  font-weight:800;font-size:1rem;margin-bottom:.8rem;
}

/* ===== dark feature band (service area) ===== */
.band{background:var(--pine);color:var(--paper);padding:4rem 0;border-top:5px solid var(--cedar);border-bottom:5px solid var(--cedar)}
.band .kicker{color:var(--seafoam)}
.band h2{color:#fff;margin:.45rem 0 1rem}
.band p{opacity:.92;max-width:38rem}
.band a{color:var(--seafoam)}
.band-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2.6rem;align-items:start}
.area-chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.2rem}
.area-chips a,.area-chips span{
  border:1px solid var(--line-dark);color:var(--paper);text-decoration:none;
  font-size:.82rem;font-weight:600;padding:.42rem .75rem;background:rgba(0,0,0,.18);
}
.area-chips a:hover{border-color:var(--seafoam);color:var(--seafoam)}

/* ===== honesty strip ===== */
.plain{background:var(--board);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.plain-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;padding:2.3rem 0}
.plain h3{font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}
.plain p{font-size:.88rem;margin-top:.4rem;color:#41504a}

/* ===== dark close ===== */
.close{background:var(--ink);color:var(--paper);padding:4rem 0 0;border-top:5px solid var(--cedar)}
.close-cta{max-width:40rem}
.close-cta h2{color:#fff;margin-bottom:.7rem}
.close-cta p{opacity:.9;margin-bottom:1.5rem}
.footer-nav{
  margin-top:3.2rem;border-top:1px solid var(--line-dark);
  padding:2rem 0 .6rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;
}
.fcol h3{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.09em;color:var(--seafoam);margin-bottom:.7rem;
}
.fcol a{display:block;color:#b9c6bf;text-decoration:none;font-size:.85rem;padding:.22rem 0}
.fcol a:hover{color:var(--seafoam)}
.footer{
  margin-top:1.2rem;border-top:1px solid var(--line-dark);
  padding:1.4rem 0 1.6rem;display:flex;flex-wrap:wrap;gap:.6rem 1.6rem;
  align-items:center;font-size:.78rem;
}
.footer,.footer a{color:#b9c6bf}
.footer a{text-decoration:none}
.footer a:hover{color:var(--seafoam)}
.footer .llc{margin-right:auto}

/* ===== responsive ===== */
@media (max-width:860px){
  .hero{grid-template-columns:1fr;gap:2rem;padding:2.4rem 0 3rem}
  .grid-3,.grid-4,.plain-inner,.footer-nav{grid-template-columns:1fr 1fr}
  .band-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  h1{font-size:1.7rem}
  .grid-3,.grid-4,.plain-inner{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .nav{gap:.9rem}
  .nav-menu{gap:.85rem;margin-left:0}
}

/* ===== inner pages (v2 additions) ===== */
.page-hero{padding:2.6rem 0 3rem;max-width:46rem}
.page-hero .kicker{color:var(--seafoam)}
.page-hero h1{color:#fff;margin:.5rem 0 .9rem}
.page-hero .lead{color:var(--paper);opacity:.92}
.crumbs{padding:.8rem 0 0;font-size:.78rem;color:#b9c6bf}
.crumbs a{color:#b9c6bf;text-decoration:none}
.crumbs a:hover{color:var(--seafoam)}
.toc-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.toc-chips a{border:1px solid var(--line-dark);color:var(--paper);text-decoration:none;font-size:.8rem;font-weight:600;padding:.4rem .7rem;background:rgba(0,0,0,.18)}
.toc-chips a:hover{border-color:var(--seafoam);color:var(--seafoam)}
.prose{max-width:46rem}
.prose h2{margin:2.2rem 0 .8rem}
.prose h3{margin:1.5rem 0 .5rem}
.prose h4{font-size:.92rem;font-weight:700;margin:1.1rem 0 .4rem}
.prose h5{font-size:.86rem;font-weight:700;margin:.9rem 0 .3rem;color:var(--cedar-press)}
.prose h6{font-size:.78rem;font-weight:700;margin:.7rem 0 .25rem;text-transform:uppercase;letter-spacing:.04em;color:var(--steel)}
.prose h6+p{margin-top:0}
.prose p{margin-bottom:.9rem}
.prose ul{margin:0 0 .9rem 1.2rem}
.prose li{margin-bottom:.35rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.tile{display:flex;gap:.9rem;align-items:flex-start}
.tile img,.tile svg{width:56px;height:56px;flex:0 0 56px}
.faq details{border:1px solid var(--line);background:#fff;margin-bottom:.6rem}
.faq summary{cursor:pointer;list-style:none;padding:.9rem 1.1rem;font-weight:700;font-size:.95rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";display:inline-block;width:1.2rem;color:var(--cedar-press);font-weight:800}
.faq details[open] summary::before{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--line);background:var(--board)}
.faq .fa-body{padding:.9rem 1.1rem;font-size:.92rem}
.faq .fa-body p{margin-bottom:.6rem}
.callout{border:1px solid var(--line);border-left:6px solid var(--cedar);background:#fff;padding:1rem 1.2rem;margin:1.4rem 0;font-size:.95rem}
.disclaim{font-size:.78rem;color:var(--steel);margin-top:.6rem}
@media (max-width:560px){.grid-2{grid-template-columns:1fr}}

/* cascade fix (2026-07-05): .band a (0,1,1) beat .btn-primary's ink text — buttons inside
   dark bands rendered seafoam-on-amber (1.25:1). Walker caught it; pin button text color. */
.band a.btn, .close a.btn{color:var(--ink)}
.band a.btn:hover, .close a.btn:hover{color:var(--ink)}

/* ===== v3: dropdown nav, cookie banner, hero image, author card ===== */
.nav-item{position:relative}
.nav-item>a{display:inline-flex;align-items:center;gap:.3rem}
.nav-item>a::after{content:"";width:.4rem;height:.4rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-left:.15rem;margin-top:-.15rem;opacity:.7}
.dropdown{position:absolute;top:100%;left:0;background:var(--ink);border:2px solid var(--cedar);border-top:none;min-width:230px;display:none;z-index:60;box-shadow:6px 6px 0 rgba(0,0,0,.3)}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown,.dropdown.open{display:block}
.dropdown a{display:block;padding:.7rem .95rem;color:var(--paper);text-decoration:none;font-size:.85rem;font-weight:600;border-bottom:1px solid var(--line-dark);white-space:nowrap}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover,.dropdown a:focus{background:var(--pine);color:var(--seafoam);outline:none}

/* hero image band */
.hero-photo{position:relative}
.hero-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:0}
.hero-photo>.container{position:relative;z-index:2}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(24,42,35,.92) 0%,rgba(24,42,35,.78) 45%,rgba(24,42,35,.35) 100%);z-index:1}
.page-photo{width:100%;max-height:340px;object-fit:cover;border:2px solid var(--ink);margin:0 0 1.4rem}
.svc-photo{width:100%;height:210px;object-fit:cover;border:1px solid var(--line);margin-bottom:.9rem}

/* author card */
.author-card{display:flex;gap:1rem;align-items:center;background:#fff;border:1px solid var(--line);border-left:6px solid var(--cedar);padding:1rem 1.2rem;margin:1.6rem 0}
.author-card img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex:0 0 64px;border:2px solid var(--ink)}
.author-card .an{font-weight:800;font-size:.95rem}
.author-card .at{font-size:.82rem;color:var(--steel);margin-top:.15rem}
.author-card .ab{font-size:.85rem;margin-top:.35rem}

/* cookie consent */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;background:var(--ink);color:var(--paper);border-top:4px solid var(--safety);padding:1rem 1.2rem;z-index:200;display:none;font-size:.85rem;line-height:1.5}
.cookie-banner.show{display:block}
.cookie-inner{max-width:var(--w);margin:0 auto;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.cookie-inner p{flex:1 1 320px;margin:0}
.cookie-inner a{color:var(--seafoam)}
.cookie-actions{display:flex;gap:.6rem}
.cookie-actions button{font-family:inherit;font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;padding:.55rem 1rem;border:2px solid var(--paper);cursor:pointer;border-radius:0}
.cookie-accept{background:var(--safety);color:var(--ink);border-color:var(--safety)}
.cookie-decline{background:transparent;color:var(--paper)}
@media (max-width:560px){.dropdown{position:static;border:none;box-shadow:none;min-width:0;padding-left:1rem}}

/* ===== v4: full-viewport hero, 3x3 gallery, mobile ===== */
.hero.hero-photo{width:100vw;margin-left:calc(50% - 50vw);box-sizing:border-box;padding:3.2rem max(24px,calc((100vw - 1040px)/2)) 3.6rem;min-height:500px;align-items:center}
/* brighter scrim: image shows more, left stays readable */
.hero-photo::after{background:linear-gradient(90deg,rgba(24,42,35,.9) 0%,rgba(24,42,35,.68) 45%,rgba(24,42,35,.34) 100%)}

/* 3x3 project gallery, images ~30% larger than the old svc-photo (210 -> 280) */
.gallery-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gallery-tile{position:relative;display:block;overflow:hidden;border:2px solid var(--ink);text-decoration:none}
.gallery-tile img{width:100%;height:280px;object-fit:cover;display:block;transition:transform .35s ease}
.gallery-tile:hover img,.gallery-tile:focus img{transform:scale(1.06)}
.gallery-tile .cap{position:absolute;left:0;right:0;bottom:0;background:rgba(15,43,53,.94);color:#fff;padding:.7rem .85rem;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;display:flex;justify-content:space-between;align-items:center;gap:.4rem}
.gallery-tile .cap span.arrow{color:var(--safety);font-weight:800}
.gallery-tile:focus-visible{outline:3px solid var(--safety);outline-offset:2px}

/* mobile: nav tap targets, hero scrim, gallery cols */
@media (max-width:860px){
  .hero.hero-photo{min-height:auto;padding-left:24px;padding-right:24px}
  .hero-photo::after{background:linear-gradient(180deg,rgba(24,42,35,.72) 0%,rgba(24,42,35,.88) 60%,rgba(24,42,35,.94) 100%)}
  .gallery-3{grid-template-columns:1fr 1fr;gap:.7rem}
  .gallery-tile img{height:210px}
  .nav-menu a,.nav-item>a{padding-top:.35rem;padding-bottom:.35rem}
}
@media (max-width:400px){
  .gallery-3{grid-template-columns:1fr}
  .gallery-tile img{height:230px}
}

/* ===== v5: hamburger mobile nav ===== */
.nav-toggle{display:none;background:none;border:2px solid var(--paper);color:var(--paper);width:44px;height:40px;cursor:pointer;padding:0;margin-left:auto;flex-direction:column;justify-content:center;gap:5px;border-radius:0}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--paper);margin:0 auto;transition:.2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media (max-width:760px){
  .nav{flex-wrap:wrap}
  .nav-toggle{display:flex}
  .nav-menu{display:none;flex-basis:100%;flex-direction:column;align-items:stretch;gap:0;margin-left:0;margin-top:.6rem;border-top:1px solid var(--line-dark)}
  .nav-menu.open{display:flex}
  .nav-menu>a,.nav-item>a{padding:.85rem .2rem;border-bottom:1px solid var(--line-dark);font-size:1rem}
  .nav-item{width:100%}
  .nav-item>a::after{margin-left:auto}
  .dropdown{position:static;display:none;border:none;box-shadow:none;background:rgba(0,0,0,.25);min-width:0;padding:0 0 .4rem}
  .dropdown.open{display:block}
  .dropdown a{padding-left:1.1rem;font-size:.92rem}
  .nav-cta{text-align:center;margin-top:.5rem;border-width:2px}
}

/* ===== v6: concerns card (hero-side social-proof style), owner strip, service hero, blog figs ===== */
.hero-flex{display:grid;grid-template-columns:1.1fr .9fr;gap:2.2rem;align-items:center}
.concerns-card{background:var(--paper);color:var(--ink);border:2px solid var(--ink);box-shadow:8px 8px 0 rgba(0,0,0,.85);padding:1.3rem 1.4rem}
.concerns-card h2,.concerns-card h3{font-size:1.05rem;margin-bottom:.2rem}
.concerns-card .sub{font-size:.82rem;color:var(--steel);margin-bottom:.9rem}
.concern{display:flex;gap:.7rem;padding:.6rem 0;border-bottom:1px solid var(--line)}
.concern:last-child{border-bottom:none}
.concern .ic{flex:0 0 26px;width:26px;height:26px;background:var(--tide);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem}
.concern .cx b{display:block;font-size:.9rem;color:var(--ink)}
.concern .cx span{font-size:.83rem;color:var(--slate);line-height:1.4}
.owner-strip{display:grid;grid-template-columns:150px 1fr;gap:1.4rem;align-items:center;background:var(--board);border:1px solid var(--line);border-left:6px solid var(--cedar);padding:1.3rem 1.4rem;margin:1.6rem 0}
.owner-strip img{width:150px;height:150px;object-fit:cover;border:2px solid var(--ink)}
.owner-strip h3{font-size:1.05rem;margin-bottom:.3rem}
.owner-strip p{font-size:.9rem;margin-bottom:.4rem}
.owner-strip .oc{font-size:.8rem;color:var(--steel)}
.svc-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin:1.4rem 0}
.svc-gallery img{width:100%;height:200px;object-fit:cover;border:1px solid var(--line)}
.owner-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.4rem 0}
.owner-photos img{width:100%;height:280px;object-fit:cover;border:2px solid var(--ink)}
@media (max-width:860px){
  .hero-flex{grid-template-columns:1fr;gap:1.4rem}
  .owner-strip{grid-template-columns:1fr;text-align:left}
  .owner-strip img{width:120px;height:120px}
  .svc-gallery{grid-template-columns:1fr 1fr}
  .owner-photos{grid-template-columns:1fr 1fr}
}
@media (max-width:460px){.svc-gallery,.owner-photos{grid-template-columns:1fr}}

/* ===== v7: full-bleed service page hero (matches homepage width) ===== */
.page-hero.hero-photo{
  max-width:none;
  width:100vw;
  margin-left:calc(50% - 50vw);
  box-sizing:border-box;
  padding:2.8rem max(24px,calc((100vw - 1040px)/2)) 3.2rem;
  min-height:340px;
  display:flex;flex-direction:column;justify-content:center;
}
.page-hero.hero-photo > div{max-width:48rem;width:100%}
@media (max-width:860px){
  .page-hero.hero-photo{min-height:auto;padding-left:24px;padding-right:24px}
}
