/* 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;
  --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}
}
