/* ===========================================
   STRATEGIC TRANSPORTATION LTD. — v2
   Light/Dark Mode · Mobile-First · SEO Ready
=========================================== */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@400;600;700&family=Barlow:ital,wght@0,300;0,400;0,600;1,300&display=swap');

/* ---- TOKENS ---- */
:root {
  --red:       #C41E3A;
  --red-dark:  #8B1528;
  --red-light: #E03050;
  --red-header:#D42040;
  --gold:      #E8C547;
  --font-d:    'Bebas Neue', sans-serif;
  --font-h:    'Barlow Condensed', sans-serif;
  --font-b:    'Barlow', sans-serif;
  --nav-h:     72px;
  --radius:    2px;
  --trans:     0.22s ease;

  /* Light mode */
  --bg:        #F5F5F0;
  --bg2:       #FFFFFF;
  --bg3:       #EBEBE6;
  --card:      #FFFFFF;
  --border:    #DDDDDD;
  --text:      #1A1A1A;
  --text2:     #444444;
  --text3:     #777777;
  --inv-bg:    #111111;
  --inv-text:  #F5F5F0;
  --shadow:    0 4px 24px rgba(0,0,0,0.09);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.13);
}
[data-theme="dark"] {
  --bg:        #111111;
  --bg2:       #1A1A1A;
  --bg3:       #222222;
  --card:      #1E1E1E;
  --border:    #333333;
  --text:      #F0F0EB;
  --text2:     #BBBBBB;
  --text3:     #888888;
  --inv-bg:    #F5F5F0;
  --inv-text:  #111111;
  --shadow:    0 4px 24px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.5);
}

/* ---- RESET ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;transition:background var(--trans),color var(--trans)}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* ---- NAV ---- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background: rgba(175, 18, 36, 0.22);
  backdrop-filter: blur(16px) saturate(1.5);
  -webkit-backdrop-filter: blur(16px) saturate(1.5);
  height:var(--nav-h);
  border-bottom: 1px solid rgba(220,40,60,0.20);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(1rem,4vw,2.5rem);
  box-shadow:0 2px 20px rgba(0,0,0,0.18);
  transition:background var(--trans);
}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.nav-logo img{height:clamp(52px,7vw,72px);width:auto;object-fit:contain;filter:drop-shadow(0 1px 3px rgba(0,0,0,0.3))}
.nav-links{display:flex;align-items:center;gap:0}
.nav-links a{
  color:#fff;text-decoration:none;
  font-family:var(--font-h);font-weight:600;font-size:.82rem;
  letter-spacing:.1em;text-transform:uppercase;
  padding:0 .95rem;height:var(--nav-h);
  display:flex;align-items:center;
  border-bottom:2px solid transparent;
  transition:color var(--trans),border-color var(--trans);
  white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{color:var(--gold);border-bottom-color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:.75rem}
.nav-cta{
  background:#fff;color:var(--red)!important;
  padding:.5rem 1.2rem!important;height:auto!important;
  font-family:var(--font-h)!important;font-weight:700!important;
  font-size:.8rem!important;letter-spacing:.12em!important;
  text-transform:uppercase!important;border-radius:2px;
  border-bottom:none!important;
  transition:opacity var(--trans)!important;
  white-space:nowrap;
}
.nav-cta:hover{opacity:.88;color:var(--red)!important}

/* Dark mode toggle */
.theme-toggle{
  background:none;border:1.5px solid rgba(255,255,255,0.5);
  color:#fff;width:38px;height:38px;border-radius:50%;
  cursor:pointer;font-size:1rem;display:flex;align-items:center;
  justify-content:center;transition:border-color var(--trans),background var(--trans);
  flex-shrink:0;
}
.theme-toggle:hover{border-color:#fff;background:rgba(255,255,255,0.1)}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:6px;background:none;border:none;
}
.hamburger span{width:24px;height:2px;background:#fff;display:block;transition:.3s;border-radius:1px}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav */
@media(max-width:960px){
  .nav-links{
    display:none;flex-direction:column;
    position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;
    background:rgba(196,30,58,0.97);backdrop-filter:blur(12px);
    padding:1.5rem 0;overflow-y:auto;align-items:stretch;
    gap:0;z-index:999;
  }
  .nav-links.open{display:flex}
  .nav-links a{height:auto;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,0.12);border-left:none;font-size:1rem}
  .nav-links a:hover,.nav-links a.active{border-left:3px solid var(--gold);padding-left:calc(1.5rem - 3px)}
  .nav-cta{margin:1rem 1.5rem!important;padding:.75rem 1.5rem!important;text-align:center!important;font-size:.85rem!important}
  .hamburger{display:flex}
}

/* ---- PAGE SPACING ---- */
.page-top{padding-top:var(--nav-h)}

/* ---- HERO ---- */
.hero{
  min-height:100svh;position:relative;overflow:hidden;
  display:flex;align-items:center;padding-top:var(--nav-h);
  background:#0d0d0d;
}
.hero-bg{
  position:absolute;inset:0;
  background-image:url('fleet_opt.jpg');
  background-size:cover;background-position:center;
  opacity:.25;
  filter:grayscale(30%);
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(10,0,3,0.92) 0%,rgba(140,20,40,0.35) 60%,rgba(10,0,3,0.7) 100%);
}
.hero-grid-lines{
  position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(196,30,58,0.04) 60px),
             repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(196,30,58,0.04) 60px);
}
.hero-content{position:relative;z-index:2;padding:4rem clamp(1.2rem,6vw,5rem);max-width:820px}
.hero-eyebrow{
  font-family:var(--font-h);font-weight:600;font-size:.8rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold);
  margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;
}
.hero-eyebrow::before{content:'';width:28px;height:2px;background:var(--gold);flex-shrink:0}
.hero h1{
  font-family:var(--font-d);
  font-size:clamp(3.2rem,10vw,7.5rem);
  line-height:.92;color:#fff;letter-spacing:.02em;margin-bottom:1.4rem;
}
.hero h1 span{color:var(--red-light)}
.hero-sub{
  font-size:clamp(.95rem,2.2vw,1.15rem);font-weight:300;
  color:rgba(245,245,240,.75);max-width:520px;margin-bottom:2.2rem;line-height:1.7;
}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-stats{
  position:absolute;bottom:2.5rem;right:clamp(1.2rem,6vw,5rem);z-index:2;
  display:flex;gap:2.5rem;
}
.hero-stat-num{font-family:var(--font-d);font-size:2.6rem;color:var(--red-light);line-height:1}
.hero-stat-label{font-family:var(--font-h);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(245,245,240,.55)}
@media(max-width:600px){.hero-stats{display:none}.hero-content{padding:3rem 1.2rem}}

/* ---- BUTTONS ---- */
.btn{
  display:inline-block;text-decoration:none;
  font-family:var(--font-h);font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.85rem 2rem;cursor:pointer;border:none;
  transition:all var(--trans);font-size:.88rem;
  border-radius:var(--radius);
}
.btn-primary{background:var(--red);color:#fff;border:2px solid var(--red)}
.btn-primary:hover{background:var(--red-light);border-color:var(--red-light);transform:translateY(-1px);box-shadow:0 4px 16px rgba(196,30,58,0.4)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4)}
.btn-outline:hover{border-color:#fff}
.btn-dark{background:var(--text);color:var(--bg);border:2px solid var(--text)}
.btn-dark:hover{opacity:.85}

/* ---- SECTION ---- */
section{padding:clamp(3rem,7vw,5.5rem) clamp(1.2rem,6vw,5rem)}
.section-dark{background:var(--inv-bg);color:var(--inv-text)}
.section-mid{background:var(--bg3);color:var(--text)}
.section-light{background:var(--bg);color:var(--text)}
.section-white{background:var(--bg2);color:var(--text)}
.section-red{background:var(--red)}

/* ---- EYEBROW / HEADINGS ---- */
.eyebrow{
  font-family:var(--font-h);font-weight:600;font-size:.76rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--red);
  margin-bottom:.7rem;display:flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:'';width:22px;height:2px;background:var(--red);flex-shrink:0}
.eyebrow-gold{color:var(--gold)}
.eyebrow-gold::before{background:var(--gold)}
h2{font-family:var(--font-d);font-size:clamp(2rem,5vw,3.6rem);line-height:1;letter-spacing:.02em}
h3{font-family:var(--font-h);font-weight:700;font-size:1.3rem;letter-spacing:.02em}
h4{font-family:var(--font-h);font-weight:700;font-size:1.05rem}
.lead{font-size:clamp(.95rem,2vw,1.05rem);font-weight:300;line-height:1.78;color:var(--text2);max-width:620px;margin-top:.9rem}
.section-dark .lead{color:rgba(245,245,240,.65)}

/* ---- TAGLINE BAND ---- */
.tagline-band{
  background:var(--red);padding:.9rem clamp(1.2rem,6vw,5rem);
  text-align:center;
}
.tagline-band p{
  font-family:var(--font-h);font-weight:700;
  font-size:clamp(.85rem,2.5vw,1.05rem);
  letter-spacing:.18em;text-transform:uppercase;color:#fff;
}

/* ---- SERVICE CARDS (homepage) ---- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:2px;margin-top:3rem}
.service-card{
  background:var(--card);
  overflow:hidden;
  border-left:3px solid transparent;
  transition:border-color var(--trans),box-shadow var(--trans),transform var(--trans);
  text-decoration:none;color:inherit;display:block;
  box-shadow:var(--shadow);
}
.service-card:hover{border-left-color:var(--red);box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.service-card-img{
  height:200px;overflow:hidden;position:relative;
  background:var(--bg3);
}
.service-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;
}
.service-card:hover .service-card-img img{transform:scale(1.05)}
.service-card-body{padding:1.6rem 1.5rem}
.service-card-icon{font-size:1.6rem;margin-bottom:.6rem}
.service-card h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--text)}
.section-dark .service-card h3{color:var(--inv-text)}
.service-card p{font-size:.88rem;color:var(--text3);line-height:1.65;font-weight:300}
.section-dark .service-card{background:#222}
.section-dark .service-card p{color:rgba(245,245,240,.55)}
.service-card-arrow{
  display:inline-flex;align-items:center;gap:.4rem;margin-top:.9rem;
  font-family:var(--font-h);font-size:.75rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--red);
  transition:gap var(--trans);
}
.service-card:hover .service-card-arrow{gap:.7rem}

/* ---- FEATURES ---- */
.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:2rem;margin-top:2.5rem}
.feature-item{display:flex;gap:1.1rem;align-items:flex-start}
.feature-num{font-family:var(--font-d);font-size:2.8rem;color:var(--red);line-height:1;flex-shrink:0;width:48px}
.feature-text h4{margin-bottom:.3rem}
.feature-text p{font-size:.88rem;font-weight:300;color:var(--text2);line-height:1.62}
.section-dark .feature-text p{color:rgba(245,245,240,.6)}

/* ---- COVERAGE ---- */
.coverage-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-top:2.5rem}
@media(max-width:768px){.coverage-grid{grid-template-columns:1fr;gap:2rem}}
.coverage-list{list-style:none}
.coverage-list li{
  padding:.8rem 0;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.7rem;
  font-family:var(--font-h);font-weight:600;font-size:.95rem;
}
.coverage-list li::before{content:'▸';color:var(--red);font-size:.75rem}
.map-visual{background:var(--bg3);border:1px solid var(--border);aspect-ratio:4/3;overflow:hidden}
.map-visual svg{width:100%;height:100%}

/* ---- DOCS ---- */
.doc-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin-top:2rem}
.doc-card{
  background:var(--bg2);border:1px solid var(--border);
  padding:1.75rem;display:flex;gap:1.2rem;align-items:flex-start;
  transition:box-shadow var(--trans),transform var(--trans);
  text-decoration:none;color:inherit;border-radius:var(--radius);
}
.doc-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.doc-icon{font-size:2rem;flex-shrink:0}
.doc-card h4{font-size:1rem;color:var(--text);margin-bottom:.35rem}
.doc-card p{font-size:.83rem;color:var(--text3);font-weight:300;line-height:1.5}
.doc-badge{display:inline-block;margin-top:.6rem;font-family:var(--font-h);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--red);font-weight:600}

/* ---- BLOG CARDS ---- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.75rem;margin-top:2.5rem}
.blog-card{background:var(--card);border:1px solid var(--border);overflow:hidden;transition:box-shadow var(--trans),transform var(--trans);border-radius:var(--radius)}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.blog-card-img{height:185px;overflow:hidden;position:relative}
.blog-card-img-bg{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .4s ease}
.blog-card:hover .blog-card-img-bg{transform:scale(1.05)}
.blog-cat{position:absolute;top:.9rem;left:.9rem;background:var(--red);color:#fff;font-family:var(--font-h);font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.2rem .55rem}
.blog-body{padding:1.4rem}
.blog-meta{font-size:.75rem;color:var(--text3);margin-bottom:.4rem;font-family:var(--font-h);letter-spacing:.05em}
.blog-card h3{font-size:1rem;margin-bottom:.5rem;line-height:1.35}
.blog-card h3 a{text-decoration:none;color:var(--text);transition:color var(--trans)}
.blog-card h3 a:hover{color:var(--red)}
.blog-card p{font-size:.85rem;color:var(--text3);font-weight:300;line-height:1.6}

/* ---- CONTACT / FORM ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr;gap:2rem}}
.contact-item{display:flex;gap:1rem;margin-bottom:1.75rem;align-items:flex-start}
.contact-icon{width:42px;height:42px;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.contact-item strong{font-family:var(--font-h);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.2rem}
.contact-item span{font-size:.9rem;color:rgba(245,245,240,.8)}
.quote-form{background:var(--bg2);padding:clamp(1.5rem,4vw,2.5rem);border:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-bottom:.9rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;margin-bottom:.9rem}
.form-group label{font-family:var(--font-h);font-weight:600;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);margin-bottom:.35rem}
.form-group input,.form-group select,.form-group textarea{
  border:1.5px solid var(--border);padding:.7rem .9rem;
  font-family:var(--font-b);font-size:.9rem;color:var(--text);
  outline:none;transition:border-color var(--trans);
  background:var(--bg);border-radius:var(--radius);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red)}
.form-group textarea{min-height:110px;resize:vertical}

/* ---- PAGE HERO ---- */
.page-hero{
  padding:clamp(5rem,10vw,8rem) clamp(1.2rem,6vw,5rem) clamp(2.5rem,5vw,4rem);
  background:linear-gradient(135deg,#0d0d0d 0%,#1e0810 55%,#0d0d0d 100%);
  position:relative;overflow:hidden;
}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red)}
.page-hero h1{font-family:var(--font-d);font-size:clamp(2.8rem,7vw,5.5rem);color:#fff;line-height:.95}
.page-hero p{font-size:clamp(.9rem,2vw,1.05rem);color:rgba(245,245,240,.6);max-width:600px;margin-top:.9rem;font-weight:300}
.breadcrumb{font-family:var(--font-h);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,245,240,.45);margin-bottom:.9rem}
.breadcrumb a{color:var(--red);text-decoration:none}
.breadcrumb a:hover{color:var(--red-light)}

/* ---- SERVICE PAGE SECTIONS ---- */
.service-hero-img{
  height:clamp(260px,40vw,480px);overflow:hidden;position:relative;
}
.service-hero-img img{width:100%;height:100%;object-fit:cover}
.service-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
@media(max-width:768px){.service-content-grid{grid-template-columns:1fr;gap:2rem}}
.service-img-block{overflow:hidden;border-radius:var(--radius)}
.service-img-block img{width:100%;height:100%;object-fit:cover;display:block}

/* ---- VALUES ---- */
.values-list{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:1.75rem}
@media(max-width:600px){.values-list{grid-template-columns:1fr}}
.value-card{background:var(--bg3);padding:1.5rem;border-top:3px solid var(--red)}
.value-card h4{color:var(--gold);margin-bottom:.4rem;font-size:.95rem}
.value-card p{font-size:.83rem;font-weight:300;color:var(--text2);line-height:1.55}

/* ---- SAFETY 8-ELEMENTS ---- */
.eight-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5px;background:var(--border);margin-top:2.5rem}
@media(max-width:900px){.eight-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.eight-grid{grid-template-columns:1fr}}
.eight-item{background:var(--bg2);padding:1.75rem 1.4rem}
.eight-num{font-family:var(--font-d);font-size:2.2rem;color:var(--red);line-height:1;margin-bottom:.4rem}
.eight-item h4{font-family:var(--font-h);font-weight:700;font-size:.9rem;color:var(--gold);margin-bottom:.4rem}
.eight-item p{font-size:.8rem;color:var(--text3);line-height:1.55;font-weight:300}

/* ---- BLOG POST ---- */
.blog-post-hero{padding:clamp(5rem,10vw,8rem) clamp(1.2rem,6vw,5rem) clamp(2rem,4vw,3rem);background:var(--inv-bg)}
.blog-post-body{max-width:760px;margin:0 auto;padding:3rem clamp(1.2rem,5vw,2rem)}
.blog-post-body h2{font-family:var(--font-d);font-size:2rem;margin:2rem 0 .8rem;color:var(--text)}
.blog-post-body h3{font-family:var(--font-h);font-weight:700;font-size:1.2rem;margin:1.5rem 0 .5rem;color:var(--text)}
.blog-post-body p{margin-bottom:1.15rem;font-weight:300;line-height:1.82;font-size:.98rem;color:var(--text2)}
.blog-post-body ul{margin:0 0 1.15rem 1.4rem}
.blog-post-body ul li{margin-bottom:.45rem;font-weight:300;line-height:1.7;color:var(--text2)}
.highlight-box{background:var(--inv-bg);color:var(--inv-text);padding:1.75rem;border-left:4px solid var(--red);margin:2rem 0;border-radius:var(--radius)}
.highlight-box p{color:rgba(245,245,240,.82)!important;margin:0!important}
[data-theme="dark"] .highlight-box{background:#2a0a12;border-left-color:var(--red)}

/* ---- CTA BAND ---- */
.cta-band{
  background:var(--red);padding:clamp(2.5rem,6vw,4rem) clamp(1.2rem,6vw,5rem);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem;
}
.cta-band h2{font-family:var(--font-d);font-size:clamp(1.8rem,5vw,3.2rem);color:#fff;line-height:1}
.cta-band p{color:rgba(255,255,255,.8);margin-top:.4rem;font-weight:300}
.cta-actions{display:flex;gap:.9rem;flex-wrap:wrap}
.btn-white{background:#fff;color:var(--red);padding:.85rem 2rem;font-family:var(--font-h);font-weight:700;font-size:.88rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:opacity var(--trans);border-radius:var(--radius);display:inline-block}
.btn-white:hover{opacity:.88}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.45);padding:.85rem 2rem;font-family:var(--font-h);font-weight:700;font-size:.88rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:border-color var(--trans);border-radius:var(--radius);display:inline-block}
.btn-ghost:hover{border-color:#fff}

/* ---- FOOTER ---- */
footer{
  background: rgba(155, 15, 32, 0.92);
  backdrop-filter: blur(8px);
  padding:clamp(2.5rem,6vw,4rem) clamp(1.2rem,6vw,5rem) clamp(1.5rem,3vw,2rem);
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{height:clamp(70px,10vw,110px);width:auto;object-fit:contain;margin-bottom:1.2rem;filter:drop-shadow(0 2px 10px rgba(0,0,0,0.45))}
.footer-brand p{font-size:.85rem;font-weight:300;line-height:1.7;color:rgba(255,255,255,.75);max-width:270px}
footer h5{font-family:var(--font-h);font-weight:700;font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:1rem}
footer ul{list-style:none}
footer ul li{margin-bottom:.55rem}
footer ul li a{color:rgba(255,255,255,.75);text-decoration:none;font-size:.85rem;transition:color var(--trans)}
footer ul li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.2);padding-top:1.25rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.5)}
.footer-tagline{font-family:var(--font-h);font-size:.78rem;letter-spacing:.1em;color:rgba(255,255,255,.7)}

/* ---- UTIL ---- */
.tag{display:inline-block;background:rgba(196,30,58,.12);color:var(--red);font-family:var(--font-h);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .55rem;margin-right:.4rem;border-radius:2px}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.text-red{color:var(--red)}.text-gold{color:var(--gold)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
@media(max-width:768px){.two-col{grid-template-columns:1fr}}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:768px){.three-col{grid-template-columns:1fr}}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ---- ANIMATIONS ---- */
@media(prefers-reduced-motion:no-preference){
  .fade-in{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
  .fade-in.visible{opacity:1;transform:none}
}
