/* =============================================================
   Puddleford - Shared Stylesheet | A Town with a Tale | MKTOC
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600&family=Source+Serif+4:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');

:root {
  --bg:           #1a120a;
  --bg-card:      #241810;
  --bg-secondary: #180e06;
  --text:         #f2e8d5;
  --text-muted:   #9a8870;
  --gold:         #d4982a;
  --gold-light:   #f0b840;
  --border:       #3a2010;
  --border-gold:  #6a4a1a;
  --radius:       6px;
  --radius-lg:    12px;
  --shadow:       0 4px 24px rgba(0,0,0,0.5);
  --shadow-gold:  0 0 20px rgba(212,152,42,0.15);
  --transition:   0.25s ease;
  --max-width:    1100px;
  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body:    'Source Serif 4', Georgia, serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:17px;line-height:1.7;min-height:100vh}
img{max-width:100%;display:block}
a{color:var(--gold);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--gold-light)}
h1,h2,h3,h4,h5{font-family:var(--font-heading);line-height:1.2;color:var(--text)}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
ul{list-style:none}

.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}
.section{padding:4rem 0}
.divider{border:none;border-top:1px solid var(--border-gold);margin:2rem 0;opacity:0.5}
.ornament{display:block;text-align:center;color:var(--gold);opacity:0.5;font-size:1.2rem;letter-spacing:0.5rem;margin:1.5rem 0}

/* NAV */
.nav{position:sticky;top:0;z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-gold);box-shadow:0 2px 16px rgba(0,0,0,0.6)}
.nav__inner{display:flex;align-items:center;gap:1rem;height:60px;position:relative}
.nav__logo{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--gold);text-decoration:none;white-space:nowrap;flex-shrink:0}
.nav__logo:hover{color:var(--gold-light)}
.nav__links{display:flex;align-items:center;gap:0.15rem;margin-left:auto;flex-wrap:wrap}
.nav__link{color:var(--text-muted);font-family:var(--font-body);font-size:0.92rem;padding:0.4rem 0.75rem;border-radius:var(--radius);transition:color var(--transition),background var(--transition);white-space:nowrap}
.nav__link:hover,.nav__link--active{color:var(--gold);background:rgba(212,152,42,0.08)}
.nav__listen{margin-left:0.5rem;background:var(--gold);color:var(--bg) !important;font-weight:600;padding:0.4rem 1rem;border-radius:20px;font-size:0.88rem;transition:background var(--transition),transform var(--transition)}
.nav__listen:hover{background:var(--gold-light);color:var(--bg) !important;transform:translateY(-1px)}
.nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;margin-left:auto;padding:4px;width:32px;height:32px}.nav__toggle span{display:block;width:24px;height:2px;background:var(--gold);border-radius:2px}

/* HERO */
.hero{position:relative;min-height:80vh;display:flex;align-items:center;overflow:hidden;text-align:center}
.hero__bg{position:absolute;inset:0;background-image:url('../img/cover-no-title.jpg');background-size:cover;background-position:center 20%;opacity:0.28;z-index:0}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(26,18,10,0.3) 0%,rgba(26,18,10,0.1) 40%,rgba(26,18,10,0.8) 85%,var(--bg) 100%);z-index:1}
.hero__content{position:relative;z-index:2;width:100%;padding:5rem 1.5rem 4rem}
.hero__eyebrow{font-family:var(--font-body);font-size:0.85rem;letter-spacing:0.3rem;text-transform:uppercase;color:var(--gold);opacity:0.8;margin-bottom:1rem}
.hero__title{font-family:var(--font-heading);font-size:clamp(3.5rem,10vw,7rem);font-weight:900;color:var(--gold);text-shadow:0 2px 20px rgba(0,0,0,0.8),0 0 60px rgba(212,152,42,0.3);letter-spacing:-0.02em;line-height:1;margin-bottom:0.75rem}
.hero__tagline{font-family:var(--font-heading);font-style:italic;font-size:clamp(1.1rem,3vw,1.6rem);color:var(--text);opacity:0.9;margin-bottom:1.5rem}
.hero__desc{max-width:560px;margin:0 auto 2.5rem;color:var(--text-muted);font-size:1rem;line-height:1.75}

/* LISTEN BUTTONS */
.listen-buttons{display:flex;flex-wrap:wrap;gap:0.75rem;justify-content:center}
.listen-btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.6rem 1.2rem;border:1px solid var(--border-gold);border-radius:30px;background:rgba(36,24,16,0.85);color:var(--text);font-family:var(--font-body);font-size:0.88rem;transition:border-color var(--transition),background var(--transition),transform var(--transition);backdrop-filter:blur(4px)}
.listen-btn:hover{border-color:var(--gold);background:rgba(212,152,42,0.1);color:var(--gold-light);transform:translateY(-2px)}

/* SECTION HEADERS */
.section-header{text-align:center;margin-bottom:3rem}
.section-header__label{display:inline-block;font-size:0.78rem;letter-spacing:0.25rem;text-transform:uppercase;color:var(--gold);opacity:0.8;margin-bottom:0.75rem}
.section-header__title{font-family:var(--font-heading);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--text);margin-bottom:0.75rem}
.section-header__sub{color:var(--text-muted);font-style:italic;font-size:1rem;max-width:520px;margin:0 auto}

/* PAGE HEADER */
.page-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-gold);padding:3.5rem 0 2.5rem;text-align:center;position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;inset:0;background-image:url('../img/cover-no-title.jpg');background-size:cover;background-position:center 30%;opacity:0.08}
.page-header__inner{position:relative;z-index:1}
.page-header__title{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3.5rem);color:var(--gold);margin-bottom:0.5rem}
.page-header__sub{font-style:italic;color:var(--text-muted);font-size:1.05rem}
.page-header__rule{display:block;width:60px;height:1px;background:var(--gold);margin:1.25rem auto 0;opacity:0.6}
.page-header p + .page-header__rule{margin-top:1.25rem}

/* CARDS */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}
.card:hover{border-color:var(--border-gold);box-shadow:var(--shadow-gold);transform:translateY(-3px)}
.card__img{width:100%;aspect-ratio:1;object-fit:cover}
.card__body{padding:1.25rem 1.5rem 1.5rem}
.card__badge{display:inline-block;font-size:0.72rem;letter-spacing:0.12rem;text-transform:uppercase;color:var(--gold);border:1px solid var(--border-gold);border-radius:20px;padding:0.15rem 0.65rem;margin-bottom:0.75rem;font-family:var(--font-body)}
.card__title{font-family:var(--font-heading);font-size:1.1rem;color:var(--text);margin-bottom:0.4rem}
.card__meta{font-size:0.82rem;color:var(--text-muted);margin-bottom:0.75rem}
.card__desc{font-size:0.92rem;color:var(--text-muted);line-height:1.6;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card__link{font-size:0.88rem;color:var(--gold);font-weight:600;display:inline-flex;align-items:center;gap:0.3rem}
.card__link:hover{color:var(--gold-light)}

/* EPISODE GRID */
.episode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}
.filter-bar{display:flex;flex-wrap:wrap;gap:0.5rem;justify-content:flex-start;margin-bottom:2rem;max-width:var(--max-width);margin-left:auto;margin-right:auto;padding:0 1.5rem}
.filter-btn{background:transparent;border:1px solid var(--border-gold);color:var(--text-muted);font-family:var(--font-body);font-size:0.85rem;padding:0.35rem 1rem;border-radius:20px;cursor:pointer;transition:all var(--transition)}
.filter-btn:hover{color:var(--gold);border-color:var(--gold);background:rgba(212,152,42,0.08)}
.filter-btn.active{background:var(--gold);border-color:var(--gold);color:var(--bg);font-weight:600}
.loading-state,.empty-state{text-align:center;color:var(--text-muted);padding:3rem;font-style:italic;grid-column:1/-1}
.error-state{text-align:center;color:var(--text-muted);padding:3rem 1.5rem;font-style:italic;grid-column:1/-1;font-size:1rem;line-height:1.7}
.error-state a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}

/* EPISODE CARDS */
.episode-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition),transform var(--transition);text-decoration:none;display:flex;flex-direction:column}
.episode-card:hover{box-shadow:0 0 18px rgba(212,152,42,0.18),0 0 4px rgba(212,152,42,0.1);transform:translateY(-2px)}
.episode-card .card-img-wrap{position:relative;width:100%;aspect-ratio:1;overflow:hidden;flex-shrink:0}
.episode-card .card-img{width:100%;height:100%;object-fit:cover;display:block}
.episode-card .card-img-wrap::after{content:'';position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,rgba(0,0,0,0.35),transparent);pointer-events:none}
.episode-card .badge{position:absolute;top:0.5rem;left:0.5rem;z-index:2;display:inline-block;font-size:0.68rem;letter-spacing:0.1rem;text-transform:uppercase;color:var(--gold-light);background:rgba(26,18,10,0.82);border:1px solid var(--border-gold);border-radius:14px;padding:0.15rem 0.55rem;font-family:var(--font-body);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.episode-card .card-body{padding:0.85rem 1rem 1rem;flex:1;display:flex;flex-direction:column}
.episode-card .card-title{font-family:var(--font-heading);font-size:1rem;color:var(--text);margin-bottom:0.3rem;line-height:1.3}
.episode-card .card-meta{font-size:0.78rem;color:var(--text-muted);margin-bottom:0.5rem}
.episode-card .card-desc{font-size:0.85rem;color:var(--text-muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}

/* SKELETON CARDS */
.skeleton-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.skeleton-card__img{width:100%;aspect-ratio:1;background:var(--bg-secondary);position:relative;overflow:hidden}
.skeleton-card__img::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.03) 40%,rgba(255,255,255,0.06) 50%,rgba(255,255,255,0.03) 60%,transparent 100%);animation:shimmer 1.8s infinite ease-in-out}
.skeleton-card__body{padding:0.85rem 1rem 1rem}
.skeleton-line{border-radius:4px;background:var(--bg-secondary);position:relative;overflow:hidden;margin-bottom:0.55rem}
.skeleton-line::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.03) 40%,rgba(255,255,255,0.06) 50%,rgba(255,255,255,0.03) 60%,transparent 100%);animation:shimmer 1.8s infinite ease-in-out}
.skeleton-line--short{width:35%;height:12px}
.skeleton-line--long{width:85%;height:14px}
.skeleton-line--med{width:65%;height:12px;margin-bottom:0}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* LATEST EPISODE */
.latest-episode{display:grid;grid-template-columns:220px 1fr;gap:2rem;align-items:start;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.latest-episode__img{width:100%;aspect-ratio:1;object-fit:cover}
.latest-episode__body{padding:2rem 2rem 2rem 0}
.latest-episode__label{font-size:0.78rem;letter-spacing:0.2rem;text-transform:uppercase;color:var(--gold);margin-bottom:0.5rem}
.latest-episode__title{font-family:var(--font-heading);font-size:clamp(1.3rem,2.5vw,1.8rem);margin-bottom:0.4rem}
.latest-episode__meta{font-size:0.85rem;color:var(--text-muted);margin-bottom:1rem}
.latest-episode__desc{color:var(--text-muted);font-size:0.95rem;line-height:1.65;margin-bottom:1.5rem}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.65rem 1.5rem;border-radius:30px;font-family:var(--font-body);font-size:0.92rem;font-weight:600;cursor:pointer;transition:all var(--transition);text-decoration:none;border:none}
.btn--gold{background:var(--gold);color:var(--bg)}
.btn--gold:hover{background:var(--gold-light);color:var(--bg);transform:translateY(-2px);box-shadow:0 4px 16px rgba(212,152,42,0.3)}
.btn--outline{background:transparent;color:var(--gold);border:1px solid var(--border-gold)}
.btn--outline:hover{border-color:var(--gold);background:rgba(212,152,42,0.08);color:var(--gold-light)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.about__img-wrap{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-gold);box-shadow:var(--shadow)}
.about__img{width:100%;display:block;transition:transform 0.5s ease}
.about__img-wrap:hover .about__img{transform:scale(1.02)}
.about__text h2{font-family:var(--font-heading);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--gold);margin-bottom:1.25rem}
.about__text p{color:var(--text-muted);font-size:1rem;line-height:1.75}

/* EVENTS */
.event-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--radius-lg);padding:2rem 2.5rem;display:grid;grid-template-columns:auto 1fr auto;gap:2rem;align-items:center;box-shadow:var(--shadow);transition:box-shadow var(--transition),transform var(--transition)}
.event-card:hover{box-shadow:var(--shadow-gold);transform:translateY(-2px)}
.event-card__date{text-align:center;background:var(--gold);color:var(--bg);border-radius:var(--radius);padding:0.75rem 1rem;min-width:70px;font-family:var(--font-heading)}
.event-card__date-month{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.1rem;font-weight:600}
.event-card__date-year{font-size:1.4rem;font-weight:900;line-height:1}
.event-card__title{font-family:var(--font-heading);font-size:1.4rem;color:var(--text);margin-bottom:0.3rem}
.event-card__location{font-size:0.9rem;color:var(--gold);margin-bottom:0.5rem}
.event-card__desc{color:var(--text-muted);font-size:0.95rem}
.event-card__cta .btn{white-space:nowrap}
.events-placeholder{text-align:center;border:1px dashed var(--border-gold);border-radius:var(--radius-lg);padding:3rem;color:var(--text-muted);font-style:italic;margin-top:2rem}

/* PLAYERS */
.players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.5rem;margin-bottom:3rem}
.player-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}
.player-card:hover{border-color:var(--border-gold);box-shadow:var(--shadow-gold);transform:translateY(-3px)}
.player-card__avatar{font-size:3rem;margin-bottom:1rem;display:block}
.player-card__name{font-family:var(--font-heading);font-size:1.1rem;color:var(--gold);margin-bottom:0.4rem}
.player-card__role{font-size:0.82rem;color:var(--text-muted);font-style:italic;margin-bottom:0.75rem}
.player-card__bio{font-size:0.88rem;color:var(--text-muted);line-height:1.6}
.blockquote{border-left:3px solid var(--gold);padding:1rem 1.5rem;margin:2rem 0;font-family:var(--font-heading);font-style:italic;font-size:clamp(1.1rem,2.5vw,1.5rem);color:var(--text);background:rgba(212,152,42,0.05);border-radius:0 var(--radius) var(--radius) 0}
.mktoc-section{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--radius-lg);padding:2.5rem;text-align:center}
.mktoc-section h2{font-family:var(--font-heading);color:var(--gold);margin-bottom:1rem;font-size:1.8rem}
.mktoc-section p{color:var(--text-muted);max-width:560px;margin:0 auto 1.5rem}

/* WIKI */
.wiki-layout{display:grid;grid-template-columns:220px 1fr;gap:3rem;align-items:start;max-width:var(--max-width);margin:0 auto;padding:2rem 1.5rem 4rem}
.wiki-main{min-width:0}

/* Wiki Sidebar */
.wiki-sidebar{position:sticky;top:80px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}
.wiki-sidebar h3{font-family:var(--font-heading);font-size:0.8rem;color:var(--gold);text-transform:uppercase;letter-spacing:0.15rem;font-variant:small-caps;margin-bottom:1rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border)}
.wiki-sidebar ul{list-style:none}
.wiki-sidebar li{margin-bottom:0.15rem}
.wiki-sidebar__link{color:var(--text-muted);font-size:0.88rem;display:block;padding:0.4rem 0.75rem;border-radius:var(--radius);border-left:2px solid transparent;transition:all var(--transition);text-decoration:none}
.wiki-sidebar__link:hover{color:var(--gold);background:rgba(212,152,42,0.07);border-left-color:var(--gold)}
.wiki-sidebar__link--active{color:var(--gold);border-left-color:var(--gold);background:rgba(212,152,42,0.07)}
.wiki-sidebar__updated{margin-top:2rem;font-size:.75rem;color:var(--border-gold)}

/* Wiki Note */
.wiki-note{border:none;border-left:3px solid var(--gold);background:rgba(212,152,42,0.05);border-radius:0 var(--radius) var(--radius) 0;padding:1rem 1.5rem;font-size:0.9rem;color:var(--text-muted);font-style:italic;margin:0 0 3rem;line-height:1.7}

/* Wiki Section */
.wiki-section{margin-bottom:3.5rem}
.wiki-section__header{margin-bottom:1.5rem;padding-bottom:0.75rem;border-bottom:1px solid var(--border-gold)}
.wiki-section__title{font-family:var(--font-heading);font-size:clamp(1.4rem,3vw,1.8rem);color:var(--gold);margin-bottom:0}
.wiki-section__intro{color:var(--text-muted);font-size:0.9rem;margin-bottom:1.5rem}

/* Wiki Search */
.wiki-search{display:block;width:100%;padding:0.7rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text);font-family:var(--font-body);font-size:0.92rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition);margin-bottom:1.25rem}
.wiki-search::placeholder{color:var(--text-muted);opacity:0.7}
.wiki-search:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(212,152,42,0.15)}

/* Wiki Card Grid */
.wiki-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}

/* Wiki Cards */
.wiki-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);display:flex;flex-direction:column}
.wiki-card:hover{border-color:var(--border-gold);box-shadow:var(--shadow-gold);transform:translateY(-2px)}
.wiki-card__name{font-family:var(--font-heading);color:var(--gold);font-size:1.05rem;margin-bottom:0.4rem;line-height:1.3}
.wiki-card__desc{color:var(--text-muted);font-size:0.88rem;line-height:1.6;flex:1;margin-bottom:0}
.wiki-card__episodes{font-size:0.75rem;color:var(--border-gold);margin-top:0.75rem;line-height:1.4;margin-bottom:0}
.wiki-card__episodes--clamp{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}

/* Wiki Empty / Search Empty */
.wiki-empty-state,.wiki-search-empty{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-style:italic;grid-column:1/-1}

/* TIMELINE */
.wiki-timeline__line{position:relative;padding-left:2.5rem}
.wiki-timeline__line::before{content:'';position:absolute;left:7px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold) 0%,var(--border-gold) 50%,transparent 100%);border-radius:2px}
.wiki-timeline__item{position:relative;margin-bottom:2rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition),box-shadow var(--transition)}
.wiki-timeline__item:hover{border-color:var(--border-gold);box-shadow:0 0 12px rgba(212,152,42,0.1)}
.wiki-timeline__dot{position:absolute;left:-2.25rem;top:1.25rem;width:14px;height:14px;border-radius:50%;background:var(--gold);border:3px solid var(--bg);box-shadow:0 0 0 2px var(--gold)}
.wiki-timeline__era{font-family:var(--font-heading);font-size:1.15rem;color:var(--gold);margin-bottom:0.2rem;line-height:1.3}
.wiki-timeline__episode{font-style:italic;color:var(--text-muted);font-size:0.88rem;margin-bottom:0.3rem}
.wiki-timeline__desc{color:var(--text-muted);font-size:0.85rem;line-height:1.6}

/* Timeline Skeleton */
.wiki-timeline__skeleton{position:relative;padding-left:2.5rem}
.wiki-timeline__skeleton::before{content:'';position:absolute;left:7px;top:0;bottom:0;width:2px;background:var(--border);border-radius:2px}
.wiki-timeline__skeleton-item{position:relative;margin-bottom:1.5rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}
.skeleton-dot{position:absolute;left:-2.25rem;top:1.25rem;width:14px;height:14px;border-radius:50%;background:var(--bg-secondary);overflow:hidden}
.skeleton-dot::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.03) 40%,rgba(255,255,255,0.06) 50%,rgba(255,255,255,0.03) 60%,transparent 100%);animation:shimmer 1.8s infinite ease-in-out}

/* FOOTER */
.footer{background:var(--bg-secondary);border-top:1px solid var(--border-gold);padding:3rem 0 2rem;margin-top:auto}
.footer__inner{display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:start;margin-bottom:2rem;position:relative;z-index:1}
.footer__brand p{font-size:0.88rem;color:var(--text-muted);max-width:260px;line-height:1.6}
.footer__nav h4,.footer__platforms h4{font-family:var(--font-heading);font-size:0.85rem;text-transform:uppercase;letter-spacing:0.15rem;color:var(--gold);margin-bottom:0.75rem}
.footer__nav li,.footer__platforms li{margin-bottom:0.35rem}
.footer__nav a,.footer__platforms a{color:var(--text-muted);font-size:0.88rem}
.footer__nav a:hover,.footer__platforms a:hover{color:var(--gold)}
.footer__bottom{border-top:1px solid var(--border);padding-top:1.5rem;text-align:center;color:var(--text-muted);font-size:0.82rem;position:relative;z-index:1}

/* CTA */
.cta-band{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-card) 100%);border:1px solid var(--border-gold);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center}
.cta-band h2{font-family:var(--font-heading);font-size:1.8rem;color:var(--gold);margin-bottom:0.75rem}
.cta-band p{color:var(--text-muted);margin-bottom:1.5rem}

/* UTILITIES */
.text-gold{color:var(--gold)}
.text-muted{color:var(--text-muted)}
.text-center{text-align:center}
.mt-1{margin-top:0.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}
.mt-4{margin-top:2rem}
.mb-4{margin-bottom:2rem}

/* SITE-NAV (episodes, wiki, players pages) */
.site-nav{position:sticky;top:0;z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-gold);box-shadow:0 2px 16px rgba(0,0,0,0.6)}
.nav-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;gap:1rem;height:60px;position:relative}
.nav-logo{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--gold);text-decoration:none;white-space:nowrap;flex-shrink:0}
.nav-logo:hover{color:var(--gold-light)}
.nav-links{display:flex;align-items:center;gap:0.15rem;margin-left:auto;flex-wrap:wrap;list-style:none}
.nav-links a{color:var(--text-muted);font-family:var(--font-body);font-size:0.92rem;padding:0.4rem 0.75rem;border-radius:var(--radius);transition:color var(--transition),background var(--transition);white-space:nowrap;text-decoration:none}
.nav-links a:hover,.nav-links a.active{color:var(--gold);background:rgba(212,152,42,0.08)}
.nav-listen{margin-left:0.5rem;background:var(--gold) !important;color:var(--bg) !important;font-weight:600;padding:0.4rem 1rem !important;border-radius:20px !important;font-size:0.88rem;transition:background var(--transition),transform var(--transition)}
.nav-listen:hover{background:var(--gold-light) !important;color:var(--bg) !important;transform:translateY(-1px)}
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;margin-left:auto;padding:0.5rem;width:36px;height:36px;position:relative}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--gold);margin:5px auto;border-radius:2px;transition:var(--transition)}

/* SITE-FOOTER (episodes, wiki, players pages) */
.site-footer{background:var(--bg-secondary);border-top:1px solid var(--border-gold);padding:3rem 0 2rem;margin-top:auto}
.footer-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:start;margin-bottom:2rem}
.footer-logo{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--gold);text-decoration:none}
.footer-logo:hover{color:var(--gold-light)}
.footer-brand p{font-size:0.88rem;color:var(--text-muted);max-width:260px;line-height:1.6}
.footer-links ul,.footer-platforms ul{list-style:none}
.footer-links li,.footer-platforms li{margin-bottom:0.35rem}
.footer-links a,.footer-platforms a{color:var(--text-muted);font-size:0.88rem;text-decoration:none}
.footer-links a:hover,.footer-platforms a:hover{color:var(--gold)}
.footer-platforms p{font-family:var(--font-heading);font-size:0.85rem;text-transform:uppercase;letter-spacing:0.15rem;color:var(--gold);margin-bottom:0.75rem}
.footer-copy{max-width:var(--max-width);margin:0 auto;padding:1.5rem 1.5rem 0;border-top:1px solid var(--border);text-align:center;color:var(--text-muted);font-size:0.82rem}

/* PULL QUOTE */
.pull-quote{border-left:3px solid var(--gold);padding:1rem 1.5rem;margin:2rem auto;font-family:var(--font-heading);font-style:italic;font-size:clamp(1.1rem,2.5vw,1.5rem);color:var(--text);background:rgba(212,152,42,0.05);border-radius:0 var(--radius) var(--radius) 0;max-width:700px;text-align:center}

/* MKTOC BLOCK */
.mktoc-block{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--radius-lg);padding:2.5rem;text-align:center;max-width:700px;margin:0 auto}
.mktoc-block h3{font-family:var(--font-heading);color:var(--gold);margin-bottom:1rem;font-size:1.8rem}
.mktoc-block p{color:var(--text-muted);max-width:560px;margin:0 auto 1.5rem}

/* PLAYER CARD extras (for pages using player-* classes) */
.player-avatar{font-size:3rem;margin-bottom:1rem;display:block;text-align:center}
.player-name{font-family:var(--font-heading);font-size:1.1rem;color:var(--gold);margin-bottom:0.4rem;text-align:center}
.player-bio{font-size:0.88rem;color:var(--text-muted);line-height:1.6;text-align:center}

/* SECTION DIVIDER */
.section-divider{border:none;border-top:1px solid var(--border-gold);opacity:0.5}

/* BTN PRIMARY (for pages using btn-primary) */
.btn-primary{display:inline-flex;align-items:center;gap:0.5rem;padding:0.65rem 1.5rem;border-radius:30px;font-family:var(--font-body);font-size:0.92rem;font-weight:600;cursor:pointer;transition:all var(--transition);text-decoration:none;border:none;background:var(--gold);color:var(--bg)}
.btn-primary:hover{background:var(--gold-light);color:var(--bg);transform:translateY(-2px);box-shadow:0 4px 16px rgba(212,152,42,0.3)}

/* WIKI MOBILE NAV */
.wiki-mobile-nav{display:none;gap:0.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0.75rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);white-space:nowrap}
.wiki-mobile-nav__link{display:inline-block;padding:0.4rem 1rem;border:1px solid var(--border-gold);border-radius:20px;color:var(--text-muted);font-size:0.85rem;font-family:var(--font-body);text-decoration:none;flex-shrink:0;transition:all var(--transition)}
.wiki-mobile-nav__link:hover,.wiki-mobile-nav__link:active{color:var(--gold);border-color:var(--gold);background:rgba(212,152,42,0.08)}

/* RESPONSIVE */
@media(max-width:900px){
  .wiki-layout{grid-template-columns:1fr;padding:1rem 1rem 3rem;gap:0}
  .wiki-sidebar{display:none}
  .wiki-mobile-nav{display:flex}
  .about-grid{grid-template-columns:1fr}
  .about__img-wrap{max-width:400px;margin:0 auto}
  .latest-episode{grid-template-columns:1fr}
  .latest-episode__body{padding:1.5rem}
  .latest-episode__img{max-height:280px;width:100%;object-fit:cover}
  .footer__inner{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .event-card{grid-template-columns:auto 1fr}
  .event-card__cta{grid-column:1/-1;text-align:center}
}

@media(max-width:640px){
  /* Main nav (index, events) */
  .nav__links{display:none;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-gold);padding:1rem;gap:0.25rem;z-index:200}
  .nav__links.open{display:flex}
  .nav__toggle{display:flex}
  .nav__listen{margin-left:0;text-align:center}

  /* Site nav (episodes, wiki, players) */
  .nav-links{display:none;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-gold);padding:1rem;gap:0.25rem;z-index:200;list-style:none}
  .nav-links.open{display:flex}
  .nav-hamburger{display:block}
  .nav-listen{margin-left:0 !important;text-align:center}

  /* Hero */
  .hero{min-height:min(80vh, 600px)}
  .hero__content{padding:3.5rem 1rem 3rem}

  /* Footer (index/events style) */
  .footer__inner{grid-template-columns:1fr}
  .footer__inner > *{text-align:center}
  .footer__brand p{margin-left:auto;margin-right:auto}
  .footer__nav{text-align:center}
  .footer__platforms{text-align:center}

  /* Footer (episodes/wiki/players style) */
  .footer-inner{grid-template-columns:1fr}
  .footer-inner > *{text-align:center}
  .footer-brand{text-align:center}
  .footer-brand p{margin-left:auto;margin-right:auto}
  .footer-links{text-align:center}
  .footer-platforms{text-align:center}
  .footer-platforms p{text-align:center}

  /* Event cards */
  .event-card{grid-template-columns:1fr}

  /* Episode grid: 2-col on mobile */
  .episode-grid{grid-template-columns:repeat(2,1fr);gap:0.75rem;padding:0 1rem}
  .filter-bar{justify-content:center;padding:0 1rem}

  /* Wiki grid: 2-col on mobile */
  .wiki-card-grid{grid-template-columns:repeat(2,1fr);gap:0.75rem}
  .wiki-card{padding:1rem 1rem}
  .wiki-card__name{font-size:0.95rem}
  .wiki-card__desc{font-size:0.82rem}
  .wiki-timeline__line{padding-left:2rem}
  .wiki-timeline__dot{left:-1.75rem;width:12px;height:12px}
  .wiki-timeline__item{padding:0.85rem 1rem}
  .wiki-timeline__era{font-size:1rem}

  /* Players grid: 2-col with consistent height */
  .players-grid{grid-template-columns:repeat(2,1fr) !important;align-items:stretch}
  .player-card{display:flex;flex-direction:column}
}

@media(max-width:480px){
  /* Stack event cards fully */
  .event-card{grid-template-columns:1fr;padding:1.5rem}
  .event-card__date{justify-self:start}

  /* Episode grid: still 2-col down to 400px */
  .episode-grid{grid-template-columns:repeat(2,1fr)}
  .episode-card .card-title{font-size:0.92rem}
  .episode-card .card-desc{font-size:0.82rem;-webkit-line-clamp:2}
}

@media(max-width:399px){
  /* Very small screens: single column */
  .episode-grid{grid-template-columns:1fr}
  .players-grid{grid-template-columns:1fr !important}
  .wiki-card-grid{grid-template-columns:1fr}
}

/* -- Platform Badges ---------------------------------------- */
.platform-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  justify-content: center;
}

.pbadge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  height: 42px;
  padding: 0 1.1rem;
  border-radius: 8px;
  font-family: 'Source Serif 4', serif;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .02em;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity .15s, transform .15s;
  min-width: 0;
  box-sizing: border-box;
}
.pbadge:hover { opacity: .85; transform: translateY(-1px); color: inherit; }

.pbadge__icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}
.pbadge__icon svg {
  width: 20px;
  height: 20px;
  display: block;
  flex-shrink: 0;
}

.pbadge--spotify     { background: #191414; color: #fff; }
.pbadge--spotify     .pbadge__icon svg { fill: #1DB954; }

.pbadge--apple       { background: #6a0dad; color: #fff; }
.pbadge--apple       .pbadge__icon svg { fill: #fff; }

.pbadge--pocketcasts { background: #F43E37; color: #fff; }
.pbadge--pocketcasts .pbadge__icon svg { fill: #fff; }

.pbadge--rss         { background: #F26522; color: #fff; }
.pbadge--rss         .pbadge__icon svg { fill: #fff; }

/* Footer: collapse to plain text links */
.footer-platforms .platform-badges,
.footer__platforms .platform-badges {
  flex-direction: column;
  align-items: flex-start;
  gap: .2rem;
  justify-content: flex-start;
}
.footer-platforms .pbadge,
.footer__platforms .pbadge {
  background: none;
  color: var(--text-muted);
  font-size: .82rem;
  font-weight: 400;
  height: auto;
  padding: 0;
  border-radius: 0;
}
.footer-platforms .pbadge:hover,
.footer__platforms .pbadge:hover {
  color: var(--gold);
  opacity: 1;
  transform: none;
}
.footer-platforms .pbadge__icon,
.footer__platforms .pbadge__icon { display: none; }

@media (max-width: 768px) {
  .platform-badges {
    justify-content: center;
    gap: .4rem;
  }
  .pbadge {
    height: 40px;
    padding: 0 .9rem;
    font-size: .8rem;
  }
  .footer-platforms .platform-badges,
  .footer__platforms .platform-badges {
    align-items: center;
  }
}

/* =============================================================
   Network Graph
   ============================================================= */
.network-container {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
#network-graph {
  width: 100%;
  height: 600px;
  position: relative;
}
@media (max-width: 767px) {
  #network-graph { height: 400px; }
}
#network-graph svg { display: block; }

.network-label {
  font-family: var(--font-body);
  font-size: 11px;
  fill: var(--text-muted);
  pointer-events: none;
  user-select: none;
}

.network-tooltip {
  position: absolute;
  pointer-events: none;
  background: var(--bg-secondary);
  border: 1px solid var(--border-gold);
  border-radius: var(--radius);
  padding: 6px 10px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text);
  line-height: 1.4;
  z-index: 10;
  white-space: nowrap;
  transition: opacity 0.15s ease;
}

.network-legend {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 5;
  display: flex;
  gap: 1rem;
  font-family: var(--font-body);
  font-size: 12px;
  font-variant: small-caps;
  color: var(--text-muted);
}
.network-legend__item {
  display: flex;
  align-items: center;
  gap: 5px;
}
.network-legend__dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
.network-legend__dot--character { background: #d4982a; }
.network-legend__dot--location  { background: #6b9e6b; }
