/* ============================================================
   Auto Springfield — self-hosted static stylesheet
   Replaces the render-blocking Tailwind CDN. Ships ~9KB gzipped
   instead of ~3MB of runtime JS. Only the utilities the templates
   actually use are defined here.
   Theme: high-urgency roadside — deep charcoal base, signal-amber
   accent (real CTA contrast, NOT the muted gray Stitch generated).
   ============================================================ */

:root{
  --primary:#FFD700;        /* signal gold — high-visibility CTA */
  --primary-600:#E6BE00;
  --accent:#FFA500;         /* orange secondary */
  --dark:#0A0A0A;           /* obsidian background base */
  --surface:#141414;        /* Level 1 card surface */
  --surface-2:#1E1F26;      /* Level 2 surface container */
  --brand-primary:#FFD700;
  --brand-accent:#FFA500;
  --brand-dark:#0A0A0A;
  --brand-light:#141414;
  --line:#262626;           /* clean industrial borders */
  --line-2:rgba(255,255,255,.05);
  --tx:#e2e1eb;             /* high-end soft text contrast */
  --tx-60:rgba(226,225,235,.62);
  --tx-40:rgba(226,225,235,.40);
  --radius:0.25rem;          /* machined soft-industrial default roundness (4px) */
  --radius-xl:0.5rem;        /* button rounded corners (8px) */
  --radius-2xl:0.75rem;      /* larger layouts */
  --maxw:75rem;             /* 1200px container-max spacing */
  --ease:cubic-bezier(.4, 0, .2, 1);
}

/* --- reset / base --- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--dark);color:var(--tx);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,p{margin:0}
::selection{background:var(--primary);color:var(--dark)}

.font-headline{font-family:"Bebas Neue",Inter,sans-serif;font-weight:400;letter-spacing:.01em}
.font-body{font-family:Inter,sans-serif}

/* --- layout --- */
.max-w-7xl{max-width:var(--maxw)}
.max-w-5xl{max-width:64rem}.max-w-4xl{max-width:56rem}.max-w-3xl{max-width:48rem}.max-w-xl{max-width:36rem}
.mx-auto{margin-left:auto;margin-right:auto}
.w-full{width:100%}.h-full{height:100%}
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}
.inset-0{inset:0}.top-0{top:0}.bottom-0{bottom:0}.left-0{left:0}
.z-0{z-index:0}.z-10{z-index:10}.z-50{z-index:50}
.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}
.hidden{display:none}.block{display:block}.inline-block{display:inline-block}
.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}
.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}
.justify-center{justify-content:center}.justify-between{justify-content:space-between}
.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-12{gap:3rem}
.overflow-hidden{overflow:hidden}
.grid-cols-1{grid-template-columns:repeat(1,1fr)}
.grid-cols-2{grid-template-columns:repeat(2,1fr)}
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}

/* spacing */
.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}
.px-4{padding-left:1rem;padding-right:1rem}.px-12{padding-left:3rem;padding-right:3rem}
.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}
.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}
.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}
.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}
.py-20{padding-top:5rem;padding-bottom:5rem}.py-24{padding-top:6rem;padding-bottom:6rem}
.pt-12{padding-top:3rem}.pt-20{padding-top:5rem}.pb-0{padding-bottom:0}.pb-10{padding-bottom:2.5rem}
.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}
.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}
.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}
.space-x-8>*+*{margin-left:2rem}

/* sizing */
.w-2{width:.5rem}.h-2{height:.5rem}.w-12{width:3rem}.h-12{height:3rem}
.w-20{width:5rem}.h-20{height:5rem}.w-24{width:6rem}.h-1{height:.25rem}
.min-h-\[85vh\]{min-height:85vh}.h-48{height:12rem}
.object-cover{object-fit:cover}.bg-cover{background-size:cover}.bg-center{background-position:center}

/* radius */
.rounded-lg{border-radius:.75rem}.rounded-xl{border-radius:var(--radius)}
.rounded-2xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:9999px}

/* typography scale */
.text-xs{font-size:.75rem;line-height:1.4}.text-sm{font-size:.875rem;line-height:1.5}
.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem;line-height:1.15}
.text-3xl{font-size:1.875rem;line-height:1.1}.text-4xl{font-size:2.25rem;line-height:1.08}
.text-6xl{font-size:3.75rem;line-height:1}.text-7xl{font-size:4.5rem;line-height:.95}
.leading-none{line-height:1}.leading-tight{line-height:1.2}.leading-relaxed{line-height:1.7}
.leading-\[0\.9\]{line-height:.9}
.tracking-tight{letter-spacing:-.01em}.tracking-tighter{letter-spacing:-.02em}
.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}
.uppercase{text-transform:uppercase}
.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-black{font-weight:900}
.list-none{list-style:none}.underline{text-decoration:underline}
.cursor-pointer{cursor:pointer}

/* colors */
.bg-dark{background:var(--dark)}.bg-white{background:#fff}
.bg-primary{background:var(--primary)}.bg-accent{background:var(--accent)}
.bg-primary\/5{background:rgba(255,195,0,.05)}.bg-primary\/10{background:rgba(255,195,0,.1)}
.bg-white\/5{background:rgba(255,255,255,.05)}.bg-white\/10{background:rgba(255,255,255,.1)}
.bg-black\/60{background:rgba(0,0,0,.6)}
.text-white{color:var(--tx)}.text-dark{color:var(--dark)}.text-black{color:#000}
.text-primary{color:var(--primary)}.text-gray-500{color:#8b9096}
.text-white\/40{color:var(--tx-40)}.text-white\/50{color:rgba(245,246,247,.5)}
.text-white\/60{color:var(--tx-60)}.text-white\/70{color:rgba(245,246,247,.72)}
.text-white\/80{color:rgba(245,246,247,.82)}
.border{border:1px solid var(--line)}.border-2{border:2px solid var(--line)}
.border-t{border-top:1px solid var(--line)}.border-b{border-bottom:1px solid var(--line)}
.border-y{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.border-white\/10{border-color:var(--line)}.border-white\/5{border-color:var(--line-2)}
.border-primary\/20{border-color:rgba(255,195,0,.2)}
.divide-y>*+*{border-top:1px solid var(--line)}
.divide-white\/5>*+*{border-color:var(--line-2)}

/* shadows */
.shadow-lg{box-shadow:0 10px 20px rgba(0,0,0,.3)}
.shadow-xl{box-shadow:0 20px 40px rgba(0,0,0,.35)}
.shadow-2xl{box-shadow:0 30px 60px rgba(0,0,0,.45)}
.shadow-primary\/20{box-shadow:0 12px 30px rgba(255,195,0,.2)}
.shadow-primary\/25{box-shadow:0 16px 40px rgba(255,195,0,.25)}

/* transitions & interactions */
.transition-all{transition:all .25s var(--ease)}
.transition-colors{transition:color .2s var(--ease),background-color .2s var(--ease),border-color .2s var(--ease)}
.transition-transform{transition:transform .25s var(--ease)}
.transition-opacity{transition:opacity .25s var(--ease)}
.opacity-40{opacity:.4}.opacity-70{opacity:.7}.opacity-80{opacity:.8}
.hover\:scale-105:hover{transform:scale(1.05)}
.hover\:scale-\[1\.02\]:hover{transform:scale(1.02)}
.active\:scale-95:active{transform:scale(.95)}
.hover\:bg-white\/5:hover{background:rgba(255,255,255,.05)}
.hover\:bg-white\/10:hover{background:rgba(255,255,255,.1)}
.hover\:bg-white\/20:hover{background:rgba(255,255,255,.2)}
.hover\:text-white:hover{color:var(--tx)}
.hover\:text-primary:hover{color:var(--primary)}
.hover\:border-primary:hover{border-color:var(--primary)}
.group:hover .group-hover\:scale-110{transform:scale(1.1)}
.group:hover .group-hover\:bg-primary{background:var(--primary)}
.group:hover .group-hover\:text-dark{color:var(--dark)}
.group:hover .group-hover\:opacity-100{opacity:1}
.group[open] .group-open\:rotate-45{transform:rotate(45deg)}

/* components */
.glass-card{background:rgba(255,255,255,.035);backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);border:1px solid var(--line);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);}
.glass-card:hover{background:rgba(255,255,255,.06);border-color:rgba(255,195,0,0.35);
  transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.4),0 0 20px rgba(255,195,0,0.05);}
.hero-gradient{background:linear-gradient(to bottom,rgba(11,13,16,.72) 0%,rgba(11,13,16,.90) 55%,var(--dark) 100%)}
.text-glow{text-shadow:0 0 24px rgba(255,195,0,.35)}

/* ---- Stitch design language (ported, self-hosted, no CDN) ---- */
/* cinematic hero overlay: dark-left → transparent-right over the photo */
.hero-overlay{background:linear-gradient(to right,rgba(10,10,10,.94) 0%,rgba(10,10,10,.72) 42%,rgba(10,10,10,.35) 100%)}
/* gold gradient for primary CTAs (135deg gold→amber) */
.gold-gradient{background:linear-gradient(135deg,#FFD700 0%,#FFA500 100%)}
.gold-text{background:linear-gradient(135deg,#FFD700 0%,#FFA500 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
/* bento cards: flat charcoal panel w/ hairline border */
.bento-card{background:#141414;border:1px solid #262626;border-radius:var(--radius);
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease),transform .3s var(--ease)}
.bento-card:hover{border-color:var(--primary);
  box-shadow:0 0 24px rgba(255,215,0,.12);transform:translateY(-3px)}
/* gold border glow (subtle hover halo used on smaller tiles) */
.gold-border-glow{border:1px solid #262626;transition:all .3s var(--ease)}
.gold-border-glow:hover{border-color:#FFD700;box-shadow:0 0 20px rgba(255,215,0,.1)}
/* live-status pulse dot */
.status-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
/* hero status badge chip */
.status-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .85rem;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,215,0,.25);border-radius:9999px;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff}
.status-dot{width:.5rem;height:.5rem;border-radius:9999px;background:var(--accent)}
.icon{width:1.5em;height:1.5em;fill:none;stroke:currentColor;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;flex:none}
/* icon size variants (replace old text-Nxl sizing of the icon font) */
.ic-24{width:24px;height:24px}.ic-28{width:28px;height:28px}
.ic-3xl{width:1.875rem;height:1.875rem}.ic-4xl{width:2.25rem;height:2.25rem}
.ic-6xl{width:3.75rem;height:3.75rem;margin:0 auto}
.call-ic{width:20px;height:20px}
.w-4{width:1rem}.h-4{height:1rem}.mt-0\.5{margin-top:.125rem}

/* sticky header */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:50;
  background:rgba(11,13,16,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);box-shadow:0 8px 30px rgba(0,0,0,.35)}
.site-header nav a{color:var(--tx-60)}
.site-header nav a:hover{color:var(--tx)}

/* small call button in header */
.btn-call-sm{display:inline-flex;align-items:center;gap:.5rem;background:transparent;
  border:2px solid var(--primary);color:var(--primary)!important;font-weight:700;
  padding:.5rem 1.25rem;border-radius:9999px;transition:all .2s var(--ease)}
.btn-call-sm:hover{background:var(--primary);color:var(--dark)!important;transform:scale(1.05)}
.btn-call-sm:active{transform:scale(.95)}

/* mobile sticky call bar */
.mobile-callbar{position:fixed;bottom:0;left:0;width:100%;z-index:50;background:var(--primary);
  padding:1rem;text-align:center;box-shadow:0 -10px 20px rgba(0,0,0,.3)}
.mobile-callbar a{display:flex;align-items:center;justify-content:center;gap:.75rem;
  color:var(--dark);font-weight:900;font-size:1.25rem}
@media(min-width:768px){.mobile-callbar{display:none}}

.backdrop-blur-md{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.font-body{font-family:Inter,sans-serif}

/* prose (service / city / blog body copy) */
.prose-dark h2{font-family:"Bebas Neue",sans-serif;font-size:2.25rem;line-height:1.05;
  margin:2.5rem 0 1rem;letter-spacing:.01em;color:var(--primary)}
.prose-dark h3{font-family:"Bebas Neue",sans-serif;font-size:1.6rem;margin:2rem 0 .75rem}
.prose-dark p{color:var(--tx-60);margin-bottom:1rem;line-height:1.75}
.prose-dark ul{color:var(--tx-60);padding-left:1.25rem;margin-bottom:1rem}
.prose-dark li{margin-bottom:.4rem}
.prose-dark a{color:var(--primary);text-decoration:underline;text-underline-offset:3px}
.prose-dark table{width:100%;margin-top:1.5rem;border-collapse:collapse}
.prose-dark th,.prose-dark td{border:1px solid var(--line);padding:12px;text-align:left}
.prose-dark th{background:rgba(255,195,0,.1);color:var(--primary)}

/* responsive */
@media(min-width:640px){.sm\:flex-row{flex-direction:row}}
@media(min-width:768px){
  .md\:flex{display:flex}.md\:hidden{display:none}
  .md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}
  .md\:grid-cols-3{grid-template-columns:repeat(3,1fr)}
  .md\:grid-cols-4{grid-template-columns:repeat(4,1fr)}
  .md\:text-7xl{font-size:4.5rem}.md\:text-8xl{font-size:6rem;line-height:.92}
}
@media(min-width:1024px){
  .lg\:grid-cols-2{grid-template-columns:repeat(2,1fr)}
  .lg\:text-9xl{font-size:7rem;line-height:.9}
}
@media(max-width:767px){
  .btn-call-sm{display:none!important}
  footer{padding-bottom:120px}
  .text-7xl{font-size:3rem}.text-6xl{font-size:2.5rem}
  .md\:text-8xl,.lg\:text-9xl{font-size:3.2rem;line-height:.95}
}
@media(prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important}
}

/* Glassmorphism nav menu dropdown logic */
.nav-item { position: relative; }
.dropdown-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background: rgba(20, 20, 20, 0.95);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.75rem;
    min-width: 240px;
    padding: 0.5rem;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s cubic-bezier(.2,.7,.2,1);
    box-shadow: 0 20px 40px rgba(0,0,0,0.5);
    z-index: 100;
}
.nav-item:hover .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}
/* Invisible bridge to prevent hover loss */
.nav-item::after {
    content: '';
    position: absolute;
    height: 20px;
    width: 100%;
    bottom: -20px;
    left: 0;
}
.dropdown-menu a {
    display: block !important;
    padding: 0.6rem 1rem !important;
    color: rgba(245,246,247,.72) !important;
    text-decoration: none !important;
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    border-radius: 0.5rem !important;
    transition: all 0.2s ease !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}
.dropdown-menu a:hover {
    color: #fff !important;
    background: rgba(255, 215, 0, 0.08) !important;
}

/* Highlights / TL;DR Bento Box */
.tldr-box {
    background: rgba(20, 20, 20, 0.65);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 215, 0, 0.15) !important;
    box-shadow: 0 0 35px rgba(255, 215, 0, 0.03);
    transition: all 0.3s ease;
}
.tldr-box:hover {
    border-color: rgba(255, 215, 0, 0.35) !important;
    box-shadow: 0 0 45px rgba(255, 215, 0, 0.1);
}
.ic-16 {
    width: 16px;
    height: 16px;
}
.ic-20 {
    width: 20px;
    height: 20px;
}
.shrink-0 {
    flex-shrink: 0;
}

/* Reveal on Scroll */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s cubic-bezier(.2,.7,.2,1), transform 0.6s cubic-bezier(.2,.7,.2,1);
}
.reveal.reveal-active {
    opacity: 1;
    transform: translateY(0);
}

/* Premium Kinetic Elite Animations & Buttons */
@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}
.status-pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
.gold-gradient {
    background: linear-gradient(135deg, #FFD700 0%, #FFA500 100%) !important;
}
.gold-btn {
    background: linear-gradient(135deg, #FFD700 0%, #FFA500 100%) !important;
    color: #0A0A0A !important;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    transition: all 0.3s var(--ease) !important;
    box-shadow: 0 0 20px rgba(255, 215, 0, 0.2);
}
.gold-btn:hover {
    opacity: 0.9;
    transform: scale(1.03);
    box-shadow: 0 0 30px rgba(255, 215, 0, 0.4);
}
.gold-btn:active {
    transform: scale(0.97);
}
