/* Compass TransitWorks – Brand Styles */
:root{
  --navy:#0b1f3a;
  --navy-2:#13315c;
  --gold:#f4a93b;
  --gold-2:#e8951f;
  --ink:#0f172a;
  --muted:#5b6b7f;
  --bg:#ffffff;
  --soft:#f5f7fa;
  --line:#e5e9f0;
  --ok:#1aa179;
  --maxw:1200px;
  --radius:10px;
  --shadow:0 6px 24px rgba(11,31,58,.08);
  --shadow-lg:0 18px 48px rgba(11,31,58,.18);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy-2);text-decoration:none}
a:hover{color:var(--gold-2)}
h1,h2,h3,h4{font-family:'Poppins','Inter',sans-serif;color:var(--navy);line-height:1.2;margin:0 0 .6em}
h1{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1em;color:#2b3a55}
ul{margin:0 0 1em;padding-left:1.25em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:72px 0}
.section.alt{background:var(--soft)}
.eyebrow{display:inline-block;font-weight:700;color:var(--gold-2);text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;margin-bottom:10px}
.grid{display:grid;gap:24px}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:900px){.grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);backdrop-filter:saturate(140%) blur(6px)}
.header-top{background:var(--navy);color:#dbe5f4;font-size:.85rem}
.header-top .container{display:flex;justify-content:space-between;align-items:center;padding-top:8px;padding-bottom:8px;flex-wrap:wrap;gap:8px}
.header-top a{color:#dbe5f4}
.header-top a:hover{color:var(--gold)}
.header-top .area{display:inline-flex;align-items:center;gap:8px}
.header-top .area::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(244,169,59,.18)}
.header-main .container{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:14px;padding-bottom:14px}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:60px;width:60px;object-fit:contain}
.brand .name{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.45rem;color:var(--navy);letter-spacing:-.01em;line-height:1.05}
.brand .name span{display:block;font-size:.72rem;color:var(--gold-2);font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-top:2px}
.nav{display:flex;align-items:center;gap:4px}
.nav > ul{list-style:none;display:flex;gap:2px;margin:0;padding:0;align-items:center}
.nav > ul > li{position:relative}
.nav > ul > li > a, .nav-toggle{display:inline-block;padding:10px 12px;color:var(--navy);font-weight:600;font-size:.95rem;border-radius:8px}
.nav > ul > li > a:hover{background:var(--soft);color:var(--navy-2)}
.has-drop > a::after{content:" ▾";font-size:.7em;color:var(--gold-2)}
.dropdown{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);min-width:260px;border-radius:10px;padding:8px;display:none;z-index:60}
.has-drop:hover > .dropdown, .has-drop:focus-within > .dropdown{display:block}
.dropdown a{display:block;padding:9px 12px;color:var(--navy);border-radius:6px;font-size:.92rem}
.dropdown a:hover{background:var(--soft);color:var(--navy-2)}
.cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:#1a1300!important;font-weight:800;padding:11px 18px;border-radius:999px;border:0;font-size:.95rem;box-shadow:0 6px 16px rgba(244,169,59,.35);transition:transform .15s,box-shadow .15s}
.cta-btn:hover{background:var(--gold-2);transform:translateY(-1px);box-shadow:0 10px 22px rgba(232,149,31,.45)}
.cta-btn.outline{background:transparent;color:#fff!important;border:2px solid #fff;box-shadow:none}
.cta-btn.outline:hover{background:#fff;color:var(--navy)!important}
.cta-btn.dark{background:var(--navy);color:#fff!important;box-shadow:0 6px 16px rgba(11,31,58,.25)}
.cta-btn.dark:hover{background:var(--navy-2)}
.menu-btn{display:none;background:var(--navy);color:#fff;border:0;padding:10px 14px;border-radius:8px;font-weight:700;cursor:pointer}

/* Hero */
.hero{position:relative;color:#fff;overflow:hidden;background:#0a1a30}
.hero .bg{position:absolute;inset:0;background:url('../images/hero.jpg') center/cover no-repeat;opacity:.55}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,31,58,.92),rgba(11,31,58,.55) 60%,rgba(11,31,58,.85))}
.hero .container{position:relative;z-index:2;padding:90px 22px 96px}
.hero h1{color:#fff;max-width:880px}
.hero p.lead{font-size:1.15rem;color:#e3ecfb;max-width:720px;margin-bottom:28px}
.hero .actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}
.hero .badges{display:flex;flex-wrap:wrap;gap:22px;margin-top:34px;color:#cfdbef;font-size:.92rem}
.hero .badges span{display:inline-flex;align-items:center;gap:8px}
.hero .badges span::before{content:"✓";color:var(--gold);font-weight:900}

/* Cards */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card h3{margin-bottom:8px}
.card p{color:var(--muted);margin-bottom:14px;flex-grow:1}
.card .more{color:var(--gold-2);font-weight:700;margin-top:auto}
.card .more::after{content:" →"}
.card .thumb{height:180px;border-radius:8px;overflow:hidden;margin:-22px -22px 18px;background:#dde}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.icon-card{padding:24px}
.icon-card .ic{width:46px;height:46px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#1a1300;font-weight:900;display:grid;place-items:center;font-size:1.3rem;margin-bottom:14px}

/* Trust strip */
.trust{background:var(--navy);color:#cfdbef;padding:24px 0}
.trust .container{display:flex;flex-wrap:wrap;justify-content:space-around;gap:18px;text-align:center}
.trust b{display:block;color:var(--gold);font-size:1.6rem;font-family:'Poppins',sans-serif}

/* Lists / FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px 18px;margin-bottom:10px;box-shadow:0 2px 8px rgba(11,31,58,.04)}
.faq summary{cursor:pointer;font-weight:700;color:var(--navy);font-size:1.02rem;list-style:none;position:relative;padding-right:28px}
.faq summary::after{content:"+";position:absolute;right:0;top:0;color:var(--gold-2);font-weight:800;font-size:1.3rem}
.faq details[open] summary::after{content:"–"}
.faq summary::-webkit-details-marker{display:none}
.faq details p{margin-top:10px;color:#3b4a66}

/* CTA strip */
.cta-strip{background:linear-gradient(110deg,var(--navy),var(--navy-2));color:#fff;border-radius:16px;padding:40px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.cta-strip h2{color:#fff;margin:0}
.cta-strip p{color:#cfdbef;margin:6px 0 0}

/* Testimonials */
.quote{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;box-shadow:var(--shadow)}
.quote .stars{color:var(--gold);font-weight:900;letter-spacing:2px;margin-bottom:8px}
.quote blockquote{margin:0 0 12px;font-style:italic;color:#2b3a55}
.quote .who{font-weight:700;color:var(--navy);font-size:.92rem}
.quote .who span{display:block;color:var(--muted);font-weight:500;font-size:.85rem}

/* Form */
form.contact{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:var(--shadow)}
form.contact label{display:block;font-weight:600;color:var(--navy);margin:10px 0 6px;font-size:.92rem}
form.contact input,form.contact select,form.contact textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font:inherit;color:var(--ink);background:#fcfdff}
form.contact input:focus,form.contact textarea:focus,form.contact select:focus{outline:2px solid var(--gold);border-color:var(--gold)}
form.contact .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){form.contact .row{grid-template-columns:1fr}}
form.contact button{margin-top:18px;width:100%}

/* Footer */
.site-footer{background:var(--navy);color:#bccbe2;padding:60px 0 24px;margin-top:60px}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:14px;font-family:'Poppins',sans-serif}
.site-footer a{color:#bccbe2;display:block;padding:4px 0;font-size:.93rem}
.site-footer a:hover{color:var(--gold)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:28px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{height:54px;width:54px}
.footer-brand .name{color:#fff;font-family:'Poppins',sans-serif;font-weight:800;font-size:1.25rem;margin:10px 0 6px}
.footer-brand p{color:#bccbe2;font-size:.92rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:36px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.85rem;color:#8ea0bf}
.footer-bottom a{display:inline;color:#8ea0bf}

/* Map */
.map-embed{border:0;width:100%;height:380px;border-radius:14px;box-shadow:var(--shadow)}

/* Coverage map (SVG) */
.coverage{background:linear-gradient(180deg,var(--soft),#fff);border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center}
.coverage svg{max-width:100%;height:auto}
.coverage .state-active{fill:var(--gold);stroke:#fff;stroke-width:.6}
.coverage .state-inactive{fill:#cfd8e6;stroke:#fff;stroke-width:.6;transition:fill .2s}
.coverage .state-inactive:hover{fill:#9fb2cd}

/* Breadcrumbs */
.crumbs{font-size:.86rem;color:var(--muted);padding:14px 0 0}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--gold-2)}
.crumbs span{color:var(--ink);font-weight:600}

/* Page header */
.page-hero{background:linear-gradient(120deg,var(--navy),var(--navy-2));color:#fff;padding:56px 0 48px}
.page-hero h1{color:#fff;margin-bottom:10px}
.page-hero p{color:#cfdbef;max-width:760px;margin:0}

/* Two-col content */
.two-col{display:grid;grid-template-columns:1.2fr 1fr;gap:42px;align-items:center}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}
.two-col img{border-radius:14px;box-shadow:var(--shadow-lg)}

/* List link group */
.linklist{list-style:none;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:8px 22px}
.linklist li a{color:var(--navy-2);padding:6px 0;display:inline-block;font-weight:600}
.linklist li a::before{content:"→ ";color:var(--gold-2)}
@media(max-width:700px){.linklist{grid-template-columns:1fr 1fr}}

/* Mobile menu */
@media(max-width:980px){
  .menu-btn{display:inline-block}
  .nav > ul{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:10px;border-top:1px solid var(--line);box-shadow:var(--shadow);max-height:75vh;overflow-y:auto}
  .nav.open > ul{display:flex}
  .nav > ul > li{width:100%}
  .nav > ul > li > a{display:block;padding:12px}
  .dropdown{position:static;display:none;box-shadow:none;border:0;border-left:3px solid var(--gold);border-radius:0;margin-left:12px}
  .has-drop.open > .dropdown{display:block}
}
