/* ============================================================
   Dalton Fence — site.css
   Design "Bold Two Doors" (dark industrial + residential/commercial split).
   Brand: brick red on charcoal/ink. Anton display · Oswald labels · Inter body.
   Hand-authored, no framework. WCAG-AA contrast targeted.
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  /* brand */
  --red:#c1362c;          /* primary red */
  --red-dk:#9c281f;       /* hover / active */
  --red-lt:#ff9c92;       /* label red on dark photos */
  --ink:#141312;          /* page background */
  --char:#201d1b;         /* dark surface (cards) */
  --char2:#2c2825;        /* alt dark surface */
  --char3:#38322e;        /* raised surface / inputs */
  --line:#3a3532;         /* hairlines on dark */
  --line-2:#4a433e;
  --text:#e9e4df;         /* body text on dark */
  --fog:#b7b0a9;          /* muted text (AA on ink) */
  --fog-2:#8f8880;        /* dim text */
  --white:#fff;

  /* type */
  --f-disp:'Anton','Arial Narrow',system-ui,sans-serif;   /* headings */
  --f-head:'Oswald','Arial Narrow',system-ui,sans-serif;  /* labels/nav/buttons/h3 */
  --f-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;

  /* rhythm */
  --wrap:1200px;
  --wrap-wide:1400px;
  --pad:clamp(1rem,4vw,2rem);
  --sec:clamp(3.5rem,7vw,6.5rem);
  --radius:4px;
  --radius-sm:3px;
  --shadow:0 12px 34px rgba(0,0,0,.4);
  --shadow-lg:0 26px 60px rgba(0,0,0,.5);
  --t:.22s ease;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--f-body);color:var(--text);background:var(--ink);
  line-height:1.65;font-size:16.5px;-webkit-font-smoothing:antialiased}
img,picture,svg{max-width:100%;display:block;height:auto}
a{color:var(--red-lt);text-decoration:none;transition:color var(--t)}
a:hover{color:#fff}
h1,h2,h3,h4{color:#fff;line-height:1.02;margin:0 0 .5em;letter-spacing:.01em}
h1,h2{font-family:var(--f-disp);font-weight:400;text-transform:uppercase;line-height:.98}
h1{font-size:clamp(2.6rem,7vw,5rem)}
h2{font-size:clamp(2rem,5vw,3.2rem)}
h3{font-family:var(--f-head);font-weight:700;text-transform:uppercase;
  font-size:clamp(1.2rem,2vw,1.5rem);letter-spacing:.02em}
h4{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
p{margin:0 0 1.1rem}
ul,ol{margin:0 0 1.1rem;padding-left:1.2rem}
strong,b{color:#fff}
:focus-visible{outline:3px solid var(--red);outline-offset:2px}
.skip{position:absolute;left:-9999px;top:0;background:var(--red);color:#fff;
  padding:.7rem 1.2rem;z-index:200}
.skip:focus{left:12px;top:12px;color:#fff}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
.wrap-wide{max-width:var(--wrap-wide);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:var(--sec)}
.section--char{background:var(--char)}
.section--char2{background:var(--char2)}
.section--angle{background:var(--char2);
  clip-path:polygon(0 2.5%,100% 0,100% 97.5%,0 100%)}
.center{text-align:center}
.mx-auto{margin-inline:auto}
.grid{display:grid;gap:clamp(1.25rem,3vw,2rem)}
@media(min-width:760px){.g-2{grid-template-columns:repeat(2,1fr)}
  .g-3{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.g-4{grid-template-columns:repeat(4,1fr)}}

/* ---------- Eyebrow / section head ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--f-head);
  font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;
  color:var(--red);margin-bottom:1rem}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--red);display:inline-block}
.sec-head{max-width:680px;margin-bottom:clamp(2rem,4vw,3rem)}
.sec-head.center{margin-inline:auto}
.sec-head.center .eyebrow{justify-content:center}
.sec-head p{color:var(--fog);font-size:1.05rem;margin-bottom:0}
.lead{font-size:1.15rem;color:var(--text)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-size:.95rem;padding:.95rem 1.7rem;border-radius:var(--radius);border:2px solid transparent;
  cursor:pointer;transition:all var(--t);line-height:1;white-space:nowrap}
.btn--primary{background:var(--red);color:#fff}
.btn--primary:hover{background:var(--red-dk);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:var(--line-2)}
.btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--light{background:#fff;color:var(--ink)}
.btn--light:hover{background:var(--ink);color:#fff}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--outline-light:hover{background:#fff;color:var(--ink)}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem}

/* ---------- Top bar ---------- */
.topbar{background:#000;color:#b8b2ab;font-size:.83rem;border-bottom:1px solid var(--line)}
.topbar .wrap-wide{display:flex;justify-content:space-between;align-items:center;
  gap:1rem;padding-block:.5rem;flex-wrap:wrap}
.topbar a{color:#d8d2cb}.topbar a:hover{color:#fff}
.topbar__left{display:flex;gap:1.4rem;flex-wrap:wrap}
.topbar__left span{display:inline-flex;align-items:center;gap:.4rem}
.topbar__right{display:flex;gap:1.1rem;align-items:center}
.topbar__right strong{color:#fff}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(20,19,18,.94);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.site-header .wrap-wide{display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;min-height:76px}
.brand img{height:44px;width:auto}
.nav{display:none}
@media(min-width:1080px){
  .nav{display:flex;align-items:center;gap:1.6rem}
  .nav>a,.nav .has-sub>a{color:#d8d2cc;font-family:var(--f-head);font-weight:500;
    text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;position:relative;
    padding:.4rem 0;cursor:pointer;white-space:nowrap}
  .nav>a:hover,.nav .has-sub>a:hover,.nav>a[aria-current="page"],
  .nav .has-sub[data-active] >a{color:#fff}
  .nav>a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;
    height:2px;background:var(--red)}
}
.nav .has-sub{position:relative}
.nav .submenu{position:absolute;top:100%;left:-.8rem;background:var(--char);min-width:230px;
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:.5rem;opacity:0;visibility:hidden;transform:translateY(6px);transition:all var(--t)}
.nav .has-sub:hover .submenu,.nav .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:none}
.nav .submenu a{display:block;padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.86rem;
  letter-spacing:.03em;color:#d8d2cc;font-family:var(--f-head);font-weight:500;text-transform:uppercase}
.nav .submenu a:hover{background:var(--red);color:#fff}
.header-cta{display:none}
@media(min-width:1080px){.header-cta{display:inline-flex}}

.menu-toggle{display:inline-flex;flex-direction:column;gap:5px;background:none;border:0;
  cursor:pointer;padding:.4rem}
@media(min-width:1080px){.menu-toggle{display:none}}
.menu-toggle span{width:26px;height:3px;background:#fff;border-radius:2px;transition:var(--t)}
.mobile-nav{display:none;border-top:1px solid var(--line);background:var(--char);
  padding:.6rem var(--pad) 1.3rem;max-height:80vh;overflow-y:auto}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:.7rem .2rem;font-family:var(--f-head);font-weight:500;
  text-transform:uppercase;letter-spacing:.03em;color:#e9e4df;border-bottom:1px solid var(--line)}
.mobile-nav .grp{color:var(--red);font-weight:600;padding-top:1rem}
.mobile-nav .sub a{padding-left:1.2rem;font-size:.9rem;color:var(--fog)}
.mobile-nav .btn{margin-top:1rem;width:100%}

/* ---------- Split "doors" hero (home) ---------- */
.doors{display:flex;flex-direction:column;min-height:84vh}
@media(min-width:900px){.doors{flex-direction:row}}
.door{position:relative;flex:1;display:flex;align-items:flex-end;overflow:hidden;
  min-height:46vh;transition:flex .5s cubic-bezier(.4,0,.2,1)}
@media(min-width:900px){.door:hover{flex:1.4}.door--res{border-right:3px solid var(--red)}}
.door img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.door .door__c{position:relative;z-index:2;padding:clamp(2rem,4vw,3rem) clamp(1.5rem,3vw,2.6rem);
  width:100%;display:flex;flex-direction:column;align-items:flex-start}
.door .k{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.25em;
  font-size:.74rem;color:var(--red-lt);display:inline-block;margin-bottom:.7rem;
  text-shadow:0 1px 8px rgba(20,19,18,.7)}
.door h2{font-size:clamp(2rem,4.2vw,3.4rem);color:#fff;margin-bottom:.6rem}
.door h2 span{color:var(--red)}
.door p{max-width:40ch;margin-bottom:1.3rem;font-size:1rem;color:#d3ccc4}
.door--res::after{content:"";position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(20,19,18,.96) 8%,rgba(20,19,18,.6) 48%,rgba(20,19,18,.18) 80%)}
.door--com::after{content:"";position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(20,19,18,.97) 8%,rgba(20,19,18,.7) 48%,rgba(20,19,18,.3) 80%)}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;background:var(--char);overflow:hidden}
.page-hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.page-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(15,14,13,.94),rgba(15,14,13,.55))}
.page-hero__inner{position:relative;z-index:2;padding-block:clamp(3rem,8vw,6rem);max-width:760px}
.page-hero h1{color:#fff;margin-bottom:.7rem}
.page-hero p{color:#e0d9d1;font-size:1.12rem;max-width:54ch;margin-bottom:0}
.crumbs{display:flex;gap:.5rem;align-items:center;font-size:.78rem;text-transform:uppercase;
  letter-spacing:.1em;color:#cfc8c0;margin-bottom:1.1rem;font-family:var(--f-head)}
.crumbs a{color:var(--red-lt)}.crumbs a:hover{color:#fff}
.crumbs span{opacity:.5}

/* ---------- Red stat bar ---------- */
.statbar{background:var(--red);border-block:3px solid var(--red-dk)}
.statbar .g{display:grid;grid-template-columns:repeat(2,1fr);text-align:center}
@media(min-width:760px){.statbar .g{grid-template-columns:repeat(4,1fr)}}
.statbar .s{padding:1.7rem .75rem;border-right:1px solid rgba(255,255,255,.18)}
.statbar .s:nth-child(2n){border-right:0}
@media(min-width:760px){.statbar .s{border-right:1px solid rgba(255,255,255,.18)}
  .statbar .s:nth-child(2n){border-right:1px solid rgba(255,255,255,.18)}
  .statbar .s:last-child{border-right:0}}
.statbar b{font-family:var(--f-disp);font-size:clamp(1.9rem,3.4vw,2.5rem);color:#fff;
  display:block;line-height:1}
.statbar span{font-family:var(--f-head);text-transform:uppercase;letter-spacing:.1em;
  font-size:.74rem;color:#ffdcd7;font-weight:500}

/* ---------- Twin path cards ---------- */
.twin{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:860px){.twin{grid-template-columns:1fr 1fr}}
.path{background:var(--char);border:1px solid var(--line);padding:clamp(1.8rem,3vw,2.6rem);
  position:relative;overflow:hidden}
.path::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--red)}
.path .k{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.22em;
  font-size:.72rem;color:var(--red);display:inline-block;margin-bottom:.9rem}
.path h3{font-family:var(--f-disp);font-weight:400;font-size:1.7rem;color:#fff;margin-bottom:1.1rem}
.path ul{list-style:none;padding:0;margin:0 0 1.6rem}
.path li{padding:.7rem 0 .7rem 2rem;position:relative;border-bottom:1px solid rgba(255,255,255,.07);
  font-size:.97rem;color:#ded8d2}
.path li::before{content:"";position:absolute;left:2px;top:1.05em;width:9px;height:9px;
  background:var(--red);transform:rotate(45deg)}

/* ---------- Split feature blocks ---------- */
.split{display:grid;gap:clamp(2rem,5vw,4rem);align-items:center}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr}.split--rev .split__media{order:2}}
.split__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;
  aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}
.split__media.tall img{aspect-ratio:4/5}

/* feature checklist */
.checks{list-style:none;padding:0;margin:0 0 1.6rem}
.checks li{position:relative;padding-left:2rem;margin-bottom:.8rem;color:#ded8d2}
.checks li::before{content:"";position:absolute;left:0;top:.35em;width:1.1rem;height:1.1rem;
  background-color:var(--red);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}

/* ---------- Cards ---------- */
.card{background:var(--char);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:transform var(--t),border-color var(--t)}
.card:hover{transform:translateY(-4px);border-color:var(--red)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card__media img{transform:scale(1.06)}
.card__body{padding:1.4rem 1.4rem 1.6rem;display:flex;flex-direction:column;flex:1}
.card__body h3{margin-bottom:.5rem}
.card__body p{color:var(--fog);font-size:.96rem;margin-bottom:1rem}
.card__link{margin-top:auto;font-family:var(--f-head);font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;font-size:.85rem;color:var(--red-lt);display:inline-flex;align-items:center;gap:.4rem}
.card__link::after{content:"→";transition:transform var(--t)}
.card:hover .card__link::after{transform:translateX(4px)}
.card--pad{padding:1.6rem}
.card--pad h3{margin-bottom:.5rem}
.card--pad p{color:var(--fog);margin-bottom:0;font-size:.96rem}
.card--pad .ico{width:44px;height:44px;border-radius:var(--radius);background:rgba(193,54,44,.16);
  color:var(--red-lt);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}

/* ---------- Stats (dark, non-bar) ---------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;text-align:center}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat b{font-family:var(--f-disp);font-size:clamp(2.2rem,4vw,3rem);color:var(--red);
  display:block;line-height:1}
.stat span{font-size:.82rem;color:var(--fog);text-transform:uppercase;letter-spacing:.08em;
  font-weight:600;font-family:var(--f-head)}

/* ---------- Steps ---------- */
.steps{counter-reset:step;display:grid;gap:1.8rem}
@media(min-width:760px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{position:relative;padding-top:.6rem;border-top:3px solid var(--red)}
.step__n{counter-increment:step;font-family:var(--f-disp);font-size:2.4rem;
  color:var(--red);line-height:1}
.step__n::before{content:"0" counter(step)}
.step h3{margin:.5rem 0 .4rem}
.step p{color:var(--fog);font-size:.94rem;margin:0}

/* ---------- Gallery ---------- */
.gal-filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2rem}
.gal-filters button{font-family:var(--f-head);font-weight:500;text-transform:uppercase;
  letter-spacing:.05em;font-size:.82rem;padding:.55rem 1.2rem;border-radius:999px;
  border:1px solid var(--line-2);background:var(--char);color:var(--fog);cursor:pointer;transition:var(--t)}
.gal-filters button:hover{border-color:var(--red);color:#fff}
.gal-filters button.active{background:var(--red);border-color:var(--red);color:#fff}
.gallery{columns:1;column-gap:1rem}
@media(min-width:560px){.gallery{columns:2}}
@media(min-width:900px){.gallery{columns:3}}
.gallery figure{margin:0 0 1rem;break-inside:avoid;border-radius:var(--radius);overflow:hidden;
  cursor:pointer;position:relative;border:1px solid var(--line)}
.gallery img{width:100%;transition:transform .4s ease}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figure::after{content:"";position:absolute;inset:0;background:rgba(193,54,44,0);transition:background var(--t)}
.gallery figure:hover::after{background:rgba(193,54,44,.18)}
.gallery figure.hide{display:none}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(10,9,8,.95);display:none;align-items:center;
  justify-content:center;z-index:300;padding:2rem}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:88vh;border-radius:var(--radius);box-shadow:var(--shadow-lg);width:auto}
.lb__close,.lb__nav{position:absolute;background:rgba(255,255,255,.12);color:#fff;border:0;
  cursor:pointer;width:52px;height:52px;border-radius:50%;font-size:1.5rem;display:flex;
  align-items:center;justify-content:center;transition:var(--t)}
.lb__close:hover,.lb__nav:hover{background:var(--red)}
.lb__close{top:1.2rem;right:1.2rem}
.lb__nav.prev{left:1.2rem;top:50%;transform:translateY(-50%)}
.lb__nav.next{right:1.2rem;top:50%;transform:translateY(-50%)}

/* ---------- Res/Com CSS toggle (home + gallery) ---------- */
.gwrap input{position:absolute;opacity:0;pointer-events:none}
.gtoggle{display:flex;justify-content:center;margin-bottom:2.2rem}
.gtoggle label{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  font-size:.88rem;padding:.8rem 2rem;border:2px solid var(--line-2);cursor:pointer;color:var(--fog)}
.gtoggle label:first-of-type{border-right-width:1px;border-radius:var(--radius) 0 0 var(--radius)}
.gtoggle label:last-of-type{border-left-width:1px;border-radius:0 var(--radius) var(--radius) 0}
#gres:checked ~ .gtoggle label[for=gres],
#gcom:checked ~ .gtoggle label[for=gcom]{background:var(--red);border-color:var(--red);color:#fff}
#gres:checked ~ .gal-toggle .com{display:none}
#gcom:checked ~ .gal-toggle .res{display:none}
.gal-toggle{display:grid;gap:1.1rem;grid-template-columns:1fr 1fr}
@media(min-width:860px){.gal-toggle{grid-template-columns:repeat(4,1fr)}}
.gal-toggle figure{margin:0;position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--line)}
.gal-toggle img{aspect-ratio:1/1;object-fit:cover;width:100%;transition:.4s;opacity:.9}
.gal-toggle figure:hover img{transform:scale(1.06);opacity:1}
.gal-toggle figcaption{position:absolute;left:0;bottom:0;width:100%;padding:.85rem 1rem;color:#fff;
  font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.76rem;
  background:linear-gradient(0deg,rgba(20,19,18,.92),transparent)}

/* ---------- Dual testimonials ---------- */
.duo{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:860px){.duo{grid-template-columns:1fr 1fr}}
.quo{background:var(--char);border:1px solid var(--line);padding:clamp(1.7rem,3vw,2.3rem);position:relative}
.quo .tag{font-family:var(--f-head);font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  font-size:.68rem;color:#fff;background:var(--red);display:inline-block;padding:.3rem .8rem;margin-bottom:1rem}
.quo .st{color:var(--red);letter-spacing:2px;margin-bottom:.8rem}
.quo p{font-size:1.05rem;color:#ded8d2;margin-bottom:1rem}
.quo .who{font-family:var(--f-head);font-weight:600;color:#fff;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}
.quo .who span{display:block;color:var(--fog);font-family:var(--f-body);font-weight:400;
  font-size:.82rem;text-transform:none;letter-spacing:0}
.placeholder-note{text-align:center;color:var(--fog-2);font-size:.82rem;margin-top:1.1rem}

/* ---------- Fence-types material rows ---------- */
.matrow{display:grid;gap:clamp(1.8rem,4vw,3.5rem);align-items:center;padding-block:clamp(2.2rem,4vw,3.2rem);
  border-top:1px solid var(--line);scroll-margin-top:120px}
@media(min-width:900px){.matrow{grid-template-columns:1fr 1fr}.matrow--rev .matrow__media{order:2}}
.matrow__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:4/3;
  object-fit:cover;border:1px solid var(--line)}
.matrow h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:.6rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.2rem 0 1rem;padding:0;list-style:none}
.chips li{background:var(--char2);border:1px solid var(--line);border-radius:999px;padding:.35rem .9rem;
  font-family:var(--f-head);font-weight:500;text-transform:uppercase;letter-spacing:.04em;
  font-size:.72rem;color:var(--fog)}
/* jump nav for fence types */
.jump{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.jump a{font-family:var(--f-head);font-weight:500;text-transform:uppercase;letter-spacing:.05em;
  font-size:.82rem;padding:.55rem 1.2rem;border-radius:999px;border:1px solid var(--line-2);
  background:var(--char);color:var(--fog)}
.jump a:hover{border-color:var(--red);color:#fff}

/* ---------- CTA band (interior) ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--char);text-align:center}
.cta-band__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.24}
.cta-band::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,19,18,.7),rgba(20,19,18,.85))}
.cta-band__inner{position:relative;z-index:2;padding-block:clamp(3rem,7vw,5.5rem);max-width:720px;margin-inline:auto}
.cta-band h2{color:#fff}
.cta-band p{color:#e4ded7;font-size:1.1rem}
.cta-band .btn-row{justify-content:center}

/* ---------- Split final CTA (home) ---------- */
.fcta{display:flex;flex-direction:column}
@media(min-width:860px){.fcta{flex-direction:row}}
.fcta .half{flex:1;text-align:center;padding:clamp(3rem,6vw,5rem) 1.8rem}
.fcta .half.res{background:var(--char2)}
.fcta .half.com{background:var(--red)}
.fcta h2{font-size:clamp(1.7rem,3vw,2.4rem);color:#fff;margin-bottom:.5rem}
.fcta p{margin-bottom:1.4rem;color:#cfc8c1}
.fcta .half.com p{color:#ffdcd7}

/* ---------- Contact / forms ---------- */
.contact-grid{display:grid;gap:clamp(2rem,4vw,3.5rem)}
@media(min-width:900px){.contact-grid{grid-template-columns:1fr 1.1fr}}
.info-card{background:var(--char);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem}
.info-list{list-style:none;padding:0;margin:0}
.info-list li{display:flex;gap:.9rem;align-items:flex-start;padding:.9rem 0;border-bottom:1px solid var(--line)}
.info-list li:last-child{border-bottom:0}
.info-list .ico{flex:none;width:42px;height:42px;border-radius:var(--radius);background:var(--red);
  color:#fff;display:flex;align-items:center;justify-content:center}
.info-list b{font-family:var(--f-head);text-transform:uppercase;letter-spacing:.05em;
  font-size:.76rem;color:var(--fog);display:block;font-weight:500}
.info-list a,.info-list span{color:#fff;font-size:1.02rem}
form .field{margin-bottom:1.1rem}
label{display:block;font-family:var(--f-head);font-weight:500;text-transform:uppercase;
  letter-spacing:.05em;font-size:.78rem;color:var(--fog);margin-bottom:.4rem}
input,select,textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--line-2);
  border-radius:var(--radius);font-family:var(--f-body);font-size:1rem;color:#fff;
  background:var(--char3);transition:var(--t)}
input::placeholder,textarea::placeholder{color:#8d867e}
input:focus,select:focus,textarea:focus{border-color:var(--red);outline:none;
  box-shadow:0 0 0 3px rgba(193,54,44,.22)}
select{color:#fff}
option{color:#111}
textarea{min-height:130px;resize:vertical}
.form-2{display:grid;gap:0 1rem}
@media(min-width:600px){.form-2{grid-template-columns:1fr 1fr}}

/* ---------- Blog (Penny → shim widget; canonical class names) ---------- */
.blog-empty,.blog-error{color:var(--fog);text-align:center;padding:2rem 0}
.blog-list{display:grid;gap:clamp(1.25rem,3vw,2rem);grid-template-columns:1fr}
@media(min-width:760px){.blog-list{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.blog-list{grid-template-columns:repeat(3,1fr)}}
.blog-card{background:var(--char);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform var(--t),border-color var(--t)}
.blog-card:hover{transform:translateY(-4px);border-color:var(--red)}
.blog-card-img{aspect-ratio:16/9;width:100%;object-fit:cover;transition:transform .4s ease}
.blog-card:hover .blog-card-img{transform:scale(1.05)}
.blog-card-body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.blog-card-date{font-family:var(--f-head);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;
  color:var(--red);margin-bottom:.5rem}
.blog-card-title{font-family:var(--f-head);font-weight:700;text-transform:uppercase;
  font-size:1.12rem;line-height:1.15;margin:0 0 .5rem}
.blog-card-title a{color:#fff}.blog-card-title a:hover{color:var(--red-lt)}
.blog-card-excerpt{color:var(--fog);font-size:.94rem;margin-bottom:1rem}
.blog-card-more{margin-top:auto;font-family:var(--f-head);font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;font-size:.82rem;color:var(--red-lt)}
/* single post */
.blog-post{max-width:min(100%,860px);margin-inline:auto}
.blog-back{font-family:var(--f-head);text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;
  color:var(--red-lt);display:inline-block;margin-bottom:1.5rem}
.blog-post-date{font-family:var(--f-head);text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;
  color:var(--red);margin-bottom:.6rem}
.blog-post-title{margin-bottom:1.3rem}
.blog-post-img{border-radius:var(--radius);margin-bottom:1.8rem;width:100%;border:1px solid var(--line)}
.blog-post-body{color:#ded8d2;font-size:1.05rem;line-height:1.75}
.blog-post-body h2,.blog-post-body h3{margin-top:1.8rem}
.blog-post-body p{margin-bottom:1.2rem}
.blog-post-body img{border-radius:var(--radius);margin:1.4rem 0}
.blog-post-body a{color:var(--red-lt);text-decoration:underline}
.blog-post-body ul,.blog-post-body ol{margin:0 0 1.2rem;padding-left:1.4rem}
.blog-post-body blockquote{border-left:3px solid var(--red);padding-left:1.2rem;margin:1.4rem 0;color:var(--fog);font-style:italic}

/* ---------- Footer ---------- */
.site-footer{background:#000;color:var(--fog);font-size:.94rem;border-top:1px solid var(--line)}
.site-footer .wrap-wide{padding-block:clamp(3rem,5vw,4rem)}
.footer-grid{display:grid;gap:2.2rem}
@media(min-width:760px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1.2fr}}
.site-footer h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.1rem}
.site-footer a{color:var(--fog)}.site-footer a:hover{color:#fff}
.footer-brand img{height:40px;margin-bottom:1rem}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:.55rem}
.footer-contact li{display:flex;gap:.6rem;margin-bottom:.75rem;align-items:flex-start}
.footer-contact svg{flex:none;color:var(--red);margin-top:.2rem}
.footer-bottom{border-top:1px solid var(--line)}
.footer-bottom .wrap-wide{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:space-between;
  padding-block:1.3rem;font-size:.84rem;color:var(--fog-2)}
.footer-bottom a{color:var(--fog-2)}

/* ---------- Scam notice ---------- */
.notice{background:rgba(193,54,44,.12);border-left:4px solid var(--red);border-radius:var(--radius);
  padding:1.1rem 1.3rem;color:#ede7e1;font-size:.97rem}
.notice b{color:#fff}

/* ---------- Misc ---------- */
.pill{display:inline-block;background:rgba(193,54,44,.16);color:var(--red-lt);font-family:var(--f-head);
  font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;padding:.35rem .9rem;
  border-radius:999px;margin-bottom:1rem}
.badges{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center}
.badges img{height:56px;width:auto;opacity:.95;border-radius:var(--radius)}
hr.rule{border:0;border-top:1px solid var(--line);margin:0}
.prose p{color:var(--fog)}
.prose h3{margin-top:1.8rem;color:#fff}
.prose a{text-decoration:underline}

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