/* ============================================================
   Flame Keepers — main stylesheet
   Palette and components as approved in the design specimen.
   ============================================================ */

/* ---------- self-hosted fonts (no third-party calls) ---------- */
@font-face{font-family:'Oswald';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/oswald-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Oswald';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/oswald-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Oswald';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/oswald-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/source-serif-4-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Source Serif 4';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/source-serif-4-latin-400-italic.woff2') format('woff2')}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/source-serif-4-latin-600-normal.woff2') format('woff2')}

:root{
  --flame:#EF9F27;
  --ember:#D85A30;
  --forge:#1A1A18;
  --warm-white:#FBF9F3;
  --soft-cream:#F5F0E8;
  --warm-grey:#888780;
  --coral-deep:#993C1D;
  --gold-pale:#FAC775;
  --hairline:#EAE4D6;
  --grad-flame:linear-gradient(to top,#993C1D,#D85A30,#EF9F27,#FAC775);
  --grad-flame-h:linear-gradient(to right,#993C1D,#D85A30,#EF9F27,#FAC775);
  --display:'Oswald',Arial Narrow,sans-serif;
  --body:'Source Serif 4',Georgia,serif;
  --max:62rem;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{background:var(--warm-white);color:var(--forge);font-family:var(--body);font-size:1.0625rem;line-height:1.65}
img{max-width:100%;height:auto}
a{color:var(--ember)}
a:hover{color:var(--coral-deep)}
:focus-visible{outline:3px solid var(--flame);outline-offset:2px}
.skip{position:absolute;left:-9999px;top:0;background:var(--forge);color:var(--warm-white);padding:.6rem 1rem;z-index:100;font-family:var(--display)}
.skip:focus{left:0}

h1,h2,h3{font-family:var(--display);text-transform:uppercase;letter-spacing:.02em;line-height:1.15}
h1{font-size:clamp(2rem,5vw,3.1rem);font-weight:600;color:var(--forge);margin-bottom:.4em}
h2{font-size:clamp(1.4rem,3.5vw,2rem);font-weight:500;color:var(--ember);margin:1.2em 0 .45em}
h3{font-size:1.12rem;font-weight:500;color:var(--forge);margin:1.1em 0 .4em}
.lede{font-size:1.22rem;line-height:1.6;max-width:42em}

.page-wrap,.wide-wrap{max-width:var(--max);margin:0 auto;padding:2.5rem 1.25rem 3.5rem}
.prose{max-width:42em}
.prose p+p{margin-top:1em}
.prose ul,.prose ol{margin:1em 0 1em 1.4em}
.prose blockquote{border-left:3px solid var(--flame);padding-left:1rem;margin:1.2em 0;font-style:italic;color:#3a3936}
.prose img{border:1px solid var(--hairline);margin:1em 0}
.post-date{font-family:var(--display);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--warm-grey);margin-bottom:1.5rem}
.back-link{margin-top:2.5rem;font-family:var(--display);letter-spacing:.05em;text-transform:uppercase;font-size:.9rem}

.btn{display:inline-block;font-family:var(--display);font-weight:500;font-size:.95rem;letter-spacing:.08em;text-transform:uppercase;padding:.7rem 1.5rem;border:2px solid var(--ember);background:var(--ember);color:var(--warm-white);text-decoration:none;cursor:pointer}
.btn:hover{background:var(--coral-deep);border-color:var(--coral-deep);color:var(--warm-white)}
.btn.ghost{background:transparent;color:var(--ember)}
.btn.ghost:hover{background:var(--ember);color:var(--warm-white)}

/* ---------- header ---------- */
.site-header{background:var(--warm-white);border-bottom:1px solid var(--hairline);position:relative}
.site-header::after{content:"";display:block;height:4px;background:var(--grad-flame-h)}
.site-bar{max-width:var(--max);margin:0 auto;padding:1.1rem 1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:.8rem;text-decoration:none;color:var(--forge)}
.flame-mark{height:44px;width:auto;display:block}
.wordmark{font-family:var(--display);font-weight:600;font-size:1.55rem;line-height:1;letter-spacing:.04em;text-transform:uppercase}
.wordmark small{display:block;font-weight:400;font-size:.62rem;letter-spacing:.26em;color:var(--warm-grey);margin-top:.28rem}
.site-nav{margin-left:auto}
.site-nav ul{display:flex;gap:1.6rem;list-style:none;flex-wrap:wrap}
.site-nav a{font-family:var(--display);font-weight:500;font-size:.95rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;color:var(--forge);padding:.35rem 0;border-bottom:3px solid transparent}
.site-nav a:hover{color:var(--ember)}
.site-nav a[aria-current]{border-bottom-color:var(--ember);color:var(--ember)}
.burger{display:none;margin-left:auto;background:none;border:2px solid var(--forge);color:var(--forge);width:48px;height:48px;cursor:pointer}
.burger svg{width:24px;height:24px;display:block;margin:auto}
.burger .ic-close{display:none}
.burger[aria-expanded="true"] .ic-open{display:none}
.burger[aria-expanded="true"] .ic-close{display:block}
@media (max-width:760px){
  .burger{display:block}
  .site-nav{display:none;margin-left:0;flex-basis:100%;border-top:1px solid var(--hairline);padding-top:.5rem}
  .site-nav.open{display:block}
  .site-nav ul{flex-direction:column;gap:0}
  .site-nav a{display:block;padding:.8rem 0;font-size:1.05rem;border-bottom:1px solid #F0EADC}
  .site-nav a[aria-current]{border-bottom-color:var(--ember)}
}

/* ---------- homepage ---------- */
.hero{padding:3.2rem 1.25rem 2.6rem}
.hero-inner{max-width:var(--max);margin:0 auto}
.hero .lede{margin-top:.6rem}
.home-section{padding:2.6rem 1.25rem;border-top:1px solid var(--hairline)}
.home-section.alt{background:#fff}
.home-inner{max-width:var(--max);margin:0 auto}
.people-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.4rem;margin-top:1.4rem}
.person-card{background:#fff;border:1px solid var(--hairline);text-decoration:none;color:var(--forge);display:block}
.person-card:hover{border-color:var(--ember)}
.person-card img{display:block;width:100%;aspect-ratio:4/5;object-fit:cover}
.person-card .pc-name{font-family:var(--display);font-weight:500;font-size:1.05rem;letter-spacing:.04em;text-transform:uppercase;padding:.7rem .85rem .15rem}
.person-card .pc-role{font-size:.88rem;color:var(--warm-grey);padding:0 .85rem .8rem;font-style:italic}
.news-teasers{margin-top:1rem}
.news-teaser{padding:1.1rem 0;border-bottom:1px solid var(--hairline);max-width:42em}
.news-teaser h3{margin:.1em 0 .2em}
.news-teaser h3 a{text-decoration:none;color:var(--forge)}
.news-teaser h3 a:hover{color:var(--ember)}
.news-teaser .nt-date{font-family:var(--display);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--warm-grey)}

/* ---------- interviews index ---------- */
.coming-soon{background:var(--soft-cream);border:1px dashed var(--warm-grey);padding:1.2rem 1.4rem;max-width:42em;font-style:italic;color:#3a3936;margin-top:1.4rem}

/* ---------- profile page ---------- */
.profile-head{display:grid;grid-template-columns:240px 1fr;gap:2rem;align-items:start;margin-bottom:2rem}
.profile-head img{border:1px solid var(--hairline)}
@media (max-width:640px){.profile-head{grid-template-columns:1fr}.profile-head img{max-width:280px}}
.profile-bio{max-width:42em}
.recorded-line{font-family:var(--display);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--warm-grey);margin-top:.8rem}

/* ---------- audio player ---------- */
.player-shell{background:#fff;border:1px solid var(--hairline);margin:1.5rem 0 2.5rem}
.player{background:var(--forge);color:var(--warm-white);padding:1rem 1.25rem;position:sticky;top:0;z-index:5}
.player-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.p-btn{background:none;border:2px solid var(--warm-white);color:var(--warm-white);border-radius:50%;width:52px;height:52px;flex:0 0 52px;display:grid;place-items:center;cursor:pointer}
.p-btn:hover{border-color:var(--flame);color:var(--flame)}
.p-btn svg{width:22px;height:22px;fill:currentColor}
.p-skip{background:none;border:none;color:var(--warm-white);cursor:pointer;font-family:var(--display);font-size:.72rem;letter-spacing:.04em;display:flex;flex-direction:column;align-items:center;gap:.15rem}
.p-skip svg{width:24px;height:24px;fill:currentColor}
.p-skip:hover{color:var(--flame)}
.p-time{font-family:var(--display);font-variant-numeric:tabular-nums;font-size:.95rem;letter-spacing:.05em;white-space:nowrap}
.p-time .total{color:var(--warm-grey)}
.timeline-wrap{flex:1 1 220px;display:flex;align-items:center;min-width:180px}
input[type=range].timeline{-webkit-appearance:none;appearance:none;width:100%;height:22px;background:transparent;cursor:pointer}
input[type=range].timeline::-webkit-slider-runnable-track{height:6px;background:#46443f;border-radius:3px;background-image:var(--grad-flame-h);background-size:var(--fill,0%) 100%;background-repeat:no-repeat}
input[type=range].timeline::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--flame);margin-top:-6px;border:2px solid var(--forge)}
input[type=range].timeline::-moz-range-track{height:6px;background:#46443f;border-radius:3px}
input[type=range].timeline::-moz-range-progress{height:6px;background:var(--flame);border-radius:3px}
input[type=range].timeline::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--flame);border:2px solid var(--forge)}
.player-fallback{padding:1rem 1.25rem;background:var(--soft-cream);font-size:.92rem}

/* ---------- transcript ---------- */
.transcript{padding:1.75rem 1.5rem}
.transcript-title{font-family:var(--display);font-weight:500;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--warm-grey);margin-bottom:1rem}
.seg{padding:.55rem .9rem .55rem 1rem;border-left:3px solid transparent;cursor:pointer;max-width:40em}
.seg:hover{background:#FAF6EC}
.seg.current{background:var(--soft-cream);border-left-color:var(--ember)}
.seg .who{font-family:var(--display);font-weight:500;font-size:.92em;letter-spacing:.03em;margin-right:.45em}
.seg.interviewer{font-style:italic;color:var(--warm-grey)}
.seg.interviewer .who{font-style:normal}
.seg time{float:right;font-family:var(--display);font-size:.72rem;color:var(--warm-grey);font-variant-numeric:tabular-nums;margin-left:.8rem}

/* ---------- profile photos strip ---------- */
.profile-photos{margin-top:2rem}
.profile-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--hairline);font-family:var(--display);letter-spacing:.04em;text-transform:uppercase;font-size:.9rem}
.profile-nav a{text-decoration:none}

/* ---------- gallery ---------- */
.coll-wrap{position:relative;background:var(--flame)}
.coll-nav{display:flex;gap:1.5rem;flex-wrap:wrap;background:var(--flame);padding:1rem 1.25rem;max-width:var(--max);margin:0 auto}
.coll-nav button{background:none;border:none;cursor:pointer;font-family:var(--display);font-weight:500;font-size:.95rem;letter-spacing:.05em;color:var(--coral-deep);padding:0 0 .3rem;border-bottom:3px solid transparent}
.coll-nav button:hover{color:var(--forge)}
.coll-nav button[aria-pressed="true"]{color:var(--forge);border-bottom-color:var(--forge)}
@media (max-width:760px){
  .coll-nav{flex-wrap:nowrap;overflow-x:auto;gap:1.4rem;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-right:3rem}
  .coll-nav::-webkit-scrollbar{display:none}
  .coll-nav button{white-space:nowrap;flex:0 0 auto}
  .coll-wrap::after{content:"";position:absolute;top:0;right:0;bottom:0;width:3rem;background:linear-gradient(to right,rgba(239,159,39,0),var(--flame));pointer-events:none}
}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:1.6rem}
@media (max-width:480px){.photo-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}}
.photo-grid button{background:#fff;border:1px solid var(--hairline);padding:0;cursor:pointer;display:block}
.photo-grid button:hover{border-color:var(--ember)}
.photo-grid img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}
.gallery-count{font-family:var(--display);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--warm-grey);margin-top:1rem}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:50;background:rgba(20,19,17,.96);display:none;flex-direction:column}
.lightbox.open{display:flex}
.lb-top{display:flex;align-items:center;gap:1rem;padding:.8rem 1rem;color:var(--warm-white)}
.lb-title{font-family:var(--display);font-weight:500;font-size:1rem;letter-spacing:.04em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-iconbtn{background:none;border:2px solid var(--warm-white);color:var(--warm-white);width:42px;height:42px;flex:0 0 42px;cursor:pointer;border-radius:50%;display:grid;place-items:center}
.lb-iconbtn:hover{border-color:var(--flame);color:var(--flame)}
.lb-iconbtn svg{width:20px;height:20px;fill:currentColor}
.lb-stage{flex:1;position:relative;display:grid;place-items:center;min-height:0;padding:0 .5rem;touch-action:pan-y}
.lb-stage img{max-width:100%;max-height:100%;display:block;object-fit:contain}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(20,19,17,.5);border:2px solid var(--warm-white);color:var(--warm-white);width:44px;height:44px;border-radius:50%;cursor:pointer;display:grid;place-items:center;z-index:2}
.lb-arrow:hover{border-color:var(--flame);color:var(--flame)}
.lb-arrow svg{width:22px;height:22px;fill:currentColor}
.lb-prev{left:.6rem}.lb-next{right:.6rem}
@media (hover:none) and (pointer:coarse){
  /* touch devices: arrows kept (per approval) but quieter, swipe is primary */
  .lb-arrow{opacity:.55;width:40px;height:40px}
}
.lb-sheet{background:var(--warm-white);color:var(--forge);padding:1.3rem 1.4rem 1.6rem;transform:translateY(100%);transition:transform .25s ease;max-height:55%;overflow-y:auto;position:relative}
@media (prefers-reduced-motion:reduce){.lb-sheet{transition:none}}
.lightbox.info .lb-sheet{transform:translateY(0)}
.lightbox:not(.info) .lb-sheet{position:absolute;bottom:0;left:0;right:0}
.lightbox.info .lb-sheet{position:absolute;bottom:0;left:0;right:0}
.lb-sheet h3{margin-top:0}
.lb-sheet dl{display:grid;grid-template-columns:auto 1fr;gap:.3rem 1rem;font-size:.95rem}
.lb-sheet dt{font-family:var(--display);font-weight:500;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--warm-grey);padding-top:.18em}

/* ---------- forms ---------- */
.form-grid{max-width:34rem;display:grid;gap:1rem;margin-top:1.4rem}
.form-grid label{font-family:var(--display);font-weight:500;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:.3rem}
.form-grid input,.form-grid textarea{width:100%;padding:.7rem .8rem;border:1px solid var(--warm-grey);background:#fff;font-family:var(--body);font-size:1rem;color:var(--forge)}
.form-grid input:focus,.form-grid textarea:focus{border-color:var(--ember);outline:2px solid var(--flame)}
.form-status{padding:1rem 1.2rem;font-size:.98rem;display:none}
.form-status.ok{display:block;background:#EAF3E6;border:1px solid #5F8B4F}
.form-status.err{display:block;background:#F8E8E2;border:1px solid var(--ember)}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---------- footer ---------- */
.site-footer{background:var(--forge);color:var(--warm-white);padding:2.5rem 1.25rem;position:relative;margin-top:3rem}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad-flame-h)}
.foot-inner{max-width:var(--max);margin:0 auto}
.foot-tag{font-family:var(--display);letter-spacing:.12em;text-transform:uppercase;font-size:.85rem;color:var(--gold-pale)}
.foot-thanks{font-style:italic;color:#CFCBC2;font-size:.92rem;margin:.9rem 0 1.2rem}
.logo-strip{display:flex;gap:2.2rem;align-items:center;flex-wrap:wrap;margin-bottom:1.6rem}
.logo-strip img{background:#FBF9F3;padding:.5rem .7rem;height:56px;width:auto}
.foot-links{display:flex;gap:1.8rem;flex-wrap:wrap;font-family:var(--display);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
.foot-links a{color:var(--warm-white);text-decoration:none}
.foot-links a:hover{color:var(--flame)}
.foot-meeja{margin-top:1.6rem;font-size:.85rem;color:var(--warm-grey)}
.foot-meeja a{color:#CFCBC2}
