/* ============================================================
   FAIRFIELD COUNTY VETERANS SERVICE COMMISSION — SHARED STYLES
   Link this file on every page:  <link rel="stylesheet" href="fcvsc-styles.css">
   Edit here once → every page updates.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@400;500;600;700;800&display=swap');

:root{
  --navy:#16284f;
  --navy-deep:#0f1d3a;
  --navy-soft:#24386a;
  --brick:#8a1a1a;
  --brick-deep:#6d1313;
  --gold:#c39b3e;
  --ink:#1f2430;
  --muted:#4a5366;
  --line:#dce1ea;
  --tint:#eef1f6;
  --tint-2:#f6f8fb;
  --paper:#ffffff;
  --body:"Raleway",-apple-system,Segoe UI,Roboto,sans-serif;
  --display:"Raleway",-apple-system,Segoe UI,Roboto,sans-serif;
  --shadow:0 12px 30px rgba(15,29,58,.12);
  --shadow-lg:0 20px 50px rgba(15,29,58,.20);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--display);font-weight:800;line-height:1.12;color:var(--navy);margin:0}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}

.skip{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:300;border-radius:0 0 6px 0}
.skip:focus{left:0}

/* Visually hidden — present for screen readers (JAWS/NVDA), invisible on screen */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.wrap{max-width:1180px;margin:0 auto;padding:0 22px}

/* ---------- Branch strip ---------- */
.branches{background:var(--tint-2);border-bottom:1px solid var(--line)}
.branches .wrap{display:flex;align-items:center;justify-content:center;gap:26px;flex-wrap:wrap;padding-top:12px;padding-bottom:12px}
.branches .lbl{font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-right:4px}
.branches a{display:inline-flex;align-items:center;filter:grayscale(.15);transition:transform .2s ease,filter .2s ease}
.branches a:hover{transform:translateY(-2px);filter:none}
.branches img{height:46px;width:auto}

/* ---------- Header / nav ---------- */
header.site{position:sticky;top:0;z-index:100;background:#fff;border-bottom:3px solid var(--brick);box-shadow:0 2px 14px rgba(15,29,58,.06)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand img.county-logo{height:54px;width:auto;flex:0 0 auto}
.brand .name{font-family:var(--display);color:var(--navy);font-weight:700;font-size:1.18rem;line-height:1.05}
.brand .name small{display:block;font-family:var(--body);font-weight:600;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brick)}
nav.primary ul{display:flex;gap:6px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
nav.primary a{font-weight:600;font-size:.95rem;color:var(--navy-deep);padding:8px 13px;border-radius:6px;transition:background .15s ease,color .15s ease}
nav.primary a:hover{background:var(--tint);text-decoration:none}
nav.primary a.cta{background:var(--brick);color:#fff}
nav.primary a.cta:hover{background:var(--brick-deep)}
nav.primary a[aria-current="page"]{background:var(--navy);color:#fff}
.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:48px;height:44px;background:#fff;border:2px solid var(--navy);border-radius:8px;cursor:pointer;padding:0}
.nav-toggle .bar{display:block;width:24px;height:3px;background:var(--navy);border-radius:2px;transition:transform .2s ease,opacity .2s ease}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
/* Dropdowns */
.sub-toggle{font-family:var(--body);font-weight:600;font-size:.95rem;color:var(--navy-deep);background:none;border:0;cursor:pointer;padding:8px 13px;border-radius:6px;display:inline-flex;align-items:center;gap:7px;transition:background .15s ease}
.sub-toggle:hover{background:var(--tint)}
.sub-toggle[aria-current="page"]{background:var(--navy);color:#fff}
.caret{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid currentColor;transition:transform .2s ease}
.sub-toggle[aria-expanded="true"] .caret{transform:rotate(180deg)}
.has-sub{position:relative}
.submenu{list-style:none;margin:0;padding:6px;position:absolute;top:100%;left:0;min-width:248px;background:#fff;border:1px solid var(--line);border-top:3px solid var(--brick);border-radius:0 0 10px 10px;box-shadow:var(--shadow-lg);z-index:120;display:none}
.submenu.open{display:block}
.submenu a{display:block;padding:9px 12px;border-radius:6px;color:var(--navy-deep);font-weight:500;font-size:.95rem;white-space:nowrap}
.submenu a:hover{background:var(--tint);text-decoration:none}

/* ---------- Home hero (clean intro image, no overlay) ---------- */
.hero-img{width:100%;display:block;border-bottom:5px solid var(--brick)}
.welcome-band{background:var(--tint-2);border-bottom:1px solid var(--line)}
.welcome-band .wrap{padding:24px 22px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px}
.free-badge{display:inline-flex;align-items:center;gap:10px;color:var(--navy-deep);font-weight:600;font-size:1.05rem}
.free-badge svg{width:24px;height:24px;fill:var(--brick);flex:0 0 auto}
.free-badge strong{color:var(--brick)}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Buttons ---------- */
.btn{font-family:var(--body);font-weight:700;font-size:1.02rem;padding:14px 28px;border-radius:8px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:2px solid transparent;text-decoration:none;transition:transform .12s ease,background .15s ease,box-shadow .2s ease}
.prose a.btn{color:#fff;text-decoration:none;font-weight:700}
.prose a.btn:hover{text-decoration:none}
.btn svg{width:20px;height:20px;fill:currentColor}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-navy{background:var(--navy);color:#fff;box-shadow:0 8px 22px rgba(22,40,79,.32)}
.btn-navy:hover{background:var(--navy-deep)}
.btn-primary{background:var(--brick);color:#fff;box-shadow:0 8px 22px rgba(138,26,26,.32)}
.btn-primary:hover{background:#b32424;color:#fff}

/* ---------- Layout: main + sidebar ---------- */
.layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:40px;padding-top:48px;padding-bottom:64px}

/* ---------- Mission ---------- */
.mission{border-left:5px solid var(--brick);padding:4px 0 4px 22px;margin-bottom:42px}
.mission h2{font-size:1.7rem;margin-bottom:10px}
.mission p{color:var(--muted);margin:0;font-size:1.05rem;max-width:62ch}

/* ---------- Section headings ---------- */
.sec-head{display:flex;align-items:baseline;gap:14px;margin:0 0 6px}
.sec-head .kicker,.kicker{font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.74rem;color:var(--brick)}
.sec-sub{color:var(--muted);margin:0 0 22px;font-size:1.02rem}
.rule{height:4px;width:64px;background:linear-gradient(90deg,var(--navy),var(--brick));border-radius:3px;margin:0 0 26px}

/* ---------- Tile grid ---------- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tile{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:26px 18px 20px;text-align:center;text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;align-items:center;gap:14px;
  transition:transform .18s ease,box-shadow .22s ease,border-color .18s ease;
  overflow:hidden;opacity:0;animation:rise .5s ease forwards;transform:translateY(14px);
}
.tile::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--navy),var(--navy-soft));opacity:0;transition:opacity .2s ease}
.tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent;text-decoration:none}
.tile:hover::before{opacity:1}
.medallion{width:84px;height:84px;border-radius:50%;background:radial-gradient(circle at 32% 28%,var(--navy-soft),var(--navy));display:grid;place-items:center;border:3px solid var(--navy);box-shadow:inset 0 0 0 3px rgba(255,255,255,.12);transition:transform .2s ease}
.tile:hover .medallion{transform:scale(1.06) rotate(-2deg)}
.medallion svg{width:40px;height:40px;stroke:#fff;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.tile .t-photo{width:130px;height:130px;border-radius:50%;overflow:hidden;border:4px solid var(--navy);box-shadow:inset 0 0 0 3px rgba(255,255,255,.55),0 6px 16px rgba(15,29,58,.18);transition:transform .2s ease}
.tile:hover .t-photo{transform:scale(1.04)}
.tile .t-photo img{width:100%;height:100%;object-fit:cover;display:block}
.tile .t-label{font-family:var(--display);font-weight:700;font-size:1.06rem;color:var(--navy);line-height:1.15}
.tile .t-bar{margin-top:auto;align-self:stretch;min-height:58px;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--navy);color:#fff;font-weight:700;font-size:1rem;line-height:1.2;letter-spacing:.01em;padding:8px 10px;border-radius:8px;transition:background .18s ease}
.tile:hover .t-bar{background:var(--brick)}
.tile:hover .t-bar{background:var(--brick-deep)}

@keyframes rise{to{opacity:1;transform:translateY(0)}}
.tiles .tile:nth-child(1){animation-delay:.04s}
.tiles .tile:nth-child(2){animation-delay:.09s}
.tiles .tile:nth-child(3){animation-delay:.14s}
.tiles .tile:nth-child(4){animation-delay:.19s}
.tiles .tile:nth-child(5){animation-delay:.24s}
.tiles .tile:nth-child(6){animation-delay:.29s}
.tiles .tile:nth-child(7){animation-delay:.34s}
.tiles .tile:nth-child(8){animation-delay:.39s}
.tiles .tile:nth-child(9){animation-delay:.44s}
.tiles .tile:nth-child(n+10){animation-delay:.49s}
@media (prefers-reduced-motion:reduce){.tile{animation:none;opacity:1;transform:none}.tile:hover{transform:none}}

.families{margin-top:54px;background:var(--tint-2);border:1px solid var(--line);border-radius:18px;padding:34px 30px 38px}

/* ---------- Inner-page banner (benefit / content pages) ---------- */
.page-banner{background:var(--navy);color:#fff;border-bottom:5px solid var(--brick)}
.page-banner .wrap{padding:42px 22px 38px}
.page-banner .kicker{color:var(--gold)}
.page-banner h1{color:#fff;font-size:clamp(1.9rem,4vw,2.8rem);margin:8px 0 10px;max-width:22ch}
.page-banner p{color:#dbe2f0;max-width:62ch;margin:0;font-size:1.1rem}
.breadcrumb{font-size:.86rem;color:#cdd6e6;margin:0 0 6px}
.breadcrumb a{color:#fff;text-decoration:underline}
.breadcrumb a:hover{color:#fff;text-decoration:none}

/* ---------- Article / prose content ---------- */
.prose h2{font-size:1.55rem;margin:34px 0 12px}
.prose h3{font-size:1.18rem;color:var(--brick);margin:24px 0 8px}
.prose h2:first-child,.prose h3:first-child{margin-top:0}
.prose p{margin:0 0 14px;color:var(--ink)}
.prose ul{margin:0 0 18px;padding-left:0;list-style:none}
.prose ul li{position:relative;padding:5px 0 5px 30px;border-bottom:1px dotted var(--line)}
.prose ul li:last-child{border-bottom:0}
.prose ul li::before{content:"";position:absolute;left:6px;top:13px;width:9px;height:9px;background:var(--brick);border-radius:2px;transform:rotate(45deg)}
.prose a{color:var(--brick);font-weight:600;text-decoration:underline}
.lead{font-size:1.12rem;color:var(--muted);margin:0 0 22px}

/* ---------- Organization cards ---------- */
.org-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:8px 0}
.org-card{background:#fff;border:1px solid var(--line);border-left:5px solid var(--navy);border-radius:10px;padding:16px 18px}
.org-card h2{font-size:1.12rem;margin:0 0 8px;color:var(--navy)}
.org-addr{margin:0 0 8px;color:var(--ink);font-size:.98rem}
.org-meet{margin:0;color:var(--brick-deep);font-weight:600;font-size:.95rem;padding-top:8px;border-top:1px dotted var(--line)}
@media (max-width:680px){.org-grid{grid-template-columns:1fr}}

/* ---------- Comparison tables ---------- */
.table-scroll{overflow-x:auto;margin:18px 0}
.prose table{width:100%;border-collapse:collapse;font-size:.97rem;min-width:420px}
.prose caption{text-align:left;font-family:var(--display);font-weight:700;color:var(--navy);font-size:1.18rem;margin-bottom:8px}
.prose th,.prose td{text-align:left;padding:11px 13px;border-bottom:1px solid var(--line);vertical-align:top}
.prose thead th{background:var(--navy);color:#fff;font-weight:700}
.prose tbody tr:nth-child(even){background:var(--tint-2)}
.prose th[scope="row"]{color:var(--brick);white-space:nowrap}

/* ---------- Callout / info card ---------- */
.callout{background:var(--tint);border:1px solid var(--line);border-left:6px solid var(--navy);border-radius:10px;padding:18px 22px;margin:22px 0}
.callout.brick{border-left-color:var(--brick)}
.callout h3,.callout .box-title{margin:0 0 8px;color:var(--navy);font-family:var(--display);font-weight:800;font-size:1.18rem;line-height:1.12}

/* ---------- "Documents needed" check list ---------- */
.doclist{display:grid;grid-template-columns:1fr 1fr;gap:6px 26px;margin:14px 0 8px;padding:0;list-style:none}
.doclist li{display:flex;gap:10px;align-items:flex-start;padding:6px 0;border-bottom:1px dotted var(--line)}
.doclist li::before{content:"";flex:0 0 auto;width:16px;height:16px;margin-top:4px;border:2px solid var(--navy);border-radius:3px}
@media (max-width:680px){.doclist{grid-template-columns:1fr}}

/* ---------- FAQ accordion ---------- */
.faq details{border:1px solid var(--line);border-radius:10px;margin:0 0 10px;background:#fff;overflow:hidden}
.faq summary{cursor:pointer;font-family:var(--display);font-weight:600;font-size:1.08rem;color:var(--navy);padding:14px 46px 14px 18px;position:relative;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--brick);font-weight:400}
.faq details[open] summary{background:var(--tint);border-bottom:1px solid var(--line)}
.faq details[open] summary::after{content:"–"}
.faq .answer{padding:14px 18px}
.faq .answer p{margin:0 0 10px}
.faq .answer p:last-child{margin-bottom:0}

/* ---------- CTA strip ---------- */
.cta-strip{background:var(--navy);color:#fff;border-radius:14px;padding:28px 30px;margin:34px 0 0;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px}
.cta-strip h3,.cta-strip .box-title{color:#fff;font-size:1.4rem;font-family:var(--display);font-weight:800;line-height:1.12;margin:0}
.cta-strip p{margin:6px 0 0;color:#dbe2f0}

/* ---------- Sidebar ---------- */
aside.contact{align-self:start;position:sticky;top:96px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;margin-bottom:18px}
.card h3{font-size:1.06rem;color:#fff;background:var(--navy);padding:13px 18px;letter-spacing:.04em}
.card .body{padding:16px 18px}
.crisis{background:var(--brick);border:0}
.crisis h3{background:var(--brick-deep)}
.crisis .body{color:#fff}
.crisis .body strong{font-size:1.32rem;font-family:var(--display);display:block;letter-spacing:.02em}
.crisis a{color:#fff;text-decoration:underline}
.addr{font-style:normal;line-height:1.5}
.addr .org{font-weight:700;color:var(--navy)}
.contact-list{list-style:none;margin:12px 0 0;padding:0;font-size:.96rem}
.contact-list li{display:flex;gap:8px;padding:5px 0;border-top:1px dashed var(--line)}
.contact-list li:first-child{border-top:0}
.contact-list .k{font-weight:700;color:var(--brick);flex:0 0 64px}
.meta{font-size:.9rem;color:var(--muted);margin:12px 0 0;padding-top:12px;border-top:1px solid var(--line)}
.meta strong{color:var(--navy)}
.reslist{list-style:none;margin:0;padding:0}
.reslist li{padding:7px 0;border-top:1px solid var(--line);font-weight:600}
.reslist li:first-child{border-top:0}
.reslist a{display:flex;align-items:center;gap:8px}
.reslist svg{width:16px;height:16px;fill:var(--brick);flex:0 0 auto}
.fb-link{display:flex;align-items:center;gap:9px;font-weight:600;font-size:.82rem;color:var(--navy);word-break:break-word}
.fb-link svg{width:22px;height:22px;fill:#1877f2;flex:0 0 auto}
.fb-link:hover{color:var(--brick)}

/* ---------- Footer (county blue band) ---------- */
footer.county{background:#032949;color:#cdd6e6;font-size:.92rem}
footer.county .cols{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;padding-top:42px;padding-bottom:32px}
footer.county h4{font-family:var(--display);color:#fff;font-size:1rem;margin:0 0 12px;letter-spacing:.04em}
footer.county ul{list-style:none;margin:0;padding:0}
footer.county li{margin:0 0 8px}
footer.county a{color:#cdd6e6}
footer.county a:hover{color:#fff}
.legal{border-top:1px solid rgba(255,255,255,.18);padding:22px 0;font-size:.84rem;color:#fff;line-height:1.6;text-align:center}
.legal .nowrap-line{display:inline-block;white-space:nowrap}
.legal .nowrap-line + .nowrap-line{margin-left:.4em}
@media (max-width:560px){.legal .nowrap-line{display:block}.legal .nowrap-line + .nowrap-line{margin-left:0}}
.legal strong{color:#fff}
.legal a{color:#fff;text-decoration:underline}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .layout{grid-template-columns:1fr}
  aside.contact{position:static}
  .nav-toggle{display:flex}
  nav.primary{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:3px solid var(--brick);box-shadow:0 14px 26px rgba(15,29,58,.16);display:none;padding:6px 0}
  nav.primary.open{display:block}
  nav.primary ul{flex-direction:column;gap:0;padding:0 14px}
  nav.primary li{width:100%}
  nav.primary a{display:block;padding:14px 10px;border-bottom:1px solid var(--line);border-radius:0;font-size:1.05rem}
  nav.primary li:last-child a{border-bottom:0}
  nav.primary a.cta{margin:8px 0;border-radius:6px;text-align:center}
  .sub-toggle{display:flex;width:100%;justify-content:space-between;padding:14px 10px;border-bottom:1px solid var(--line);border-radius:0;font-size:1.05rem}
  .submenu{position:static;display:none;box-shadow:none;border:0;border-top:0;border-radius:0;padding:0 0 6px 14px;min-width:0}
  .submenu.open{display:block}
  .submenu a{white-space:normal;border-bottom:1px solid var(--line)}
  footer.county .cols{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  body{font-size:16px}
  .tiles{grid-template-columns:repeat(2,1fr)}
  .branches .lbl{flex-basis:100%;text-align:center;margin:0 0 2px}
  .branches .wrap{gap:14px 18px}
  .branches img{height:34px}
  .welcome-band .wrap{flex-direction:column;justify-content:center;text-align:center;gap:16px}
  .free-badge{justify-content:center;flex-wrap:wrap;font-size:1rem}
  .hero-ctas{justify-content:center;width:100%}
  .hero-ctas .btn{flex:1 1 auto;justify-content:center}
}
@media (max-width:430px){
  .tiles{grid-template-columns:1fr}
}
