/* ============================================================
   My Podcast — public site styles
   Dark theme + lime accent, mobile-first, no framework.
   ============================================================ */

:root{
  --accent:#d6f32f;
  --accent-dark:#bcd91f;
  --on-accent:#0e0e0e;   /* readable text/icon colour on top of --accent */
  --bg:#0e0e0e;
  --bg-2:#141414;
  --card:#181818;
  --card-2:#1f1f1f;
  --line:#2a2a2a;
  --text:#f5f5f5;
  --muted:#9a9a9a;
  --radius:18px;
  --radius-lg:28px;
  --maxw:1180px;
  --shadow:0 20px 50px rgba(0,0,0,.45);
  --font:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);background:var(--bg);color:var(--text);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.15;margin:0 0 .5em;font-weight:700;letter-spacing:-.01em}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.section-title{font-size:clamp(1.5rem,3vw,2.1rem);margin:0}
.accent{color:var(--accent)}
.muted{color:var(--muted)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:none;
  font-family:inherit;font-weight:600;font-size:.95rem;padding:13px 24px;border-radius:12px;
  transition:transform .15s ease,background .2s ease,color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent);color:var(--on-accent)}
.btn-primary:hover{background:var(--accent-dark)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.link-arrow{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600}
.link-arrow svg{width:18px;height:18px}

/* Play button circle */
.play-btn{
  display:inline-grid;place-items:center;width:46px;height:46px;border-radius:50%;
  background:var(--accent);color:var(--on-accent);flex:0 0 auto;transition:transform .15s ease;
}
.play-btn:hover{transform:scale(1.08)}
.play-btn svg{width:18px;height:18px}

/* ---------------- Header / nav ---------------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(14,14,14,.85);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.25rem}
.brand .logo{width:38px;height:38px;border-radius:50%;background:var(--accent);display:grid;place-items:center;color:var(--on-accent)}
.brand .brand-logo{display:block;width:auto;border-radius:8px}
.brand .brand-name{font-weight:700}
.brand .logo svg{width:20px;height:20px}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--text);font-size:.95rem;opacity:.85;transition:opacity .2s,color .2s}
.nav-links a:hover{opacity:1;color:var(--accent)}
.nav-links .nav-cta{display:none}        /* shown only inside the mobile menu */
.nav-actions{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:none;color:var(--text);cursor:pointer;padding:6px}
.nav-toggle svg{width:28px;height:28px}

/* ---------------- Hero ---------------- */
.hero{position:relative;padding:60px 0 40px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.2rem,5.2vw,3.6rem)}
.hero p.lead{color:var(--muted);max-width:46ch;margin:0 0 28px}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:34px}
.hero-meta{display:flex;align-items:center;gap:34px;flex-wrap:wrap}
.avatars{display:flex;align-items:center}
.avatars span{width:40px;height:40px;border-radius:50%;border:2px solid var(--bg);margin-left:-12px;
  background:var(--card-2) center/cover;display:grid;place-items:center;font-size:.7rem;color:var(--muted)}
.avatars span:first-child{margin-left:0}
.count-num{font-weight:700;font-size:1.15rem}
.count-num .accent{font-size:1.15rem}
.listen-on{display:flex;align-items:center;gap:14px}
.listen-on .label{color:var(--muted);font-size:.85rem}
.listen-on a{width:30px;height:30px;color:var(--muted);transition:color .2s,transform .2s}
.listen-on a:hover{color:var(--accent);transform:translateY(-2px)}
.listen-on svg{width:26px;height:26px}
.hero-figure{position:relative}
.hero-figure .frame{
  border:3px solid var(--accent);border-radius:var(--radius-lg);
  overflow:hidden;aspect-ratio:4/5;background:var(--card-2);
}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.hero-waves{position:absolute;left:0;top:90px;bottom:0;width:120px;opacity:.25;pointer-events:none;
  background:repeating-linear-gradient(90deg,var(--accent) 0 2px,transparent 2px 9px);
  -webkit-mask:linear-gradient(90deg,#000,transparent);mask:linear-gradient(90deg,#000,transparent)}

/* ---------------- Featured banner ---------------- */
.featured{
  background:var(--accent);color:var(--on-accent);border-radius:var(--radius-lg);
  display:grid;grid-template-columns:1fr auto;gap:26px;align-items:center;
  padding:34px 44px;overflow:hidden;
}
.featured h3{font-size:clamp(1.3rem,2.8vw,1.9rem);margin:0 0 6px}
.featured .meta{font-size:.85rem;font-weight:600;opacity:.7}
.featured .link-arrow{color:var(--on-accent);white-space:nowrap}

/* ---------------- About block ---------------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.about-collage{position:relative;min-height:360px}
.about-collage img{position:absolute;border-radius:14px;object-fit:cover;box-shadow:var(--shadow)}
.about-collage img:nth-child(1){width:62%;left:0;top:0;aspect-ratio:3/4}
.about-collage img:nth-child(2){width:55%;right:0;bottom:0;aspect-ratio:4/3;border:6px solid var(--bg)}
.about-collage .single{position:static;width:100%;aspect-ratio:4/3}
.about-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.about-eyebrow .play-btn{width:40px;height:40px}
.about-eyebrow b{display:block}
.about-eyebrow small{color:var(--muted)}
.about-text{white-space:pre-line;color:var(--muted);margin-bottom:22px}

/* ---------------- Episode list (latest) ---------------- */
.ep-list{display:flex;flex-direction:column;gap:18px}
.ep-card{
  display:grid;grid-template-columns:150px 1fr auto;gap:22px;align-items:center;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;transition:border-color .2s,transform .2s;
}
.ep-card:hover{border-color:#3a3a3a;transform:translateY(-2px)}
.ep-card.is-featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.ep-card .thumb{width:150px;height:110px;border-radius:14px;object-fit:cover;background:var(--card-2)}
.ep-card .cat{color:var(--muted);font-size:.8rem;font-weight:600;text-transform:capitalize;margin-bottom:4px}
.ep-card h3{font-size:1.15rem;margin:0 0 6px}
.ep-card p{color:var(--muted);font-size:.9rem;margin:0}

/* ---------------- Guests ---------------- */
.guests-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px;align-items:start}
.guest-intro h2{font-size:clamp(1.5rem,3vw,2rem)}
.guest-intro p{color:var(--muted)}
.guest-card{position:relative;display:block;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;background:var(--card-2);
  transition:transform .2s ease}
a.guest-card:hover{transform:translateY(-3px)}
.guest-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
a.guest-card:hover img{transform:scale(1.04)}
.guest-card .tag{position:absolute;left:12px;bottom:12px;background:var(--accent);color:var(--on-accent);
  border-radius:10px;padding:8px 14px}
.guest-card .tag b{display:block;font-size:.95rem}
.guest-card .tag small{font-size:.75rem;opacity:.8}
.guest-card .guest-play{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;background:var(--accent);color:var(--on-accent);opacity:1;
  box-shadow:0 4px 14px rgba(0,0,0,.35);transition:transform .2s ease}
a.guest-card:hover .guest-play{transform:scale(1.1)}
.guest-card .guest-play svg{width:18px;height:18px}

/* ---------------- Pagination ---------------- */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:34px}
.pagination .page-num,.pagination .page-arrow{
  display:inline-grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border-radius:12px;
  border:1px solid var(--line);background:var(--card);color:var(--text);font-weight:600;font-size:.95rem;
  transition:border-color .2s,background .2s,color .2s,transform .15s;
}
.pagination a.page-num:hover,.pagination a.page-arrow:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.pagination .page-num.active{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.pagination .page-arrow svg{width:20px;height:20px}
.pagination .page-arrow.disabled{opacity:.35;cursor:not-allowed}
.pagination .page-gap{min-width:24px;text-align:center;color:var(--muted)}

/* ---------------- Page head (sub-pages) ---------------- */
.page-head{margin-bottom:28px}
.page-head h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:0 0 6px}
.page-head .muted{margin:0}

/* ---------------- Platform bar ---------------- */
.platform-bar{background:var(--accent);color:var(--on-accent);border-radius:var(--radius-lg);
  padding:34px 40px;display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center}
.platform-bar h2{font-size:clamp(1.3rem,2.6vw,1.8rem);margin:0;line-height:1.1}
.platform-logos{display:flex;flex-wrap:wrap;gap:26px 40px;align-items:center;justify-content:flex-end}
.platform-logos a{display:flex;align-items:center;gap:8px;font-weight:600;opacity:.85;transition:opacity .2s,transform .2s}
.platform-logos a:hover{opacity:1;transform:translateY(-2px)}
.platform-logos svg{width:26px;height:26px}

/* ---------------- Top episodes grid ---------------- */
.ep-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ep-tile{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:border-color .2s,transform .2s}
.ep-tile:hover{border-color:#3a3a3a;transform:translateY(-3px)}
.ep-tile .cover{aspect-ratio:16/10;object-fit:cover;width:100%;background:var(--card-2)}
.ep-tile .body{padding:18px;display:flex;flex-direction:column;gap:8px;flex:1}
.ep-tile .cat{color:var(--muted);font-size:.78rem;font-weight:600;text-transform:capitalize}
.ep-tile h3{font-size:1.05rem;margin:0}
.ep-tile p{color:var(--muted);font-size:.88rem;margin:0;flex:1}

/* ---------------- Footer ---------------- */
.site-footer{border-top:1px solid var(--line);padding:48px 0 30px;margin-top:30px}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:32px;margin-bottom:30px}
.footer-grid p{color:var(--muted);max-width:40ch}
.footer-grid h4{font-size:1rem}
.footer-grid ul{list-style:none;padding:0;margin:0;line-height:2}
.footer-grid a{color:var(--muted)}
.footer-grid a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.85rem}
.footer-social{display:flex;gap:12px;align-items:center}
.footer-social a{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;
  border:1px solid var(--line);background:var(--card);color:var(--muted);
  transition:color .2s,border-color .2s,background .2s,transform .15s}
.footer-social a:hover{color:var(--on-accent);background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.footer-social a svg{width:20px;height:20px;display:block}

.empty-note{color:var(--muted);background:var(--card);border:1px dashed var(--line);
  border-radius:var(--radius);padding:30px;text-align:center}

/* ---------------- Watch chooser modal ---------------- */
.watch-modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.watch-modal.open{display:flex}
.watch-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(4px)}
.watch-dialog{position:relative;z-index:1;width:100%;max-width:860px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);
  padding:30px;animation:watch-pop .2s ease}
@keyframes watch-pop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
.watch-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;background:var(--card-2);border:1px solid var(--line);
  color:var(--text);cursor:pointer;transition:color .2s,border-color .2s}
.watch-close:hover{color:var(--accent);border-color:var(--accent)}
.watch-close svg{width:20px;height:20px}
.watch-choose{text-align:center;padding:14px 6px 6px}
.watch-choose h3{font-size:1.4rem;margin:0 0 8px}
.watch-choose p{margin:0 0 22px}
.watch-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.watch-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;background:#000}
.watch-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media (max-width:560px){
  .watch-dialog{padding:22px 16px}
  .watch-actions .btn{width:100%;justify-content:center}
}

/* ---------------- Responsive ---------------- */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-figure{max-width:420px;margin:0 auto}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .about-collage{min-height:300px;max-width:460px;margin-inline:auto}
  .guests-grid{grid-template-columns:1fr 1fr}
  .guest-intro{grid-column:1/-1}
  .platform-bar{grid-template-columns:1fr;gap:20px}
  .platform-logos{justify-content:flex-start}
  .ep-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .nav-links,.nav-actions .btn{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{
    display:flex;position:absolute;left:0;right:0;top:74px;flex-direction:column;gap:0;
    background:var(--bg-2);border-bottom:1px solid var(--line);padding:8px 20px;
  }
  .nav.open .nav-links li{padding:12px 0;border-bottom:1px solid var(--line)}
  .nav.open .nav-links li:last-child{border-bottom:none}
  .nav.open .nav-links .nav-cta{display:block}
  .nav.open .nav-links .nav-cta a{display:inline-flex}
  .section{padding:46px 0}
  .featured{grid-template-columns:1fr;text-align:left;padding:26px 24px}
  .featured .link-arrow{justify-self:start}
  .ep-card{grid-template-columns:96px 1fr;grid-template-areas:"thumb body" "play play"}
  .ep-card .thumb{grid-area:thumb;width:96px;height:96px}
  .ep-card .ep-body{grid-area:body}
  .ep-card .play-btn{grid-area:play;justify-self:start}
  .ep-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
}
@media (max-width:480px){
  .guests-grid{grid-template-columns:1fr}
  .hero-meta{gap:20px}
}
