/* Great Lakes Bay STEM Career Exposure Resource Hub, prototype theme by Stoa Works.
   Palette + type committed in DESIGN-DNA.md. Signature accent: industry copper #C2622D. */

/* ---- Self-hosted fonts (OFL, no CDN) ---- */
@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:500;font-display:swap;
  src:url("/bayarenacisd/assets/fonts/space-grotesk-500.woff2") format("woff2");}
@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:700;font-display:swap;
  src:url("/bayarenacisd/assets/fonts/space-grotesk-700.woff2") format("woff2");}
@font-face{font-family:"Mulish";font-style:normal;font-weight:400;font-display:swap;
  src:url("/bayarenacisd/assets/fonts/mulish-400.woff2") format("woff2");}
@font-face{font-family:"Mulish";font-style:normal;font-weight:500;font-display:swap;
  src:url("/bayarenacisd/assets/fonts/mulish-500.woff2") format("woff2");}
@font-face{font-family:"Mulish";font-style:normal;font-weight:600;font-display:swap;
  src:url("/bayarenacisd/assets/fonts/mulish-600.woff2") format("woff2");}
@font-face{font-family:"Mulish";font-style:normal;font-weight:700;font-display:swap;
  src:url("/bayarenacisd/assets/fonts/mulish-700.woff2") format("woff2");}

:root{
  --bay:#0B6E99; --bay-deep:#075877; --harbor:#21333F; --harbor-2:#2b4250;
  --copper:#C2622D; --copper-deep:#9c4e22; --spark:#F2B705;
  --sky:#E6F2F7; --paper:#FBFAF7; --ink:#1A1A1A; --muted:#52606b;
  --line:#d6e2ea; --card:#ffffff;
  --display:"Space Grotesk",Verdana,sans-serif;
  --body:"Mulish","Segoe UI",sans-serif;
  --wrap:1180px; --radius:14px;
  --shadow:0 1px 2px rgba(10,46,69,.06),0 10px 28px -12px rgba(10,46,69,.22);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--display);color:var(--harbor);line-height:1.12;
  letter-spacing:-.01em;margin:0 0 .5em;font-weight:700}
h1{font-size:clamp(2.1rem,5.2vw,3.5rem)}
h2{font-size:clamp(1.55rem,3.2vw,2.3rem)}
h3{font-size:clamp(1.15rem,2vw,1.4rem)}
p{margin:0 0 1rem;max-width:68ch}
a{color:var(--bay-deep);text-underline-offset:2px}
a:hover{color:var(--harbor)}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 1.25rem}

/* ---- Accessibility helpers ---- */
.skip-link{position:absolute;left:-999px;top:0;background:var(--spark);color:var(--harbor);
  padding:.7rem 1.1rem;font-weight:700;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--spark);outline-offset:2px;border-radius:4px}
.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}

/* ---- Pathway motif (CSS dots + rule, no SVG) ---- */
.pathway{display:flex;align-items:center;gap:.5rem;list-style:none;padding:0;margin:0}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--display);
  font-weight:500;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--copper-deep);margin:0 0 .75rem}
.eyebrow::before{content:"";width:30px;height:8px;flex:none;border-radius:6px;
  background:radial-gradient(circle 3px at 4px 50%,var(--copper) 99%,transparent),
             radial-gradient(circle 3px at 15px 50%,var(--bay) 99%,transparent),
             radial-gradient(circle 3px at 26px 50%,var(--harbor) 99%,transparent)}
.eyebrow.on-dark{color:var(--spark)}

/* ---- Proto banner / chrome ---- */
.proto-banner{background:var(--harbor);color:#dcebd9;color:#e9d9bf;font-size:.86rem;
  text-align:center;padding:.5rem 1rem;line-height:1.4;border-bottom:3px solid var(--copper)}
.proto-banner strong{color:#fff}
.proto-banner a{color:var(--spark);font-weight:600}

.util-bar{background:var(--harbor-2);color:#cfe0ea;font-size:.82rem}
.util-bar .wrap{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;align-items:center;
  justify-content:space-between;padding-top:.4rem;padding-bottom:.4rem}
.util-bar a{color:#fff;font-weight:600}
.util-bar .util-links{display:flex;flex-wrap:wrap;gap:.4rem 1rem;align-items:center}

/* Masthead carries the career-pathway node rail along its bottom edge so the
   chrome reads as THIS build's world on every page (squint-test differentiator). */
.masthead{background:#fff;position:relative;border-bottom:1px solid var(--line)}
.masthead::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:6px;
  pointer-events:none;
  background:
    radial-gradient(circle 2.5px at 5px 50%,var(--copper) 99%,transparent),
    radial-gradient(circle 2.5px at 17px 50%,var(--bay) 99%,transparent),
    radial-gradient(circle 2.5px at 29px 50%,var(--spark) 99%,transparent);
  background-size:48px 6px;background-repeat:repeat-x;background-position:left center;
  opacity:.9}
.masthead .wrap{display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding-top:.9rem;padding-bottom:.95rem}
.brand{display:flex;align-items:center;gap:.85rem;text-decoration:none;color:var(--harbor)}
.brand-mark{width:54px;height:54px;flex:none;border-radius:14px;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 30% 15%,#fff 0%,var(--sky) 100%);position:relative;
  border:1.5px solid #e2cdbb;box-shadow:0 6px 16px -8px rgba(194,98,45,.5)}
.brand-mark img{width:40px;height:40px;object-fit:contain}
.brand:hover .brand-mark{border-color:var(--copper);box-shadow:0 8px 20px -8px rgba(194,98,45,.7)}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text .kicker{font-family:var(--display);font-weight:500;font-size:.66rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--copper-deep)}
.brand-text .name{font-family:var(--display);font-weight:700;font-size:1.16rem;color:var(--harbor)}
.brand-text .sub{font-size:.74rem;color:var(--muted)}

.menu-btn{display:none;align-items:center;gap:.5rem;background:var(--harbor);color:#fff;
  border:0;border-radius:10px;padding:.6rem .9rem;font-family:var(--display);font-weight:500;
  font-size:.95rem;cursor:pointer;min-height:44px}

.primary-nav{background:var(--harbor);border-bottom:3px solid var(--copper)}
.primary-nav ul{max-width:var(--wrap);margin:0 auto;padding:0 .6rem;list-style:none;
  display:flex;flex-wrap:wrap;gap:.1rem}
.primary-nav a{display:block;color:#e7eef3;text-decoration:none;font-weight:600;
  font-size:.95rem;padding:.85rem .95rem;min-height:44px;border-bottom:3px solid transparent}
.primary-nav a:hover{background:rgba(255,255,255,.12);color:#fff}
.primary-nav a[aria-current="page"]{color:#fff;border-bottom-color:var(--spark);background:rgba(255,255,255,.12)}
.primary-nav a[aria-current="page"]::before{content:"";display:inline-block;width:7px;height:7px;
  border-radius:50%;background:var(--spark);margin-right:.5rem;vertical-align:middle}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);font-weight:500;
  font-size:1rem;text-decoration:none;border-radius:11px;padding:.8rem 1.3rem;min-height:48px;
  border:2px solid transparent;cursor:pointer;transition:transform .08s ease,box-shadow .15s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:#a8501c;color:#fff;border-color:#a8501c}
.btn-primary:hover{background:var(--copper-deep);border-color:var(--copper-deep);color:#fff}
.btn-bay{background:var(--bay);color:#fff;border-color:var(--bay)}
.btn-bay:hover{background:var(--bay-deep);color:#fff}
.btn-ghost{background:#fff;color:var(--harbor);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--bay);color:var(--bay-deep)}
.btn-ghost.on-dark{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost.on-dark:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}

/* ---- Duotone photo treatment ---- */
.duotone{position:relative;overflow:hidden;background:var(--harbor)}
.duotone img{width:100%;height:100%;object-fit:cover;mix-blend-mode:luminosity;opacity:.62}
.duotone::after{content:"";position:absolute;inset:0;mix-blend-mode:color;
  background:linear-gradient(135deg,var(--bay) 0%,var(--harbor) 85%)}
.duotone.copper::after{background:linear-gradient(135deg,var(--copper) 0%,var(--harbor) 90%)}

/* ---- Hero ---- */
.hero{position:relative;background:var(--harbor);color:#fff;overflow:hidden}
.hero .bg{position:absolute;inset:0}
.hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 60%;opacity:.92}
.hero::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 88% 108%,rgba(194,98,45,.5) 0%,rgba(194,98,45,0) 52%),
             linear-gradient(90deg,rgba(17,30,40,.95) 0%,rgba(17,30,40,.82) 38%,rgba(17,30,40,.42) 72%,rgba(17,30,40,.22) 100%),
             linear-gradient(0deg,rgba(17,30,40,.58) 0%,rgba(17,30,40,0) 40%)}
.hero .wrap{position:relative;z-index:2;padding-top:4.2rem;padding-bottom:4.2rem}
.hero h1{color:#fff;max-width:16ch}
.hero .lede{font-size:1.18rem;color:#d6e6f0;max-width:54ch}
.audience-rail{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.4rem 0 0;padding:0;list-style:none}
.audience-rail a{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.28);color:#fff;text-decoration:none;font-weight:600;
  font-size:.95rem;padding:.55rem 1rem;border-radius:999px;min-height:44px}
.audience-rail a:hover{background:var(--copper);border-color:var(--copper)}
.audience-rail a::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--spark)}

/* ---- Search box ---- */
.searchbox{display:flex;gap:.5rem;background:#fff;border-radius:14px;padding:.45rem;
  box-shadow:0 18px 40px -18px rgba(0,0,0,.55);max-width:640px}
.searchbox input{flex:1;border:0;background:transparent;font-family:var(--body);font-size:1.05rem;
  padding:.7rem .85rem;color:var(--ink);min-height:44px}
.searchbox input:focus{outline:none}
.searchbox .btn{flex:none}

/* ---- Generic sections + cards ---- */
.section{padding:3.2rem 0}
.section.tint{background-color:var(--sky);
  background-image:url("/bayarenacisd/assets/contour-texture.jpg");
  background-size:560px;background-position:center;background-blend-mode:multiply}
.section.harbor{position:relative;background:var(--harbor);color:#fff;overflow:hidden}
.section.harbor::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(rgba(18,30,40,.86),rgba(18,30,40,.93)),
             url("/bayarenacisd/assets/museum-band.png") center/cover no-repeat}
.section.harbor>.wrap{position:relative;z-index:1}
.section.harbor h2,.section.harbor h3{color:#fff}
.section.harbor p{color:#cfe0ea}
.section.harbor .stat b{color:var(--spark)}
.section.harbor .stat span,.section.harbor .meta{color:#cfe0ea}
.player-frame p,.player-frame .meta{color:#dbe7ee}
.lead-head{max-width:60ch;margin-bottom:1.6rem}
.grid{display:grid;gap:1.1rem}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.cols-4{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.3rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.5rem}
a.card{text-decoration:none;color:var(--ink);transition:transform .1s,border-color .15s,box-shadow .15s}
a.card:hover{transform:translateY(-3px);border-color:var(--bay);box-shadow:0 16px 34px -16px rgba(11,110,153,.4)}
.card h3{margin:0}
.card .meta{font-size:.85rem;color:var(--muted)}
.card .tag-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.2rem}

/* destination cards with photo portal */
.dest{position:relative;overflow:hidden;color:#fff;border-radius:var(--radius);
  min-height:230px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.3rem;text-decoration:none;border:1px solid var(--line)}
.dest .duotone{position:absolute;inset:0;z-index:0}
.dest>*{position:relative;z-index:1}
.dest h3{color:#fff;margin:0 0 .2rem}
.dest p{color:#e7f1f7;margin:0;font-size:.95rem}
.dest:hover .duotone img{opacity:.75}

/* chips / tags */
.chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;
  padding:.28rem .65rem;border-radius:999px;background:var(--sky);color:var(--bay-deep);
  border:1px solid var(--line);line-height:1.2}
.chip.type{background:#fdeede;color:var(--copper-deep);border-color:#f3d8bc}
.chip.grade{background:#eaf6fc;color:var(--bay-deep)}
.chip.sample{background:var(--harbor);color:var(--spark);border-color:var(--harbor);
  text-transform:uppercase;letter-spacing:.08em;font-size:.66rem}

/* cluster wall */
.cluster-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:.7rem}
.cluster{display:flex;flex-direction:column;gap:.3rem;background:#fff;border:1px solid var(--line);
  border-left:5px solid var(--bay);border-radius:10px;padding:.85rem .95rem;text-decoration:none;
  color:var(--ink);min-height:84px;transition:transform .1s,border-color .15s}
.cluster:hover{transform:translateY(-2px);border-left-color:var(--copper)}
.cluster .n{font-family:var(--display);font-size:.72rem;color:var(--muted)}
.cluster .t{font-weight:700;font-size:.95rem;line-height:1.2;color:var(--harbor)}
.cluster .c{font-size:.78rem;color:var(--muted)}

/* ---- Flagship faceted search layout ---- */
.lib{display:grid;grid-template-columns:270px 1fr;gap:1.6rem;align-items:start}
.facets{position:sticky;top:1rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.1rem;box-shadow:var(--shadow)}
.facets h2{font-size:1.05rem;margin:.2rem 0 .8rem}
.facet{border-top:1px solid var(--line);padding:.85rem 0}
.facet:first-of-type{border-top:0;padding-top:0}
.facet legend,.facet .lh{font-family:var(--display);font-weight:500;font-size:.78rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--copper-deep);margin-bottom:.5rem;padding:0}
.facet label{display:flex;align-items:center;gap:.55rem;font-size:.92rem;padding:.32rem 0;
  cursor:pointer;min-height:30px;color:var(--ink)}
.facet label .ct{margin-left:auto;font-size:.78rem;color:var(--muted)}
.facet input{width:18px;height:18px;accent-color:var(--bay);flex:none}
.facet label.zero{opacity:.45}
.lib-main .toolbar{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;
  justify-content:space-between;margin-bottom:1rem}
.result-count{font-family:var(--display);font-weight:500;color:var(--harbor)}
.result-count b{color:var(--copper-deep)}
.active-filters{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}
.active-filters button{background:var(--bay);color:#fff;border:0;border-radius:999px;
  padding:.3rem .7rem;font-size:.8rem;font-weight:600;cursor:pointer;display:inline-flex;
  align-items:center;gap:.4rem;min-height:30px}
.active-filters button::after{content:"\00d7";font-size:1rem;line-height:1}
.clear-all{background:none;border:0;color:var(--bay-deep);font-weight:700;cursor:pointer;
  text-decoration:underline;font-size:.85rem}
select,.field{font-family:var(--body);font-size:.95rem;border:1px solid var(--line);
  border-radius:9px;padding:.5rem .7rem;background:#fff;color:var(--ink);min-height:44px}

.res-list{display:grid;gap:.9rem}
.res{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.05rem 1.15rem;
  box-shadow:var(--shadow);border-left:5px solid var(--bay)}
.res[data-type="Video"],.res[data-type="Virtual tour"]{border-left-color:var(--copper)}
.res[data-type="Lesson plan"],.res[data-type="PD module"]{border-left-color:var(--harbor)}
.res h3{margin:0 0 .25rem;font-size:1.12rem}
.res h3 a{color:var(--harbor);text-decoration:none}
.res h3 a:hover{color:var(--bay-deep);text-decoration:underline}
.res .desc{margin:.2rem 0 .6rem;font-size:.95rem;color:#2a3640}
.res .tag-row{display:flex;flex-wrap:wrap;gap:.4rem}
.pathway-art{width:clamp(150px,30vw,230px);height:auto;margin:0 auto 1.4rem;display:block;
  filter:drop-shadow(0 10px 20px rgba(194,98,45,.22))}
.empty{position:relative;overflow:hidden;background:#fff;border:2px dashed var(--line);border-radius:14px;
  padding:2.4rem 1.5rem;text-align:center;color:var(--muted)}
.empty::before{content:"";position:absolute;right:-30px;bottom:-40px;width:200px;height:200px;
  background:url("/bayarenacisd/assets/pathway-motif.png") right bottom/contain no-repeat;
  opacity:.1;pointer-events:none}
.empty>*{position:relative}
.empty .dots{display:inline-flex;gap:.5rem;margin-bottom:.8rem}
.empty .dots i{width:12px;height:12px;border-radius:50%;display:block}
.empty .dots i:nth-child(1){background:var(--copper)}
.empty .dots i:nth-child(2){background:var(--bay)}
.empty .dots i:nth-child(3){background:var(--harbor)}

/* ---- Finder (audience picker) ---- */
.finder{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.6rem;
  box-shadow:var(--shadow);max-width:920px}
.finder .step{margin-bottom:1.1rem}
.finder .opts{display:flex;flex-wrap:wrap;gap:.6rem}
.finder .opt{border:2px solid var(--line);background:#fff;border-radius:12px;padding:.7rem 1.05rem;
  font-family:var(--display);font-weight:500;font-size:.98rem;cursor:pointer;color:var(--harbor);min-height:48px}
.finder .opt[aria-pressed="true"]{background:var(--bay);border-color:var(--bay);color:#fff}
.finder .opt:hover{border-color:var(--bay)}
.finder-results{margin-top:1.2rem}

/* ---- video gallery ---- */
.video-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow);display:flex;flex-direction:column}
.video-card .thumb{position:relative;aspect-ratio:16/9}
.video-card .thumb .play{position:absolute;inset:0;display:grid;place-items:center}
.video-card .thumb .play span{width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.92);
  display:grid;place-items:center;box-shadow:0 8px 20px -6px rgba(0,0,0,.5)}
.video-card .thumb .play span::after{content:"";border-left:18px solid var(--copper);
  border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:4px}
.video-card .body{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.4rem}
.video-card h3{margin:0;font-size:1.05rem}
.player-frame{aspect-ratio:16/9;background:var(--harbor);border-radius:14px;display:grid;
  place-items:center;color:#cfe0ea;text-align:center;padding:1.5rem;border:1px solid var(--line)}

/* ---- partner showcase ---- */
.sector{margin-bottom:2.2rem}
.sector h3{display:flex;align-items:center;gap:.6rem}
.sector h3::before{content:"";width:14px;height:14px;border-radius:4px;background:var(--copper)}
.partner{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.1rem;
  box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.4rem}
/* Placeholder partner slots read as intentional copper "pathway nodes" awaiting a
   real partner — not default avatars (home page carries the real sector photos). */
.partner .logo{width:52px;height:52px;border-radius:50%;
  background:radial-gradient(circle at 35% 28%,#fff 0%,var(--sky) 100%);
  display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.05rem;
  color:var(--copper-deep);border:2px solid var(--copper);
  box-shadow:0 6px 16px -8px rgba(194,98,45,.5),0 0 0 4px #fff}
/* Committed DNA treatment: copper-ring "portal" photo crop for partner/sector cards
   (replaces placeholder monograms). Duotone keeps mixed open-license sources one-world. */
.partner-portal{width:100%;aspect-ratio:5/3;border-radius:14px;overflow:hidden;position:relative;
  border:3px solid var(--copper);box-shadow:0 12px 26px -14px rgba(194,98,45,.6),inset 0 0 0 1.5px rgba(255,255,255,.4);
  background:var(--harbor)}
.partner-portal img{width:100%;height:100%;object-fit:cover;mix-blend-mode:luminosity;opacity:.72}
.partner-portal::after{content:"";position:absolute;inset:0;mix-blend-mode:color;
  background:linear-gradient(135deg,var(--copper) 0%,var(--harbor) 92%)}
.partner-portal .badge{position:absolute;left:.55rem;bottom:.55rem;z-index:2;
  font-family:var(--display);font-weight:500;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(33,51,63,.82);color:var(--spark);padding:.2rem .5rem;border-radius:999px}
.partner.has-portal{gap:.7rem}

/* ---- Pathway timeline (the "newest" strip as a connected path, not a card grid) ---- */
.timeline{position:relative;display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));
  gap:1.1rem 1.4rem;margin-top:1.6rem}
.timeline::before{content:"";position:absolute;left:0;right:0;top:13px;height:2px;
  background:repeating-linear-gradient(90deg,var(--line) 0 10px,transparent 10px 18px)}
.t-node{position:relative;display:flex;flex-direction:column;gap:.5rem;text-decoration:none;
  color:var(--ink);padding-top:2.1rem}
.t-node::before{content:"";position:absolute;top:6px;left:2px;width:16px;height:16px;border-radius:50%;
  background:var(--bay);border:3px solid var(--paper);box-shadow:0 0 0 1px var(--bay)}
.t-node:nth-child(3n+1)::before{background:var(--copper);box-shadow:0 0 0 1px var(--copper)}
.t-node:nth-child(3n+3)::before{background:var(--spark);box-shadow:0 0 0 1px var(--spark)}
.t-node .when{font-family:var(--display);font-weight:500;font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted)}
.t-node h3{margin:.1rem 0 0;font-size:1.04rem;line-height:1.2;transition:color .12s}
.t-node:hover h3{color:var(--bay-deep)}
.t-node .meta{font-size:.82rem;color:var(--muted);margin:0}
@media (max-width:560px){.timeline::before{display:none}.t-node{padding-top:0;padding-left:1.6rem}
  .t-node::before{top:3px;left:0}}

/* shared eyebrow-style label inside the finder steps (was repeated inline) */
.step-label{font-family:var(--display);font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  font-size:.78rem;color:var(--copper-deep);margin:0 0 .5rem}

/* ---- Ask the Hub: answer-first front desk over the same corpus ---- */
.ask{background:linear-gradient(135deg,#fff 0%,var(--sky) 100%);border:1px solid var(--line);
  border-radius:18px;padding:1.5rem 1.6rem;box-shadow:var(--shadow);max-width:920px}
.ask-form{display:flex;gap:.5rem;flex-wrap:wrap}
.ask-form input{flex:1 1 320px;border:2px solid var(--line);border-radius:12px;background:#fff;
  font-family:var(--body);font-size:1.05rem;padding:.75rem .9rem;color:var(--ink);min-height:50px}
.ask-form input:focus{outline:none;border-color:var(--bay)}
.ask-form .btn{flex:none}
.ask-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.9rem}
.ask-chips button{background:#fff;border:1px solid var(--line);border-radius:999px;cursor:pointer;
  font-family:var(--body);font-size:.86rem;color:var(--bay-deep);font-weight:600;padding:.4rem .8rem;
  min-height:34px;display:inline-flex;align-items:center;gap:.4rem}
.ask-chips button::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--copper);flex:none}
.ask-chips button:hover{border-color:var(--bay);background:var(--sky)}
.ask-answer{margin-top:1.3rem;border-top:1px solid var(--line);padding-top:1.2rem}
.ask-answer[hidden]{display:none}
.ask-answer .lead{font-size:1.08rem;color:var(--harbor);margin:0 0 1rem}
.ask-answer .lead b{color:var(--copper-deep)}
.ask-answer .route{display:inline-flex;align-items:center;gap:.5rem;background:var(--sky);
  border:1px solid var(--line);border-left:4px solid var(--copper);border-radius:10px;
  padding:.6rem .85rem;text-decoration:none;color:var(--harbor);font-weight:600;font-size:.92rem;margin-bottom:1rem}
.ask-answer .route:hover{border-color:var(--bay);color:var(--bay-deep)}
.ask-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.8rem}
.ask-actions{margin-top:1.1rem;display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}
.ask-note{font-size:.82rem;color:var(--muted);margin:.9rem 0 0}

/* ---- callout / steward ---- */
.callout{background:linear-gradient(135deg,var(--sky),#fff);border:1px solid var(--line);
  border-left:6px solid var(--copper);border-radius:14px;padding:1.4rem 1.5rem}
.stat-row{display:flex;flex-wrap:wrap;gap:1.6rem;margin:1rem 0}
.stat{display:flex;flex-direction:column}
.stat b{font-family:var(--display);font-size:2rem;color:var(--bay-deep);line-height:1}
.stat span{font-size:.85rem;color:var(--muted)}

/* prose pages */
.prose{max-width:74ch}
.prose h2{margin-top:2rem}
.prose ul{padding-left:1.2rem}
.prose li{margin:.35rem 0}
.note{background:var(--sky);border-radius:10px;padding:1rem 1.2rem;font-size:.92rem;color:var(--harbor)}

/* a11y compare table */
.cmp{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.95rem}
.cmp caption{text-align:left;color:var(--muted);font-size:.85rem;margin-bottom:.5rem}
.cmp th,.cmp td{text-align:left;padding:.7rem .8rem;border-bottom:1px solid var(--line);vertical-align:top}
.cmp th{font-family:var(--display);font-weight:500;color:var(--harbor);background:var(--sky)}
.cmp .yes{color:#0f6b3f;font-weight:700}
.cmp .no{color:var(--copper-deep);font-weight:700}

/* ---- footer ---- */
.site-footer{background:var(--harbor);color:#cfe0ea;margin-top:0;border-top:4px solid var(--copper)}
.site-footer .wrap{padding-top:2.6rem;padding-bottom:1.6rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:1.6rem}
.site-footer h4{color:#fff;font-size:1rem;margin:0 0 .6rem}
.site-footer a{color:#eaf6fc}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.3rem 0}
.steward{font-size:.84rem;color:#9fb8c6;border-top:1px solid rgba(255,255,255,.14);
  margin-top:1.6rem;padding-top:1.1rem;display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;justify-content:space-between}
.steward .navy-credit{display:inline-flex;align-items:center;gap:.5rem}
.steward .navy-credit b{width:11px;height:11px;border-radius:50%;background:var(--harbor);
  border:2px solid #5b7c8e}

/* ---- responsive ---- */
@media (max-width:900px){
  .lib{grid-template-columns:1fr}
  .facets{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .menu-btn{display:inline-flex}
  .primary-nav ul{display:none;flex-direction:column;padding:.4rem}
  .primary-nav.open ul{display:flex}
  .primary-nav a{border-bottom:1px solid rgba(255,255,255,.16)}
  .footer-grid{grid-template-columns:1fr}
  .util-bar .wrap{justify-content:flex-start}
  body{font-size:16px}
  .cmp{display:block;overflow-x:auto;max-width:100%}
}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto !important;transition:none !important}}
