/* =========================================================================
   Jason Price Speaks — design system
   Grounded in the fire service: smoke + ember + reflective turnout trim.
   ========================================================================= */
@import url('fonts/fonts.css');

:root{
  --smoke:#14110F;        /* warm near-black (smoke) */
  --smoke-2:#1C1714;      /* raised dark surface */
  --ink:#211B17;          /* body ink on light */
  --ember:#DB5B23;        /* primary accent, pulled from the fire */
  --ember-2:#B4431A;      /* deep ember, for light backgrounds */
  --khaki:#C9B79C;        /* turnout-gear tan */
  --silver:#C7CBCE;       /* reflective trim */
  --paper:#EFE9E0;        /* warm light (station house) */
  --bone:#F6F2EA;         /* light surface / text on dark */
  --fog:rgba(246,242,234,.72);
  --fog-2:rgba(246,242,234,.52);
  --line-dark:rgba(246,242,234,.14);
  --line-light:rgba(33,27,23,.14);

  --serif:'Fraunces',Georgia,serif;
  --sans:'Archivo',system-ui,-apple-system,sans-serif;
  --mono:'Spline Sans Mono',ui-monospace,monospace;

  --container:1200px;
  --pad:clamp(24px,5vw,64px);
  --section:clamp(72px,11vw,150px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--bone);
  background:var(--smoke);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--ember);color:#fff}

/* ---------- shared atoms ---------- */
.container{max-width:var(--container);margin:0 auto;padding-inline:var(--pad)}

.eyebrow{
  font-family:var(--mono);text-transform:uppercase;
  letter-spacing:.26em;font-size:clamp(.6rem,1vw,.74rem);
  font-weight:500;color:var(--ember);
}

/* reflective turnout-trim band: ember / silver / ember */
.trim{display:flex;flex-direction:column;gap:3px;width:200px;height:14px}
.trim span{flex:1;display:block}
.trim .a,.trim .c{background:var(--ember)}
.trim .b{background:var(--silver);flex:1.4}
.trim.sm{width:120px;height:11px}
.trim.full{width:100%}

.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--mono);font-size:.8rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;
  padding:15px 26px;border:1px solid var(--ember);
  background:var(--ember);color:#fff;cursor:pointer;
  transition:background .2s,color .2s,transform .2s;
}
.btn:hover{background:transparent;color:var(--ember);transform:translateY(-2px)}
.btn.ghost{background:transparent;color:var(--bone);border-color:var(--line-dark)}
.btn.ghost:hover{border-color:var(--ember);color:var(--ember)}
.btn .arw{transition:transform .2s}
.btn:hover .arw{transform:translateX(4px)}

.section{padding-block:var(--section)}

/* section eyebrow header used on inner sections */
.shead{display:flex;flex-direction:column;gap:20px;margin-bottom:clamp(36px,5vw,60px)}
.shead h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.9rem,4vw,3rem);line-height:1.05;letter-spacing:-.015em}

/* =========================================================================
   HEADER
   ========================================================================= */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:background .3s,border-color .3s,padding .3s;
  border-bottom:1px solid transparent;
}
.site-head.scrolled{
  background:rgba(20,17,15,.86);
  backdrop-filter:blur(10px);
  border-bottom-color:var(--line-dark);
  padding-block:12px;
}
.brand{font-family:var(--serif);font-weight:600;font-size:1.35rem;letter-spacing:-.01em;color:var(--bone);display:flex;align-items:center;gap:12px}
.brand .dot{width:9px;height:9px;background:var(--ember);flex:none}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  font-family:var(--mono);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--fog);padding:9px 14px;transition:color .2s;position:relative;
}
.nav a:hover,.nav a[aria-current="page"]{color:var(--bone)}
.nav a[aria-current="page"]::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--ember);
}
.nav .btn{padding:11px 18px;margin-left:8px}
.nav .btn:hover{color:var(--ember)}
.menu-btn{display:none;background:none;border:0;color:var(--bone);cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.menu-btn span{display:block;width:24px;height:2px;background:var(--bone);transition:.25s}

/* =========================================================================
   HERO — Direction A (Into the Flames)
   ========================================================================= */
.hero{position:relative;min-height:100svh;display:flex;overflow:hidden;background:var(--smoke)}
.hero .bg{position:absolute;inset:0}
.hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero .scrim{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(20,17,15,.62) 0%,rgba(20,17,15,.05) 26%,rgba(20,17,15,.34) 56%,rgba(20,17,15,.95) 100%)}
.hero .inner{position:relative;z-index:5;align-self:flex-end;width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--pad) clamp(64px,10vw,128px)}
.hero .eyebrow{color:var(--khaki);margin-bottom:26px}
.hero .trim{margin-bottom:30px}
.hero h1{
  font-family:var(--sans);font-weight:900;text-transform:uppercase;
  font-size:clamp(3rem,11vw,10rem);line-height:.88;letter-spacing:-.025em;
  color:#fff;max-width:15ch;
}
.hero h1 em{font-style:normal;color:var(--ember)}
.hero .sub{margin-top:30px;max-width:46ch;color:var(--fog);font-size:clamp(1.05rem,1.7vw,1.35rem);line-height:1.5}
.hero .cta-row{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:6;font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fog-2);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue::after{content:"";width:1px;height:34px;background:linear-gradient(var(--fog-2),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* =========================================================================
   SECTION B — Fire Station Wisdom (dark editorial split)
   ========================================================================= */
.wisdom{background:var(--smoke-2);position:relative}
.wisdom .grid{display:grid;grid-template-columns:1.1fr .9fr}
.wisdom .txt{padding:var(--section) var(--pad);display:flex;flex-direction:column;justify-content:center;position:relative;max-width:760px;margin-left:auto}
.wisdom .txt::after{content:"";position:absolute;top:15%;bottom:15%;right:0;width:3px;background:linear-gradient(180deg,transparent,var(--ember),transparent)}
.wisdom .eyebrow{margin-bottom:26px}
.wisdom h2{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4.2vw,3.7rem);line-height:1.04;letter-spacing:-.015em;color:var(--bone);max-width:15ch}
.wisdom h2 em{font-style:italic;color:var(--ember);font-weight:600}
.wisdom p{margin-top:30px;color:var(--fog);font-size:clamp(1rem,1.4vw,1.18rem);max-width:48ch}
.wisdom .who{margin-top:28px;font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--khaki)}
.wisdom .img{position:relative;overflow:hidden;background:#0d0b0a;min-height:420px}
.wisdom .img img{width:100%;height:100%;object-fit:cover;object-position:center 20%;filter:grayscale(.12) contrast(1.03)}
.wisdom .img .tint{position:absolute;inset:0;background:linear-gradient(210deg,rgba(219,91,35,.14),rgba(20,17,15,.55))}

/* =========================================================================
   SECTION C — Service Record (warm light)
   ========================================================================= */
.record{background:var(--paper);color:var(--ink)}
.record .grid{display:grid;grid-template-columns:1fr .8fr;gap:clamp(36px,6vw,80px);align-items:center}
.record .eyebrow{color:var(--ember-2)}
.record .spine{margin:22px 0 30px}
.record h2{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,5.2vw,4.4rem);line-height:.98;letter-spacing:-.02em;color:var(--ink)}
.record h2 .amp{color:var(--ember-2)}
.record .lead{margin-top:22px;font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2vw,1.7rem);line-height:1.3;color:#4a423b;max-width:26ch}
.record dl{margin-top:36px;display:grid;grid-template-columns:auto 1fr;gap:0}
.record dl>div{display:contents}
.record dt{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#9a8d7d;padding:14px 24px 14px 0;border-top:1px solid var(--line-light);white-space:nowrap}
.record dd{font-family:var(--sans);font-weight:500;font-size:clamp(.98rem,1.4vw,1.12rem);color:var(--ink);padding:14px 0;border-top:1px solid var(--line-light)}
.record .portrait{position:relative}
.record .portrait img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center 12%}
.record .portrait .tag{position:absolute;bottom:0;left:0;background:var(--ink);color:var(--bone);font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:9px 13px}

/* =========================================================================
   WRITING TEASER (dark) + card grid
   ========================================================================= */
.teaser{background:var(--smoke)}
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2px;background:var(--line-dark);border:1px solid var(--line-dark)}
.card{
  background:var(--smoke);padding:clamp(28px,3vw,40px);
  display:flex;flex-direction:column;gap:16px;min-height:260px;
  transition:background .25s;position:relative;
}
.card:hover{background:var(--smoke-2)}
.card .kind{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ember)}
.card h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.3rem,2vw,1.7rem);line-height:1.15;color:var(--bone)}
.card p{color:var(--fog);font-size:.96rem;margin-top:-4px}
.card .meta{margin-top:auto;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fog-2);display:flex;align-items:center;gap:10px}
.card.linked:hover h3{color:var(--ember)}
.card .go{position:absolute;top:clamp(28px,3vw,40px);right:clamp(28px,3vw,40px);color:var(--fog-2);transition:.2s}
.card.linked:hover .go{color:var(--ember);transform:translate(3px,-3px)}

/* soon / disabled card */
.card.soon{opacity:.72}
.card.soon .kind{color:var(--khaki)}

/* =========================================================================
   CONTACT STRIP (home) + CONTACT PAGE
   ========================================================================= */
.cstrip{background:var(--smoke-2);border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.cstrip .in{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-block:clamp(48px,7vw,84px)}
.cstrip h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3.4vw,2.8rem);line-height:1.05;max-width:18ch}
.cstrip h2 em{font-style:italic;color:var(--ember)}

/* page hero band (inner pages) */
.page-hero{padding:calc(var(--section) + 40px) 0 var(--section);background:var(--smoke);position:relative;border-bottom:1px solid var(--line-dark)}
.page-hero .eyebrow{margin-bottom:22px}
.page-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,6vw,5rem);line-height:1;letter-spacing:-.02em;color:var(--bone)}
.page-hero p{margin-top:24px;max-width:52ch;color:var(--fog);font-size:clamp(1.05rem,1.5vw,1.25rem)}
.page-hero .trim{margin-top:30px}

/* contact form */
.contact-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,90px);align-items:start}
.form-field{display:flex;flex-direction:column;gap:9px;margin-bottom:22px}
.form-field label{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--khaki)}
.form-field input,.form-field textarea{
  font-family:var(--sans);font-size:1rem;color:var(--bone);
  background:var(--smoke-2);border:1px solid var(--line-dark);
  padding:14px 16px;transition:border-color .2s;resize:vertical;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--ember)}
.form-field textarea{min-height:150px}
.form-note{font-family:var(--mono);font-size:.72rem;color:var(--fog-2);margin-top:6px}
.form-status{margin-top:16px;font-family:var(--mono);font-size:.82rem;min-height:1.2em}
/* thank-you page */
.thanks{min-height:calc(100svh - 80px);display:flex;align-items:center;padding-block:clamp(90px,14vw,160px);background:
  radial-gradient(120% 90% at 82% 8%, rgba(219,91,35,.14), transparent 60%), var(--smoke)}
.thanks .eyebrow{margin-bottom:24px}
.thanks .trim{margin-bottom:32px}
.thanks h1{font-family:var(--serif);font-weight:600;font-size:clamp(3.4rem,9vw,7.5rem);line-height:.95;letter-spacing:-.02em;color:var(--bone)}
.thanks p{margin-top:26px;max-width:50ch;color:var(--fog);font-size:clamp(1.1rem,1.7vw,1.4rem);line-height:1.55}
.thanks .cta-row{margin-top:40px;display:flex;gap:16px;flex-wrap:wrap}
.thanks-sig{font-family:var(--serif)!important;font-style:italic;font-size:1.25rem!important;color:var(--khaki)!important;margin-top:34px!important;max-width:none!important}

.form-sent{display:flex;flex-direction:column;gap:14px;padding:30px 0}
.form-sent .trim{margin-bottom:8px}
.form-sent h3{font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,3.4vw,2.8rem);line-height:1.05;color:var(--bone)}
.form-sent p{color:var(--fog);font-size:clamp(1rem,1.4vw,1.15rem);max-width:42ch}
.form-status.ok{color:var(--khaki)}
.form-status.err{color:var(--ember)}
.contact-side{display:flex;flex-direction:column;gap:26px}
.contact-side .row{display:flex;flex-direction:column;gap:6px;padding-bottom:22px;border-bottom:1px solid var(--line-dark)}
.contact-side .row .k{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fog-2)}
.contact-side .row a,.contact-side .row span{font-size:1.15rem;color:var(--bone);transition:color .2s}
.contact-side .row a:hover{color:var(--ember)}

/* =========================================================================
   PROSE (about bio + article reader)
   ========================================================================= */
.prose-light{background:var(--paper);color:var(--ink)}
.prose{max-width:68ch;margin:0 auto}
.prose p{font-size:clamp(1.08rem,1.5vw,1.24rem);line-height:1.72;margin-bottom:1.3em;color:#33291f}
.prose p:first-of-type::first-letter{
  font-family:var(--serif);font-weight:600;float:left;font-size:4.4rem;line-height:.8;
  padding:6px 12px 0 0;color:var(--ember-2);
}
.prose h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.5rem,2.6vw,2rem);margin:1.6em 0 .5em;color:var(--ink)}
.prose ul{margin:0 0 1.3em 1.2em}
.prose li{font-size:clamp(1.02rem,1.4vw,1.16rem);line-height:1.7;margin-bottom:.7em;color:#33291f}
.prose li::marker{color:var(--ember-2)}
.prose .lede{font-family:var(--serif);font-style:italic;font-size:clamp(1.25rem,2vw,1.6rem);line-height:1.4;color:#4a423b;margin-bottom:1.4em}
.prose .lede::first-letter{all:unset}

.pullquote{background:var(--smoke);color:var(--bone);text-align:center}
.pullquote blockquote{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,4vw,3.2rem);line-height:1.15;letter-spacing:-.01em;max-width:20ch;margin:0 auto}
.pullquote .trim{margin:0 auto 34px}
.pullquote cite{display:block;margin-top:28px;font-family:var(--mono);font-style:normal;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--khaki)}

/* article reader specifics */
.article-hero{padding:calc(var(--section) + 30px) 0 clamp(40px,6vw,70px);background:var(--smoke);border-bottom:1px solid var(--line-dark)}
.article-hero .kind{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ember)}
.article-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,5vw,4rem);line-height:1.03;letter-spacing:-.015em;margin-top:20px;max-width:20ch;color:var(--bone)}
.article-hero .meta{margin-top:24px;font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fog-2)}
.back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fog);margin-bottom:30px;transition:color .2s}
.back-link:hover{color:var(--ember)}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-foot{background:var(--smoke);border-top:1px solid var(--line-dark);padding-block:clamp(48px,6vw,72px)}
.site-foot .top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.site-foot .brand{font-size:1.6rem;margin-bottom:14px}
.site-foot .tagline{color:var(--fog-2);font-size:.95rem;max-width:34ch}
.site-foot .fnav{display:flex;gap:26px;flex-wrap:wrap}
.site-foot .fnav a{font-family:var(--mono);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fog);transition:color .2s}
.site-foot .fnav a:hover{color:var(--ember)}
.site-foot .trim{margin:40px 0 24px}
.site-foot .legal{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;color:var(--fog-2)}

/* =========================================================================
   MOTION — one restrained reveal
   ========================================================================= */
/* content is visible by default; only hidden once JS confirms it can reveal it */
html.js .rise{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
html.js .rise.in{opacity:1;transform:none}
.rise.d1{transition-delay:.06s}.rise.d2{transition-delay:.16s}.rise.d3{transition-delay:.26s}.rise.d4{transition-delay:.36s}
/* hero rises on load, not scroll */
.hero .rise{transition-duration:.9s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .rise{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  .scroll-cue::after{animation:none}
}

:focus-visible{outline:2px solid var(--ember);outline-offset:3px}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:900px){
  .wisdom .grid{grid-template-columns:1fr}
  .wisdom .img{order:-1;min-height:52vh}
  .wisdom .txt::after{display:none}
  .wisdom .txt{margin-left:0;max-width:none}
  .record .grid{grid-template-columns:1fr}
  .record .portrait{max-width:440px}
  .contact-wrap{grid-template-columns:1fr}
}
@media (max-width:760px){
  .menu-btn{display:flex}
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;
    background:rgba(20,17,15,.97);backdrop-filter:blur(14px);
    padding:40px;transform:translateX(100%);transition:transform .3s;
    border-left:1px solid var(--line-dark);
  }
  .nav.open{transform:none}
  .nav a{font-size:1rem;padding:12px 0}
  .nav a[aria-current="page"]::after{left:0;right:auto;width:24px}
  .nav .btn{margin-left:0;margin-top:14px}
  body.nav-open{overflow:hidden}
  .menu-btn.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-btn.active span:nth-child(2){opacity:0}
  .menu-btn.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .cstrip .in{flex-direction:column;align-items:flex-start}
}
