/* costcoquote.com homepage — remake (T1 Costco marketing landing).
   Reuses the BLESSED Large Group design system 1:1 (palette + Costco Sans Micro + WCAG defaults),
   laid out as a full-width, mobile-first MARKETING page (header+nav, hero w/ dark scrim, segment
   chooser, services grid, channel programs, carrier band, footer). Same brand system as the exemplars.
   Real Costco palette (verified vs live theme.css). No third-party, no pixels. */

@font-face{font-family:"Costco Sans Micro";src:url("assets/CostcoSansMicro-Regular.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Costco Sans Micro";src:url("assets/CostcoSansMicro-Medium.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Costco Sans Micro";src:url("assets/CostcoSansMicro-Semibold.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Costco Sans Micro";src:url("assets/CostcoSansMicro-Black.woff2") format("woff2");font-weight:800;font-display:swap}

:root{
  --blue:#005DAB; --blue-dark:#004a8a;        /* Costco primary */
  --red:#E31936; --red-dark:#c2142e;          /* CTA accent */
  --focus:#DE2127;                            /* input/focus ring (theme.css:1701) */
  --ink:#1f2733; --body:#444; --muted:#6a717b;
  --line:#d9dee4; --soft:#f4f7fa; --bg:#fff;
  --font:"Costco Sans Micro",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1180px; --radius:14px;
  --shadow:0 6px 28px rgba(15,30,50,.10),0 1px 2px rgba(15,30,50,.06);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--body);font-family:var(--font);font-size:16px;line-height:1.55}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue)}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
@media(max-width:480px){ .wrap{padding:0 16px} }

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skiplink{position:absolute;left:-999px;top:0;background:var(--blue);color:#fff;padding:10px 14px;z-index:100;border-radius:0 0 8px 0}
.skiplink:focus{left:0}

/* ---------- top operator disclaimer (regulated, verbatim) ---------- */
.topbar{background:#eef2f6;color:#3a424d;font-size:.78rem;line-height:1.45;text-align:center;padding:8px 16px}
.topbar a{color:var(--blue-dark);font-weight:600;text-decoration:underline}
@media(max-width:780px){
  .topbar{padding:6px 16px}
  .topbar a{display:inline-block;padding:11px 4px;line-height:22px;min-height:44px}
}

/* ---------- header ---------- */
.site-head{background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.site-head__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:68px;padding-top:8px;padding-bottom:8px}
.site-head__logo{display:inline-flex;align-items:center;gap:28px}
.site-head__logo .logo-cbc{height:116px;width:auto}
.site-head__logo .logo-costco{height:36px;width:auto}
.site-head__logo .logo-div{width:1px;height:80px;background:rgba(0,0,0,.18);flex:none}
@media(max-width:480px){ .site-head__logo{gap:16px} .site-head__logo .logo-cbc{height:56px} .site-head__logo .logo-costco{height:18px} .site-head__logo .logo-div{height:38px} }

.nav{display:flex;align-items:center;gap:6px}
.nav__link{color:var(--ink);text-decoration:none;font-weight:600;font-size:.95rem;padding:10px 12px;border-radius:8px;min-height:44px;display:inline-flex;align-items:center}
.nav__link:hover{background:var(--soft);color:var(--blue-dark)}
.nav__cta{background:var(--red);color:#fff;margin-left:6px}
.nav__cta:hover{background:var(--red-dark);color:#fff}

.navtoggle{display:none;background:none;border:1px solid var(--line);border-radius:9px;width:46px;height:44px;cursor:pointer;
  align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:0}
.navtoggle__bar{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px}
.navtoggle:focus-visible{outline:3px solid var(--focus);outline-offset:2px}

@media(max-width:860px){
  .navtoggle{display:inline-flex}
  .nav{position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg);border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:8px 16px 14px;display:none}
  .nav.open{display:flex}
  .nav__link{padding:14px 10px;border-radius:8px;font-size:1.05rem}
  .nav__cta{margin-left:0;margin-top:6px;justify-content:center}
}

/* ---------- hero (dark scrim over real photo — passes contrast: scrim has a real bg color) ---------- */
.hero{position:relative;background:#013a66 url("assets/home-bg.jpg") center center/cover no-repeat}
.hero__scrim{background:linear-gradient(90deg,rgba(0,33,60,.82) 0%,rgba(0,40,76,.66) 55%,rgba(0,40,76,.50) 100%)}
.hero__inner{padding:72px 20px 80px;max-width:760px;margin-left:0}
.hero__eyebrow{color:#dce8f4;font-weight:600;font-size:.95rem;margin:0 0 14px;text-transform:none}
.hero__title{color:#fff;font-weight:800;font-size:clamp(1.9rem,5.2vw,3.1rem);line-height:1.08;margin:0 0 .35em;text-shadow:0 1px 2px rgba(0,0,0,.35)}
.hero__sub{color:#eaf1f8;font-size:clamp(1.02rem,2.4vw,1.25rem);margin:0 0 28px;max-width:46ch}
.hero__cta{font-size:1.1rem}
@media(max-width:480px){ .hero__inner{padding:48px 16px 52px} }

/* ---------- buttons (shared component language with the exemplars) ---------- */
.btn{font-family:inherit;font-weight:700;font-size:1.02rem;border:0;border-radius:10px;padding:14px 24px;
  cursor:pointer;min-height:50px;display:inline-flex;align-items:center;gap:9px;justify-content:center;text-decoration:none}
.btn--primary{background:var(--blue);color:#fff} .btn--primary:hover{background:var(--blue-dark);color:#fff}
.btn--send{background:var(--red);color:#fff} .btn--send:hover{background:var(--red-dark);color:#fff}
.btn:focus-visible{outline:3px solid var(--focus);outline-offset:2px}

/* ---------- red bar ---------- */
.redbar{background:var(--red);color:#fff;text-align:center;font-weight:700;font-size:clamp(1.05rem,2.6vw,1.4rem);
  padding:16px 20px;letter-spacing:.2px}
@media(max-width:480px){ .redbar{padding:22px 24px} }

/* ---------- generic section ---------- */
.section{padding:54px 0}
.section--soft{background:var(--soft)}
.section__title{color:var(--ink);font-weight:800;font-size:clamp(1.4rem,3.6vw,2rem);line-height:1.18;text-align:center;margin:0 0 32px}
@media(max-width:480px){ .section{padding:40px 0} .section__title{margin-bottom:24px} }

/* ---------- segment chooser ---------- */
.chooser{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.chooser__card{display:flex;flex-direction:column;justify-content:space-between;gap:18px;min-height:128px;
  background:var(--bg);border:1px solid var(--line);border-top:5px solid var(--red);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:22px 22px 20px;text-decoration:none;transition:transform .12s,box-shadow .12s,border-color .12s}
.chooser__card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(15,30,50,.16);border-color:var(--blue)}
.chooser__card:focus-visible{outline:3px solid var(--focus);outline-offset:2px}
.chooser__name{color:var(--ink);font-weight:800;font-size:1.25rem;line-height:1.15}
.chooser__go{color:var(--red);font-weight:700;font-size:1rem}
.chooser__more{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px}
.chooser__pill{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:11px 20px;min-height:44px;
  display:inline-flex;align-items:center;color:var(--blue-dark);font-weight:600;text-decoration:none}
.chooser__pill:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
@media(max-width:780px){
  .chooser{grid-template-columns:1fr;gap:12px}
  .chooser__card{min-height:0;justify-content:flex-start;gap:8px;padding:16px 18px}
  .chooser__name{font-size:1.12rem}
}

/* ---------- coverage-needs checklist ---------- */
.needs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px 36px;max-width:980px;margin:0 auto}
.needs__list{list-style:none;margin:0;padding:0}
.needs__list li{position:relative;padding:8px 0 8px 30px;color:var(--ink);font-weight:500;border-bottom:1px solid var(--line)}
.needs__list li::before{content:"";position:absolute;left:0;top:13px;width:14px;height:8px;
  border-left:3px solid var(--red);border-bottom:3px solid var(--red);transform:rotate(-45deg)}
@media(max-width:780px){ .needs{grid-template-columns:1fr 1fr;gap:4px 24px} }
@media(max-width:480px){ .needs{grid-template-columns:1fr} }

/* ---------- services grid (tiles) ---------- */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.tile{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
.tile__pic{aspect-ratio:542/330;background:var(--soft);overflow:hidden}
.tile__pic img{width:100%;height:100%;object-fit:cover}
.tile__body{display:flex;flex-direction:column;flex:1;padding:18px 18px 20px}
.tile__h{color:var(--ink);font-weight:800;font-size:1.12rem;line-height:1.2;margin:0 0 12px}
.tile__list{list-style:none;margin:0 0 16px;padding:0;flex:1}
.tile__list li{position:relative;padding:5px 0 5px 24px;color:var(--body);font-size:.92rem;line-height:1.4}
.tile__list li::before{content:"";position:absolute;left:0;top:9px;width:11px;height:6px;
  border-left:2.5px solid var(--red);border-bottom:2.5px solid var(--red);transform:rotate(-45deg)}
.tile__sublist{list-style:none;margin:4px 0 0;padding:0}
.tile__sublist li{padding-left:24px;font-size:.88rem}
.tile__sublist li::before{border-color:var(--blue)}
.tile__cta{align-self:flex-start;margin-top:auto;color:var(--red);font-weight:700;text-decoration:none;
  padding:10px 0;min-height:44px;display:inline-flex;align-items:center;gap:6px}
.tile__cta:hover{color:var(--red-dark);text-decoration:underline}
@media(max-width:1080px){ .tiles{grid-template-columns:repeat(3,1fr)} }
@media(max-width:780px){ .tiles{grid-template-columns:repeat(2,1fr)} }
@media(max-width:460px){ .tiles{grid-template-columns:1fr} }

/* ---------- channel associate programs ---------- */
.cp{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cp__card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--line);border-top:5px solid var(--blue);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 20px 20px}
.cp__logo{height:54px;display:flex;align-items:center;margin-bottom:16px}
.cp__logo img{max-height:48px;width:auto;max-width:80%;object-fit:contain}
.cp__list{list-style:none;margin:0 0 16px;padding:0;flex:1}
.cp__list li{position:relative;padding:5px 0 5px 24px;color:var(--body);font-size:.9rem;line-height:1.4}
.cp__list li::before{content:"";position:absolute;left:0;top:9px;width:11px;height:6px;
  border-left:2.5px solid var(--red);border-bottom:2.5px solid var(--red);transform:rotate(-45deg)}
@media(max-width:1080px){ .cp{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .cp{grid-template-columns:1fr} }

/* ---------- carrier logos band ---------- */
.carriers__title{font-size:clamp(1.15rem,3vw,1.6rem);max-width:50ch;margin-left:auto;margin-right:auto}
.carriers__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;align-items:center}
.carriers__cell{background:var(--bg);border:1px solid var(--line);border-radius:10px;height:96px;
  display:flex;align-items:center;justify-content:center;padding:14px}
.carriers__cell img{max-height:56px;max-width:100%;width:auto;object-fit:contain}
.carriers__action{text-align:center;margin-top:28px}
@media(max-width:900px){ .carriers__grid{grid-template-columns:repeat(4,1fr)} }
@media(max-width:560px){ .carriers__grid{grid-template-columns:repeat(2,1fr)} .carriers__cell{height:84px} }

/* ---------- footer ---------- */
.foot{background:#0f2438;color:#cdd7e2;font-size:.9rem}
.foot__redbar{height:6px;background:var(--red)}
.foot__inner{padding:42px 20px 36px}
.foot__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-bottom:34px}
.foot__col{display:flex;flex-direction:column}
.foot__h{color:#fff;font-size:1rem;font-weight:700;margin:0 0 12px}
.foot__col a{color:#cdd7e2;text-decoration:none;padding:6px 0;min-height:36px;display:inline-flex;align-items:center;line-height:1.3}
.foot__col a:hover{color:#fff;text-decoration:underline}
/* ACA Section 1557 language-access disclosure (regulated; restyled to design system) */
.langassist{border-top:1px solid rgba(255,255,255,.14);padding-top:24px;margin-bottom:30px}
.langassist__h{color:#fff;font-size:1.05rem;font-weight:700;margin:0 0 14px}
.langassist__list{list-style:none;margin:0;padding:0;columns:4 180px;column-gap:24px}
.langassist__list li{break-inside:avoid;margin:0 0 2px}
.langassist__link{display:inline-flex;align-items:center;min-height:36px;padding:6px 0;color:#cdd7e2;
  text-decoration:none;font-size:.82rem;line-height:1.3}
.langassist__link:hover{color:#fff;text-decoration:underline}
.langassist__toggle{margin-top:12px;background:none;border:0;color:#9cc4ec;font-family:inherit;font-weight:700;
  font-size:.85rem;cursor:pointer;padding:8px 0;min-height:44px;display:inline-flex;align-items:center;text-decoration:underline}
.langassist__toggle:hover{color:#fff}
.langassist__toggle:focus-visible{outline:3px solid var(--focus);outline-offset:2px;text-decoration:none}
.langassist__more{margin-top:14px}
.langassist__more[hidden]{display:none}
.langassist__line{color:#9fb0c2;font-size:.78rem;line-height:1.5;margin:16px 0 0;max-width:80ch}
@media(max-width:780px){ .langassist__list{columns:2 140px} }
@media(max-width:480px){ .langassist__list{columns:1} }

.foot__legal{border-top:1px solid rgba(255,255,255,.14);padding-top:22px;color:#9fb0c2;font-size:.78rem;line-height:1.5}
.foot__legal p{margin:0 0 12px;max-width:none}
.foot__links a{color:#cdd7e2;font-weight:600;text-decoration:none}
.foot__links a:hover{color:#fff;text-decoration:underline}
.foot__attn strong{color:#fff}
.foot__attn a,.foot__legal a{color:#9cc4ec}
.foot__filing{color:#7e91a4;font-size:.74rem}
@media(max-width:780px){ .foot__cols{grid-template-columns:1fr 1fr;gap:22px} }
@media(max-width:480px){ .foot__cols{grid-template-columns:1fr} .foot__inner{padding:34px 16px 30px} }
