/* Newton Falls — shared styles
   Treasure Hunt Amusement Park
   Brand palette: deep purple #2D1B47, gold #D19900, cream #FCF3E5, ink #28251D */

:root{
  --purple:#2D1B47;
  --purple-deep:#1f1232;
  --purple-soft:#3d2a5e;
  --gold:#D19900;
  --gold-bright:#e6b220;
  --gold-soft:#f0d27a;
  --cream:#FCF3E5;
  --cream-warm:#f6e8cf;
  --ink:#28251D;
  --paper:#fffaf0;
  --line:rgba(40,37,29,.18);
  --shadow-sm:0 2px 6px rgba(31,18,50,.12);
  --shadow-md:0 8px 24px rgba(31,18,50,.18);
  --shadow-lg:0 16px 48px rgba(31,18,50,.25);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream);
}

/* ===== Header ===== */
.nf-topbar{
  background:var(--purple);
  color:var(--cream);
  padding:14px 24px;
  border-bottom:3px solid var(--gold);
}
.nf-topbar-inner{
  max-width:1180px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.nf-back{
  color:var(--cream);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  letter-spacing:.04em;
  text-transform:uppercase;
  opacity:.85;
  transition:opacity .15s;
}
.nf-back:hover{opacity:1;color:var(--gold-bright);}
.nf-park-mark{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:'Playfair Display',Georgia,serif;
  font-weight:700;
  font-size:15px;
  letter-spacing:.05em;
  color:var(--gold-soft);
  text-transform:uppercase;
}
.nf-park-mark::before{
  content:"⚙";
  color:var(--gold);
  font-size:18px;
}

/* ===== Hero ===== */
.nf-hero{
  background:linear-gradient(180deg,var(--purple) 0%,var(--purple-deep) 100%);
  color:var(--cream);
  padding:48px 24px 56px;
  position:relative;
  overflow:hidden;
}
.nf-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 600px 300px at 20% 0%,rgba(209,153,0,.12),transparent 60%),
    radial-gradient(ellipse 400px 200px at 90% 100%,rgba(209,153,0,.08),transparent 60%);
  pointer-events:none;
}
.nf-hero-inner{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:48px;
  align-items:center;
  position:relative;
}
.nf-hero-text .eyebrow{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold-bright);
  font-weight:700;
  margin:0 0 12px;
}
.nf-hero-text h1{
  font-family:'Playfair Display',Georgia,serif;
  font-weight:900;
  font-size:clamp(2.2rem,4.5vw,3.6rem);
  line-height:1.05;
  margin:0 0 16px;
  color:var(--cream);
}
.nf-hero-text .creator{
  font-size:18px;
  color:var(--gold-soft);
  margin:0 0 20px;
  font-style:italic;
}
.nf-hero-text .desc{
  font-size:18px;
  line-height:1.55;
  margin:0 0 24px;
  color:rgba(252,243,229,.92);
}
.nf-stats{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  padding:18px 22px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(209,153,0,.3);
  border-radius:10px;
  backdrop-filter:blur(4px);
}
.nf-stat{display:flex;flex-direction:column;gap:2px;}
.nf-stat .num{
  font-family:'Playfair Display',Georgia,serif;
  font-size:24px;
  font-weight:900;
  color:var(--gold-bright);
  line-height:1;
}
.nf-stat .lbl{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(252,243,229,.7);
}
.nf-hero-img{
  border-radius:12px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  border:3px solid var(--gold);
}
.nf-hero-img img{display:block;width:100%;height:auto;}

@media (max-width:860px){
  .nf-hero{padding:32px 20px 40px;}
  .nf-hero-inner{grid-template-columns:1fr;gap:28px;}
}

/* ===== Section nav ===== */
.nf-section-nav{
  background:var(--cream-warm);
  border-bottom:1px solid var(--line);
  padding:14px 24px;
  position:sticky;
  top:0;
  z-index:10;
  box-shadow:0 2px 6px rgba(0,0,0,.04);
}
.nf-section-nav-inner{
  max-width:1180px;
  margin:0 auto;
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  font-size:14px;
}
.nf-section-nav a{
  color:var(--ink);
  text-decoration:none;
  font-weight:600;
  padding:6px 12px;
  border-radius:6px;
  transition:background .15s;
}
.nf-section-nav a:hover,.nf-section-nav a.active{
  background:var(--purple);
  color:var(--cream);
}

/* ===== Main content ===== */
.nf-main{max-width:1180px;margin:0 auto;padding:48px 24px 64px;}
.nf-section{margin-bottom:56px;scroll-margin-top:80px;}
.nf-section h2{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(1.6rem,3vw,2.4rem);
  color:var(--purple);
  margin:0 0 8px;
  font-weight:900;
  border-bottom:3px solid var(--gold);
  padding-bottom:12px;
}
.nf-section h3{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.4rem;
  color:var(--purple-soft);
  margin:24px 0 12px;
}
.nf-section h4{
  font-size:1.05rem;
  color:var(--purple);
  margin:18px 0 8px;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.nf-section p{margin:0 0 14px;}
.nf-lead{font-size:18px;color:var(--ink);}

/* ===== Cards ===== */
.nf-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:12px;
  padding:24px 28px;
  margin:18px 0;
  box-shadow:var(--shadow-sm);
}
.nf-card.featured{
  border-left:5px solid var(--gold);
  background:linear-gradient(180deg,var(--paper),var(--cream-warm));
}

/* ===== Clue blocks ===== */
.clue-block{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:14px;
  margin:32px 0;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.clue-header{
  background:linear-gradient(135deg,var(--purple) 0%,var(--purple-soft) 100%);
  color:var(--cream);
  padding:20px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.clue-header .clue-num{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.6rem;
  font-weight:900;
  color:var(--gold-bright);
}
.clue-header .clue-date{
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(252,243,229,.85);
}
.clue-status{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  background:var(--gold);
  color:var(--ink);
  padding:4px 10px;
  border-radius:999px;
  font-weight:700;
}
.clue-status.upcoming{background:rgba(252,243,229,.18);color:var(--cream);}
.clue-body{padding:24px 32px 28px;}

/* Verse text — the clue itself */
.verse{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.15rem;
  line-height:1.65;
  color:var(--ink);
  background:var(--cream-warm);
  border-left:4px solid var(--gold);
  padding:22px 28px;
  margin:14px 0 22px;
  border-radius:0 8px 8px 0;
  font-style:italic;
  white-space:pre-line;
}
.verse strong{color:var(--purple);font-style:normal;}
.preamble{
  font-size:1rem;
  font-style:italic;
  color:rgba(40,37,29,.78);
  background:rgba(252,243,229,.6);
  border-left:3px solid var(--purple-soft);
  padding:14px 22px;
  margin:14px 0;
  border-radius:0 6px 6px 0;
  white-space:pre-line;
}

/* Latin block */
.latin-block{
  background:linear-gradient(180deg,#fff8e7,#fdebbf);
  border:1px solid rgba(209,153,0,.35);
  border-radius:10px;
  padding:18px 24px;
  margin:18px 0;
}
.latin-block .latin{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.15rem;
  font-style:italic;
  color:var(--purple-deep);
  margin:0 0 8px;
}
.latin-block .translation{
  font-size:.95rem;
  color:var(--ink);
  margin:0;
}
.latin-block .label{
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
  margin:0 0 6px;
}

/* Hooks list */
.hooks{margin:14px 0;padding-left:0;list-style:none;}
.hooks li{
  position:relative;
  padding:8px 0 8px 28px;
  border-bottom:1px dashed var(--line);
  font-size:.97rem;
}
.hooks li:last-child{border-bottom:none;}
.hooks li::before{
  content:"◆";
  position:absolute;
  left:6px;
  top:8px;
  color:var(--gold);
  font-size:.85rem;
}

/* Tables */
.nf-table{
  width:100%;
  border-collapse:collapse;
  margin:14px 0 22px;
  font-size:.95rem;
  background:var(--paper);
  border-radius:8px;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.nf-table thead{background:var(--purple);color:var(--cream);}
.nf-table th,.nf-table td{
  padding:10px 14px;
  text-align:left;
  border-bottom:1px solid var(--line);
}
.nf-table tbody tr:nth-child(even){background:rgba(209,153,0,.06);}
.nf-table tbody tr:last-child td{border-bottom:none;}
.nf-table .status-released{color:#1e7c3a;font-weight:700;}
.nf-table .status-upcoming{color:var(--purple-soft);font-weight:700;}

/* Schedule pill */
.pill{
  display:inline-block;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:700;
  padding:4px 10px;
  border-radius:999px;
}
.pill-released{background:#d4f0d4;color:#1e7c3a;}
.pill-upcoming{background:#f3e5b4;color:#7a5a00;}

/* Transcript index list */
.tx-list{display:grid;gap:14px;margin:0;padding:0;list-style:none;}
.tx-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-left:4px solid var(--gold);
  border-radius:10px;
  padding:18px 22px;
  display:block;
  text-decoration:none;
  color:var(--ink);
  transition:transform .15s,box-shadow .15s,border-color .15s;
}
.tx-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-left-color:var(--purple);
}
.tx-card .tx-meta{
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
  margin:0 0 4px;
}
.tx-card .tx-title{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.2rem;
  color:var(--purple);
  margin:0 0 8px;
  font-weight:700;
}
.tx-card .tx-summary{font-size:.95rem;color:var(--ink);margin:0;}

/* Quotes inside transcripts */
blockquote.nf-quote{
  border-left:4px solid var(--gold);
  background:var(--cream-warm);
  margin:14px 0;
  padding:14px 22px;
  border-radius:0 8px 8px 0;
  font-style:italic;
  color:var(--ink);
}
blockquote.nf-quote p:last-child{margin-bottom:0;}

/* Source links bar */
.sources{
  background:var(--cream-warm);
  border:1px solid var(--line);
  border-radius:10px;
  padding:16px 20px;
  margin:18px 0;
  font-size:.92rem;
}
.sources strong{color:var(--purple);}
.sources a{color:var(--purple);text-decoration:underline;text-decoration-color:var(--gold);}
.sources a:hover{color:var(--gold);}

/* Inline links */
.nf-section a{color:var(--purple);text-decoration:underline;text-decoration-color:var(--gold-soft);}
.nf-section a:hover{color:var(--gold);text-decoration-color:var(--gold);}

/* Callout */
.callout{
  background:linear-gradient(180deg,#fdebbf,#f6e8cf);
  border:1px solid rgba(209,153,0,.4);
  border-radius:10px;
  padding:18px 22px;
  margin:18px 0;
}
.callout .label{
  display:inline-block;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink);
  background:var(--gold);
  padding:3px 10px;
  border-radius:999px;
  font-weight:700;
  margin:0 0 8px;
}
.callout p{margin:6px 0;font-size:.97rem;}

/* Footer */
.nf-footer{
  background:var(--purple-deep);
  color:rgba(252,243,229,.8);
  padding:32px 24px;
  text-align:center;
  border-top:3px solid var(--gold);
  font-size:.92rem;
}
.nf-footer a{color:var(--gold-bright);text-decoration:none;}
.nf-footer a:hover{text-decoration:underline;}

/* Utility */
.no-marker{list-style:none;padding-left:0;}
.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 14px;}
.tag{
  display:inline-block;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:700;
  background:var(--purple);
  color:var(--cream);
  padding:5px 12px;
  border-radius:999px;
}
.tag-gold{background:var(--gold);color:var(--ink);}

/* Ticket Counter (matches other ride pages, brand-tinted) */
.view-counter-wrap{
  display:flex;
  justify-content:center;
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(209,153,0,.25);
}
.ticket-counter{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  color:var(--gold-bright);
}
.ticket-counter svg{flex:none;}
.ticket-counter .vc-num{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.1rem;
  font-weight:700;
  color:var(--gold-bright);
  font-variant-numeric:tabular-nums;
  letter-spacing:.04em;
}
.ticket-counter .vc-label{
  font-size:.65rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(252,243,229,.6);
  font-weight:600;
}
