/*
Theme Name: Leave The Plantation
Theme URI: https://leavetheplantation.com
Author: Leave The Plantation
Description: Freedom & American Culture — The New Underground Railroad
Version: 1.2.0
License: GNU General Public License v2 or later
Text Domain: leave-the-plantation
*/

/* ============================================================
   DESIGN TOKENS — Old Glory Blue, American Red, White
   ============================================================ */
:root {
  --color-bg:          #0f3d6e;
  --color-surface:     #1a4f82;
  --color-surface-2:   #1f5a94;
  --color-surface-3:   #2666a8;
  --color-border:      #2d70b8;
  --color-primary:     #b22234;
  --color-primary-lt:  #d42b40;
  --color-primary-dk:  #8a1a28;
  --color-accent:      #002868;
  --color-accent-lt:   #1a4a9e;
  --color-text:        #e8edf5;
  --color-text-muted:  #b8d0ec;
  --color-text-faint:  #6d9cc4;
  --color-white:       #ffffff;
  --color-member:      #1a6b3a;
  --color-member-lt:   #27ae60;
  --color-gold:        #c8963e;
  --color-gold-lt:     #e8b85a;
  --color-gold-dk:     #a07030;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Source Serif 4', Georgia, serif;
  --font-ui:      'DM Sans', system-ui, sans-serif;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.5);
  --shadow-md:   0 4px 16px rgba(0,0,0,.6);
  --shadow-lg:   0 8px 32px rgba(0,0,0,.7);
  --shadow-red:  0 0 20px rgba(178,34,52,.3);
  --shadow-blue: 0 0 20px rgba(0,40,104,.3);
  --max-w:      1280px;
  --max-w-text: 760px;
  --header-h:   64px;
  --transition: 0.2s ease;
}

/* ============================================================
   RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { background: var(--color-bg); color: var(--color-text); font-family: var(--font-body); line-height: 1.7; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-white); }
h1,h2,h3,h4,h5,h6 { font-family: var(--font-display); font-weight: 700; line-height: 1.2; color: var(--color-white); }
h1 { font-size: clamp(1.75rem,4vw,3rem); }
h2 { font-size: clamp(1.4rem,3vw,2rem); }
h3 { font-size: clamp(1.1rem,2vw,1.5rem); }
p { margin-bottom: 1rem; } p:last-child { margin-bottom: 0; }
blockquote { border-left: 4px solid var(--color-primary); padding: 1rem 1.5rem; margin: 1.5rem 0; background: var(--color-surface-2); border-radius: 0 var(--radius-md) var(--radius-md) 0; font-style: italic; }
code,pre { font-family: monospace; background: var(--color-surface-3); border-radius: var(--radius-sm); }
code { padding: .15em .4em; font-size: .9em; }
pre  { padding: 1.25rem; overflow-x: auto; margin: 1.5rem 0; }
ul,ol { padding-left: 1.5rem; margin-bottom: 1rem; }
li { margin-bottom: .35rem; }
hr { border: none; border-top: 1px solid var(--color-border); margin: 2rem 0; }

/* ============================================================
   UTILITIES
   ============================================================ */
.text-red    { color: var(--color-primary); }
.text-gold   { color: var(--color-gold); }
.text-muted  { color: var(--color-text-muted); }
.text-faint  { color: var(--color-text-faint); }
.text-white  { color: var(--color-white); }
.text-center { text-align: center; }
.text-small  { font-size: .875rem; }
.font-ui     { font-family: var(--font-ui); }

/* ============================================================
   LAYOUT
   ============================================================ */
.container { width: 100%; max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.container--narrow { max-width: var(--max-w-text); }
.section     { padding: 2.25rem 0; }
.section--lg { padding: 3.5rem 0; }
.section--sm { padding: 1rem 0; }
.section--alt {
  background: linear-gradient(135deg, rgba(178,34,52,.06) 0%, var(--color-surface) 100%);
  border-top: 2px solid rgba(178,34,52,.2);
  border-bottom: 2px solid rgba(178,34,52,.2);
}
.grid   { display: grid; gap: 1rem; }
.grid--2 { grid-template-columns: repeat(2,1fr); }
.grid--3 { grid-template-columns: repeat(3,1fr); }
.grid--4 { grid-template-columns: repeat(4,1fr); }
.alert { display:flex; align-items:center; gap:.75rem; padding:1rem 1.25rem; border-radius:var(--radius-md); font-family:var(--font-ui); font-size:.875rem; }
.alert--success { background:rgba(27,107,58,.15); border:1px solid rgba(27,107,58,.4); color:#7de8a0; }
.alert--error   { background:rgba(178,34,52,.15); border:1px solid rgba(178,34,52,.4); color:#ffb0b8; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .65rem 1.4rem;
  border-radius: var(--radius-md);
  font-family: var(--font-ui); font-size: .875rem; font-weight: 600;
  cursor: pointer; border: 2px solid transparent;
  transition: all var(--transition); text-decoration: none; white-space: nowrap; line-height: 1;
}
.btn:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }
.btn--primary { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.btn--primary:hover { background: var(--color-primary-lt); color: #fff; box-shadow: var(--shadow-red); transform: translateY(-1px); }
.btn--donate { background: linear-gradient(135deg,var(--color-primary-lt),var(--color-primary-dk)); color: #fff; border-color: var(--color-primary); font-weight: 700; }
.btn--donate:hover { background: linear-gradient(135deg,#e83048,var(--color-primary)); color: #fff; box-shadow: var(--shadow-red); transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--color-text); border-color: var(--color-border); }
.btn--ghost:hover { border-color: var(--color-primary); color: var(--color-primary); }
.btn--outline { background: transparent; color: var(--color-primary); border-color: var(--color-primary); }
.btn--outline:hover { background: var(--color-primary); color: #fff; }
.btn--outline-white { background: transparent; color: #fff; border-color: rgba(255,255,255,.45); }
.btn--outline-white:hover { background: rgba(255,255,255,.1); border-color: #fff; }
.btn--gold { background: var(--color-gold); color: #0a0a0a; border-color: var(--color-gold); font-weight: 700; }
.btn--gold:hover { background: var(--color-gold-lt); color: #0a0a0a; }
.btn--outline-gold { background: transparent; color: var(--color-gold); border-color: var(--color-gold); }
.btn--outline-gold:hover { background: var(--color-gold); color: #0a0a0a; }
.btn--sm  { padding: .4rem .9rem; font-size: .78rem; }
.btn--lg  { padding: .85rem 1.85rem; font-size: 1rem; }
.btn--full { width: 100%; justify-content: center; }

/* ============================================================
   BADGES
   ============================================================ */
.badge { display:inline-flex; align-items:center; padding:.2rem .65rem; border-radius:999px; font-family:var(--font-ui); font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.badge--premium    { background:var(--color-primary);    color:#fff; }
.badge--free       { background:var(--color-surface-3);  color:var(--color-text-muted); }
.badge--podcast    { background:#3a1a60;                 color:#c4a0f5; }
.badge--video      { background:#002868;                 color:#a8c4f5; }
.badge--news       { background:var(--color-primary-dk); color:#ffb0b8; }
.badge--spiritual  { background:#2a1a5e;                 color:#c4aef5; }
.badge--political  { background:var(--color-primary-dk); color:#ffb0b8; }
.badge--economical { background:#0a3d20;                 color:#7de8a0; }
.badge--cultural   { background:#3d2200;                 color:#f5c87d; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.6} }

/* ============================================================
   HEADER
   ============================================================ */
#site-header {
  position: sticky; top: 0; z-index: 1000;
  height: var(--header-h);
  background: rgba(15,61,110,.97);
  backdrop-filter: blur(12px);
  border-bottom: 3px solid var(--color-primary);
  transition: box-shadow var(--transition);
}
#site-header.scrolled { box-shadow: 0 4px 24px rgba(178,34,52,.3); }
#site-header::after {
  content: ''; position: absolute; bottom: -5px; left: 0; right: 0; height: 2px;
  background: linear-gradient(to right, var(--color-primary) 33%, #fff 33%, #fff 66%, #0f3d6e 66%);
  opacity: .4;
}
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 100%; gap: 1rem; }
.site-logo { flex-shrink: 0; display: flex; align-items: center; text-decoration: none; }
.site-logo img { height: 40px; width: auto; }
.site-logo__text { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--color-white); line-height: 1.1; }
.site-logo__text span { color: var(--color-primary); }

#primary-nav { display: flex; align-items: center; gap: .15rem; }
.nav-item { position: relative; }
.nav-link {
  display: flex; align-items: center; gap: .3rem;
  padding: .45rem .75rem;
  font-family: var(--font-ui); font-size: .8rem; font-weight: 500;
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
  transition: all var(--transition); text-decoration: none; white-space: nowrap;
}
.nav-link:hover, .nav-link.active { color: var(--color-white); background: var(--color-surface-2); }
.nav-link .arrow { font-size: .6rem; transition: transform var(--transition); }
.nav-item:hover .arrow { transform: rotate(180deg); }
.nav-link--spec { color: var(--color-primary) !important; font-weight: 700 !important; }
.nav-link--spec:hover { background: rgba(178,34,52,.12) !important; }
.nav-link--trib { color: var(--color-gold) !important; font-weight: 700 !important; }
.nav-link--trib:hover { background: rgba(200,150,62,.1) !important; color: var(--color-gold-lt) !important; }

.nav-dropdown {
  position: absolute; top: calc(100% + .4rem); left: 0; min-width: 190px;
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-top: 2px solid var(--color-primary);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  box-shadow: var(--shadow-lg); padding: .4rem;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: all var(--transition); z-index: 100;
}
.nav-item:hover .nav-dropdown,
.nav-item:focus-within .nav-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-dropdown a {
  display: flex; align-items: center; justify-content: space-between;
  padding: .6rem .85rem; font-family: var(--font-ui); font-size: .8rem;
  color: var(--color-text-muted); border-radius: var(--radius-sm); text-decoration: none; transition: all var(--transition);
}
.nav-dropdown a:hover { color: var(--color-white); background: var(--color-surface-2); }
.nav-dropdown .dropdown-label { font-family: var(--font-ui); font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--color-text-faint); padding: .4rem .85rem .2rem; }
.nav-dropdown-ext::after { content: ' ↗'; font-size: .65rem; color: var(--color-text-faint); }

.header-actions { display: flex; align-items: center; gap: .6rem; flex-shrink: 0; }
.header-search-btn { background: transparent; border: none; color: var(--color-text-muted); cursor: pointer; padding: .4rem; border-radius: var(--radius-sm); font-size: 1rem; transition: color var(--transition); }
.header-search-btn:hover { color: var(--color-white); }
.menu-toggle { display: none; background: transparent; border: 1px solid var(--color-border); color: var(--color-text-muted); cursor: pointer; padding: .4rem .6rem; border-radius: var(--radius-sm); font-size: 1rem; }

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search-overlay { position: fixed; inset: 0; background: rgba(15,61,110,.96); z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 2rem; opacity: 0; visibility: hidden; transition: all var(--transition); }
.search-overlay.open { opacity: 1; visibility: visible; }
.search-overlay__inner { width: 100%; max-width: 600px; }
.search-form { display: flex; align-items: center; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; }
.search-input { flex: 1; background: transparent; border: none; padding: 1rem 1.25rem; font-family: var(--font-ui); font-size: 1.1rem; color: var(--color-white); outline: none; }
.search-input::placeholder { color: var(--color-text-faint); }
.search-submit { background: var(--color-primary); color: #fff; border: none; padding: 0 1.5rem; height: 100%; cursor: pointer; font-size: 1rem; min-height: 52px; transition: background var(--transition); }
.search-submit:hover { background: var(--color-primary-lt); }
.search-close { display: block; margin: 1rem auto 0; background: transparent; border: none; color: var(--color-text-faint); font-family: var(--font-ui); font-size: .85rem; cursor: pointer; }

/* ============================================================
   NEWS TICKER
   ============================================================ */
.news-ticker { background: var(--color-primary); padding: .45rem 0; overflow: hidden; }
.news-ticker__inner { display: flex; align-items: center; gap: .75rem; padding: 0 1.5rem; }
.news-ticker__label { flex-shrink: 0; background: rgba(0,0,0,.3); color: #fff; font-family: var(--font-ui); font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; padding: .15rem .6rem; border-radius: 999px; }
.news-ticker__track { flex: 1; overflow: hidden; }
.news-ticker__scroll { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-family: var(--font-ui); font-size: .8rem; font-weight: 600; color: rgba(255,255,255,.92); }
.news-ticker__scroll a { color: rgba(255,255,255,.92); }
.news-ticker__scroll a:hover { color: #fff; }
.news-ticker__sep { margin: 0 .65rem; opacity: .5; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; min-height: 460px; display: flex; align-items: center; justify-content: center; overflow: hidden; background: #061220; }
.hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(.5) saturate(.85); }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(15,61,110,.15) 0%, rgba(15,61,110,.55) 45%, #0f3d6e 100%); }
.hero__content { position: relative; z-index: 2; text-align: center; padding: 3rem 2rem 2.5rem; width: 100%; }
.hero__stars { color: var(--color-primary); font-size: .75rem; letter-spacing: .5em; margin-bottom: 1rem; opacity: .9; }
.hero__title { font-family: var(--font-display); font-size: clamp(2rem,6vw,4rem); font-weight: 900; color: var(--color-white); line-height: 1.1; margin-bottom: .85rem; text-shadow: 0 2px 20px rgba(0,0,0,.9); }
.hero__title em { font-style: normal; color: var(--color-primary); }
.hero__subtitle { font-family: var(--font-ui); font-size: clamp(.9rem,2vw,1.1rem); color: rgba(255,255,255,.85); max-width: 480px; margin: 0 auto 2rem; line-height: 1.65; }
.hero__actions { display: flex; gap: .85rem; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   NEWSLETTER BAR
   ============================================================ */
.newsletter-bar { background: linear-gradient(135deg,var(--color-primary-dk),var(--color-primary)); padding: 1.1rem 0; border-bottom: 2px solid rgba(255,255,255,.12); }
.newsletter-bar__inner { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.newsletter-bar__text { flex: 1; min-width: 200px; }
.newsletter-bar__title { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: #fff; margin-bottom: .15rem; }
.newsletter-bar__sub { font-family: var(--font-ui); font-size: .8rem; color: rgba(255,255,255,.82); }
.newsletter-bar__form { display: flex; flex: 1; min-width: 240px; background: rgba(255,255,255,.12); border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,.22); overflow: hidden; }
.newsletter-bar__input { flex: 1; background: transparent; border: none; padding: .7rem 1rem; font-family: var(--font-ui); font-size: .875rem; color: #fff; outline: none; min-width: 0; }
.newsletter-bar__input::placeholder { color: rgba(255,255,255,.5); }
.newsletter-bar__btn { background: #fff; color: var(--color-primary); font-family: var(--font-ui); font-size: .78rem; font-weight: 700; border: none; padding: .7rem 1.1rem; cursor: pointer; white-space: nowrap; flex-shrink: 0; }
.newsletter-bar__btn:hover { background: rgba(255,255,255,.92); }

/* ============================================================
   TRIBALISM HOMEPAGE FEATURE BAND
   ============================================================ */
.trib-band { position: relative; background: linear-gradient(135deg,#080808 0%,#1c0a00 45%,#080814 100%); border-top: 2px solid var(--color-gold); border-bottom: 2px solid var(--color-gold); padding: 1.4rem 1.5rem; overflow: hidden; }
.trib-band::before { content: 'TRIBALISM'; position: absolute; font-family: var(--font-display); font-size: 5.5rem; font-weight: 900; color: rgba(200,150,62,.05); top: 50%; right: 1.5rem; transform: translateY(-50%); white-space: nowrap; letter-spacing: .12em; pointer-events: none; user-select: none; }
.trib-band__inner { display: flex; align-items: center; gap: 1.25rem; position: relative; z-index: 1; }
.trib-band__accent { width: 4px; min-height: 80px; background: linear-gradient(to bottom,var(--color-gold),var(--color-gold-dk)); border-radius: 2px; flex-shrink: 0; align-self: stretch; }
.trib-band__content { flex: 1; min-width: 0; }
.trib-band__label { display: inline-flex; align-items: center; gap: .35rem; font-family: var(--font-ui); font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--color-gold); background: rgba(200,150,62,.1); border: 1px solid rgba(200,150,62,.28); border-radius: 999px; padding: .22rem .75rem; margin-bottom: .55rem; }
.trib-band__title { font-family: var(--font-display); font-size: 1.2rem; font-weight: 900; color: var(--color-white); line-height: 1.15; margin-bottom: .45rem; white-space: nowrap; }
.trib-band__title em { font-style: normal; color: var(--color-gold); }
.trib-band__desc { font-family: var(--font-ui); font-size: .82rem; color: rgba(200,150,62,.65); line-height: 1.55; max-width: 560px; margin-bottom: .85rem; }
.trib-band__actions { display: flex; gap: .55rem; flex-wrap: wrap; }

/* ============================================================
   BIO CARD
   ============================================================ */
.bio-card { background: var(--color-surface); border: 1px solid var(--color-border); border-left: 4px solid var(--color-primary); border-radius: var(--radius-lg); padding: 1.5rem; display: flex; gap: 1.5rem; align-items: flex-start; }
.bio-card__avatar { width: 88px; height: 88px; border-radius: 50%; flex-shrink: 0; border: 3px solid var(--color-primary); overflow: hidden; background: var(--color-surface-2); display: flex; align-items: center; justify-content: center; }
.bio-card__img { width: 100%; height: 100%; object-fit: cover; }
.bio-card__initials { font-family: var(--font-ui); font-size: 1.1rem; font-weight: 700; color: var(--color-text-muted); }
.bio-card__name   { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--color-white); margin-bottom: .2rem; }
.bio-card__role   { font-family: var(--font-ui); font-size: .72rem; color: rgba(255,255,255,.65); text-transform: uppercase; letter-spacing: .1em; margin-bottom: .75rem; }
.bio-card__text   { font-family: var(--font-ui); font-size: .875rem; color: var(--color-text-muted); line-height: 1.7; margin-bottom: .9rem; }

/* ============================================================
   MEMBERSHIP SECTION
   ============================================================ */
.mem-section { padding: 3rem 0; background: radial-gradient(ellipse at 50% -10%,rgba(178,34,52,.15) 0%,transparent 60%); text-align: center; }
.mem-section__head { max-width: 640px; margin: 0 auto 2rem; }
.mem-eyebrow { display: inline-block; font-family: var(--font-ui); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--color-primary); background: rgba(178,34,52,.12); border: 1px solid rgba(178,34,52,.3); border-radius: 999px; padding: .28rem .9rem; margin-bottom: .85rem; }
.mem-title { font-family: var(--font-display); font-size: clamp(1.6rem,4vw,2.4rem); font-weight: 900; color: var(--color-white); line-height: 1.15; margin-bottom: .85rem; }
.mem-title em { font-style: normal; color: var(--color-primary); }
.mem-sub { font-family: var(--font-ui); font-size: clamp(.875rem,2vw,1rem); color: var(--color-text-muted); line-height: 1.82; max-width: 600px; margin: 0 auto; }
.mem-sub strong { color: var(--color-white); }
.mem-plans { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; max-width: 680px; margin: 0 auto 1rem; text-align: left; }
.plan-card { background: var(--color-surface); border: 2px solid var(--color-border); border-radius: var(--radius-lg); padding: 1.5rem; position: relative; text-align: left; transition: border-color var(--transition); }
.plan-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; border-radius: var(--radius-lg) var(--radius-lg) 0 0; background: var(--color-border); }
.plan-card--featured { border-color: var(--color-primary); }
.plan-card--featured::before { background: linear-gradient(to right,var(--color-primary),var(--color-accent-lt)); }
.plan-card:hover { border-color: var(--color-primary); }
.plan-card__badge { position: absolute; top: 12px; right: 12px; background: var(--color-primary); color: #fff; font-family: var(--font-ui); font-size: .68rem; font-weight: 700; padding: .2rem .65rem; border-radius: 999px; text-transform: uppercase; }
.plan-card__name  { font-family: var(--font-ui); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.6); margin-bottom: .5rem; text-align: left; }
.plan-card__price { font-family: var(--font-display); font-size: 2.25rem; font-weight: 700; color: var(--color-white); line-height: 1; margin-bottom: .35rem; text-align: left; }
.plan-card__price sub { font-size: .75rem; vertical-align: super; }
.plan-card__price span { font-size: .8rem; color: var(--color-text-muted); }
.plan-card__desc { font-family: var(--font-ui); font-size: .82rem; color: var(--color-text-muted); margin-bottom: 1rem; text-align: left; }
.plan-card__features { list-style: none; padding: 0; margin: 0 0 1.1rem; text-align: left; }
.plan-card__features li { display: flex; align-items: flex-start; gap: .45rem; font-family: var(--font-ui); font-size: .82rem; padding: .35rem 0; border-bottom: 1px solid var(--color-border); text-align: left; }
.plan-card__features li:last-child { border: none; }
.plan-card__features .check { color: var(--color-member-lt); flex-shrink: 0; }
.plan-card__features .cross { color: var(--color-text-faint); flex-shrink: 0; }
.donate-strip { max-width: 680px; margin: 0 auto; background: rgba(178,34,52,.08); border: 1px solid rgba(178,34,52,.22); border-radius: var(--radius-md); padding: .9rem 1.2rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; text-align: left; }
.donate-strip__text { font-family: var(--font-ui); font-size: .875rem; color: var(--color-text-muted); }
.donate-strip__text strong { color: var(--color-white); display: block; margin-bottom: .15rem; }

/* ============================================================
   SEARCH BAR
   ============================================================ */
.ltp-search-bar { padding: .9rem 0; background: var(--color-surface-2); border-top: 1px solid var(--color-border); border-bottom: 2px solid rgba(178,34,52,.25); }
.ltp-search-main { display: flex; align-items: center; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.11); border-radius: var(--radius-md); overflow: hidden; margin-bottom: .65rem; }
.ltp-search-main:focus-within { border-color: rgba(178,34,52,.5); }
.ltp-search-icon { padding: 0 .9rem; color: var(--color-text-faint); font-size: .95rem; flex-shrink: 0; }
.ltp-search-input { flex: 1; background: transparent; border: none; padding: .7rem 0; font-family: var(--font-ui); font-size: .875rem; color: var(--color-white); outline: none; min-width: 0; }
.ltp-search-input::placeholder { color: var(--color-text-faint); }
.ltp-search-btn { background: var(--color-primary); color: #fff; border: none; padding: 0 1.25rem; height: 100%; font-family: var(--font-ui); font-size: .8rem; font-weight: 700; cursor: pointer; min-height: 42px; flex-shrink: 0; }
.ltp-search-btn:hover { background: var(--color-primary-lt); }
.ltp-search-filters { display: flex; gap: .45rem; flex-wrap: wrap; align-items: center; }
.ltp-filter-label { font-family: var(--font-ui); font-size: .68rem; color: var(--color-text-faint); text-transform: uppercase; letter-spacing: .08em; }
.ltp-pill { display: inline-flex; align-items: center; padding: .3rem .8rem; border-radius: 999px; font-family: var(--font-ui); font-size: .75rem; cursor: pointer; border: 1px solid var(--color-border); background: transparent; color: var(--color-text-muted); transition: all .15s; white-space: nowrap; }
.ltp-pill:hover, .ltp-pill--on { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.ltp-filter-divider { width: 1px; height: 16px; background: var(--color-border); flex-shrink: 0; }
.ltp-filter-select { background: transparent; border: 1px solid var(--color-border); border-radius: 999px; padding: .3rem .65rem; font-family: var(--font-ui); font-size: .75rem; color: var(--color-text-muted); cursor: pointer; outline: none; }
.ltp-filter-select option { background: var(--color-surface); }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.1rem; }
.section-head__title { display: flex; align-items: center; gap: .6rem; font-family: var(--font-display); font-size: 1.15rem; font-weight: 700; color: var(--color-white); }
.section-head__title::before { content: ''; display: block; width: 4px; height: 1.2em; background: var(--color-primary); border-radius: 2px; flex-shrink: 0; }

/* ============================================================
   CARDS
   ============================================================ */
.card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: border-color var(--transition),box-shadow var(--transition); }
.card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-red); }
.card__thumb { aspect-ratio: 16/9; overflow: hidden; position: relative; background: var(--color-surface-2); }
.card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card:hover .card__thumb img { transform: scale(1.03); }
.card__thumb-badge { position: absolute; bottom: .6rem; left: .6rem; }
.card__thumb-lock { position: absolute; inset: 0; background: rgba(0,0,0,.35); display: flex; align-items: center; justify-content: center; }
.card__body { padding: 1rem; flex: 1; display: flex; flex-direction: column; }
.card__eyebrow { margin-bottom: .5rem; }
.card__title { font-family: var(--font-ui); font-size: .875rem; font-weight: 700; color: var(--color-white); line-height: 1.4; margin-bottom: .4rem; }
.card__title a { color: var(--color-white); }
.card__title a:hover { color: var(--color-primary); }
.card__excerpt { font-family: var(--font-ui); font-size: .8rem; color: var(--color-text-muted); line-height: 1.55; margin-bottom: .6rem; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.card__footer { display: flex; justify-content: space-between; align-items: center; font-family: var(--font-ui); font-size: .72rem; color: var(--color-text-faint); padding-top: .6rem; border-top: 1px solid var(--color-border); margin-top: auto; }
.play-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.35); }
.play-btn { background: var(--color-primary); border-radius: 50%; width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; color: #fff; font-size: .9rem; }

/* ============================================================
   EPISODE ROWS
   ============================================================ */
.ep-row { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: .9rem; display: flex; gap: .9rem; align-items: center; margin-bottom: .6rem; transition: border-color var(--transition); }
.ep-row:hover { border-color: var(--color-primary); }
.ep-row:last-child { margin-bottom: 0; }
.ep-row__art { width: 50px; height: 50px; border-radius: var(--radius-md); background: var(--color-surface-2); flex-shrink: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; font-family: var(--font-ui); font-size: .72rem; font-weight: 700; color: var(--color-text-muted); }
.ep-row__art img { width: 100%; height: 100%; object-fit: cover; }
.ep-row__info { flex: 1; min-width: 0; }
.ep-row__show { font-family: var(--font-ui); font-size: .68rem; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .06em; margin-bottom: .2rem; }
.ep-row__title { font-family: var(--font-ui); font-size: .875rem; font-weight: 600; color: var(--color-white); overflow: hidden; white-space: nowrap; text-overflow: ellipsis; margin-bottom: .2rem; }
.ep-row__title a { color: var(--color-white); }
.ep-row__title a:hover { color: var(--color-primary); }
.ep-row__meta { font-family: var(--font-ui); font-size: .72rem; color: var(--color-text-muted); display: flex; gap: .6rem; }
.ep-row__play { width: 34px; height: 34px; background: var(--color-primary); border: none; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-size: .8rem; flex-shrink: 0; cursor: pointer; transition: all var(--transition); }
.ep-row__play:hover { background: var(--color-primary-lt); transform: scale(1.08); }

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar-widget { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 1rem; margin-bottom: 1rem; }
.sidebar-widget__title { font-family: var(--font-ui); font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--color-primary); margin-bottom: .75rem; padding-bottom: .6rem; border-bottom: 1px solid var(--color-border); }

/* ============================================================
   MEMBER GATE
   ============================================================ */
.member-gate { position: relative; }
.member-gate__blur { max-height: 220px; overflow: hidden; mask-image: linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 90%); -webkit-mask-image: linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,0) 90%); pointer-events: none; user-select: none; font-family: var(--font-ui); font-size: .875rem; color: var(--color-text-muted); line-height: 1.7; }
.member-gate__overlay { display: flex; align-items: center; justify-content: center; padding: 2.5rem 1.5rem; }
.member-gate__cta { background: var(--color-surface); border: 1px solid var(--color-border); border-top: 3px solid var(--color-primary); border-radius: var(--radius-lg); padding: 2rem; text-align: center; max-width: 440px; width: 100%; }
.member-gate__cta h3 { margin-bottom: .5rem; font-size: 1.2rem; }
.member-gate__cta p { font-family: var(--font-ui); font-size: .875rem; color: var(--color-text-muted); margin-bottom: 1.25rem; }
.member-gate__actions { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer-pre-cta { background: var(--color-surface-2); border-top: 1px solid var(--color-border); padding: 1rem 0; }
.footer-pre-cta .container { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.footer-pre-cta__title { font-family: var(--font-display); font-size: 1rem; color: var(--color-white); margin-bottom: .2rem; }
.footer-pre-cta__sub { font-family: var(--font-ui); font-size: .8rem; color: var(--color-text-muted); }
.footer-pre-cta__actions { display: flex; gap: .65rem; flex-wrap: wrap; }

#site-footer { background: var(--color-surface); border-top: 3px solid var(--color-primary); padding: 2rem 0 1rem; margin-top: 0; }
.footer-flag-bar { height: 4px; background: linear-gradient(to right, var(--color-primary) 33%, #ffffff 33%, #ffffff 66%, #0f3d6e 66%); margin-bottom: 1.75rem; display: block; width: 100%; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 1.75rem; margin-bottom: 1.5rem; }
.footer-col-title { font-family: var(--font-ui); font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--color-primary); margin-bottom: .85rem; }
.footer-links { list-style: none; padding: 0; }
.footer-links a { display: block; font-family: var(--font-ui); font-size: .82rem; color: var(--color-text-muted); padding: .25rem 0; text-decoration: none; transition: color var(--transition); }
.footer-links a:hover { color: var(--color-white); }
.footer-social { display: flex; gap: .5rem; margin-top: 1rem; }
.social-btn { width: 32px; height: 32px; background: var(--color-surface-2); border: 1px solid var(--color-border); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: var(--color-text-muted); font-size: .85rem; transition: all var(--transition); text-decoration: none; }
.social-btn:hover { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; padding-top: 1.1rem; border-top: 1px solid var(--color-border); font-family: var(--font-ui); font-size: .72rem; color: var(--color-text-faint); flex-wrap: wrap; gap: .5rem; }
.footer-bottom a { color: var(--color-text-faint); }
.footer-bottom a:hover { color: var(--color-text-muted); }

/* ============================================================
   AUTH PAGES
   ============================================================ */
.auth-page { min-height: 70vh; display: flex; align-items: center; justify-content: center; padding: 2.5rem 1.5rem; background: radial-gradient(ellipse at 50% 0%,rgba(178,34,52,.07) 0%,transparent 55%); }
.auth-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 2.25rem; width: 100%; max-width: 380px; }
.auth-logo { text-align: center; margin-bottom: 1.25rem; }
.auth-title { font-family: var(--font-display); font-size: 1.4rem; color: var(--color-white); text-align: center; margin-bottom: .3rem; }
.auth-sub { font-family: var(--font-ui); font-size: .82rem; color: var(--color-text-muted); text-align: center; margin-bottom: 1.5rem; }
.form-label { font-family: var(--font-ui); font-size: .7rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .07em; display: block; margin-bottom: .3rem; }
.form-input { width: 100%; background: var(--color-surface-2); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: .7rem .9rem; color: var(--color-text); font-family: var(--font-ui); font-size: .875rem; margin-bottom: .9rem; outline: none; transition: border-color var(--transition); }
.form-input:focus { border-color: var(--color-primary); }
.form-input::placeholder { color: var(--color-text-faint); }
.form-divider { display: flex; align-items: center; gap: .75rem; margin: 1rem 0; font-family: var(--font-ui); font-size: .75rem; color: var(--color-text-faint); }
.form-divider::before, .form-divider::after { content: ''; flex: 1; height: 1px; background: var(--color-border); }

/* ============================================================
   MY ACCOUNT
   ============================================================ */
.account-header { background: var(--color-surface); border-bottom: 1px solid var(--color-border); padding: 1.25rem 0; }
.account-header__inner { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.account-avatar-wrap { position: relative; }
.account-avatar { width: 54px; height: 54px; border-radius: 50%; background: linear-gradient(135deg,var(--color-primary),var(--color-primary-dk)); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: #fff; font-weight: 700; border: 3px solid var(--color-primary); font-family: var(--font-ui); }
.account-avatar__badge { position: absolute; bottom: -2px; right: -2px; background: var(--color-primary); border-radius: 50%; width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; font-size: .6rem; color: #fff; }
.account-name { font-family: var(--font-display); font-size: 1.15rem; color: var(--color-white); margin-bottom: .35rem; }
.account-layout { display: grid; grid-template-columns: 190px 1fr; gap: 1.25rem; align-items: start; }
.account-nav { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: .4rem; }
.account-nav__item { display: flex; align-items: center; gap: .6rem; padding: .75rem .9rem; font-family: var(--font-ui); font-size: .875rem; border-radius: var(--radius-md); color: var(--color-text-muted); cursor: pointer; margin-bottom: .2rem; transition: all var(--transition); }
.account-nav__item:hover { background: var(--color-surface-2); color: var(--color-white); }
.account-nav__item--active { background: var(--color-surface-2); color: var(--color-white); font-weight: 600; }
.stat-card { background: var(--color-surface-2); border-radius: var(--radius-md); padding: 1rem; text-align: center; }
.stat-card__num { font-family: var(--font-display); font-size: 1.75rem; font-weight: 700; color: var(--color-white); }
.stat-card__label { font-family: var(--font-ui); font-size: .72rem; color: var(--color-text-muted); margin-top: .2rem; }

/* ============================================================
   TRIBALISM PASSWORD GATE
   ============================================================ */
.trib-gate-page { background: #0a0a0a; min-height: 80vh; display: flex; align-items: center; justify-content: center; padding: 2rem; }
.trib-gate-card { background: #111; border: 1px solid rgba(200,150,62,.2); border-top: 3px solid var(--color-gold); border-radius: var(--radius-xl); padding: 2.5rem; max-width: 400px; width: 100%; text-align: center; box-shadow: 0 8px 40px rgba(0,0,0,.7); }
.trib-gate-icon { font-size: 2.5rem; margin-bottom: .75rem; }
.trib-gate-title { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--color-white); margin-bottom: .4rem; }
.trib-gate-sub { font-family: var(--font-ui); font-size: .85rem; color: rgba(200,150,62,.6); line-height: 1.65; margin-bottom: 1.5rem; }
.trib-gate-lock { display: inline-flex; align-items: center; gap: .4rem; background: rgba(200,150,62,.1); border: 1px solid rgba(200,150,62,.28); border-radius: 999px; padding: .28rem .85rem; font-family: var(--font-ui); font-size: .72rem; color: var(--color-gold); font-weight: 600; margin-bottom: 1.1rem; }
.trib-gate-error { background: rgba(178,34,52,.15); border: 1px solid rgba(178,34,52,.4); border-radius: var(--radius-md); padding: .6rem; font-family: var(--font-ui); font-size: .8rem; color: #ffb0b8; margin-bottom: .85rem; }
.trib-gate-input { width: 100%; background: rgba(255,255,255,.05); border: 1px solid rgba(200,150,62,.28); border-radius: var(--radius-md); padding: .8rem 1rem; color: var(--color-white); font-family: var(--font-ui); font-size: 1rem; margin-bottom: .85rem; text-align: center; letter-spacing: .15em; outline: none; transition: border-color var(--transition); }
.trib-gate-input:focus { border-color: var(--color-gold); }
.trib-gate-submit { width: 100%; background: var(--color-gold); color: #0a0a0a; font-family: var(--font-ui); font-size: .95rem; font-weight: 700; border: none; border-radius: var(--radius-md); padding: .85rem; cursor: pointer; transition: background var(--transition); }
.trib-gate-submit:hover { background: var(--color-gold-lt); }
.trib-gate-hint { margin-top: 1rem; font-family: var(--font-ui); font-size: .72rem; color: rgba(200,150,62,.3); line-height: 1.5; }

/* ============================================================
   TRIBALISM FULL PAGE (cinematic dark)
   ============================================================ */
.trib-page-wrap { background: #0a0a0a; color: #e8e0d0; }
.trib-page-hero { position: relative; background: linear-gradient(160deg,#050505 0%,#1a0800 40%,#0a0814 80%,#050505 100%); padding: 4rem 2rem 3rem; text-align: center; border-bottom: 3px solid var(--color-gold); overflow: hidden; }
.trib-page-hero::before { content: 'TRIBALISM'; position: absolute; font-family: var(--font-display); font-size: clamp(4rem,14vw,9rem); font-weight: 900; color: rgba(200,150,62,.045); top: 50%; left: 50%; transform: translate(-50%,-50%); white-space: nowrap; letter-spacing: .12em; pointer-events: none; user-select: none; }
.trib-page-eyebrow { display: inline-block; font-family: var(--font-ui); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .15em; color: var(--color-gold); background: rgba(200,150,62,.1); border: 1px solid rgba(200,150,62,.3); border-radius: 999px; padding: .3rem 1rem; margin-bottom: 1rem; }
.trib-page-title { font-family: var(--font-display); font-size: clamp(2.5rem,7vw,4.5rem); font-weight: 900; color: var(--color-white); line-height: 1.05; margin-bottom: .45rem; text-shadow: 0 2px 24px rgba(0,0,0,.9); }
.trib-page-title em { font-style: normal; color: var(--color-gold); }
.trib-page-tagline { font-family: var(--font-ui); font-size: 1rem; color: rgba(200,150,62,.65); font-style: italic; margin-bottom: 1.35rem; }
.trib-page-meta { display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap; font-family: var(--font-ui); font-size: .78rem; color: rgba(200,150,62,.5); margin-bottom: 1.75rem; }
.trib-page-hero-btns { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }
.trib-page-qnav { background: rgba(0,0,0,.5); border-bottom: 1px solid rgba(200,150,62,.15); padding: .65rem 1.5rem; display: flex; gap: 1.5rem; overflow-x: auto; position: sticky; top: 0; z-index: 10; }
.trib-page-qnav a { font-family: var(--font-ui); font-size: .78rem; color: rgba(200,150,62,.65); text-decoration: none; white-space: nowrap; transition: color var(--transition); }
.trib-page-qnav a:hover { color: var(--color-gold); }
.trib-page-qnav-sep { color: rgba(200,150,62,.2); font-size: .7rem; align-self: center; }
.trib-block { padding: 2.5rem 2rem; border-bottom: 1px solid rgba(200,150,62,.1); }
.trib-block:last-child { border-bottom: none; }
.trib-block--alt { background: rgba(255,255,255,.02); }
.trib-block-header { display: flex; align-items: center; gap: .85rem; margin-bottom: 1rem; }
.trib-block-num { width: 34px; height: 34px; background: var(--color-gold); color: #0a0a0a; font-family: var(--font-ui); font-size: .85rem; font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.trib-block-title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; color: var(--color-white); }
.trib-block-divider { width: 48px; height: 3px; background: linear-gradient(to right,var(--color-gold),transparent); border-radius: 2px; margin-bottom: 1.5rem; }
.trib-story-text { font-family: var(--font-ui); font-size: .875rem; color: rgba(220,210,195,.85); line-height: 1.85; max-width: 780px; }
.trib-story-text p { margin-bottom: .95rem; }
.trib-story-pull { background: linear-gradient(to right,rgba(200,150,62,.08),transparent); border-left: 3px solid var(--color-gold); padding: .9rem 1.25rem; border-radius: 0 var(--radius-md) var(--radius-md) 0; margin: 1.25rem 0; font-style: italic; color: var(--color-gold-lt); font-size: .95rem; line-height: 1.65; }
.trib-story-hl { color: var(--color-white); font-weight: 600; }
.trib-trailer-row { display: flex; gap: .65rem; margin-top: 1.5rem; flex-wrap: wrap; }
.trib-drive-card { background: rgba(255,255,255,.04); border: 1px solid rgba(200,150,62,.2); border-radius: var(--radius-lg); padding: 1.35rem; display: flex; align-items: center; gap: 1.1rem; max-width: 560px; text-decoration: none; transition: border-color var(--transition); }
.trib-drive-card:hover { border-color: var(--color-gold); }
.trib-drive-icon { width: 52px; height: 52px; background: rgba(200,150,62,.12); border: 1px solid rgba(200,150,62,.22); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; flex-shrink: 0; }
.trib-drive-title { font-family: var(--font-ui); font-size: .95rem; font-weight: 700; color: var(--color-white); margin-bottom: .2rem; }
.trib-drive-sub { font-family: var(--font-ui); font-size: .75rem; color: rgba(200,150,62,.5); margin-bottom: .7rem; }
.trib-video-area { background: rgba(0,0,0,.5); border: 1px solid rgba(200,150,62,.18); border-radius: var(--radius-lg); overflow: hidden; max-width: 700px; }
.trib-video-placeholder { aspect-ratio: 16/9; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1rem; background: linear-gradient(135deg,#0a0808,#180d00); }
.trib-video-ring { width: 72px; height: 72px; border: 3px solid var(--color-gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; color: var(--color-gold); }
.trib-video-note { padding: .9rem 1.25rem; border-top: 1px solid rgba(200,150,62,.1); font-family: var(--font-ui); font-size: .78rem; color: rgba(200,150,62,.4); }
.trib-about-section { background: linear-gradient(135deg,rgba(200,150,62,.06),transparent 70%); border-top: 1px solid rgba(200,150,62,.12); padding: 2.5rem 2rem; text-align: center; }

/* ============================================================
   MINI PODCAST PLAYER
   ============================================================ */
#mini-player { position: fixed; bottom: 0; left: 0; right: 0; background: rgba(10,20,40,.97); border-top: 1px solid var(--color-border); padding: .65rem 1.5rem; display: none; align-items: center; gap: 1rem; z-index: 900; backdrop-filter: blur(10px); }
#mini-player.active { display: flex; }
.mini-player__art { width: 38px; height: 38px; border-radius: var(--radius-sm); background: var(--color-surface-2); flex-shrink: 0; overflow: hidden; }
.mini-player__art img { width: 100%; height: 100%; object-fit: cover; }
.mini-player__info { flex: 1; min-width: 0; }
.mini-player__show { font-family: var(--font-ui); font-size: .65rem; color: var(--color-text-muted); margin-bottom: .15rem; }
.mini-player__title { font-family: var(--font-ui); font-size: .82rem; font-weight: 600; color: var(--color-white); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mini-player__controls { display: flex; align-items: center; gap: .6rem; }
.mini-player__btn { background: transparent; border: none; color: var(--color-text-muted); cursor: pointer; font-size: .9rem; padding: .25rem; transition: color var(--transition); }
.mini-player__btn:hover { color: var(--color-white); }
.mini-player__play { background: var(--color-primary); border: none; border-radius: 50%; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; color: #fff; cursor: pointer; font-size: .75rem; transition: all var(--transition); }
.mini-player__play:hover { background: var(--color-primary-lt); transform: scale(1.05); }
.mini-player__progress { display: flex; align-items: center; gap: .5rem; max-width: 180px; }
.mini-player__time { font-family: monospace; font-size: .72rem; color: var(--color-text-muted); white-space: nowrap; }
.mini-player__bar { flex: 1; height: 3px; background: var(--color-surface-3); border-radius: 999px; cursor: pointer; }
.mini-player__fill { height: 100%; background: var(--color-primary); border-radius: 999px; width: 0%; transition: width .5s linear; }
.mini-player__speed { font-family: var(--font-ui); font-size: .72rem; color: var(--color-text-muted); padding: .25rem .55rem; background: var(--color-surface-2); border-radius: var(--radius-sm); cursor: pointer; border: none; }

/* ============================================================
   MISC
   ============================================================ */
.pagination { display: flex; gap: .5rem; justify-content: center; padding: 2rem 0; flex-wrap: wrap; }
.page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding: 0 .75rem; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm); font-family: var(--font-ui); font-size: .82rem; color: var(--color-text-muted); text-decoration: none; transition: all var(--transition); }
.page-numbers:hover, .page-numbers.current { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.skip-link { position: absolute; top: -100px; left: 1rem; background: var(--color-primary); color: #fff; padding: .5rem 1rem; border-radius: var(--radius-md); z-index: 9999; font-family: var(--font-ui); font-size: .875rem; }
.skip-link:focus { top: 1rem; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
  .account-layout { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  :root { --header-h: 56px; }
  #primary-nav { display: none; }
  #primary-nav.open { display: flex; flex-direction: column; position: absolute; top: var(--header-h); left: 0; right: 0; background: rgba(10,49,97,.98); border-bottom: 2px solid var(--color-primary); padding: 1rem; z-index: 999; }
  .menu-toggle { display: flex; }
  .grid--4 { grid-template-columns: repeat(2,1fr); }
  .grid--3 { grid-template-columns: repeat(2,1fr); }
  .mem-plans { grid-template-columns: 1fr; }
  .newsletter-bar__inner { flex-direction: column; align-items: stretch; }
  .newsletter-bar__form { min-width: 0; width: 100%; }
  .bio-card { flex-direction: column; align-items: center; text-align: center; }
  .donate-strip { flex-direction: column; align-items: stretch; }
  .donate-strip .btn { width: 100%; justify-content: center; }
  .hero__actions { flex-direction: column; align-items: center; padding: 0 1rem; }
  .hero__actions .btn { width: 100%; justify-content: center; }
  .trib-band__title { white-space: normal; }
  .trib-page-meta { flex-direction: column; gap: .5rem; }
}
@media (max-width: 480px) {
  .grid--4, .grid--3, .grid--2 { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero { min-height: 340px; }
  .hero__title { font-size: 1.9rem; }
  .section { padding: 1.5rem 0; }
  .trib-page-hero { padding: 2.5rem 1rem 2rem; }
  .trib-block { padding: 1.5rem 1rem; }
}


/* ── READABILITY FIX ─────────────────────────────────────────
   Small red text on blue/dark backgrounds converted to white.
   Per client feedback: red is illegible at small sizes on blue. */

/* Event type labels (e.g. "Speaking Engagement", "Film Festival") */
.ev-type { color: rgba(255,255,255,.6) !important; }

/* Card source labels (e.g. "Breitbart", "Epoch Times") */
.card__source { color: rgba(255,255,255,.55) !important; }

/* Hub episode show labels */
.hub-ep-show { color: rgba(255,255,255,.55) !important; }

/* SPEC area labels in cards */
.spec-area-tag { color: rgba(255,255,255,.6) !important; }

/* Hub tab inactive state */
.hub-tab { color: rgba(255,255,255,.55); }
.hub-tab.on { color: var(--color-white); }

/* Podcast show name in episode rows */
.ep-show { color: rgba(255,255,255,.55) !important; }
