/* ════════════════════════════════════════════════════
   WAYBOUND SITE — shared styles
   ════════════════════════════════════════════════════ */

@font-face { font-family:'Cinzel'; src:url('assets/fonts/Cinzel-Regular.ttf') format('truetype'); font-weight:400; font-display:swap; }
@font-face { font-family:'Cinzel'; src:url('assets/fonts/Cinzel-Medium.ttf') format('truetype'); font-weight:500; font-display:swap; }
@font-face { font-family:'Cinzel'; src:url('assets/fonts/Cinzel-SemiBold.ttf') format('truetype'); font-weight:600; font-display:swap; }
@font-face { font-family:'Cinzel'; src:url('assets/fonts/Cinzel-Bold.ttf') format('truetype'); font-weight:700; font-display:swap; }
@font-face { font-family:'Cinzel'; src:url('assets/fonts/Cinzel-ExtraBold.ttf') format('truetype'); font-weight:800; font-display:swap; }
@font-face { font-family:'Cinzel'; src:url('assets/fonts/Cinzel-Black.ttf') format('truetype'); font-weight:900; font-display:swap; }

:root {
  --wb-bg:#0D0A06;
  --wb-card:#1A1208;
  --wb-card-2:#221808;
  --wb-border:#6B4E1A;
  --wb-gold:#D4A017;
  --wb-gold-l:#F5C842;
  --wb-gold-d:#8B6914;
  --wb-gold-pale:#FFF0A0;
  --wb-dim:#9E8860;
  --ink:#3B2A14;
  --e-out:cubic-bezier(.22,.9,.3,1);
}

* { box-sizing:border-box; margin:0; padding:0; }

html, body {
  background:var(--wb-bg);
  color:var(--wb-dim);
  font-family:'Cinzel', 'Times New Roman', serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  scroll-behavior:smooth;
}

body {
  background-image:
    radial-gradient(1200px 800px at 50% -200px, rgba(212,160,23,.08), transparent 60%),
    radial-gradient(800px 600px at 100% 100%, rgba(212,160,23,.04), transparent 50%),
    url('assets/images/app_background.webp');
  background-size:cover;
  background-attachment:fixed;
  background-position:center;
  position:relative;
  min-height:100vh;
}
body::before {
  content:''; position:fixed; inset:0;
  background:linear-gradient(180deg, rgba(13,10,6,.78), rgba(13,10,6,.94));
  pointer-events:none; z-index:0;
}

a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

.container { max-width:1240px; margin:0 auto; padding:0 32px; position:relative; z-index:1; }

section { padding:96px 0; position:relative; z-index:1; }
section.tight { padding:64px 0; }

/* ── TYPE ───────────────────────────────────── */
.eyebrow {
  display:inline-block;
  font-size:11px; letter-spacing:3px; font-weight:700;
  color:var(--wb-gold-d); text-transform:uppercase;
  padding:6px 14px;
  background:rgba(212,160,23,.08);
  border:1px solid rgba(212,160,23,.3);
  border-radius:999px;
}
.h1 {
  font-family:'Cinzel', serif;
  font-size:clamp(40px, 6vw, 72px);
  font-weight:700; letter-spacing:2px; line-height:1.05;
}
.h2 {
  font-family:'Cinzel', serif;
  font-size:clamp(28px, 3.6vw, 44px);
  font-weight:700; letter-spacing:1.5px; line-height:1.1;
}
.h3 {
  font-family:'Cinzel', serif;
  font-size:20px; font-weight:700; letter-spacing:1px;
  color:var(--wb-gold-l);
}
.gold-grad {
  background:linear-gradient(180deg, var(--wb-gold-pale) 0%, var(--wb-gold) 55%, var(--wb-gold-d) 100%);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:0 0 60px rgba(212,160,23,.18);
}
.lede { font-size:18px; line-height:1.65; color:#CFB98A; letter-spacing:.3px; }
.body { font-size:14px; line-height:1.75; color:var(--wb-dim); }

/* ── BUTTONS ───────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px;
  font-family:'Cinzel', serif;
  font-size:12px; letter-spacing:2px; font-weight:700;
  text-transform:uppercase; cursor:pointer;
  border-radius:10px;
  background:transparent; color:var(--wb-dim);
  border:1px solid rgba(107,78,26,.5);
  transition:all .2s var(--e-out);
}
.btn:hover { border-color:var(--wb-gold-d); color:var(--wb-gold); }
.btn--primary {
  background:linear-gradient(180deg, #6B4A00 0%, #3D2A00 100%);
  color:var(--wb-gold-l);
  border:1.5px solid var(--wb-gold);
  box-shadow:0 0 20px rgba(212,160,23,.2);
}
.btn--primary:hover {
  box-shadow:0 0 30px rgba(212,160,23,.45);
  transform:translateY(-1px);
}
.btn svg { width:14px; height:14px; }

/* ── NAV ───────────────────────────────────── */
.nav {
  position:sticky; top:0; z-index:50;
  background:rgba(13,10,6,.7);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(107,78,26,.4);
}
.nav__inner {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 32px;
}
.nav__brand { display:flex; align-items:center; gap:12px; }
.nav__logo { height:36px; width:auto; filter:drop-shadow(0 0 8px rgba(212,160,23,.35)); }
.nav__name {
  font-family:'Cinzel', serif; font-weight:700;
  font-size:13px; letter-spacing:3px;
  color:var(--wb-gold-l); text-transform:uppercase;
}
.nav__links { display:flex; gap:8px; }
.nav__link {
  font-size:11px; letter-spacing:2px; font-weight:600;
  text-transform:uppercase; color:var(--wb-dim);
  padding:10px 14px; border-radius:8px;
  transition:all .2s;
}
.nav__link:hover { color:var(--wb-gold); }
.nav__link.active { color:var(--wb-gold-l); background:rgba(212,160,23,.08); }
.nav__cta {
  font-family:'Cinzel', serif;
  font-size:11px; letter-spacing:2px; font-weight:700;
  text-transform:uppercase; color:var(--wb-gold-l);
  padding:10px 18px; border-radius:8px;
  background:linear-gradient(180deg, #6B4A00, #3D2A00);
  border:1.5px solid var(--wb-gold);
  transition:all .2s;
}
.nav__cta:hover { box-shadow:0 0 16px rgba(212,160,23,.35); }

/* ── HERO ──────────────────────────────────── */
.hero { padding:120px 0 100px; text-align:center; position:relative; overflow:hidden; }
.hero__inner { display:flex; flex-direction:column; align-items:center; gap:22px; }
.hero__logo {
  width:140px; height:auto; margin-bottom:8px;
  filter:drop-shadow(0 0 24px rgba(212,160,23,.35));
  animation:float 6s ease-in-out infinite;
}
@keyframes float { 50% { transform:translateY(-8px); } }
.hero__title { margin:0; }
.hero__sub { max-width:680px; }
.hero__ctas { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:14px; }

/* particles */
.particles { position:absolute; inset:0; pointer-events:none; z-index:1; }
.particles span {
  position:absolute; bottom:-20px;
  width:3px; height:3px; border-radius:50%;
  background:var(--wb-gold-l);
  box-shadow:0 0 8px var(--wb-gold-l);
  opacity:0;
  animation:rise 14s linear infinite;
}
@keyframes rise {
  0% { transform:translateY(0) scale(.3); opacity:0; }
  10% { opacity:.7; }
  90% { opacity:.7; }
  100% { transform:translateY(-100vh) scale(1.1); opacity:0; }
}

.section-divider {
  height:1px;
  background:linear-gradient(90deg, transparent, var(--wb-gold-d), transparent);
  margin:0 auto; max-width:1100px;
}

/* ── GRIDS / CARDS ─────────────────────────── */
.grid { display:grid; gap:20px; }
.grid-3 { grid-template-columns:repeat(3, 1fr); }
.grid-4 { grid-template-columns:repeat(4, 1fr); }

.card {
  padding:28px 24px;
  background:linear-gradient(135deg, rgba(34,24,8,.75), rgba(18,13,4,.85));
  border:1px solid rgba(107,78,26,.5);
  border-radius:14px;
  transition:all .3s var(--e-out);
}
.card:hover {
  border-color:var(--wb-gold-d);
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(0,0,0,.3), 0 0 30px rgba(212,160,23,.08);
}
.card__glyph {
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:rgba(212,160,23,.12);
  border:1px solid rgba(212,160,23,.4);
  color:var(--wb-gold-l);
  margin-bottom:16px;
}
.card__glyph svg { width:18px; height:18px; }
.card__title {
  font-family:'Cinzel', serif; font-weight:700;
  font-size:14px; letter-spacing:2px;
  color:var(--wb-gold-l); text-transform:uppercase;
  margin-bottom:10px;
}
.card__text { font-size:13px; line-height:1.6; color:var(--wb-dim); }

/* ── LORE PAGE ─────────────────────────────── */
.lore-hero {
  padding:120px 0 70px; text-align:center;
  border-bottom:1px solid rgba(107,78,26,.35);
}
.lore-hero__title { margin:0; }
.lore-hero__lede { max-width:680px; margin:24px auto 0; font-style:italic; }

.lore-chapter {
  display:grid;
  grid-template-columns:140px 1fr;
  gap:48px;
  padding:80px 0;
  border-bottom:1px solid rgba(107,78,26,.2);
}
.lore-chapter:last-child { border-bottom:none; }
.lore-chapter__roman {
  font-family:'Cinzel', serif;
  font-size:80px; font-weight:900; letter-spacing:2px;
  background:linear-gradient(180deg, var(--wb-gold-pale), var(--wb-gold-d));
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  line-height:1; padding-top:6px;
  display:flex; flex-direction:column; gap:14px;
}
.lore-chapter__roman small {
  font-size:10px; letter-spacing:2.5px; font-weight:700;
  color:var(--wb-gold-d);
  -webkit-text-fill-color:var(--wb-gold-d);
  text-transform:uppercase;
}
.lore-chapter__title {
  font-family:'Cinzel', serif;
  font-size:clamp(22px, 2.6vw, 32px);
  font-weight:700; letter-spacing:1px;
  color:var(--wb-gold-l);
  margin-bottom:24px; line-height:1.2;
}
.lore-chapter__body p {
  font-size:16px; line-height:1.8; color:#CFB98A;
  margin-bottom:16px; max-width:680px;
}
.lore-chapter__body p strong { color:var(--wb-gold-l); font-weight:700; }
.lore-chapter__body p em { color:var(--wb-gold); font-style:italic; }
.pullquote {
  font-style:italic;
  font-size:18px !important;
  color:var(--wb-gold-l) !important;
  border-left:2px solid var(--wb-gold);
  padding:8px 0 8px 24px !important;
  margin:24px 0 !important;
}

.era-grid {
  display:grid; grid-template-columns:repeat(2, 1fr);
  gap:14px; margin-top:30px;
}
.era {
  padding:18px 20px;
  background:rgba(26,18,8,.6);
  border:1px solid rgba(107,78,26,.45);
  border-radius:10px;
}
.era__num {
  font-size:9px; letter-spacing:2px; font-weight:700;
  color:var(--wb-gold-d); text-transform:uppercase;
  margin-bottom:6px;
}
.era__title {
  font-family:'Cinzel', serif; font-weight:700;
  font-size:14px; color:var(--wb-gold-l);
  margin-bottom:8px; letter-spacing:1px;
}
.era__text { font-size:12px; line-height:1.55; color:var(--wb-dim); }

/* ── NARRATOR PAGE ─────────────────────────── */
.narrator-hero {
  padding:120px 0 50px; text-align:center;
}
.player {
  display:grid; grid-template-columns:120px 1fr;
  gap:24px; align-items:center;
  padding:24px;
  background:linear-gradient(135deg, rgba(34,24,8,.85), rgba(18,13,4,.95));
  border:1px solid var(--wb-gold-d);
  border-radius:16px;
  margin-bottom:60px;
  box-shadow:0 0 40px rgba(212,160,23,.12);
}
.player__visual {
  width:100px; height:100px; border-radius:50%;
  background:radial-gradient(circle, rgba(212,160,23,.3), rgba(212,160,23,.05));
  display:flex; align-items:center; justify-content:center;
  position:relative;
  border:1px solid rgba(212,160,23,.4);
}
.player__visual::before {
  content:''; position:absolute; inset:-8px;
  border-radius:50%; border:2px solid transparent;
  border-top-color:var(--wb-gold-l);
  opacity:0;
  transition:opacity .3s;
}
.player__visual.playing::before {
  opacity:1; animation:spin 1.6s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }
.player__inner {
  width:64px; height:64px; border-radius:50%;
  background:linear-gradient(180deg, var(--wb-gold-l), var(--wb-gold-d));
  display:flex; align-items:center; justify-content:center;
  color:#1a1208;
  box-shadow:0 0 20px rgba(212,160,23,.4);
}
.player__label {
  font-size:10px; letter-spacing:2px; font-weight:700;
  color:var(--wb-gold-d); text-transform:uppercase;
  margin-bottom:6px;
}
.player__title {
  font-family:'Cinzel', serif; font-weight:700;
  font-size:22px; color:var(--wb-gold-l);
  letter-spacing:1px; margin-bottom:14px;
}
.player__controls {
  display:flex; align-items:center; gap:14px;
}
.player__btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Cinzel', serif;
  font-size:11px; letter-spacing:2px; font-weight:700;
  text-transform:uppercase;
  padding:10px 16px;
  background:linear-gradient(180deg, #6B4A00, #3D2A00);
  color:var(--wb-gold-l);
  border:1.5px solid var(--wb-gold);
  border-radius:8px;
  cursor:pointer;
}
.player__btn:hover { box-shadow:0 0 16px rgba(212,160,23,.4); }
.player__btn svg { width:10px; height:10px; }
.player__progress {
  flex:1; height:3px;
  background:rgba(107,78,26,.4);
  border-radius:2px; overflow:hidden;
}
.player__progress span {
  display:block; height:100%; width:0%;
  background:linear-gradient(90deg, var(--wb-gold-d), var(--wb-gold-l));
  transition:width .12s linear;
}
.player__time {
  font-size:11px; color:var(--wb-gold-d);
  font-variant-numeric:tabular-nums; letter-spacing:1px;
}

.script {
  max-width:760px; margin:0 auto;
  padding:40px 0;
  position:relative;
}
.script::before {
  content:''; position:absolute;
  left:32px; top:0; bottom:0;
  width:1px; background:linear-gradient(180deg, transparent, var(--wb-gold-d), transparent);
}
.line {
  display:grid; grid-template-columns:80px 1fr;
  gap:20px; padding:14px 0;
  align-items:flex-start;
  opacity:.55; transition:all .4s var(--e-out);
}
.line.spoken { opacity:.4; }
.line.active {
  opacity:1; transform:translateX(4px);
}
.line__num {
  font-family:'Cinzel', serif;
  font-size:10px; letter-spacing:2px; font-weight:700;
  color:var(--wb-gold-d);
  padding-top:6px;
  text-align:right;
}
.line.active .line__num { color:var(--wb-gold-l); }
.line__text {
  font-family:'Cinzel', serif;
  font-size:18px; line-height:1.6; color:#CFB98A;
  letter-spacing:.3px;
}
.line.active .line__text {
  color:var(--wb-gold-l);
  text-shadow:0 0 24px rgba(245,200,66,.3);
}
.line.shout .line__text {
  font-size:22px; font-weight:700;
  color:var(--wb-gold);
}
.line.silent .line__text {
  font-style:italic; font-size:13px;
  color:var(--wb-gold-d); opacity:.7;
}
.line__cue {
  display:block;
  margin-top:8px;
  font-family:'Cinzel', serif;
  font-size:10px; letter-spacing:1.5px; font-weight:600;
  color:var(--wb-gold-d); text-transform:uppercase;
  opacity:.7;
}
.line em { font-style:italic; color:var(--wb-gold); }

/* ── FOOTER ────────────────────────────────── */
.footer {
  border-top:1px solid rgba(107,78,26,.4);
  padding:60px 0 30px;
  background:rgba(13,10,6,.6);
}
.footer__grid {
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:48px;
  margin-bottom:40px;
}
.footer__brand { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.footer__logo { height:42px; width:auto; }
.footer__name {
  font-family:'Cinzel', serif; font-weight:700;
  font-size:14px; letter-spacing:3px;
  color:var(--wb-gold-l); text-transform:uppercase;
}
.footer__tag {
  font-size:10px; letter-spacing:2px;
  color:var(--wb-gold-d); margin-top:2px;
  text-transform:uppercase;
}
.footer__about { font-size:13px; line-height:1.7; color:var(--wb-dim); max-width:420px; }
.footer__col h4 {
  font-family:'Cinzel', serif; font-weight:700;
  font-size:11px; letter-spacing:2.5px;
  color:var(--wb-gold-l); text-transform:uppercase;
  margin-bottom:14px;
}
.footer__col ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.footer__col a {
  font-size:13px; color:var(--wb-dim);
  transition:color .2s;
}
.footer__col a:hover { color:var(--wb-gold-l); }
.footer__legal {
  border-top:1px solid rgba(107,78,26,.3);
  padding-top:20px;
  font-size:11px; letter-spacing:1.5px;
  color:var(--wb-gold-d); text-align:center;
}

/* ── RESPONSIVE ────────────────────────────── */
@media (max-width:980px) {
  .grid-4 { grid-template-columns:repeat(2, 1fr); }
  .grid-3 { grid-template-columns:1fr; }
  .lore-chapter { grid-template-columns:1fr; gap:20px; padding:60px 0; }
  .lore-chapter__roman { font-size:60px; flex-direction:row; align-items:center; gap:18px; }
  .era-grid { grid-template-columns:1fr; }
  .footer__grid { grid-template-columns:1fr; gap:32px; }
}
@media (max-width:680px) {
  section { padding:64px 0; }
  .container { padding:0 20px; }
  .nav__inner { padding:14px 20px; flex-wrap:wrap; gap:10px; }
  .nav__links { order:3; flex-basis:100%; justify-content:center; gap:4px; }
  .nav__link { padding:8px 10px; font-size:10px; }
  .grid-4 { grid-template-columns:1fr; }
  .player { grid-template-columns:1fr; text-align:center; }
  .player__visual { margin:0 auto; }
  .player__controls { flex-wrap:wrap; justify-content:center; }
  .line { grid-template-columns:50px 1fr; gap:12px; }
  .line__text { font-size:16px; }
  .line.shout .line__text { font-size:18px; }
  .script::before { left:18px; }
  .hero { padding:80px 0 60px; }
}
