/* ============================================================
   PitSlate — pre-dawn smoke design world
   Dials: charcoal slate + ember orange + smoke gray + butcher-paper
   tan; Big Shoulders Display (condensed workshop) + Inter (body);
   slate-board texture with chalk-line accents; hand-drawn smoker/
   ember mascot; deliberate slow-burn motion tempo; ambient wash =
   pre-dawn smoke. The reverse-schedule slate timeline is the
   signature interaction. No emoji in chrome. Accessibility floor:
   focus rings, contrast, reduced-motion respected everywhere.
   ============================================================ */

:root {
  --ps-char: #1b1e23;         /* deep charcoal slate */
  --ps-char-2: #24282e;       /* slate panel */
  --ps-char-3: #2e333b;       /* hover slate */
  --ps-slate: #22252a;        /* the board itself */
  --ps-ember: #e8632c;        /* ember orange */
  --ps-ember-hot: #ff8a4a;    /* glowing edge */
  --ps-ember-deep: #a84517;   /* pressed / dark accents on paper */
  --ps-ember-soft: #fbe3d5;   /* light wash */
  --ps-smoke: #8b939e;        /* smoke gray */
  --ps-smoke-soft: #aeb6bf;
  --ps-paper: #f4ead7;        /* butcher-paper canvas */
  --ps-paper-2: #fbf5e9;      /* card paper */
  --ps-tan: #e9d9bf;
  --ps-chalk: #f2f0ea;        /* chalk on slate */
  --ps-ink: #23262b;
  --ps-ink-soft: #565d68;
  --ps-line: rgba(35, 38, 43, .14);
  --ps-safety: #2e7d5b;       /* USDA floor badge — never ember */
  --ps-safety-soft: #dfeee6;
  --ps-danger: #b3382e;
  --ps-danger-soft: #f7e5e2;
  --ps-radius: 14px;
  --ps-shadow: 0 2px 6px rgba(20, 22, 27, .12), 0 14px 34px rgba(20, 22, 27, .14);
  --ps-shadow-sm: 0 1px 3px rgba(20, 22, 27, .16);
  --ps-display: "Big Shoulders Display", "Arial Narrow", sans-serif;
  --ps-body: "Inter", -apple-system, "Segoe UI", sans-serif;
  --ps-slow: 340ms;           /* slow-burn tempo */
  --ps-mid: 220ms;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--ps-body);
  font-size: 16px;
  line-height: 1.55;
  color: var(--ps-ink);
  background: var(--ps-paper);
  font-variant-numeric: tabular-nums;
  overflow-x: hidden;
}
img, svg { max-width: 100%; }
button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }
a { color: var(--ps-ember-deep); }
h1, h2, h3, h4 { font-family: var(--ps-display); line-height: 1.05; margin: 0 0 .4em; letter-spacing: .015em; }

:focus-visible { outline: 3px solid var(--ps-ember); outline-offset: 2px; border-radius: 4px; }
.ps-skip {
  position: absolute; left: -9999px; top: 0; z-index: 200;
  background: var(--ps-ember); color: #fff; padding: 10px 16px; font-weight: 700;
}
.ps-skip:focus { left: 12px; top: 12px; }

.ps-hidden { display: none !important; }
.ps-wrap { max-width: 1080px; margin: 0 auto; padding: 0 20px; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001s !important; transition-duration: 0.001s !important; }
}

/* ---------- ambient depth: pre-dawn smoke wash on the app shell ---------- */
#ps-app {
  min-height: 100vh;
  background:
    radial-gradient(1100px 400px at 75% -100px, rgba(139, 147, 158, .16), transparent 70%),
    radial-gradient(900px 320px at 8% 108%, rgba(232, 99, 44, .07), transparent 68%),
    linear-gradient(180deg, rgba(27, 30, 35, .06), transparent 340px),
    var(--ps-paper);
}

/* ============================ BUTTONS ============================ */
.ps-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: 0; border-radius: 10px; padding: 12px 22px;
  font-weight: 700; font-size: 15px; letter-spacing: .01em;
  transition: transform var(--ps-mid) ease, box-shadow var(--ps-mid) ease, background var(--ps-slow) ease;
  text-decoration: none;
}
.ps-btn:active { transform: translateY(1px) scale(.99); }
.ps-btn--ember { background: var(--ps-ember); color: #fff; box-shadow: var(--ps-shadow-sm); }
.ps-btn--ember:hover { background: var(--ps-ember-deep); box-shadow: 0 0 0 4px rgba(232, 99, 44, .18); }
.ps-btn--slate { background: var(--ps-char-2); color: var(--ps-chalk); }
.ps-btn--slate:hover { background: var(--ps-char-3); }
.ps-btn--ghost { background: transparent; color: var(--ps-ink); border: 2px solid var(--ps-line); }
.ps-btn--ghost:hover { border-color: var(--ps-ink-soft); }
.ps-btn--ghost-light { background: transparent; color: var(--ps-chalk); border: 2px solid rgba(242, 240, 234, .38); }
.ps-btn--ghost-light:hover { border-color: rgba(242, 240, 234, .7); }
.ps-btn--sm { padding: 8px 14px; font-size: 13.5px; }
.ps-btn--lg { padding: 15px 30px; font-size: 17px; }
.ps-btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ============================ BADGES (the two-number doctrine) ============================ */
.ps-badge {
  display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 4px;
}
.ps-badge--safety { background: var(--ps-safety); color: #fff; }
.ps-badge--target { background: var(--ps-ember); color: #fff; }
.ps-badge--soft-safety { background: var(--ps-safety-soft); color: var(--ps-safety); }
.ps-badge--soft-target { background: var(--ps-ember-soft); color: var(--ps-ember-deep); }
.ps-badge--smoke { background: rgba(139, 147, 158, .18); color: var(--ps-ink-soft); }

/* ============================ LANDING ============================ */
/* full-page ambient background — NO photo hero exists, so a subtle brand gradient stands in (PTP pattern,
   gradient fallback): the charcoal pit-slate board with a low ember glow. The dark top keeps the hero's chalk
   copy readable; a butcher-paper-tan scrim ties the lower paper bands to the brand. */
.pagebg { position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(1000px 460px at 82% 6%, rgba(232,99,44,.18), transparent 60%),
    radial-gradient(800px 380px at 12% -8%, rgba(139,147,158,.12), transparent 62%),
    linear-gradient(180deg, #14161c 0%, #232936 52%, #3a3742 100%); }
.pagebg::after { content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(244,234,215,0) 0%, rgba(244,234,215,.10) 55%, rgba(244,234,215,.32) 100%); }
/* landing goes transparent so the ambient board carries through; opaque content bands stay readable */
#ps-landing { background: transparent; }

.pl-nav { background: var(--ps-char); color: var(--ps-chalk); position: sticky; top: 0; z-index: 50; }
.pl-nav__in { display: flex; align-items: center; gap: 20px; padding: 12px 0; }
.pl-brand { display: flex; align-items: center; gap: 10px; text-decoration: none; color: inherit; }
.pl-brand__mark { width: 40px; height: 40px; flex: none; }
.pl-brand__name { font-family: var(--ps-display); font-weight: 800; font-size: 24px; letter-spacing: .05em; text-transform: uppercase; }
.pl-brand__name b { color: var(--ps-ember); font-weight: 800; }
.pl-brand__tag { display: block; font-size: 11.5px; color: rgba(242, 240, 234, .68); margin-top: -3px; }
.pl-nav__links { display: flex; gap: 20px; margin-left: auto; }
.pl-nav__links a { color: rgba(242, 240, 234, .88); text-decoration: none; font-size: 14.5px; font-weight: 600; }
.pl-nav__links a:hover { color: var(--ps-ember-hot); }
@media (max-width: 780px) { .pl-nav__links { display: none; } }

.pl-hero {
  /* transparent so the pagebg brand board gradient carries continuously through the hero; chalk copy stays readable */
  background: transparent;
  color: var(--ps-chalk);
  overflow: hidden;
}
.pl-hero__grid { display: grid; grid-template-columns: 1.02fr .98fr; gap: 40px; align-items: center; padding: 64px 0 56px; }
@media (max-width: 880px) { .pl-hero__grid { grid-template-columns: 1fr; padding: 44px 0 36px; } }
.pl-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .16em;
  font-size: 14px; font-weight: 700; color: var(--ps-ember-hot);
}
.pl-h1 { font-size: clamp(44px, 6.4vw, 72px); font-weight: 800; text-transform: uppercase; letter-spacing: .02em; margin: 10px 0 14px; }
.pl-h1 em { font-style: normal; color: var(--ps-ember-hot); }
.pl-lede { font-size: 18px; line-height: 1.6; color: rgba(242, 240, 234, .92); max-width: 34em; margin: 0 0 22px; }
.pl-cta-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.pl-hero__note { margin-top: 14px; font-size: 13.5px; color: rgba(242, 240, 234, .62); max-width: 40em; }
.pl-hero__media { position: relative; }

/* slow smoke drift in the hero scene */
.pl-smoke { animation: pl-drift 9s ease-in-out infinite alternate; transform-origin: 60% 90%; }
.pl-smoke--2 { animation-duration: 12s; animation-delay: -4s; }
@keyframes pl-drift {
  from { transform: translate(0, 0) rotate(0deg); }
  to { transform: translate(-14px, -10px) rotate(-3deg); }
}

.pl-strip { background: #101216; color: var(--ps-chalk); border-top: 1px solid rgba(242, 240, 234, .08); }
.pl-strip ul { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; list-style: none; margin: 0; padding: 18px 0; }
@media (max-width: 880px) { .pl-strip ul { grid-template-columns: repeat(2, 1fr); } }
.pl-strip li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; line-height: 1.4; }
.pl-strip li svg { width: 26px; height: 26px; flex: none; margin-top: 2px; }
.pl-strip b { display: block; font-family: var(--ps-display); font-size: 17.5px; text-transform: uppercase; letter-spacing: .05em; }

.pl-sec { padding: 64px 0; }
.pl-sec--slate {
  background:
    radial-gradient(circle at 18% 24%, rgba(242, 240, 234, .045) 0 1.6px, transparent 2.6px),
    radial-gradient(circle at 72% 64%, rgba(242, 240, 234, .035) 0 1.4px, transparent 2.4px),
    var(--ps-char);
  background-size: 90px 90px, 130px 130px, 100% 100%;
  color: var(--ps-chalk);
}
.pl-sec--paper { background: var(--ps-paper-2); }
.pl-h2 { font-size: clamp(30px, 4vw, 44px); font-weight: 800; text-transform: uppercase; }
.pl-h2 em { font-style: normal; color: var(--ps-ember); }
.pl-sec--slate .pl-h2 em { color: var(--ps-ember-hot); }
.pl-center { text-align: center; }
.pl-sub { color: var(--ps-ink-soft); max-width: 46em; margin: 0 auto 8px; }
.pl-sub--light { color: rgba(242, 240, 234, .78); }

/* chalk-line section kicker */
.pl-chalkline {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .15em; font-size: 13.5px; font-weight: 700;
  color: var(--ps-ember-deep);
}
.pl-chalkline::before { content: ""; width: 34px; height: 0; border-top: 2px dashed currentColor; opacity: .65; }
.pl-chalkline--light { color: var(--ps-ember-hot); }

.pl-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 34px; }
@media (max-width: 820px) { .pl-steps { grid-template-columns: 1fr; } }
.pl-step { background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-radius: var(--ps-radius); padding: 24px; box-shadow: var(--ps-shadow-sm); }
.pl-step__n { font-family: var(--ps-display); font-size: 46px; font-weight: 800; color: var(--ps-ember); line-height: 1; }
.pl-step h3 { font-size: 22px; text-transform: uppercase; margin: 8px 0 6px; }
.pl-step p { margin: 0; color: var(--ps-ink-soft); font-size: 14.5px; }

.pl-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 34px; }
@media (max-width: 880px) { .pl-features { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .pl-features { grid-template-columns: 1fr; } }
.pl-feat { background: rgba(242, 240, 234, .05); border: 1px solid rgba(242, 240, 234, .14); border-radius: var(--ps-radius); padding: 22px; }
.pl-feat svg { width: 34px; height: 34px; }
.pl-feat h3 { font-size: 20px; text-transform: uppercase; letter-spacing: .04em; margin: 10px 0 6px; }
.pl-feat p { margin: 0; font-size: 14px; color: rgba(242, 240, 234, .76); }

/* two-number section */
.pl-twonum { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 34px; }
@media (max-width: 780px) { .pl-twonum { grid-template-columns: 1fr; } }
.pl-twonum__card { border-radius: var(--ps-radius); padding: 24px; box-shadow: var(--ps-shadow-sm); }
.pl-twonum__card--safety { background: var(--ps-safety-soft); border-left: 6px solid var(--ps-safety); }
.pl-twonum__card--target { background: var(--ps-ember-soft); border-left: 6px solid var(--ps-ember); }
.pl-twonum__card h3 { font-size: 21px; text-transform: uppercase; margin: 10px 0 8px; }
.pl-twonum__card p { margin: 0; font-size: 14.5px; }
.pl-safety-note { margin-top: 22px; font-size: 13px; color: var(--ps-ink-soft); max-width: 56em; }

/* pricing */
.pl-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 36px; align-items: stretch; }
@media (max-width: 880px) { .pl-tiers { grid-template-columns: 1fr; } }
.pl-tier { background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-radius: var(--ps-radius); padding: 26px; display: flex; flex-direction: column; box-shadow: var(--ps-shadow-sm); }
.pl-tier--hero { border: 2px solid var(--ps-ember); box-shadow: var(--ps-shadow); position: relative; }
.pl-tier--hero::before {
  content: "The Pit Book"; position: absolute; top: -13px; left: 22px;
  background: var(--ps-ember); color: #fff; font-family: var(--ps-display); text-transform: uppercase;
  letter-spacing: .08em; font-size: 13px; font-weight: 700; padding: 3px 12px; border-radius: 4px;
}
.pl-tier h3 { font-size: 23px; text-transform: uppercase; }
.pl-tier .pl-price { font-family: var(--ps-display); font-size: 46px; font-weight: 800; line-height: 1; margin: 6px 0 2px; }
.pl-tier .pl-price small { font-size: 16px; font-weight: 600; color: var(--ps-ink-soft); }
.pl-tier ul { list-style: none; padding: 0; margin: 14px 0 20px; font-size: 14.5px; display: grid; gap: 8px; }
.pl-tier li { padding-left: 24px; position: relative; }
.pl-tier li::before {
  content: ""; position: absolute; left: 2px; top: 7px; width: 12px; height: 0;
  border-top: 3px solid var(--ps-ember); transform: rotate(-4deg); /* chalk tick */
}
.pl-tier .ps-btn { margin-top: auto; }
.pl-tier__note { font-size: 12.5px; color: var(--ps-ink-soft); margin-top: 10px; }

.pl-faq { max-width: 720px; margin: 30px auto 0; }
.pl-faq details { background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-radius: 12px; padding: 4px 20px; margin-bottom: 10px; }
.pl-faq summary { font-weight: 700; padding: 12px 0; cursor: pointer; font-size: 15.5px; }
.pl-faq p { margin: 0 0 14px; color: var(--ps-ink-soft); font-size: 14.5px; }

.pl-final { background: linear-gradient(180deg, var(--ps-char), #101216); color: var(--ps-chalk); text-align: center; padding: 70px 0 34px; }
.pl-final .pl-h2 { margin-bottom: 8px; }
.pl-foot { margin-top: 46px; padding-top: 22px; border-top: 1px dashed rgba(242, 240, 234, .22); display: flex; flex-wrap: wrap; gap: 8px 22px; justify-content: center; font-size: 13px; color: rgba(242, 240, 234, .62); }
.pl-foot a { color: rgba(242, 240, 234, .85); }
.pl-foot__legal { width: 100%; font-size: 12px; color: rgba(242, 240, 234, .45); margin-top: 6px; }

/* ============================ GATE ============================ */
.ps-gate {
  position: fixed; inset: 0; z-index: 100; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(800px 500px at 50% 24%, rgba(232, 99, 44, .16), transparent 70%), rgba(16, 18, 22, .95);
  padding: 20px;
}
.ps-gate__card { background: var(--ps-char-2); color: var(--ps-chalk); border: 1px solid rgba(242, 240, 234, .16); border-radius: 18px; padding: 34px 30px; max-width: 420px; width: 100%; text-align: center; box-shadow: var(--ps-shadow); }
.ps-gate__card h1 { font-size: 34px; text-transform: uppercase; letter-spacing: .06em; margin: 12px 0 2px; font-weight: 800; }
.ps-gate__card h1 b { color: var(--ps-ember); }
.ps-gate__tag { color: rgba(242, 240, 234, .72); font-size: 14px; margin: 0 0 18px; }
.ps-gate__form { display: flex; gap: 10px; }
.ps-gate__form input {
  flex: 1; border-radius: 10px; border: 1px solid rgba(242, 240, 234, .28); background: rgba(255, 255, 255, .07);
  color: var(--ps-chalk); padding: 11px 16px;
}
.ps-gate__form input::placeholder { color: rgba(242, 240, 234, .45); }
.ps-gate__err { color: #ffb0a8; font-size: 13.5px; min-height: 20px; margin-top: 10px; }
.ps-gate__hint { font-size: 12.5px; color: rgba(242, 240, 234, .55); margin: 12px 0 0; }
.ps-gate__hint a { color: var(--ps-ember-hot); }
.ps-gate.shake .ps-gate__card { animation: ps-shake .4s; }
@keyframes ps-shake { 20%, 60% { transform: translateX(-7px); } 40%, 80% { transform: translateX(7px); } }

/* ============================ APP SHELL ============================ */
.ps-header { background: var(--ps-char); color: var(--ps-chalk); position: sticky; top: 0; z-index: 40; box-shadow: 0 2px 10px rgba(16, 18, 22, .35); }
.ps-header__in { display: flex; align-items: center; gap: 18px; padding: 10px 0; }
.ps-tabs { display: flex; gap: 4px; margin-left: auto; }
.ps-tabs a {
  color: rgba(242, 240, 234, .82); text-decoration: none; font-family: var(--ps-display); text-transform: uppercase;
  letter-spacing: .06em; font-weight: 700; font-size: 16px; padding: 8px 12px; border-radius: 8px;
  transition: background var(--ps-mid);
}
.ps-tabs a:hover { background: rgba(242, 240, 234, .1); }
.ps-tabs a.on { background: var(--ps-ember); color: #fff; }
@media (max-width: 820px) { .ps-tabs { display: none; } }

.ps-bottomnav { display: none; }
@media (max-width: 820px) {
  .ps-bottomnav {
    display: grid; grid-template-columns: repeat(5, 1fr); position: fixed; bottom: 0; left: 0; right: 0; z-index: 40;
    background: var(--ps-char); border-top: 1px solid rgba(242, 240, 234, .12); padding: 6px 4px calc(6px + env(safe-area-inset-bottom));
  }
  .ps-bottomnav a { color: rgba(242, 240, 234, .75); text-decoration: none; text-align: center; font-size: 10.5px; font-weight: 600; padding: 4px 2px; border-radius: 8px; }
  .ps-bottomnav a svg { display: block; width: 22px; height: 22px; margin: 0 auto 2px; }
  .ps-bottomnav a.on { color: var(--ps-ember-hot); }
  #ps-main { padding-bottom: 84px !important; }
}

#ps-main { padding: 26px 20px 60px; max-width: 1080px; margin: 0 auto; }
.ps-view-title { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; margin-bottom: 4px; }
.ps-view-title h1 { font-size: clamp(30px, 4.5vw, 42px); text-transform: uppercase; margin: 0; font-weight: 800; }
.ps-view-sub { color: var(--ps-ink-soft); margin: 2px 0 22px; font-size: 14.5px; max-width: 56em; }

.ps-card { background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-radius: var(--ps-radius); padding: 20px; box-shadow: var(--ps-shadow-sm); margin-bottom: 18px; }
.ps-card h2 { font-size: 21px; text-transform: uppercase; letter-spacing: .04em; }
.ps-card h3 { font-size: 17px; }

.ps-field { display: grid; gap: 5px; margin-bottom: 14px; }
.ps-field label { font-size: 13px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--ps-ink-soft); }
.ps-input, .ps-select, .ps-textarea {
  border: 1.5px solid var(--ps-line); border-radius: 10px; padding: 10px 14px; background: #fff; width: 100%;
}
.ps-input:focus, .ps-select:focus, .ps-textarea:focus { border-color: var(--ps-ember); outline: none; box-shadow: 0 0 0 3px rgba(232, 99, 44, .16); }
.ps-row { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.ps-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 700px) { .ps-grid2 { grid-template-columns: 1fr; } }

.ps-note { font-size: 13px; color: var(--ps-ink-soft); }
.ps-callout { border-left: 4px solid var(--ps-ember); background: var(--ps-ember-soft); border-radius: 8px; padding: 12px 16px; font-size: 13.5px; margin: 12px 0; }
.ps-callout--safety { border-left-color: var(--ps-safety); background: var(--ps-safety-soft); }
.ps-callout--danger { border-left-color: var(--ps-danger); background: var(--ps-danger-soft); }

.ps-chip {
  display: inline-flex; align-items: center; gap: 6px; background: rgba(139, 147, 158, .16); color: var(--ps-ink);
  border-radius: 999px; padding: 5px 13px; font-size: 13.5px; font-weight: 600; border: 0;
  transition: background var(--ps-mid);
}
.ps-chip--slate { background: var(--ps-char-2); color: var(--ps-chalk); }
.ps-chip--ember { background: var(--ps-ember-soft); color: var(--ps-ember-deep); }

/* meat template picker */
.ps-meats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 860px) { .ps-meats { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .ps-meats { grid-template-columns: 1fr; } }
.ps-meat {
  text-align: left; background: #fff; border: 2px solid var(--ps-line); border-radius: 12px; padding: 14px 16px;
  transition: border-color var(--ps-mid), background var(--ps-mid), box-shadow var(--ps-slow);
}
.ps-meat:hover { border-color: var(--ps-ember); }
.ps-meat.on { border-color: var(--ps-ember); background: var(--ps-ember-soft); box-shadow: 0 0 0 4px rgba(232, 99, 44, .12); }
.ps-meat b { font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .04em; font-size: 19px; display: block; }
.ps-meat span { font-size: 12.5px; color: var(--ps-ink-soft); display: block; }

/* ============================ THE SLATE TIMELINE (signature) ============================ */
.ps-board {
  background:
    radial-gradient(circle at 22% 28%, rgba(242, 240, 234, .05) 0 1.6px, transparent 2.6px),
    radial-gradient(circle at 68% 62%, rgba(242, 240, 234, .04) 0 1.4px, transparent 2.4px),
    radial-gradient(circle at 42% 84%, rgba(0, 0, 0, .28) 0 1.8px, transparent 2.8px),
    linear-gradient(168deg, var(--ps-char-2), var(--ps-slate) 55%, #1d2025);
  background-size: 90px 90px, 120px 120px, 105px 105px, 100% 100%;
  border: 10px solid #4a3d33;
  border-radius: 12px;
  box-shadow: inset 0 2px 14px rgba(0, 0, 0, .5), var(--ps-shadow);
  padding: 24px 20px;
  color: var(--ps-chalk);
  position: relative;
}
.ps-board__head { text-align: center; margin-bottom: 6px; }
.ps-board__title {
  font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .14em; font-weight: 800; font-size: 22px;
  display: inline-block; padding-bottom: 4px; border-bottom: 2px dashed rgba(242, 240, 234, .35);
}
.ps-board__sub { display: block; font-size: 12.5px; color: rgba(242, 240, 234, .62); margin-top: 6px; }
.ps-board__fire {
  text-align: center; font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .06em;
  font-size: clamp(22px, 3.4vw, 30px); font-weight: 800; color: var(--ps-ember-hot); margin: 10px 0 16px;
}
.ps-board__fire small { display: block; font-family: var(--ps-body); font-weight: 600; font-size: 12px; letter-spacing: .08em; color: rgba(242, 240, 234, .6); }

.ps-slats { list-style: none; margin: 0; padding: 0 0 0 92px; position: relative; }
.ps-slats::before { /* chalk spine */
  content: ""; position: absolute; left: 80px; top: 6px; bottom: 6px; width: 0;
  border-left: 2px dashed rgba(242, 240, 234, .3);
}
.ps-slat {
  position: relative; margin: 0 0 10px;
  background: rgba(242, 240, 234, .07);
  border: 1px solid rgba(242, 240, 234, .14);
  border-left: 5px solid var(--ps-smoke);
  border-radius: 8px; padding: 10px 14px;
  animation: ps-slat-in var(--ps-slow) ease both;
  animation-delay: var(--delay, 0ms);
}
@keyframes ps-slat-in {
  from { opacity: 0; transform: translateX(14px); }
  to { opacity: 1; transform: translateX(0); }
}
.ps-slat--prep { border-left-color: var(--ps-smoke); }
.ps-slat--fire { border-left-color: var(--ps-ember-hot); background: rgba(232, 99, 44, .12); }
.ps-slat--cook { border-left-color: var(--ps-ember); }
.ps-slat--rest { border-left-color: var(--ps-tan); }
.ps-slat--serve { border-left-color: var(--ps-chalk); }
.ps-slat__time {
  position: absolute; left: -92px; top: 10px; width: 78px; text-align: right;
  font-family: var(--ps-display); font-weight: 700; font-size: 16px; letter-spacing: .03em; color: var(--ps-chalk); line-height: 1.15;
}
.ps-slat__time small { display: block; font-family: var(--ps-body); font-weight: 600; font-size: 10px; letter-spacing: .06em; color: var(--ps-ember-hot); text-transform: uppercase; }
.ps-slat__tick { /* chalk tick where the slat meets the spine */
  content: ""; position: absolute; left: -15px; top: 16px; width: 12px; height: 0;
  border-top: 2px solid rgba(242, 240, 234, .55);
}
.ps-slat__name { font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .05em; font-weight: 700; font-size: 17.5px; }
.ps-slat__meta { font-size: 12px; color: rgba(242, 240, 234, .66); margin-top: 1px; }
.ps-slat__meta .ps-way { color: var(--ps-ember-hot); font-weight: 700; }
.ps-slat__note { font-size: 12.5px; color: rgba(242, 240, 234, .78); margin-top: 6px; }
.ps-slat--done { opacity: .55; }
.ps-slat--now { box-shadow: 0 0 0 2px var(--ps-ember-hot), 0 0 22px rgba(255, 138, 74, .3); }
.ps-slat--now::after {
  content: "Now"; position: absolute; right: 10px; top: 8px;
  font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .1em; font-size: 12px; font-weight: 700;
  color: var(--ps-ember-hot); animation: ps-glow 2.4s ease-in-out infinite;
}
@keyframes ps-glow { 0%, 100% { opacity: .55; } 50% { opacity: 1; } }
.ps-slat__check { position: absolute; right: 10px; bottom: 8px; }
.ps-slat__check input { width: 18px; height: 18px; accent-color: var(--ps-ember); }

.ps-board__temps { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.ps-board__temps > span { font-size: 12.5px; padding: 6px 12px; border-radius: 6px; font-weight: 600; }
.ps-board__temps .t-safety { background: rgba(46, 125, 91, .25); color: #9fd8bd; border: 1px solid rgba(46, 125, 91, .5); }
.ps-board__temps .t-target { background: rgba(232, 99, 44, .18); color: var(--ps-ember-hot); border: 1px solid rgba(232, 99, 44, .45); }

/* ============================ LIVE COOK LOG ============================ */
.ps-log { display: grid; gap: 8px; margin-top: 12px; }
.ps-log__entry {
  display: grid; grid-template-columns: 74px 1fr auto; gap: 12px; align-items: baseline;
  background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-radius: 10px; padding: 9px 14px; font-size: 14px;
}
.ps-log__entry time { font-family: var(--ps-display); font-weight: 700; font-size: 15px; color: var(--ps-ink-soft); }
.ps-log__entry .temp { font-family: var(--ps-display); font-weight: 800; font-size: 18px; color: var(--ps-ember-deep); }
.ps-log__del { background: none; border: 0; color: var(--ps-ink-soft); font-weight: 700; padding: 0 4px; }
.ps-log__del:hover { color: var(--ps-danger); }

.ps-stall {
  border: 2px dashed var(--ps-smoke); border-radius: 12px; padding: 14px 18px; margin-top: 14px;
  background: rgba(139, 147, 158, .08); font-size: 13.5px;
}
.ps-stall b { font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .06em; font-size: 16px; }

/* rating stars (accessible buttons, drawn — not emoji) */
.ps-stars { display: inline-flex; gap: 4px; }
.ps-stars button { background: none; border: 0; padding: 2px; line-height: 0; }
.ps-stars svg { width: 26px; height: 26px; fill: rgba(139, 147, 158, .35); transition: fill var(--ps-mid); }
.ps-stars button.on svg { fill: var(--ps-ember); }

/* ============================ PIT BOOK ============================ */
.ps-cookrow {
  display: grid; grid-template-columns: 54px 1fr auto; gap: 14px; align-items: center;
  background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-radius: 12px; padding: 12px 16px; margin-bottom: 10px;
  box-shadow: var(--ps-shadow-sm);
}
.ps-cookrow__icon { width: 54px; height: 54px; border-radius: 10px; background: var(--ps-char-2); display: flex; align-items: center; justify-content: center; }
.ps-cookrow__icon svg { width: 34px; height: 34px; }
.ps-cookrow b { font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .03em; font-size: 18px; display: block; }
.ps-cookrow small { color: var(--ps-ink-soft); font-size: 12.5px; }
.ps-compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 720px) { .ps-compare-grid { grid-template-columns: 1fr; } }

/* ============================ TEMPS CHART ============================ */
.ps-temps-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.ps-temps-table th { text-align: left; font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .06em; font-size: 13.5px; color: var(--ps-ink-soft); padding: 8px 10px; border-bottom: 2px solid var(--ps-line); }
.ps-temps-table td { padding: 9px 10px; border-bottom: 1px solid var(--ps-line); vertical-align: top; }
.ps-temps-table .big { font-family: var(--ps-display); font-weight: 800; font-size: 22px; white-space: nowrap; }
.ps-temps-table .big.safety { color: var(--ps-safety); }
.ps-temps-table .big.target { color: var(--ps-ember-deep); }

/* ============================ COACH ============================ */
.ps-coach-log { display: grid; gap: 12px; margin: 16px 0; }
.ps-msg { max-width: 46em; padding: 12px 16px; border-radius: 14px; font-size: 14.5px; }
.ps-msg--me { background: var(--ps-char-2); color: var(--ps-chalk); justify-self: end; border-bottom-right-radius: 4px; }
.ps-msg--coach { background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-bottom-left-radius: 4px; box-shadow: var(--ps-shadow-sm); }
.ps-msg--coach .ps-cite { margin-top: 10px; padding-top: 8px; border-top: 1px dashed var(--ps-line); font-size: 12px; color: var(--ps-ink-soft); }
.ps-grade { display: inline-block; font-weight: 800; font-size: 10.5px; border-radius: 4px; padding: 1px 6px; margin-right: 6px; vertical-align: 1px; }
.ps-grade--A { background: var(--ps-safety-soft); color: var(--ps-safety); }
.ps-grade--B { background: var(--ps-ember-soft); color: var(--ps-ember-deep); }
.ps-grade--C { background: rgba(139, 147, 158, .18); color: var(--ps-ink-soft); }
.ps-grade--D { background: var(--ps-danger-soft); color: var(--ps-danger); }
.ps-coach-form { display: flex; gap: 10px; }
.ps-coach-form input { flex: 1; }
.ps-suggest { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }

/* mascot corner */
.ps-ember-mascot { display: flex; align-items: center; gap: 14px; }
.ps-ember-mascot svg { width: 74px; height: 74px; flex: none; }
.ps-ember-mascot p { font-size: 13.5px; color: var(--ps-ink-soft); margin: 0; max-width: 40em; }
.ps-mascot-flame { animation: ps-flicker 3.2s ease-in-out infinite; transform-origin: 50% 90%; }
@keyframes ps-flicker { 0%, 100% { transform: scale(1); } 40% { transform: scale(1.05) rotate(-1.4deg); } 70% { transform: scale(.97) rotate(1deg); } }

/* ============================ TOAST + REWARD (rising embers) ============================ */
.ps-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--ps-char); color: var(--ps-chalk); border-radius: 999px; padding: 11px 22px;
  font-size: 14px; font-weight: 600; box-shadow: var(--ps-shadow); opacity: 0; pointer-events: none;
  transition: opacity var(--ps-slow), transform var(--ps-slow); z-index: 90; max-width: min(92vw, 480px); text-align: center;
}
.ps-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

.ps-embers { position: fixed; inset: 0; pointer-events: none; z-index: 95; overflow: hidden; }
.ps-embers i {
  position: absolute; bottom: -12px; width: 7px; height: 7px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--ps-ember-hot), var(--ps-ember) 70%);
  box-shadow: 0 0 8px 2px rgba(255, 138, 74, .5);
  animation: ps-rise ease-out both;
}
@keyframes ps-rise {
  from { transform: translateY(0) translateX(0) scale(1); opacity: 1; }
  60% { opacity: .95; }
  to { transform: translateY(-105vh) translateX(var(--sway, 0px)) scale(.35); opacity: 0; }
}

/* upgrade panel */
.ps-upgrade { border: 2px solid var(--ps-ember); border-radius: var(--ps-radius); background: var(--ps-ember-soft); padding: 20px; }
.ps-upgrade h3 { text-transform: uppercase; font-size: 20px; }

/* ============================ TRUST BAND (hero) ============================ */
.pl-trust { list-style: none; padding: 0; margin: 18px 0 0; display: flex; flex-wrap: wrap; gap: 8px 18px; }
.pl-trust li { display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; font-weight: 700; color: var(--ps-ink-soft); }
.pl-trust svg { width: 18px; height: 18px; flex: none; }

/* ============================ FOUNDER + CAPTURE ============================ */
.pl-founder { display: grid; grid-template-columns: 1.15fr .85fr; gap: 34px; align-items: start; }
@media (max-width: 860px) { .pl-founder { grid-template-columns: 1fr; gap: 26px; } }
.pl-founder__note .pl-h2 { margin-top: 12px; color: var(--ps-chalk); }
.pl-founder__note p { color: rgba(242, 240, 234, .82); font-size: 15px; margin: 0 0 12px; }
.pl-founder__sign { font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .06em; color: var(--ps-ember-hot) !important; font-weight: 700; }

.pl-capture { background: var(--ps-paper-2); border: 1px solid var(--ps-line); border-radius: var(--ps-radius); padding: 24px; box-shadow: var(--ps-shadow-sm); }
.pl-capture h3 { font-size: 21px; text-transform: uppercase; letter-spacing: .03em; margin: 0 0 6px; }
.pl-capture__lede { font-size: 14px; color: var(--ps-ink-soft); margin: 0 0 16px; }
.pl-capture__row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.pl-capture__row .ps-input { flex: 1; min-width: 170px; }
.pl-capture__fine { font-size: 12px; color: var(--ps-ink-soft); margin: 12px 0 0; }
.pl-capture__msg { font-size: 13.5px; font-weight: 600; color: var(--ps-ember-deep); margin: 10px 0 0; min-height: 1.2em; }

/* consent checkboxes — two, both default OFF, plainly labeled (used on landing + in-app) */
.pl-consent { display: flex; align-items: flex-start; gap: 9px; font-size: 13px; color: var(--ps-ink-soft); margin: 6px 0; cursor: pointer; line-height: 1.4; }
.pl-consent input { margin-top: 2px; width: 17px; height: 17px; flex: none; accent-color: var(--ps-ember); }
.ps-capture { border: 2px dashed var(--ps-ember); }

/* ============================ CROSS-SELL (Also from Apps 4 That) ============================ */
.a4t-crosssell { width: 100%; margin-top: 30px; padding-top: 24px; border-top: 1px dashed rgba(242, 240, 234, .22); display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; align-items: stretch; }
.a4t-crosssell__label { width: 100%; text-align: center; font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .14em; font-size: 12.5px; font-weight: 700; color: var(--ps-ember-hot); margin: 0 0 4px; }
.a4t-crosssell__card { display: flex; flex-direction: column; gap: 3px; min-width: 220px; max-width: 300px; text-decoration: none; background: rgba(242, 240, 234, .06); border: 1px solid rgba(242, 240, 234, .16); border-radius: 12px; padding: 14px 18px; transition: border-color var(--ps-mid) ease, transform var(--ps-mid) ease, background var(--ps-mid) ease; }
.a4t-crosssell__card:hover { border-color: var(--ps-ember); background: rgba(232, 99, 44, .1); transform: translateY(-2px); }
.a4t-crosssell__name { font-family: var(--ps-display); text-transform: uppercase; letter-spacing: .04em; font-size: 17px; font-weight: 700; color: var(--ps-chalk); }
.a4t-crosssell__tag { font-size: 13px; color: rgba(242, 240, 234, .72); }

@media print {
  .pl-nav, .ps-header, .ps-bottomnav, .ps-toast, .ps-gate { display: none !important; }
  .ps-board { border-color: #999; }
}

/* Mobile launch polish: contain the dark hero and keep action rows readable. */
@media (max-width: 600px) {
  html, body, #ps-app { max-width: 100%; overflow-x: hidden; }
  .ps-wrap { width: 100%; padding: 0 18px; }
  .pl-nav__in { gap: 12px; }
  .pl-brand { min-width: 0; }
  .pl-brand__mark { width: 34px; height: 34px; }
  .pl-brand__name { font-size: 21px; }
  .pl-brand__tag { font-size: 10.5px; line-height: 1.2; }
  .pl-nav .ps-btn { flex: none; padding: 10px 14px; font-size: 13.5px; white-space: nowrap; }
  .pl-hero__grid { min-width: 0; gap: 26px; padding: 36px 18px 30px; }
  .pl-hero__grid > * { min-width: 0; }
  .pl-kicker { max-width: 100%; align-items: flex-start; font-size: 12.5px; line-height: 1.3; }
  .pl-h1 { font-size: clamp(40px, 12vw, 48px); line-height: 1.03; max-width: 100%; }
  .pl-lede { font-size: 16px; line-height: 1.55; max-width: 100%; }
  .pl-cta-row { display: grid; grid-template-columns: 1fr; gap: 10px; width: 100%; }
  .pl-cta-row .ps-btn { width: 100%; min-width: 0; white-space: normal; text-align: center; }
  .pl-hero .pl-trust li { color: rgba(242, 240, 234, .78); font-size: 12.5px; }
  .pl-hero__media svg { display: block; width: 100%; height: auto; }
  .pl-strip ul { grid-template-columns: 1fr; }
}
