/* ============================================================
   Punishers LEMC Worldwide — Redesign
   Dark, service-friendly, industrial. Mobile-first.
   ============================================================ */
:root{
  --bg:#13161b;            /* deep charcoal, not pure black */
  --bg-2:#191d24;          /* alt section */
  --surface:#222831;       /* cards */
  --surface-2:#2b323d;
  --line:#333b47;
  --text:#e9edf3;
  --muted:#a6b0bd;
  --steel:#3f93d4;         /* primary brand steel-blue */
  --steel-bright:#5fb0ee;
  --steel-deep:#27567f;
  --red:#e0394a;           /* first responder / CTA accent */
  --green:#3fa34d;         /* military */
  --blue:#2f80ed;          /* law enforcement */
  --white:#ffffff;
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 14px 38px rgba(0,0,0,.45);
  --maxw:1180px;
  --head:'Oswald',Impact,'Arial Narrow',sans-serif;
  --body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--body);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--steel-bright);text-decoration:none}
a:hover{color:var(--white)}
h1,h2,h3{font-family:var(--head);font-weight:700;line-height:1.05;letter-spacing:.5px;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,7vw,4.4rem);text-transform:uppercase}
h2{font-size:clamp(1.7rem,4vw,2.6rem);text-transform:uppercase}
h3{font-size:1.15rem;text-transform:uppercase;letter-spacing:1px}
p{margin:0 0 1.1em}
.container{width:min(100% - 2.2rem,var(--maxw));margin-inline:auto}
.eyebrow{font-family:var(--head);text-transform:uppercase;letter-spacing:3px;
  font-weight:600;font-size:.82rem;color:var(--steel-bright);margin:0 0 .6em}
.lead{font-size:1.12rem;color:var(--muted);max-width:60ch}
.skip-link{position:absolute;left:-999px;top:0;background:var(--steel);color:#fff;
  padding:.6rem 1rem;border-radius:0 0 8px 0;z-index:200}
.skip-link:focus{left:0}

/* ---------------- emblem ---------------- */
.emblem{width:100%;height:100%;color:var(--steel-bright);display:block}
.emblem-img{width:100%;height:100%;object-fit:contain;display:block}
.brand-mark{display:inline-flex;width:46px;height:46px;flex:0 0 auto;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.55))}

/* ---------------- disclaimer strip ---------------- */
.disclaimer-bar{background:#3a2a12;border-bottom:1px solid #5c4524;color:#f4dca8;
  font-size:.78rem;line-height:1.45;text-align:center;padding:.42rem 1rem}
.disclaimer-bar strong{color:#ffd684;font-weight:700}

/* ---------------- header / nav ---------------- */
.topbar{position:sticky;top:0;z-index:100;background:rgba(15,18,23,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar-inner{display:flex;align-items:center;gap:1rem;min-height:68px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:.65rem;color:var(--text);margin-right:auto}
.brand:hover{color:var(--text)}
.brand-name{font-family:var(--head);font-weight:700;font-size:1.35rem;letter-spacing:1.5px;
  text-transform:uppercase;line-height:1;display:inline-flex;align-items:center;gap:.4rem}
.tricolor{display:inline-block;width:30px;height:5px;border-radius:3px;
  background:linear-gradient(90deg,var(--blue) 0 33%,#fff 33% 66%,var(--red) 66% 100%)}
.brand-text{display:flex;flex-direction:column}
.brand-sub{font-size:.66rem;letter-spacing:2.5px;color:var(--muted);text-transform:uppercase}

.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:42px;background:var(--surface);border:1px solid var(--line);
  border-radius:9px;cursor:pointer;padding:0 11px}
.nav-toggle span{height:2.5px;background:var(--text);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.primary-nav{flex-basis:100%;display:none}
.primary-nav.open{display:block}
.primary-nav>ul{list-style:none;margin:.4rem 0 1rem;padding:0;display:flex;flex-direction:column;gap:2px}
.primary-nav a,.sub-toggle{font-family:var(--head);text-transform:uppercase;letter-spacing:1px;
  font-size:1rem;color:var(--text);font-weight:500}
.primary-nav>ul>li>a,.sub-toggle{display:flex;align-items:center;gap:.4rem;width:100%;
  padding:.75rem .6rem;background:none;border:0;cursor:pointer;text-align:left;border-radius:8px}
.primary-nav>ul>li>a:hover,.sub-toggle:hover{background:var(--surface)}
.primary-nav a.active{color:var(--steel-bright)}
.sub-toggle i{margin-left:auto;width:8px;height:8px;border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;transform:rotate(45deg);transition:.25s}
.sub-toggle[aria-expanded="true"] i{transform:rotate(-135deg)}
.sub{list-style:none;margin:0;padding:.1rem 0 .4rem .8rem;display:none}
.has-sub.open .sub{display:block}
.sub a{padding:.55rem .6rem;font-size:.92rem;color:var(--muted)}
.sub a:hover{color:var(--text)}
.nav-member{color:var(--steel-bright)!important}
.nav-member:hover{color:#fff!important}

@media(min-width:1000px){
  .nav-toggle{display:none}
  .primary-nav{display:block;flex-basis:auto}
  .primary-nav>ul{flex-direction:row;align-items:center;gap:.15rem;margin:0}
  .primary-nav>ul>li>a,.sub-toggle{padding:.55rem .7rem;font-size:.95rem;width:auto}
  .has-sub{position:relative}
  .sub-toggle i{margin-left:.35rem}
  .sub{position:absolute;top:100%;left:0;min-width:215px;margin-top:0;background:var(--surface);
    border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:.4rem;z-index:50}
  .sub::before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px}
  .has-sub:hover .sub,.has-sub:focus-within .sub,.has-sub.open .sub{display:block}
  .sub a{border-radius:7px}
  .sub a:hover{background:var(--surface-2)}
  .nav-member{border:1px solid var(--steel-deep);border-radius:8px;background:rgba(63,147,212,.12)}
}

/* ---------------- hero ---------------- */
.hero{position:relative;min-height:clamp(440px,76vh,720px);display:flex;align-items:center;
  background-image:var(--hero-img);background-size:cover;background-position:center;
  border-bottom:3px solid var(--steel-deep)}
.hero-compact{min-height:clamp(300px,42vh,420px)}
.hero-overlay{position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(10,12,16,.72) 0%,rgba(10,12,16,.5) 38%,rgba(10,12,16,.5) 62%,rgba(10,12,16,.6) 100%),
    linear-gradient(180deg,rgba(10,12,16,.2) 0%,rgba(10,12,16,.32) 55%,rgba(16,19,24,.96) 100%)}
/* desktop: solid menu on top, hero sits below it; frame the banner from the top so the PUNISHERS wordmark is never clipped */
@media(min-width:1000px){
  .hero{background-position:center top}
  .hero-overlay{background:
    linear-gradient(90deg,rgba(10,12,16,.82) 0%,rgba(10,12,16,.55) 30%,rgba(10,12,16,.2) 52%,rgba(10,12,16,.05) 70%,rgba(10,12,16,0) 100%),
    linear-gradient(180deg,rgba(10,12,16,.1) 0%,rgba(10,12,16,.12) 55%,rgba(16,19,24,.82) 100%)}
  body[data-page="home"] .hero-eyebrow{display:none}
}
.hero-content{position:relative;z-index:2;padding:3.5rem 0;max-width:760px}
.hero-eyebrow{font-family:var(--head);text-transform:uppercase;letter-spacing:3px;font-weight:600;
  color:var(--steel-bright);margin:0 0 .8rem;font-size:.9rem;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.hero h1{color:#fff;text-shadow:0 2px 5px rgba(0,0,0,.9),0 8px 30px rgba(0,0,0,.6);margin-bottom:.4em}
.hero-sub{font-size:1.18rem;color:#eef2f7;max-width:54ch;text-shadow:0 1px 3px rgba(0,0,0,.95),0 2px 12px rgba(0,0,0,.6)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.hero-ctas.center{justify-content:center}

/* ---------------- buttons ---------------- */
.btn{display:inline-block;font-family:var(--head);text-transform:uppercase;letter-spacing:1.5px;
  font-weight:600;font-size:.95rem;padding:.85rem 1.6rem;border-radius:10px;cursor:pointer;
  transition:transform .15s ease,background .2s,box-shadow .2s;border:2px solid transparent}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:#2b6ba0;color:#fff;box-shadow:0 8px 22px rgba(63,147,212,.32)}
.btn-primary:hover{background:var(--steel-bright);color:#0b1116}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.12);color:#fff}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:#ff4f5f;color:#fff}

/* ---------------- sections ---------------- */
.section{padding:clamp(3rem,7vw,5.5rem) 0}
.section.alt-bg{background:var(--bg-2)}
.section-head{max-width:62ch;margin:0 auto clamp(2rem,4vw,3rem);text-align:center}
.section-head h2{color:#fff}
.section-head .lead{margin-inline:auto}

/* stats */
.stats{list-style:none;margin:0;padding:0;display:grid;gap:1rem;
  grid-template-columns:repeat(2,1fr);text-align:center}
.stats li{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.3rem .6rem}
.stat-num{display:block;font-family:var(--head);font-weight:700;font-size:2rem;color:var(--steel-bright)}
.stat-label{font-size:.78rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}
@media(min-width:760px){.stats{grid-template-columns:repeat(5,1fr)}}

/* pillars */
.pillars{display:grid;gap:1.4rem;grid-template-columns:1fr}
@media(min-width:760px){.pillars{grid-template-columns:repeat(3,1fr)}}
.pillar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);transition:transform .2s}
.pillar:hover{transform:translateY(-4px)}
.pillar-img{height:190px;background-size:cover;background-position:center;border-bottom:4px solid var(--steel)}
.pillar-le .pillar-img{border-color:var(--blue)}
.pillar-mil .pillar-img{border-color:var(--green)}
.pillar-fr .pillar-img{border-color:var(--red)}
.pillar-body{padding:1.3rem 1.4rem 1.6rem}
.pillar-body h3{color:#fff}
.pillar-body p{color:var(--muted);margin:0}

/* welcome */
.welcome{display:grid;gap:2rem;align-items:center}
@media(min-width:880px){.welcome{grid-template-columns:1.1fr .9fr}}
.welcome-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%}
.signature{font-family:var(--head);font-weight:600;text-transform:uppercase;letter-spacing:1px;
  color:#fff;line-height:1.2;margin-top:.4rem}
.signature span{display:block;font-size:.8rem;color:var(--steel-bright);letter-spacing:2px;margin-top:.2rem}
.center-sig{text-align:center}

/* prose */
.prose.narrow{max-width:78ch;margin-inline:auto}
.prose.center{text-align:center}
.prose blockquote{border-left:4px solid var(--steel);margin:1.6rem 0;padding:.4rem 1.2rem;
  font-family:var(--head);font-size:1.4rem;color:#fff;letter-spacing:.5px;text-transform:uppercase;line-height:1.2}
.prose-media.full{margin-top:2rem}
.prose-media.full img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%}
.split{display:grid;gap:2rem;align-items:center}
@media(min-width:880px){.split{grid-template-columns:1fr 1fr}.split.reverse .prose-media{order:-1}}
.prose-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%}
.prose-text h2{color:#fff}
.fineprint{font-size:.85rem;color:var(--muted)}

/* facts list / factbox */
.factbox{display:grid;gap:2rem;align-items:center}
@media(min-width:880px){.factbox{grid-template-columns:1.15fr .85fr}}
.factbox-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.facts-list{list-style:none;margin:0;padding:0;display:grid;gap:.8rem}
.facts-list li{position:relative;padding-left:1.8rem;color:var(--muted)}
.facts-list li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;
  background:var(--steel-bright);transform:rotate(45deg)}
.facts-list strong{color:var(--text)}

/* gallery */
.gallery{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:760px){.gallery{grid-template-columns:repeat(3,1fr)}}
.gallery-item{margin:0;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface);
  border:1px solid var(--line)}
.gallery-item img{width:100%;height:230px;object-fit:cover;transition:transform .4s}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item.with-cap figcaption{padding:.7rem .9rem;font-size:.82rem;color:var(--muted)}

/* rides */
.rides{display:grid;gap:1.4rem;grid-template-columns:1fr}
@media(min-width:760px){.rides{grid-template-columns:repeat(3,1fr)}}
.ride-card{margin:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.ride-card img{width:100%;height:200px;object-fit:cover}
.ride-card figcaption{padding:1rem 1.1rem}
.ride-card strong{display:block;color:#fff;font-family:var(--head);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.3rem}
.ride-card span{color:var(--muted);font-size:.9rem}

/* quotes */
.quotes{display:grid;gap:1.4rem}
@media(min-width:880px){.quotes{grid-template-columns:repeat(3,1fr)}}
.quote-card{margin:0;background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--steel);
  border-radius:var(--radius);padding:1.6rem}
.quote-card p{color:var(--muted);font-style:italic}
.quote-card cite{font-family:var(--head);text-transform:uppercase;letter-spacing:1px;color:var(--steel-bright);font-style:normal;font-weight:600;font-size:.9rem}

/* link cards */
.link-grid{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:620px){.link-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:920px){.link-grid{grid-template-columns:repeat(3,1fr)}}
.link-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.4rem 1.5rem;transition:.2s;color:var(--text)}
.link-card:hover{background:var(--surface-2);transform:translateY(-3px);border-color:var(--steel-deep);color:var(--text)}
.link-card h3{color:#fff;margin-bottom:.4rem}
.link-card span{color:var(--steel-bright);font-size:.9rem;font-weight:600}

/* video card */
.video-card{text-align:center;max-width:60ch;margin-inline:auto}
.video-card h2{color:#fff}

/* contact */
.contact-grid{display:grid;gap:2.4rem}
@media(min-width:880px){.contact-grid{grid-template-columns:.9fr 1.1fr}}
.contact-intro h2{color:#fff}
.contact-points{list-style:none;margin:1rem 0 1.4rem;padding:0;display:grid;gap:.6rem}
.contact-points li{padding-left:1.6rem;position:relative;color:var(--muted)}
.contact-points li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;background:var(--steel);transform:rotate(45deg)}
.contact-points strong{color:var(--text)}
.contact-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow)}
.field{margin-bottom:1rem;display:flex;flex-direction:column}
.field-row{display:grid;gap:1rem}
@media(min-width:560px){.field-row{grid-template-columns:1fr 1fr}}
.field label{font-family:var(--head);text-transform:uppercase;letter-spacing:1px;font-size:.82rem;color:var(--muted);margin-bottom:.35rem}
.field input,.field textarea{background:var(--bg);border:1px solid var(--line);border-radius:9px;
  color:var(--text);padding:.7rem .85rem;font:inherit;width:100%}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--steel);box-shadow:0 0 0 3px rgba(63,147,212,.2)}
.form-note{margin-top:.9rem;color:var(--steel-bright);font-weight:600}
.contact-form .btn{margin-top:.3rem}

/* ---------------- footer ---------------- */
.site-footer{background:#0e1116;border-top:1px solid var(--line);margin-top:0}
.footer-grid{display:grid;gap:2rem;padding:clamp(2.5rem,5vw,3.5rem) 0 2rem;grid-template-columns:1fr}
@media(min-width:680px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.footer-brand .brand-mark{width:48px;height:48px;margin-bottom:.6rem}
.footer-motto{font-family:var(--head);text-transform:uppercase;letter-spacing:1px;color:var(--steel-bright);font-size:1.2rem;margin:.2rem 0 .6rem}
.footer-small{color:var(--muted);font-size:.88rem;max-width:38ch}
.footer-col h3{color:#fff;font-size:.95rem;margin-bottom:.8rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.footer-col a{color:var(--muted);font-size:.92rem}
.footer-col a:hover{color:#fff}
.footer-bar{border-top:1px solid var(--line);background:#0b0e12}
.footer-bar-inner{display:flex;flex-direction:column;gap:.4rem;padding:1rem 0;align-items:flex-start}
.footer-bar p{margin:0;font-size:.84rem;color:var(--muted)}
.no-cookie-note strong{color:var(--steel-bright)}
@media(min-width:680px){.footer-bar-inner{flex-direction:row;justify-content:space-between;align-items:center}}

/* ---------------- cookie banner ---------------- */
.cookie-bar{position:fixed;left:50%;transform:translateX(-50%);bottom:1rem;z-index:150;
  width:min(100% - 1.6rem,640px);background:var(--surface);border:1px solid var(--steel-deep);
  border-radius:12px;box-shadow:var(--shadow);padding:.9rem 1.1rem;display:flex;gap:1rem;
  align-items:center;justify-content:space-between}
.cookie-bar p{margin:0;font-size:.88rem;color:var(--muted)}
.cookie-bar strong{color:var(--steel-bright)}
.cookie-bar button{flex:0 0 auto;background:var(--steel);color:#fff;border:0;border-radius:8px;
  padding:.55rem 1rem;font-family:var(--head);text-transform:uppercase;letter-spacing:1px;font-size:.82rem;cursor:pointer}
.cookie-bar button:hover{background:var(--steel-bright);color:#0b1116}
.cookie-bar.hide{display:none}

/* ---------------- calendar embed (Events) ---------------- */
.cal-embed{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}
.cal-placeholder{display:flex;align-items:center;justify-content:center;min-height:360px;padding:2rem 1.2rem;
  background:linear-gradient(180deg,var(--surface),var(--bg-2))}
.cal-ph-inner{text-align:center;max-width:48ch}
.cal-ph-inner h3{color:#fff}
.cal-ph-inner p{color:var(--muted)}
.cal-ph-inner .btn{margin:.6rem 0 1rem}
.cal-embed iframe{display:block;width:100%;height:75vh;min-height:560px;border:0;background:#fff}

/* ---------------- mobile refinements ---------------- */
@media(max-width:640px){
  .hero{min-height:72vh;background-position:18% center}
  .hero-compact{min-height:38vh;background-position:center}
  .hero-content{padding:2.4rem 0}
  .hero h1{font-size:clamp(2.3rem,11vw,3.2rem)}
  .hero-sub{font-size:1.02rem}
  .hero-ctas .btn{flex:1 1 auto;text-align:center}
  .stats{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .gallery-item img{height:140px}
  .ride-card img{height:170px}
  .pillar-img{height:160px}
  .welcome-media img,.prose-media img,.factbox-media img{width:100%}
  .cal-embed iframe{height:70vh;min-height:460px}
  .cookie-bar{flex-wrap:wrap;gap:.6rem;bottom:.6rem}
  .cookie-bar button{width:100%}
}
@media(max-width:380px){
  .gallery{grid-template-columns:1fr}
  .gallery-item img{height:200px}
  .brand-sub{display:none}
}

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