@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;600;700&family=Source+Sans+3:wght@300;400;600&family=Roboto+Mono:wght@400;500&display=swap');

:root {
  --navy:#0a1628; --blue:#0d2d6b; --royal:#1a47a8;
  --accent:#2673bd; --accent2:#4a9fd4;
  --steel:#8ba0b8; --light:#dce8f5; --dark:#060e1a;
  --card:rgba(13,45,107,0.35); --border:rgba(26,71,168,0.4);
  --glow:0 0 20px rgba(26,71,168,0.5);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;background:var(--dark);color:#fff;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(26,71,168,.07) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(26,71,168,.07) 60px);pointer-events:none;z-index:0}

/* HEADER */
header{position:sticky;top:0;z-index:1000;background:rgba(6,14,26,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:0 2px 30px rgba(0,0,0,.6)}
.header-inner{max-width:1280px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:72px;gap:1rem}
.logo-wrap{display:flex;align-items:center;text-decoration:none}
.logo-wrap img{height:54px;width:auto;filter:drop-shadow(0 0 8px rgba(26,71,168,.5));transition:filter .3s}
.logo-wrap:hover img{filter:drop-shadow(0 0 16px rgba(38,115,189,.9))}
nav{display:flex;align-items:center;gap:.15rem}
nav a{font-family:'Oswald',sans-serif;font-size:.82rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--steel);text-decoration:none;padding:.5rem .9rem;border-radius:4px;white-space:nowrap;position:relative;transition:color .2s,background .2s}
nav a::after{content:'';position:absolute;bottom:4px;left:50%;right:50%;height:2px;background:var(--accent);border-radius:2px;transition:left .25s,right .25s}
nav a:hover,nav a.active{color:#fff;background:rgba(26,71,168,.2)}
nav a:hover::after,nav a.active::after{left:12px;right:12px}
nav a.nav-cta{background:var(--accent);color:#fff;font-weight:600;margin-left:.5rem}
nav a.nav-cta:hover{background:var(--accent2)}
nav a.nav-cta::after{display:none}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--steel);border-radius:2px;transition:background .2s}
.nav-toggle:hover span{background:#fff}

/* TICKER */
.promo-bar{background:linear-gradient(90deg,var(--accent),#1a5499);padding:.8rem 0;overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-block;white-space:nowrap;animation:ticker 55s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.ticker{font-family:'Roboto Mono',monospace;font-size:.8rem;color:#fff;letter-spacing:.07em;padding:0 5rem}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* PAGE HERO */
.page-hero{padding:5rem 2rem 4rem;text-align:center;background:linear-gradient(160deg,var(--dark) 0%,var(--navy) 100%);border-bottom:1px solid var(--border)}
.eyebrow{font-family:'Roboto Mono',monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}
.page-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(2rem,4vw,3.5rem);font-weight:700;text-transform:uppercase;color:#fff}
.page-hero p{color:var(--steel);font-size:1.05rem;margin-top:.75rem}

/* BUTTONS */
.btn-p,.btn-s{display:inline-flex;align-items:center;gap:.5rem;font-family:'Oswald',sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;padding:.85rem 2rem;border-radius:4px;cursor:pointer;border:none;transition:background .25s,transform .25s,box-shadow .25s,border-color .25s}
.btn-p{background:var(--accent);color:#fff;box-shadow:0 4px 20px rgba(38,115,189,.35)}
.btn-p:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(38,115,189,.5)}
.btn-s{background:transparent;color:#fff;border:2px solid var(--border)}
.btn-s:hover{border-color:var(--royal);background:rgba(26,71,168,.2);transform:translateY(-2px)}

/* SEC HEADER */
.sec-hdr{text-align:center;margin-bottom:3.5rem}
.sec-ey{font-family:'Roboto Mono',monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}
.sec-t{font-family:'Oswald',sans-serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;text-transform:uppercase;color:#fff}
.sec-sub{font-size:1rem;color:var(--steel);margin-top:.75rem;max-width:600px;margin-left:auto;margin-right:auto}

/* FOOTER */
footer{background:var(--dark);border-top:1px solid var(--border);padding:4rem 2rem 2rem;position:relative;z-index:1}
.ft-inner{max-width:1280px;margin:0 auto}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.ft-brand img{height:50px;width:auto}
.ft-brand p{font-size:.88rem;color:var(--steel);line-height:1.75;max-width:280px;margin-top:.75rem}
.ft-col h4{font-family:'Oswald',sans-serif;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:1.25rem}
.ft-col ul{list-style:none}
.ft-col ul li{margin-bottom:.6rem}
.ft-col ul li a{color:var(--steel);text-decoration:none;font-size:.9rem;transition:color .2s}
.ft-col ul li a:hover{color:var(--accent)}
.ft-bot{border-top:1px solid var(--border);padding-top:1.5rem;font-size:.82rem;color:var(--steel);text-align:center}

/* FADE IN */
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:900px){
  .nav-toggle{display:flex}
  nav{display:none;flex-direction:column;align-items:flex-start;position:absolute;top:72px;left:0;right:0;background:rgba(6,14,26,.98);padding:1rem 1.5rem 1.5rem;border-bottom:1px solid var(--border);gap:.25rem}
  nav.open{display:flex}
  nav a{width:100%;padding:.75rem 1rem}
  nav a.nav-cta{margin-left:0;margin-top:.5rem;justify-content:center}
  .ft-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .ft-grid{grid-template-columns:1fr}
  .header-inner{padding:0 1rem}
}

/* ══════════════════════════════════════════════
   LIGHT THEME — body.theme-light overrides
   ══════════════════════════════════════════════ */
body.theme-light {
  --navy:#e8f0f8; --blue:#d0e2f2; --royal:#2a7cc7;
  --accent:#1a5fa8; --accent2:#2a7cc7;
  --steel:#5a6e87; --light:#1a2840; --dark:#f0f4f8;
  --card:#ffffff; --border:#ccd8e8;
  --glow:0 4px 20px rgba(26,95,168,0.15);
  background:#f0f4f8; color:#1a2840;
}
body.theme-light::before{background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(26,95,168,.05) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(26,95,168,.05) 60px)}
body.theme-light header{background:rgba(255,255,255,.97);box-shadow:0 2px 16px rgba(26,95,168,.12)}
body.theme-light nav a{color:#5a6e87}
body.theme-light nav a:hover,body.theme-light nav a.active{color:#1a2840;background:rgba(26,95,168,.08)}
body.theme-light nav a.nav-cta{color:#fff}
body.theme-light nav a.nav-cta:hover{color:#fff;background:var(--accent2)}
body.theme-light .promo-bar{background:linear-gradient(90deg,var(--accent),#1a5499)}
body.theme-light .ticker{color:#fff}
body.theme-light .sec-t{color:#1a2840}
body.theme-light .btn-s{color:#1a2840;border-color:rgba(26,40,64,.25)}
body.theme-light .btn-s:hover{background:rgba(26,95,168,.1);border-color:var(--accent)}
body.theme-light h1.hero-title{color:#1a2840}
body.theme-light h1.hero-title span{-webkit-text-stroke-color:var(--accent)}
body.theme-light .fcard h3{color:#1a2840}
body.theme-light .srv-card h3{color:#1a2840}
body.theme-light .srv-link{color:var(--accent)}
body.theme-light .vend-content h2{color:#1a2840}
body.theme-light .vend-features li{color:#1a2840}
body.theme-light .promo-card h3{color:#1a2840}
body.theme-light .vm-screen{background:#1a2840}
body.theme-light footer{background:#fff;border-color:#ccd8e8}
body.theme-light .ft-col h4{color:#1a2840}
body.theme-light .ft-bot{color:#5a6e87}
body.theme-light .ft-col ul li a{color:#5a6e87}
body.theme-light .ft-col ul li a:hover{color:var(--accent)}
body.theme-light .ft-brand p{color:#5a6e87}

/* hero gradient for light theme */
body.theme-light .hero{background:linear-gradient(135deg,#dae6f5 0%,#bdd1ea 60%,#92b8da 100%)}
body.theme-light .hero-overlay{background:linear-gradient(to right,rgba(240,244,248,.92) 40%,rgba(240,244,248,.25) 100%)}
body.theme-light .hero-radial{background:radial-gradient(circle at 70% 50%,rgba(26,95,168,.12),transparent 60%),radial-gradient(circle at 20% 80%,rgba(42,124,199,.08),transparent 40%)}
body.theme-light .hero-desc{color:#5a6e87}
body.theme-light .hero-eyebrow{color:var(--accent)}
body.theme-light .hero-eyebrow::before{background:var(--accent)}
body.theme-light .stat-lbl{color:#5a6e87}
body.theme-light .stat-num{color:var(--accent)}
body.theme-light .hero-stats{border-color:#ccd8e8}

body.theme-light .srv-sec{background:linear-gradient(180deg,#f0f4f8,rgba(26,95,168,.06) 50%,#f0f4f8)}
body.theme-light .vend-sec{background:linear-gradient(135deg,#dae6f5,#e8f0f8);border-color:#ccd8e8}
body.theme-light .vm-box{background:linear-gradient(160deg,#e8f0f8,#f0f4f8);border-color:#ccd8e8;box-shadow:0 4px 20px rgba(26,95,168,.12)}
body.theme-light .vm-title{color:#1a2840}
body.theme-light .vm-bar-lbl{color:#5a6e87}
body.theme-light .promo-sec{background:#f8fafc}
body.theme-light .about-sec{background:linear-gradient(135deg,rgba(26,95,168,.08),rgba(240,244,248,.6));border-color:#ccd8e8}
body.theme-light .about-inner h2{color:#1a2840}

/* mobile nav light */
body.theme-light nav.open{background:rgba(255,255,255,.98)}

/* ── THEME TOGGLE BAR ── */
.theme-toggle-bar{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;
  display:flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.95);
  border:1px solid #ccd8e8;
  border-radius:100px;
  padding:.45rem .45rem .45rem .9rem;
  box-shadow:0 4px 24px rgba(0,0,0,.18);
  backdrop-filter:blur(10px);
  font-family:'Oswald',sans-serif;
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:#5a6e87;
  transition:opacity .3s;
}
body.theme-light .theme-toggle-bar{background:rgba(255,255,255,.95);border-color:#ccd8e8;color:#5a6e87}
.theme-toggle-bar span{white-space:nowrap}
.theme-toggle-pill{
  display:flex;align-items:center;
  background:#e8f0f8;border-radius:100px;
  padding:3px;gap:2px;border:1px solid #ccd8e8;
}
body.theme-light .theme-toggle-pill{background:#e8f0f8}
.theme-opt{
  font-family:'Oswald',sans-serif;font-size:.7rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.3rem .85rem;border-radius:100px;cursor:pointer;
  border:none;outline:none;background:transparent;color:#5a6e87;
  transition:background .2s,color .2s;
}
.theme-opt.active{background:#1a5fa8;color:#fff}
body.theme-light .theme-opt.active{background:#1a5fa8;color:#fff}
body:not(.theme-light) .theme-opt.active{background:#1a47a8;color:#fff}
body:not(.theme-light) .theme-toggle-bar{background:rgba(6,14,26,.92);border-color:rgba(26,71,168,.5);color:#8ba0b8}
body:not(.theme-light) .theme-toggle-pill{background:rgba(13,45,107,.4);border-color:rgba(26,71,168,.4)}
body:not(.theme-light) .theme-opt{color:#8ba0b8}
body.theme-light .page-hero h1{color:#1a2840}
body.theme-light .section-divider::after{background:#ccd8e8}
body.theme-light .promo-card.past{background:#f8fafc}

/* PROMO CARDS — shared across index + promotions pages */
.promo-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:2rem;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.promo-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(38,115,189,.2)}
.promo-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.badge{display:inline-block;background:rgba(38,115,189,.15);border:1px solid rgba(38,115,189,.4);color:var(--accent);font-family:'Roboto Mono',monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .75rem;border-radius:100px;margin-bottom:1rem}
.promo-card h3{font-family:'Oswald',sans-serif;font-size:1.2rem;font-weight:600;text-transform:uppercase;color:#fff;margin-bottom:.5rem}
.promo-card p{font-size:.88rem;color:var(--steel);line-height:1.65}
.promo-vendor{font-size:.8rem;color:var(--accent2);margin-top:.85rem;font-weight:600}
.promo-expiry{font-size:.78rem;color:#fbbf24;margin-top:.35rem;font-weight:600}
.promo-pdf{display:inline-flex;align-items:center;gap:.4rem;margin-top:.9rem;font-size:.82rem;color:#fff;background:rgba(38,115,189,.35);border:1px solid rgba(38,115,189,.5);padding:.35rem .85rem;border-radius:4px;text-decoration:none;transition:background .2s}
.promo-pdf:hover{background:rgba(38,115,189,.6)}

/* Light theme — major-lines & additional-lines page elements */
body.theme-light .ml-card{background:#fff;border-color:#ccd8e8}
body.theme-light .ml-card:hover{background:rgba(26,95,168,.08);border-color:var(--accent);box-shadow:0 16px 48px rgba(26,95,168,.15)}
body.theme-light .ml-logo-wrap img{filter:none;opacity:1}
body.theme-light .ml-card:hover .ml-logo-wrap img{filter:none;opacity:1}
/* Garr and Titan have white-only logos — convert to brand blue in light theme */
body.theme-light .ml-logo-wrap img[src*="Garr-Logo"],
body.theme-light .ml-logo-wrap img[src*="TitanUSA-Logo"]{filter:brightness(0) saturate(100%) invert(27%) sepia(74%) saturate(600%) hue-rotate(190deg) brightness(95%);opacity:.9}
body.theme-light .ml-card:hover .ml-logo-wrap img[src*="Garr-Logo"],
body.theme-light .ml-card:hover .ml-logo-wrap img[src*="TitanUSA-Logo"]{opacity:1}
body.theme-light .vname-fallback{color:#1a2840}
body.theme-light .ml-card:hover .vname-fallback{color:#1a2840}
body.theme-light .vdesc{color:#5a6e87}
body.theme-light .ml-card:hover .vdesc{color:#1a2840}
body.theme-light .cta-strip{background:#fff;border-color:#ccd8e8}
body.theme-light .cta-strip h3{color:#1a2840}
body.theme-light .cta-strip p{color:#5a6e87}
body.theme-light .group-letter{color:var(--accent);border-color:#ccd8e8}
body.theme-light .vendor-link{color:#1a2840}
body.theme-light .vendor-link:hover{background:rgba(26,95,168,.08);border-color:#ccd8e8;color:#1a2840}
body.theme-light .vendor-nolink{color:#5a6e87}
body.theme-light .search-bar input{background:#fff;border-color:#ccd8e8;color:#1a2840}
body.theme-light .search-bar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(26,95,168,.15)}
body.theme-light .alpha-btn{background:#fff;border-color:#ccd8e8;color:#5a6e87}
body.theme-light .alpha-btn:hover,body.theme-light .alpha-btn.has-results{color:var(--accent);border-color:var(--accent);background:rgba(26,95,168,.08)}
