/* costcoquote.com /medicare LANDING — remake (T1 Costco marketing landing, stamp B6).
   Reuses the BLESSED B6 Costco design system 1:1 (palette + Costco Sans Micro + WCAG defaults + glass/rise),
   laid out as a full-width, mobile-first LANDING (header+nav, breadcrumb, hero w/ dark scrim over the live
   Medicare_LandingPgBG photo, which-plan two-col w/ MedicarePic0 circle, VIP service band w/ SmallGroupsService
   photo, FAQ accordion, full regulated footer). Same brand system as the B6 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;                /* ONE card-radius family (C6) */
  --btn-radius:10px;                           /* ONE button radius (C6) */
  --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:auto;scroll-padding-top:84px}   /* B6 stamp: scroll-behavior:auto */
section{scroll-margin-top:84px}
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);clip-path:inset(50%);white-space:nowrap;border:0}
.skiplink{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}
.skiplink:focus,.skiplink:focus-visible{position:absolute;left:0;top:0;width:auto;height:auto;margin:0;clip:auto;clip-path:none;overflow:visible;
  background:var(--blue);color:#fff;padding:10px 14px;z-index:100;border-radius:0 0 8px 0}

/* ---------- top operator disclaimer (regulated, verbatim) ---------- */
.topbar{background:#eef2f6;color:#3a424d;font-size:.875rem;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;flex-wrap:wrap}
.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} }

/* header welcome text (live .headerWelcome) */
.site-head__welcome{flex:1 1 260px;min-width:0;color:var(--ink);font-weight:600;font-size:1rem;line-height:1.25;text-align:center}
@media(max-width:980px){ .site-head__welcome{display:none} }

/* header social links (inline-SVG brand icons; no external icon font) */
.site-head__socials{display:flex;align-items:center;gap:12px}
.headerRHLink{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;color:var(--muted)}
.headerRHLink:hover{color:var(--blue-dark);background:var(--soft)}
.headerRHLink:focus-visible{outline:3px solid var(--focus);outline-offset:2px}
.headerRHLink svg{display:block}
@media(max-width:860px){ .site-head__socials{display:none} }

.nav{display:flex;align-items:center;gap:12px}
.nav__link{color:var(--ink);text-decoration:none;font-weight:600;font-size:.875rem;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:0}
.nav__cta:hover{background:var(--red-dark);color:#fff}

.navtoggle{display:none;background:none;border:1px solid var(--line);border-radius:var(--btn-radius);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:1rem}
  .nav__cta{margin-left:0;margin-top:6px;justify-content:center}
}

/* ---------- breadcrumb ---------- */
.breadcrumb{background:var(--soft);border-bottom:1px solid var(--line);font-size:.875rem}
.breadcrumb .wrap{padding-top:10px;padding-bottom:10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.breadcrumb a{color:var(--blue-dark);text-decoration:none;display:inline-flex;align-items:center;min-height:24px;padding:3px 2px}
.breadcrumb a:hover{text-decoration:underline}
@media(max-width:480px){ .breadcrumb a{min-height:28px;padding:5px 2px} }
.breadcrumb strong{color:var(--ink)}
.breadcrumb span{color:var(--muted)}

/* ---------- hero (dark scrim over the live Medicare landing photo) ---------- */
.hero{position:relative;background:#013a66 url("assets/medicare-hero-bg.jpg") center right/cover no-repeat}
.hero__scrim{background:linear-gradient(90deg,rgba(0,33,60,.82) 0%,rgba(0,40,76,.60) 55%,rgba(0,40,76,.42) 100%)}
.hero__inner{padding-top:72px;padding-bottom:80px}
.hero__title{color:#fff;font-weight:800;font-size:clamp(1.9rem,5.2vw,3.1rem);line-height:1.1;margin:0 0 .55em;text-shadow:0 1px 2px rgba(0,0,0,.35);max-width:16ch}
.hero__bullets{list-style:none;margin:0 0 30px;padding:0;display:flex;flex-direction:column;gap:14px;max-width:48ch}
.hero__bullets li{position:relative;color:#eaf1f8;font-size:1.05rem;line-height:1.35;padding-left:34px}
.hero__bullets li::before{content:"";position:absolute;left:0;top:4px;width:15px;height:9px;
  border-left:3px solid var(--red);border-bottom:3px solid var(--red);transform:rotate(-45deg)}
.hero__ctas{display:flex;flex-wrap:wrap;gap:14px}
@media(max-width:480px){ .hero__inner{padding-top:48px;padding-bottom:52px} .hero__ctas .btn{width:100%} }

/* ---------- buttons (shared component language with B6) ---------- */
.btn{font-family:inherit;font-weight:700;font-size:1.02rem;border:0;border-radius:var(--btn-radius);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}
.section__title--left{text-align:left}
@media(max-width:480px){ .section{padding:40px 0} .section__title{margin-bottom:24px} }

/* ---------- which type of plan (two-col: circle photo + copy) ---------- */
.whichplan{display:grid;grid-template-columns:280px 1fr;gap:40px;align-items:start}
.whichplan__media{display:flex;justify-content:center}
.whichplan__circle{width:230px;height:230px;border-radius:50%;object-fit:cover;border:7px solid var(--blue);box-shadow:var(--shadow)}
.whichplan__lede{color:var(--body);font-size:1rem;line-height:1.55;margin:0 0 18px}
.whichplan__list{list-style:none;margin:0 0 24px;padding:0;display:flex;flex-direction:column;gap:12px}
.whichplan__list li{position:relative;padding-left:28px;color:var(--body);font-size:.95rem;line-height:1.45}
.whichplan__list li::before{content:"";position:absolute;left:0;top:7px;width:12px;height:7px;
  border-left:2.5px solid var(--blue);border-bottom:2.5px solid var(--blue);transform:rotate(-45deg)}
.whichplan__list strong.black,.whichplan__list strong{color:var(--ink)}
.whichplan__cta{margin-top:4px}
@media(max-width:780px){
  .whichplan{grid-template-columns:1fr;gap:24px}
  .whichplan__media{order:-1}
}

/* ---------- VIP service band (greybar + service photo) ----------
   Full-bleed split band: the photo is a right-half BAND background (absolute), the copy lives in the
   SAME centered .wrap container as every other band (C1/C2 — content column aligns to the page grid),
   constrained to the left half on desktop. The .vip__h reuses .section__title for the ONE H2 scale (C3). */
.vip{position:relative;background:#3a4452;overflow:hidden}
.vip__pic{position:absolute;inset:0 0 0 50%;background:url("assets/medicare-service.jpg") center right/cover no-repeat}
.vip__pic::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#3a4452 0%,rgba(58,68,82,0) 22%)}
.vip__copy{position:relative;z-index:1;color:#fff;padding-top:54px;padding-bottom:54px}  /* .wrap keeps the centered page container (C1/C2) */
.vip__inner{max-width:48%}                                /* inner content sits in the left half; container stays full-width centered */
.vip__h{color:#fff;margin:0 0 14px}                      /* size/weight inherit from .section__title (C3) */
.vip__sub{color:#8fc0ff;font-weight:600;font-size:1.02rem;line-height:1.45;margin:0 0 20px}
.vip__list{list-style:none;margin:0 0 26px;padding:0;display:flex;flex-direction:column;gap:12px}
.vip__list li{position:relative;padding-left:28px;color:#e7edf4;font-size:1rem;line-height:1.4}
.vip__list li::before{content:"";position:absolute;left:0;top:6px;width:12px;height:7px;
  border-left:2.5px solid var(--red);border-bottom:2.5px solid var(--red);transform:rotate(-45deg)}
.vip__cta{margin-top:2px}
@media(max-width:780px){
  .vip{display:flex;flex-direction:column-reverse}
  .vip__pic{position:relative;inset:auto;width:100%;min-height:220px}
  .vip__pic::after{display:none}
  .vip__copy{padding-top:40px;padding-bottom:40px}
  .vip__inner{max-width:none}
}

/* ---------- FAQ accordion ---------- */
.faq{max-width:880px;margin:0 auto}
.faq__item{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden}
.faq__q{cursor:pointer;list-style:none;padding:18px 48px 18px 20px;color:var(--ink);font-weight:700;font-size:1.02rem;line-height:1.3;position:relative;min-height:44px}
.faq__q::-webkit-details-marker{display:none}
.faq__q::after{content:"";position:absolute;right:20px;top:50%;width:11px;height:11px;border-right:2.5px solid var(--red);border-bottom:2.5px solid var(--red);
  transform:translateY(-70%) rotate(45deg);transition:transform .18s}
.faq__item[open] .faq__q::after{transform:translateY(-30%) rotate(225deg)}
.faq__q:focus-visible{outline:3px solid var(--focus);outline-offset:-3px}
.faq__a{padding:0 20px 20px;color:var(--body);font-size:.95rem;line-height:1.55}
.faq__list{margin:10px 0 0;padding-left:24px;display:flex;flex-direction:column;gap:8px}
.faq__list li{line-height:1.45}
.faq__a a{color:var(--blue-dark);font-weight:600}

.faq__cta{max-width:880px;margin:28px auto 0;background:var(--bg);border:1px solid var(--line);border-top:5px solid var(--red);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 24px;display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between}
.faq__cta-q{color:var(--ink);font-weight:800;font-size:1rem;margin:0 0 6px}   /* prominence via weight; size stays on the {16/14} body scale (C3) */
.faq__cta-a{color:var(--body);font-size:.875rem;margin:0}
@media(max-width:560px){ .faq__cta{flex-direction:column;align-items:flex-start} .faq__cta .btn{width:100%} }

/* ---------- footer ---------- */
.foot{background:#0f2438;color:#cdd7e2;font-size:.875rem}
.foot__redbar{height:6px;background:var(--red)}
.foot__inner{padding:42px 20px 36px}
.foot__contact{display:flex;flex-wrap:wrap;gap:16px 32px;align-items:flex-start;margin-bottom:30px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.14)}
.foot__contact a,.foot__contact span{color:#cdd7e2;text-decoration:none;line-height:1.4;display:inline-flex;align-items:center;min-height:36px}
.foot__contact a:hover{color:#fff;text-decoration:underline}
.foot__sitemap-label{margin:0 0 18px}
.foot__sitemap-label strong{color:#fff;font-size:1.05rem}
.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:54px;padding-bottom:54px;margin-bottom:30px}
.langassist__h{color:#fff;font-size:1rem;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:.875rem;line-height:1.3}
.langassist__link:hover{color:#fff;text-decoration:underline}
.langassist__toggle{margin-top:12px;background:none;border:0;border-radius:var(--btn-radius);color:#9cc4ec;font-family:inherit;font-weight:700;
  font-size:.875rem;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:.875rem;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:.875rem;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:.875rem}
@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} }

/* ========================================================================
   LOOK-LAYER: liquid-glass cards + entrance-reveal (T1 Costco B6 stamp).
   ======================================================================== */
.glass{
  background: rgba(255,255,255,.55);
  -webkit-backdrop-filter: blur(18px) saturate(1.5);
  backdrop-filter: blur(18px) saturate(1.5);
  border: 1px solid rgba(255,255,255,.75);
  border-radius: var(--radius);
  box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 10px 30px rgba(0,0,0,.08);
  position: relative;
}
.glass::before{
  content:""; position:absolute; inset:0 0 auto 0; height:40%;
  border-radius: var(--radius) var(--radius) 0 0;
  background: linear-gradient(180deg, rgba(255,255,255,.5), rgba(255,255,255,0));
  pointer-events:none;
}
.glass > *{ position:relative; z-index:1 }
@media (prefers-reduced-motion: reduce){
  .glass{ -webkit-backdrop-filter: blur(4px) saturate(1.12) brightness(1.03); backdrop-filter: blur(4px) saturate(1.12) brightness(1.03); }
}

/* ---- entrance-reveal (.rise) ---- (capture-safe: opacity stays 1, only transform animates) */
@keyframes rise { from { transform:translateY(16px) } to { transform:translateY(0) } }
.rise{ opacity:1 }
.js .rise{ opacity:1; transform:translateY(16px) }
.js .rise.is-in{ transform:translateY(0); animation: rise .9s cubic-bezier(.2,.7,.2,1) forwards }
.js .rise.d1.is-in{animation-delay:.05s}
.js .rise.d2.is-in{animation-delay:.16s}
.js .rise.d3.is-in{animation-delay:.27s}
.js .rise.d4.is-in{animation-delay:.38s}
.no-js .rise{ opacity:1 !important; animation:none !important; transform:none !important }
@media (prefers-reduced-motion: reduce){
  .rise, .js .rise, .js .rise.is-in{ opacity:1 !important; animation:none !important; transform:none !important }
}
