/* Honor site for the John Gibson, Dan James, William Sapp, and Frankie Smiley VA Clinic */
:root{
  --navy:#0a1f3c;
  --navy-2:#12294b;
  --gold:#c9a227;
  --gold-soft:#e6c75a;
  --paper:#f7f5f0;
  --paper-2:#efebe1;
  --ink:#1c2330;
  --muted:#5b6472;
  --red:#7d2b2b;
  --line:#d9d3c4;
  --shadow:0 6px 24px rgba(10,31,60,.10);
  --serif:Georgia,"Times New Roman",serif;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --wrap:1080px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.65;font-size:18px;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,.serif{font-family:var(--serif)}
a{color:var(--navy)}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}

.skip{position:absolute;left:-999px;top:0;background:var(--gold);color:var(--navy);padding:10px 16px;z-index:100}
.skip:focus{left:8px;top:8px}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(10,31,60,.97);color:#fff;backdrop-filter:saturate(140%) blur(4px)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:62px}
.nav .brand{font-family:var(--serif);font-weight:700;letter-spacing:.3px;color:#fff;text-decoration:none;font-size:1.05rem}
.nav .brand .star{color:var(--gold)}
.nav ul{display:flex;gap:6px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.nav a.link{color:#dfe6f1;text-decoration:none;padding:8px 12px;border-radius:6px;font-size:.95rem}
.nav a.link:hover,.nav a.link:focus{background:rgba(255,255,255,.10);color:#fff}
.nav a.cta{background:var(--gold);color:var(--navy);font-weight:700}
.nav a.cta:hover{background:var(--gold-soft)}

/* ---- Hero ---- */
.hero{
  background:linear-gradient(180deg,var(--navy),var(--navy-2));
  color:#fff;text-align:center;padding:64px 0 56px;position:relative;overflow:hidden;
}
.hero:before{
  content:"";position:absolute;inset:0;opacity:.10;pointer-events:none;
  background:radial-gradient(circle at 20% 18%,#fff 1.4px,transparent 1.6px) 0 0/46px 46px;
}
.hero .eyebrow{color:var(--gold-soft);letter-spacing:.22em;text-transform:uppercase;font-size:.78rem;font-weight:700;margin:0 0 14px}
.hero h1{font-size:clamp(2rem,5vw,3.3rem);line-height:1.1;margin:.1em 0 .35em;color:#fff}
.hero .names{color:var(--gold);display:block;margin-top:.25em;font-size:clamp(1.2rem,3.4vw,1.9rem)}
.hero p.lede{max-width:760px;margin:0 auto 8px;color:#e7ecf5;font-size:1.12rem}
.hero .tagline{margin-top:22px;font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-size:1.05rem}
.hero .rule{width:78px;height:3px;background:var(--gold);margin:26px auto 0;border-radius:2px}

/* ---- Sections ---- */
section{padding:62px 0}
section.alt{background:var(--paper-2)}
.section-head{text-align:center;max-width:720px;margin:0 auto 40px}
.section-head .kicker{color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.76rem;margin:0 0 8px}
.section-head h2{font-size:clamp(1.7rem,3.6vw,2.4rem);margin:0 0 .35em;color:var(--navy)}
.section-head p{color:var(--muted);margin:0;font-size:1.05rem}

/* ---- Hero (memorial) cards ---- */
.heroes{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:720px){.heroes{grid-template-columns:1fr}}
.hcard{
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow);display:flex;flex-direction:column;
}
.hcard .top{display:flex;gap:16px;align-items:center;padding:22px 22px 8px}
.medallion{
  flex:0 0 auto;width:76px;height:76px;border-radius:50%;
  background:radial-gradient(circle at 50% 35%,var(--navy-2),var(--navy));
  color:var(--gold);display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1.5rem;
  border:3px solid var(--gold);box-shadow:0 2px 8px rgba(0,0,0,.18)
}
/* To add a real photo: put it in assets/ and replace .medallion markup with
   <img class="portrait" src="assets/gibson.jpg" alt="PFC John Gibson"> */
.portrait{width:76px;height:76px;border-radius:50%;object-fit:cover;border:3px solid var(--gold)}
.hcard h3{margin:0;font-size:1.4rem;color:var(--navy)}
.hcard .rank{color:var(--red);font-weight:700;font-size:.92rem;margin-top:2px}
.hcard .body{padding:6px 22px 22px}
.hcard dl{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;margin:12px 0 0;font-size:.96rem}
.hcard dt{color:var(--muted);font-weight:600}
.hcard dd{margin:0}
.hcard .story{margin:16px 0 0;font-size:.97rem;color:#39414f}
.awards{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0 0;padding:0;list-style:none}
.awards li{background:var(--paper-2);border:1px solid var(--line);color:#46505f;border-radius:999px;padding:3px 10px;font-size:.78rem;font-weight:600}
.awards li.valor{background:#f3e7c8;border-color:var(--gold);color:#6b541a}

/* ---- Renaming / prose ---- */
.prose{max-width:760px;margin:0 auto}
.prose p{margin:0 0 1em}
.clinic-name{
  text-align:center;margin:34px auto 0;max-width:760px;background:#fff;border:1px solid var(--line);
  border-left:5px solid var(--gold);border-radius:10px;padding:20px 24px;box-shadow:var(--shadow)
}
.clinic-name .label{color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:700}
.clinic-name .name{font-family:var(--serif);font-size:1.3rem;color:var(--navy);margin-top:6px}
.clinic-name .law{color:var(--muted);font-size:.9rem;margin-top:6px}

/* ---- Timeline ---- */
.timeline{max-width:820px;margin:0 auto;position:relative;padding-left:34px}
.timeline:before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:3px;background:var(--line)}
.tl-item{position:relative;padding:0 0 26px 8px}
.tl-item:before{content:"";position:absolute;left:-30px;top:4px;width:15px;height:15px;border-radius:50%;background:var(--gold);border:3px solid var(--paper)}
.tl-item.law:before{background:var(--navy)}
.tl-item.issue:before{background:var(--red)}
.tl-item .date{font-weight:700;color:var(--navy);font-size:.95rem}
.tl-item .event{margin:2px 0 0;color:#39414f}
section.alt .tl-item:before{border-color:var(--paper-2)}
.legend{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin:0 0 30px;font-size:.82rem;color:var(--muted)}
.legend span{display:inline-flex;align-items:center;gap:7px}
.legend i{width:12px;height:12px;border-radius:50%;display:inline-block}

/* ---- Issue ---- */
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:8px 0 30px}
@media (max-width:720px){.facts{grid-template-columns:1fr}}
.fact{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px;text-align:center;box-shadow:var(--shadow)}
.fact .num{font-family:var(--serif);font-size:1.9rem;color:var(--red);font-weight:700;line-height:1}
.fact .cap{color:var(--muted);font-size:.92rem;margin-top:8px}
.note{max-width:760px;margin:0 auto;color:var(--muted);font-size:.9rem;text-align:center}

/* ---- Take action ---- */
.actions{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:820px){.actions{grid-template-columns:1fr}}
.action{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;box-shadow:var(--shadow)}
.action h3{margin:0 0 .4em;color:var(--navy);font-size:1.2rem}
.action p{color:#46505f;font-size:.96rem;margin:0 0 14px}
.btn{display:inline-block;background:var(--navy);color:#fff;text-decoration:none;padding:10px 16px;border-radius:8px;font-weight:600;font-size:.93rem;border:0;cursor:pointer}
.btn:hover{background:var(--navy-2)}
.btn.gold{background:var(--gold);color:var(--navy)}
.btn.gold:hover{background:var(--gold-soft)}
.btn.ghost{background:transparent;border:1.5px solid var(--navy);color:var(--navy)}
.btn-row{display:flex;flex-wrap:wrap;gap:10px}
.reps{list-style:none;margin:0 0 14px;padding:0}
.reps li{padding:7px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.reps li:last-child{border-bottom:0}
.reps a{font-weight:600}
.reps .role{color:var(--muted);font-size:.82rem}
.template{background:var(--paper-2);border:1px dashed var(--line);border-radius:10px;padding:14px 16px;font-size:.9rem;color:#39414f;margin-top:6px}
.share-row{display:flex;gap:10px;flex-wrap:wrap}
.share-row a,.share-row button{flex:0 0 auto}

/* ---- Footer ---- */
footer{background:var(--navy);color:#cdd6e6;padding:42px 0;font-size:.9rem}
footer h4{color:#fff;font-family:var(--serif);margin:0 0 .5em}
footer a{color:var(--gold-soft)}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr;gap:28px}
@media (max-width:720px){footer .cols{grid-template-columns:1fr}}
footer .disclaimer{margin-top:26px;padding-top:18px;border-top:1px solid rgba(255,255,255,.15);color:#9fb0c9;font-size:.82rem}
footer ul{list-style:none;margin:0;padding:0}
footer li{margin:.3em 0}

.center{text-align:center}
.mt{margin-top:30px}

/* ---- Hero card "read more" link ---- */
.hcard .more{margin:16px 0 0}
.hcard .more a{font-weight:700;color:var(--navy);text-decoration:none}
.hcard .more a:hover{text-decoration:underline}

/* ---- Individual hero (detail) pages ---- */
.hero-detail{background:linear-gradient(180deg,var(--navy),var(--navy-2));color:#fff;padding:48px 0}
.hero-detail .wrap{display:flex;gap:34px;align-items:center;flex-wrap:wrap}
.portrait-frame{flex:0 0 auto;width:190px;height:232px;border-radius:12px;border:3px solid var(--gold);overflow:hidden;background:var(--navy-2);box-shadow:0 8px 26px rgba(0,0,0,.35)}
.portrait-photo{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.portrait-fallback{width:100%;height:100%;place-items:center;font-family:var(--serif);font-weight:700;font-size:3.6rem;color:var(--gold);background:radial-gradient(circle at 50% 30%,var(--navy-2),#08182f)}
.hero-detail .id{flex:1 1 320px}
.hero-detail .eyebrow2{color:var(--gold-soft);letter-spacing:.16em;text-transform:uppercase;font-size:.75rem;font-weight:700;margin:0 0 6px}
.hero-detail h1{color:#fff;font-size:clamp(1.9rem,4.5vw,2.8rem);margin:0 0 .12em}
.hero-detail .rank2{color:var(--gold);font-size:1.12rem;font-weight:700}
.hero-detail .life{color:#dbe3f0;margin-top:10px;font-size:1.02rem}
.hero-detail .kia{display:inline-block;margin-top:14px;background:rgba(125,43,43,.32);border:1px solid var(--red);color:#f3d6d6;padding:5px 12px;border-radius:999px;font-size:.85rem;font-weight:600}

.detail-body{max-width:820px;margin:0 auto}
.detail-body h2{color:var(--navy);font-size:1.4rem;margin:34px 0 12px;border-left:4px solid var(--gold);padding-left:12px}
.detail-body p{font-size:1.04rem}
.spec{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:1rem;margin:0}
.spec dt{color:var(--muted);font-weight:700;white-space:nowrap}
.spec dd{margin:0}
.citation{background:#fff;border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:10px;padding:18px 22px;color:#33404f;box-shadow:var(--shadow)}
.citation .q{font-style:italic}
.citation .src{display:block;margin-top:12px;font-size:.82rem;color:var(--muted)}
.decorations{columns:2;column-gap:26px;padding:0;margin:0;list-style:none}
@media (max-width:620px){.decorations{columns:1}}
.decorations li{break-inside:avoid;padding:5px 0 5px 22px;position:relative;font-size:.96rem}
.decorations li:before{content:"\2605";position:absolute;left:0;color:var(--gold)}
.decorations li.valor{font-weight:700}
.wall-link{display:flex;gap:16px;align-items:center;flex-wrap:wrap;background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:16px 20px;margin-top:6px}
.wall-link .wl-txt{flex:1 1 240px;font-size:.96rem;color:#39414f}
.hero-nav{display:flex;justify-content:space-between;gap:14px;margin:42px 0 0;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:20px}
.hero-nav a{text-decoration:none;font-weight:600;color:var(--navy)}
.hero-nav a:hover{text-decoration:underline}
.hero-nav .all{color:var(--muted)}

/* ---- Case page ---- */
.figure{margin:0 auto;max-width:780px}
.figure img{width:100%;border-radius:12px;border:1px solid var(--line);box-shadow:var(--shadow)}
.figure figcaption{color:var(--muted);font-size:.88rem;margin-top:10px;text-align:center;font-style:italic}
.keylist{max-width:840px;margin:0 auto;padding:0;list-style:none}
.keylist li{position:relative;padding:14px 0 14px 42px;border-bottom:1px solid var(--line);font-size:1rem}
.keylist li:last-child{border-bottom:0}
.keylist li:before{content:"\2605";position:absolute;left:8px;top:13px;color:var(--gold);font-size:1.15rem}
.keylist strong{color:var(--navy)}
.doclist{max-width:780px;margin:0 auto;padding:0;list-style:none}
.doclist li{display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;padding:14px 18px;border:1px solid var(--line);border-radius:10px;background:#fff;margin-bottom:10px;box-shadow:var(--shadow)}
.doclist .d-name{font-weight:700;color:var(--navy)}
.doclist .d-meta{color:var(--muted);font-size:.85rem;display:block;font-weight:400}
.doclist .pending{color:var(--muted);font-style:italic;font-size:.88rem}

/* ---- Press page ---- */
.release{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:12px;padding:30px 34px;box-shadow:var(--shadow)}
.release .fir{color:var(--red);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;margin:0 0 8px}
.release h2{margin:.1em 0 .45em;color:var(--navy);font-size:1.55rem;border:0;padding:0}
.release p{font-size:1.02rem}
.release .dateline{font-weight:700}
.release .epigraph{border-left:4px solid var(--gold);background:var(--paper-2);padding:14px 20px;font-family:var(--serif);font-style:italic;color:#39414f;border-radius:6px;margin:20px 0;font-size:1.05rem}
.release .epigraph cite{display:block;font-style:normal;font-size:.84rem;color:var(--muted);margin-top:10px}
.release .contact{margin-top:24px;border-top:1px solid var(--line);padding-top:16px;font-size:.96rem}
.kit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;max-width:840px;margin:0 auto}
.kit-thumb{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff}
.kit-thumb img{width:100%;height:140px;object-fit:cover;object-position:center top;display:block}
.kit-thumb span{display:block;padding:7px 10px;font-size:.8rem;color:var(--muted)}
