/*
Theme Name: Ironclad Thor Industries
Theme URI: https://ironclad-thor.com
Author: Ironclad Thor Industries LLC
Author URI: https://ironclad-thor.com
Description: Dark, mission-ready theme for emergency vehicle upfitting, emergency response, media production, technology solutions, and custom design/build projects.
Version: 6.10.2
Requires at least: 5.8
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ironcladthor
*/

/* ─── DESIGN TOKENS ──────────────────────────────────────── */
:root {
  --crimson:      #C8102E;
  --crimson-deep: #8B0A1F;
  --crimson-lit:  #E8203F;
  --bg:           #0A0A0A;
  --bg2:          #0f1218;
  --card:         #111418;
  --card2:        #1C2128;
  --text:         #F5F7FA;
  --muted:        #8A9BB0;
  --subtle:       #4A5568;
  --line:         rgba(245,247,250,.10);
  --line-strong:  rgba(245,247,250,.18);
  --accent:       #C8102E;
  --accent2:      #E8203F;
  --shadow:       0 18px 50px rgba(0,0,0,.45);
  --radius:       18px;
  --max:          1160px;
}

/* ─── RESET + BASE ───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:'Barlow',system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 500px at 15% 0%,rgba(200,16,46,.10),transparent 60%),
    radial-gradient(700px 400px at 85% 5%,rgba(139,10,31,.07),transparent 55%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
select{width:100%;padding:12px;border-radius:14px;border:1px solid rgba(245,247,250,.14);background:rgba(10,10,10,.35);color:var(--text);outline:none}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

/* ─── TOPBAR ─────────────────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:50;background:rgba(10,10,10,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);border-top:3px solid var(--crimson)}
.nav{display:flex;align-items:center;gap:16px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;font-family:'Impact','Arial Black',sans-serif;font-weight:400;letter-spacing:.05em;text-transform:uppercase;margin-right:auto}
.defaultLogo,.custom-logo{height:40px;width:auto}
.logoMark{width:36px;height:36px;border-radius:4px;background:var(--crimson)}
.navlinks{display:flex;align-items:center;gap:18px;color:var(--muted);font-weight:700;font-size:14px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.04em}
.navlinks a{padding:8px 10px;border-radius:10px}
.navlinks a:hover{background:rgba(200,16,46,.08);color:var(--text)}
.ctaRow{display:flex;align-items:center;gap:10px}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn{padding:10px 16px;font-weight:700;font-size:14px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.04em;border-radius:10px;border:1px solid rgba(245,247,250,.14);background:rgba(10,10,10,.35);color:var(--text);cursor:pointer;white-space:nowrap;display:inline-block;transition:background .15s,border-color .15s}
.btn:hover{background:rgba(245,247,250,.08);border-color:rgba(245,247,250,.22)}
.btnPrimary{background:var(--crimson);color:#fff;border:none;box-shadow:0 4px 18px rgba(200,16,46,.35)}
.btnPrimary:hover{background:var(--crimson-lit);box-shadow:0 6px 22px rgba(200,16,46,.5)}
.btnSecondary{background:rgba(245,247,250,.07);border:1px solid rgba(245,247,250,.16);color:var(--muted)}
.btnSecondary:hover{background:rgba(245,247,250,.12);color:var(--text)}
.backLink{display:block;margin-top:12px;padding:12px 14px;background:rgba(245,247,250,.06);border-radius:10px;color:var(--muted);font-weight:700;font-family:'Barlow Condensed',sans-serif;border:1px solid var(--line)}
.backLink:hover{background:rgba(245,247,250,.12);color:var(--text)}

/* ─── MOBILE NAV ─────────────────────────────────────────── */
.hamburger{display:none;background:none;border:none;color:var(--text);font-size:24px;padding:10px;cursor:pointer}
.mobileMenu{display:none;padding:14px 0;border-top:1px solid var(--line);flex-direction:column;gap:8px}
.mobileMenu.active{display:flex}
.mobileMenu a{padding:12px 14px;border-radius:10px;font-weight:700;font-size:14px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.03em}
.mobileMenu a:hover{background:rgba(200,16,46,.08)}

/* ─── HERO ───────────────────────────────────────────────── */
.hero{padding:44px 0}
.heroGrid{display:grid;grid-template-columns:1.2fr .9fr;gap:24px;align-items:start}
.kicker{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:12px;color:var(--muted);font-family:'Barlow Condensed',sans-serif;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.dot{width:6px;height:6px;border-radius:999px;background:var(--crimson);box-shadow:0 0 12px rgba(200,16,46,.7)}
h1{margin:0;font-size:42px;letter-spacing:.02em;max-width:30ch;font-family:'Impact','Arial Black','Helvetica Neue',sans-serif;font-weight:400;text-transform:uppercase}
h2{font-family:'Impact','Arial Black',sans-serif;font-weight:400;letter-spacing:.02em;text-transform:uppercase}
h3{font-family:'Impact','Arial Black',sans-serif;font-weight:400;letter-spacing:.04em;text-transform:uppercase}
.lead{margin:14px 0 0;color:var(--muted);max-width:54ch;font-size:14.5px;line-height:1.65}
.heroActions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}

/* ─── STAT PANEL ─────────────────────────────────────────── */
.panel{border-radius:var(--radius);border:1px solid rgba(200,16,46,.25);background:linear-gradient(135deg,rgba(200,16,46,.07),rgba(139,10,31,.05));box-shadow:0 10px 30px rgba(0,0,0,.3)}
.panelInner{padding:20px}
.statGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat{text-align:center;padding:14px;border-radius:12px;background:rgba(10,10,10,.35);border:1px solid rgba(200,16,46,.15)}
.stat .big{font-weight:900;font-size:15px;margin-bottom:6px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.06em;color:var(--crimson)}
.stat .small{font-size:12px;color:var(--muted)}

/* ─── SECTIONS ───────────────────────────────────────────── */
section{padding:46px 0}
.sectionHead{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px}
.sectionHead h2{margin:0;font-size:26px;letter-spacing:-.2px}
.sectionHead p{margin:0;color:var(--muted);max-width:70ch}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}

/* ─── CARDS ──────────────────────────────────────────────── */
.card{border-radius:var(--radius);border:1px solid var(--line);background:rgba(17,20,24,.75);box-shadow:0 8px 28px rgba(0,0,0,.28);padding:18px;transition:border-color .2s,box-shadow .2s}
.card:hover{border-color:rgba(200,16,46,.3);box-shadow:0 12px 36px rgba(0,0,0,.35)}
.card h3{margin:0 0 6px;font-size:16px;color:var(--text)}
.card p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.6}

/* ─── PILLS ──────────────────────────────────────────────── */
.pillRow{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.pill{padding:5px 10px;border-radius:6px;border:1px solid rgba(200,16,46,.2);background:rgba(200,16,46,.06);color:var(--muted);font-weight:700;font-size:12px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.06em}

/* ─── CTA BLOCK ──────────────────────────────────────────── */
.ctaBlock{border-radius:calc(var(--radius) + 8px);border:1px solid rgba(200,16,46,.2);background:radial-gradient(800px 400px at 0% 0%,rgba(200,16,46,.14),transparent 60%),radial-gradient(700px 400px at 100% 30%,rgba(139,10,31,.10),transparent 58%),rgba(17,20,24,.75);box-shadow:var(--shadow);padding:28px;display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:center}
.ctaBlock h2{margin:0 0 8px;font-size:26px}
.ctaBlock p{margin:0;color:var(--muted)}
.ctaMini{border-radius:var(--radius);border:1px solid rgba(200,16,46,.18);background:rgba(10,10,10,.35);padding:16px}
.ctaMini strong{display:block;font-size:14px;margin-bottom:6px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.04em;color:var(--crimson)}
.ctaMini .small{color:var(--muted);font-size:13.5px;line-height:1.8}

/* ─── PAGE HEAD ──────────────────────────────────────────── */
.pageHead{padding:44px 0 8px}
.pageHead h1{margin:0}
.pageHead .lead{margin-top:10px}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer{padding:26px 0;border-top:2px solid var(--crimson);color:var(--muted);background:rgba(10,10,10,.7)}
.footerRow{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:center}
.footerLinks{display:flex;gap:12px;flex-wrap:wrap}
.footerLinks a{padding:8px 10px;border-radius:8px;font-family:'Barlow Condensed',sans-serif;font-size:14px;letter-spacing:.04em;font-weight:600}
.footerLinks a:hover{background:rgba(200,16,46,.08);color:var(--text)}

/* ─── FORMS ──────────────────────────────────────────────── */
.form label{display:block;font-weight:700;font-size:13px;margin:10px 0 6px;font-family:'Barlow Condensed',sans-serif;letter-spacing:.04em;color:var(--muted)}
.form input,.form textarea,.form select{width:100%;padding:12px;border-radius:10px;border:1px solid rgba(245,247,250,.14);background:rgba(10,10,10,.4);color:var(--text);outline:none;font-family:'Barlow',sans-serif;transition:border-color .15s}
/* v6.6.4 — checkboxes and radios must NOT be stretched to 100% width.
   Without this override they expand inside their <label> flex container and
   visually drift away from the text label (recruiting affirmations / roles,
   AAR form, availability page). */
.form input[type="checkbox"],
.form input[type="radio"]{
  width:auto;
  min-width:18px;
  height:18px;
  padding:0;
  margin:0;
  flex:0 0 auto;
  accent-color:var(--crimson);
  cursor:pointer;
}
/* Inline labels that wrap a checkbox/radio + text — make sure text doesn't
   color-shift to the muted form-label tone. */
.form label:has(input[type="checkbox"]),
.form label:has(input[type="radio"]){
  color:var(--text);
  font-family:'Barlow',sans-serif;
  font-weight:400;
  letter-spacing:normal;
  text-transform:none;
}
.form input:focus,.form textarea:focus,.form select:focus{border-color:rgba(200,16,46,.5)}
.form textarea{min-height:120px;resize:vertical}
.help{color:var(--muted);font-size:13px;margin-top:10px}

/* ─── SPLASH PAGE ────────────────────────────────────────── */
.splashHero{min-height:75vh;display:flex;align-items:center;padding:60px 0}
.splashIntro{text-align:center;margin-bottom:40px}
.splashLogo{height:80px;width:auto;margin:0 auto 30px;display:block}
.splashIntro h1{font-size:44px;margin:0 0 10px;letter-spacing:-.4px}
.splashIntro .lead{font-size:16px;color:var(--muted);margin:0}
.splashFooter{text-align:center;margin-top:40px;color:var(--muted);font-size:14px}
.splashFooter a{color:var(--crimson);font-weight:700;text-decoration:underline}
.splashFooter a:hover{color:var(--text)}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:980px){
  .heroGrid{grid-template-columns:1fr}
  .ctaBlock{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .navlinks{display:none}
  .hamburger{display:inline-flex;align-items:center;justify-content:center}
  .splashGrid{grid-template-columns:1fr}
  h1{font-size:28px}
}

/* ───────────────────────────────────────────────────────────────────────────
   ADA / WCAG 2.1 Level AA — added v6.2.0 (2026-05-22)
   Lawsuit-prevention layer. Three things:
     1. Contrast fixes for tokens that failed AA (--subtle, --crimson on bg)
     2. Visible :focus-visible indicators on all interactive elements
     3. Skip-link, reduced-motion respect, prefers-color-scheme accommodations
   --------------------------------------------------------------------------- */

:root {
  /* Was #4A5568 = 2.63:1 on bg (FAIL). New: 7.0:1 passes AA & AAA. */
  --subtle:        #9AA6B5;
  /* Bright crimson for INLINE TEXT on dark bg (contrast 4.5:1+). The original
     --crimson token stays the brand red for solid blocks (buttons, borders) where
     contrast is achieved against #FFFFFF foreground inside the block. */
  --crimson-text:  #FF4D63;
}

/* SKIP LINK — first focusable element. Press Tab on any page to jump to main. */
.skip-link{
  position:absolute; top:-40px; left:8px; z-index:9999;
  background:#fff; color:#000; padding:8px 12px; border-radius:4px;
  text-decoration:none; font-weight:700; font-size:14px;
}
.skip-link:focus{ top:8px; outline:3px solid var(--crimson); }

/* FOCUS INDICATORS — visible for keyboard users on every interactive element */
:focus-visible{
  outline:3px solid #FF4D63 !important;
  outline-offset:2px;
  border-radius:4px;
}
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, [role="button"]:focus-visible{
  outline:3px solid #FF4D63 !important;
  outline-offset:2px;
}

/* Form fields — clearer focus state + ensure label association is supported */
.form input:focus, .form textarea:focus, .form select:focus{
  border-color:var(--crimson-text);
  box-shadow: 0 0 0 3px rgba(255,77,99,.25);
}

/* Buttons — make sure hover/focus contrast remains high */
.btn:focus, .btn:focus-visible{ outline:3px solid #FF4D63; outline-offset:2px; }

/* Reduced motion — respect user's OS preference */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* Higher color-contrast mode (Windows / browser setting) */
@media (forced-colors: active){
  .btn, .card, .pill{ border:1px solid CanvasText; }
  .skip-link{ background:Canvas; color:CanvasText; }
}

/* Make sure body text never falls under the AA contrast floor.
   Anywhere that used --subtle for text now reads with the brighter token. */
small, .muted-text, .legal-text{ color:var(--muted); }

/* ───────────────────────────────────────────────────────────────────────────
   v6.3.0 — Ad-blocker compatibility: fallback styling when Google Fonts is
   blocked. The html class .iti-fonts-blocked is set by the inline script in
   header.php after 2.5s without successful font load. Make headings slightly
   bolder + tighter letter-spacing so Impact / Arial Black fallbacks read well.
   ─────────────────────────────────────────────────────────────────────────── */
.iti-fonts-blocked h1,
.iti-fonts-blocked h2,
.iti-fonts-blocked h3,
.iti-fonts-blocked .brand{
  letter-spacing: 0.01em;  /* tighter — fallback fonts are wider than Barlow */
}
.iti-fonts-blocked body{
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
.iti-fonts-blocked .kicker,
.iti-fonts-blocked .navlinks,
.iti-fonts-blocked .btn,
.iti-fonts-blocked .pill{
  font-family: "Arial Narrow", "Helvetica Condensed", Arial, sans-serif;
}
/* Tone down the no-FOIT flash period — show fallback text from the start */
html:not(.iti-fonts-loaded) body{
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
