/* =========================================================
   The Don McCool Archive - shared stylesheet
   Hybrid: modern museum/archive + archival newspaper accents
   ========================================================= */

:root{
  --navy:#172a45;
  --navy-deep:#0f1d33;
  --maroon:#7a2230;
  --maroon-deep:#5e1924;
  --gold:#b08d39;
  --gold-light:#cda94e;
  --parchment:#f5eee1;
  --parchment-deep:#ece1cd;
  --paper:#fbf7ef;
  --ink:#272219;
  --muted:#6c6457;
  --line:#d9cbb0;
  --news:#efe7d6;
  --shadow:0 18px 44px rgba(15,29,51,.13);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Source Sans 3',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--parchment);
  line-height:1.68;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:var(--maroon);}

h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.12;color:var(--navy);}
.wrap{max-width:1120px;margin:0 auto;padding:0 26px;}
.narrow{max-width:820px;margin-left:auto;margin-right:auto;}

/* ---------- Masthead ---------- */
.masthead{
  background:var(--navy-deep);
  color:var(--parchment);
  border-bottom:3px solid var(--gold);
}
.masthead .wrap{display:flex;align-items:center;justify-content:space-between;padding:18px 26px;gap:18px;flex-wrap:wrap;}
.brand{display:flex;flex-direction:column;text-decoration:none;}
.brand .pre{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.34em;font-size:.66rem;color:var(--gold-light);}
.brand .name{font-family:'Playfair Display',serif;font-weight:900;font-size:1.5rem;color:#fff;letter-spacing:.5px;}
.brand .sub{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.2em;font-size:.62rem;color:#aebbd0;}
.masthead .est{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.22em;font-size:.66rem;color:#9fb0c9;text-align:right;}

/* ---------- Nav ---------- */
nav.main{position:sticky;top:0;z-index:60;background:var(--navy);border-bottom:2px solid var(--gold);}
nav.main .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 22px;padding:11px 26px;}
nav.main a{
  color:#e7ddca;text-decoration:none;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;
  padding:5px 2px;border-bottom:2px solid transparent;transition:.18s;white-space:nowrap;
}
nav.main a:hover{color:var(--gold-light);}
nav.main a.active{color:#fff;border-color:var(--gold);}

/* ---------- Hero / page header ---------- */
.page-hero{
  background:linear-gradient(rgba(15,29,51,.9),rgba(15,29,51,.94)),
    repeating-linear-gradient(45deg,#142339 0 20px,#16273e 20px 40px);
  color:var(--parchment);text-align:center;padding:62px 0 56px;border-bottom:5px solid var(--gold);
}
.page-hero .eyebrow{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.34em;font-size:.8rem;color:var(--gold-light);margin-bottom:14px;}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);color:#fff;font-weight:900;}
.page-hero p{max-width:660px;margin:18px auto 0;color:#e3d9c6;font-size:1.1rem;}

/* big home hero */
.hero{
  background:linear-gradient(rgba(15,29,51,.82),rgba(15,29,51,.9)),
    repeating-linear-gradient(45deg,#132238 0 22px,#16273e 22px 44px);
  color:var(--parchment);text-align:center;padding:96px 0 84px;border-bottom:6px solid var(--gold);
}
.hero .kicker{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.42em;font-size:.92rem;color:var(--gold-light);margin-bottom:18px;}
.hero h1{font-size:clamp(3rem,9vw,6rem);font-weight:900;color:#fff;letter-spacing:-1px;text-shadow:0 2px 20px rgba(0,0,0,.4);}
.hero h1 .yrs{display:block;font-family:'Oswald',sans-serif;font-weight:500;font-size:.2em;letter-spacing:.3em;color:var(--gold-light);margin-top:18px;}
.hero .tag{display:block;font-style:italic;font-weight:500;font-size:.34em;color:#e7ddc9;margin-top:14px;letter-spacing:0;font-family:'Playfair Display',serif;}
.hero p.sub{max-width:640px;margin:26px auto 0;font-size:1.2rem;color:#e7ddc9;}

/* ---------- Sections ---------- */
section{padding:66px 0;}
section.alt{background:var(--parchment-deep);}
section.dark{background:var(--navy);color:var(--parchment);}
section.dark h2,section.dark h3{color:#fff;}
.section-head{text-align:center;margin-bottom:42px;}
.section-head .eyebrow{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.3em;font-size:.78rem;color:var(--maroon);margin-bottom:11px;}
section.dark .section-head .eyebrow{color:var(--gold-light);}
.section-head h2{font-size:clamp(1.9rem,4vw,2.7rem);}
.section-head .rule{width:64px;height:3px;background:var(--gold);margin:16px auto 0;}
.lead{font-family:'Playfair Display',serif;font-style:italic;font-size:1.4rem;line-height:1.45;color:var(--navy);text-align:center;max-width:760px;margin:0 auto 30px;}
section.dark .lead{color:#f0e7d4;}
p{margin-bottom:16px;}
.prose p{font-size:1.05rem;}

/* ---------- Stat band ---------- */
.statband{background:var(--maroon);color:#f7ecd6;padding:34px 0;}
.statband .grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;text-align:center;}
.statband .num{font-family:'Playfair Display',serif;font-weight:900;font-size:2.4rem;color:#fff;line-height:1;}
.statband .lbl{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:#eccba9;margin-top:7px;}
@media(max-width:760px){.statband .grid{grid-template-columns:repeat(3,1fr);gap:24px 14px;}}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.cards.two{grid-template-columns:repeat(2,1fr);}
.card{background:var(--paper);border:1px solid var(--line);border-top:4px solid var(--gold);padding:26px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;text-decoration:none;color:inherit;display:block;}
a.card:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(15,29,51,.2);}
.card h3{font-size:1.3rem;margin-bottom:8px;}
.card .meta{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--maroon);margin-bottom:10px;}
.card p{color:var(--muted);font-size:.96rem;margin:0;}
.card .go{display:inline-block;margin-top:14px;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--maroon);}
@media(max-width:860px){.cards,.cards.two{grid-template-columns:1fr;}}

/* ---------- Quote ---------- */
blockquote{font-family:'Playfair Display',serif;font-style:italic;font-size:1.5rem;line-height:1.42;color:#fff;position:relative;padding-left:32px;}
blockquote::before{content:"\201C";position:absolute;left:-8px;top:-22px;font-size:4.4rem;color:var(--gold);font-family:'Playfair Display',serif;}
blockquote cite{display:block;margin-top:12px;font-style:normal;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;color:var(--gold-light);}
.qgrid{display:grid;grid-template-columns:1fr 1fr;gap:44px;}
@media(max-width:720px){.qgrid{grid-template-columns:1fr;gap:48px;}}

/* ---------- Tables ---------- */
.table-wrap{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;}
table{width:100%;border-collapse:collapse;}
caption{background:var(--navy);color:#fff;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:.9rem;padding:15px;}
th{background:var(--parchment-deep);font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;color:var(--navy);padding:12px 16px;text-align:left;border-bottom:2px solid var(--gold);}
td{padding:12px 16px;border-bottom:1px solid var(--line);font-size:.95rem;vertical-align:top;}
tr:last-child td{border-bottom:none;}
tbody tr:hover{background:var(--parchment);}
td .hl{color:var(--maroon);font-weight:600;}

/* ---------- Timeline ---------- */
.timeline{max-width:820px;margin:0 auto;position:relative;padding-left:34px;}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:3px;background:var(--gold);}
.tl-item{position:relative;margin-bottom:34px;}
.tl-item::before{content:"";position:absolute;left:-34px;top:4px;width:15px;height:15px;border-radius:50%;background:var(--maroon);border:3px solid var(--parchment);box-shadow:0 0 0 2px var(--maroon);}
.tl-item .yr{font-family:'Oswald',sans-serif;font-weight:700;color:var(--maroon);letter-spacing:.06em;font-size:1.05rem;}
.tl-item h3{font-size:1.25rem;margin:2px 0 6px;}
.tl-item p{color:var(--muted);margin:0;}

/* ---------- Newspaper clipping frame ---------- */
.clip{background:var(--news);border:1px solid var(--line);padding:16px;box-shadow:var(--shadow);}
.clip img{border:1px solid #e0d4b9;width:100%;}
.clip figcaption{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--muted);text-align:center;margin-top:12px;}

/* gallery grid */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;}
.gallery-grid figure{transition:transform .22s,box-shadow .22s;}
.gallery-grid figure:hover{transform:translateY(-5px);}
@media(max-width:820px){.gallery-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.gallery-grid{grid-template-columns:1fr;}}

/* ---------- Pull / callout ---------- */
.callout{background:var(--paper);border-left:5px solid var(--maroon);padding:22px 26px;box-shadow:var(--shadow);margin:26px 0;}
.callout h3{color:var(--maroon);margin-bottom:6px;}
.tag-pill{display:inline-block;background:var(--navy);color:#fff;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;padding:4px 11px;border-radius:2px;margin:3px 4px 3px 0;}

/* ---------- Buttons ---------- */
.btn{display:inline-block;background:var(--maroon);color:#fff;text-decoration:none;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;padding:12px 24px;border-radius:2px;transition:.18s;}
.btn:hover{background:var(--maroon-deep);}
.btn.ghost{background:transparent;border:2px solid var(--gold);color:var(--gold-light);}
.btn.ghost:hover{background:var(--gold);color:var(--navy-deep);}
.btn-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:24px;}

/* ---------- Source note ---------- */
.source{font-size:.85rem;color:var(--muted);font-style:italic;}
.sources-list{max-width:820px;margin:0 auto;}
.sources-list li{margin-bottom:12px;font-size:.92rem;color:var(--muted);}

/* coming soon */
.soon{text-align:center;background:var(--paper);border:1px dashed var(--gold);padding:40px 26px;max-width:680px;margin:0 auto;box-shadow:var(--shadow);}
.soon .badge{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--maroon);}

/* ---------- Footer ---------- */
footer{background:var(--navy-deep);color:#b8c2d4;padding:50px 0 40px;}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;}
footer .name{font-family:'Playfair Display',serif;color:#fff;font-size:1.4rem;margin-bottom:6px;}
footer h4{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--gold-light);margin-bottom:12px;}
footer a{color:#b8c2d4;text-decoration:none;display:block;margin-bottom:6px;font-size:.92rem;}
footer a:hover{color:#fff;}
footer .colophon{border-top:1px solid #243650;margin-top:34px;padding-top:20px;text-align:center;font-size:.82rem;color:#8595ad;}
@media(max-width:760px){footer .grid{grid-template-columns:1fr;gap:24px;}}
