:root{
  --pink-main:#f9d7e1;
  --pink-soft:#f0e0e3;
  --brown:#332202;
  --white:#fffafc;
  --rose:#f6cad7;
  --rose-deep:#eec1cf;
  --cream:#fcf5f7;
  --cream-new:#F6F6F4;
  --pink-accent-new:#FFE9EC;
  --purple-accent:#A25D96;
  --bg:linear-gradient(180deg,#fff8fa 0%,#fff2f5 100%);
  --bg-alt:#fffdfd;
  --surface:rgba(255,253,253,.78);
  --surface-strong:rgba(255,248,250,.95);
  --text:var(--brown);
  --text-muted:#9C8B79;
  --heading:#332202;
  --accent:var(--pink-main);
  --accent-strong:#F8C8DC;
  --accent-soft:rgba(249,215,225,.32);
  --accent-soft-2:rgba(240,224,227,.8);
  --border:rgba(51,34,2,.1);
  --shadow:0 12px 35px rgba(143,115,126,.12);
  --shadow-soft:0 6px 20px rgba(143,115,126,.08);
  --shadow-glow:0 0 0 1px #A25D96,0 18px 40px rgba(232,183,201,.22);
  --radius-xl:30px;
  --radius-lg:22px;
  --radius-md:16px;
  --radius-sm:12px
}

[data-theme="night"]{
  --bg:linear-gradient(180deg,#2a1e28 0%,#22171f 100%);
  --bg-alt:#342630;
  --surface:rgba(63,45,58,.78);
  --surface-strong:rgba(74,54,68,.92);
  --text:#F8C8DC;
  --text-muted:#edd5df;
  --heading:#FFC0CB;
  --accent:#f9d7e1;
  --accent-strong:#ffe7f3;
  --accent-soft:rgba(249,215,225,.18);
  --accent-soft-2:rgba(240,224,227,.16);
  --border:rgba(249,215,225,.16);
  --shadow:0 14px 36px rgba(0,0,0,.22);
  --shadow-soft:0 8px 18px rgba(0,0,0,.14);
  --shadow-glow:0 0 0 1px rgba(249,215,225,.2),0 18px 38px rgba(0,0,0,.25)
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  min-height:100vh;
  background:var(--bg);
  color:var(--text);
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.6;
  overflow-x:hidden;
  transition:background .25s ease,color .25s ease
}

body::before{
  content:"";
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:0;
  opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")
}

button,input,textarea,a,.segment-btn{-webkit-tap-highlight-color:transparent;font:inherit}
button{border:none;background:none;touch-action:manipulation}
a{touch-action:manipulation}

.bg-pattern{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  overflow:hidden
}

.bg-blob{
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  animation:float 18s ease-in-out infinite;
  opacity:.55
}

.bg-blob:nth-child(1){
  width:520px;
  height:520px;
  top:-140px;
  right:-150px;
  background:rgba(249,215,225,.85)
}

.bg-blob:nth-child(2){
  width:420px;
  height:420px;
  bottom:-120px;
  left:-120px;
  background:rgba(240,224,227,.75);
  animation-delay:-5s
}

.bg-blob:nth-child(3){
  width:320px;
  height:320px;
  top:35%;
  left:24%;
  background:rgba(255,214,235,.32);
  animation-delay:-10s
}

.bg-dots{
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle at 15% 25%,rgba(255,235,243,.08) 0 1.5px,transparent 1.5px),
    radial-gradient(circle at 78% 16%,rgba(255,235,243,.07) 0 1.5px,transparent 1.5px),
    radial-gradient(circle at 68% 80%,rgba(255,235,243,.08) 0 1.5px,transparent 1.5px),
    radial-gradient(circle at 28% 74%,rgba(255,235,243,.07) 0 1.5px,transparent 1.5px);
  background-size:230px 230px;
  opacity:.9
}

[data-theme="pink"] .bg-dots{
  background-image:
    radial-gradient(circle at 15% 25%,rgba(51,34,2,.05) 0 1.5px,transparent 1.5px),
    radial-gradient(circle at 78% 16%,rgba(51,34,2,.04) 0 1.5px,transparent 1.5px),
    radial-gradient(circle at 68% 80%,rgba(51,34,2,.05) 0 1.5px,transparent 1.5px),
    radial-gradient(circle at 28% 74%,rgba(51,34,2,.04) 0 1.5px,transparent 1.5px)
}

@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(26px,-22px) scale(1.05)}
  66%{transform:translate(-16px,18px) scale(.95)}
}

@keyframes shimmerSweep{
  0%{transform:translateX(-130%) skewX(-14deg);opacity:0}
  15%{opacity:.38}
  100%{transform:translateX(220%) skewX(-14deg);opacity:0}
}

@keyframes pulse{
  0%{opacity:1}
  50%{opacity:.5}
  100%{opacity:1}
}

@keyframes bounce{
  0%,100%{transform:scaleY(.55);opacity:.6}
  50%{transform:scaleY(1.15);opacity:1}
}

@keyframes spinVinyl{to{transform:rotate(360deg)}}
@keyframes counterSpin{to{transform:translate(-50%,-50%) rotate(-360deg)}}

@keyframes floatSticker{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-8px) rotate(3deg)}
}

@keyframes gentlePulse{
  0%,100%{opacity:.6;transform:scale(1)}
  50%{opacity:1;transform:scale(1.05)}
}

.nav-brand-bar{
  position:sticky;
  top:12px;
  z-index:120;
  width:min(1140px,calc(100% - 24px));
  margin:0 auto 24px;
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  border-radius:28px;
  padding:14px 20px;
  display:flex;
  justify-content:space-between;
  align-items:center
}

.nav-links-bar{
  position:sticky;
  top:90px;
  z-index:119;
  width:min(1140px,calc(100% - 24px));
  margin:0 auto;
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  box-shadow:var(--shadow-soft);
  border-radius:999px;
  padding:12px 20px;
  display:flex;
  justify-content:center
}

.nav-brand{display:flex;align-items:center;gap:10px}

.nav-brand-text{
  font-family:"Playfair Display",Georgia,serif;
  font-size:25px;
  font-weight:600;
  color:var(--heading)
}

.nav-actions{display:flex;gap:8px}

.nav-btn{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface-strong);
  color:var(--text);
  font-size:18px;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:transform .2s ease,background .2s ease;
  touch-action:manipulation;
  text-decoration:none
}

.nav-btn:hover{
  transform:translateY(-1px) scale(1.03);
  background:var(--accent-soft)
}

.nav-links-bar .nav-links{
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap
}

.nav-link{
  border:none;
  background:transparent;
  color:var(--text-muted);
  padding:8px 16px;
  border-radius:999px;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:all .25s ease;
  touch-action:manipulation;
  position:relative
}

.nav-link::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:4px;
  width:0;
  height:2px;
  background:var(--pink-main);
  transition:width .3s;
  transform:translateX(-50%)
}

.nav-link:hover::after,
.nav-link.active::after{
  width:100%;
  transform:translateX(-50%)
}

.nav-link:hover{
  background:var(--accent-soft);
  color:var(--heading)
}

.nav-link.active{
  background:var(--accent-soft);
  color:var(--heading);
  box-shadow:var(--shadow-soft)
}

@media(max-width:720px){
  .nav-links-bar{display:none!important}
  .nav-brand-bar{
    width:100%;
    border-radius:0 0 20px 20px;
    margin-top:0;
    padding:12px 16px
  }
  .nav-link::after{display:none}
}

.mobile-nav-wrap{
  display:none;
  position:sticky;
  top:88px;
  z-index:110;
  margin:12px auto 24px
}

.mobile-nav{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--surface);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  box-shadow:var(--shadow-soft);
  border-radius:999px;
  padding:8px
}

.mobile-nav-arrow{
  width:38px;
  height:38px;
  flex:0 0 38px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface-strong);
  color:var(--text);
  display:grid;
  place-items:center;
  cursor:pointer
}

.mobile-nav-scroll{
  display:flex;
  gap:8px;
  overflow-x:auto;
  scroll-behavior:smooth;
  scrollbar-width:none;
  flex:1;
  -webkit-overflow-scrolling:touch
}

.mobile-nav-scroll::-webkit-scrollbar{display:none}

.mobile-nav-link{
  flex:0 0 auto;
  border:1px solid var(--border);
  background:rgba(255,255,255,.28);
  color:var(--text-muted);
  border-radius:999px;
  padding:10px 14px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  white-space:nowrap;
  transition:all .2s ease;
  touch-action:manipulation
}

.mobile-nav-link.active,
.mobile-nav-link:hover{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731
}

.main{
  position:relative;
  z-index:1;
  width:min(1180px,calc(100% - 32px));
  margin:0 auto;
  padding:24px 0 84px
}

.reveal{
  opacity:0;
  transform:translateY(32px);
  transition:opacity .7s ease,transform .7s ease
}

.reveal.visible{
  opacity:1;
  transform:translateY(0)
}

.hero{
  min-height:calc(100vh - 180px);
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:42px;
  align-items:center;
  padding:34px 0 24px
}

.hero-content h1{
  font-family:"Playfair Display",Georgia,serif;
  font-size:clamp(3rem,8vw,5.2rem);
  line-height:1.03;
  letter-spacing:-.04em;
  font-weight:500;
  margin-bottom:22px;
  max-width:720px;
  color:var(--heading)
}

.hero-content h1 span{
  color:var(--accent-strong);
  font-style:italic;
  text-shadow:0 2px 8px rgba(162,93,150,.25)
}

.hero-content p{
  max-width:600px;
  font-size:18px;
  line-height:1.75;
  color:var(--text-muted);
  margin-bottom:26px
}

.hero-tags{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:24px
}

.hero-tag{
  padding:9px 16px;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--text);
  font-size:13px;
  font-weight:700;
  letter-spacing:.02em;
  border:1px solid var(--border);
  box-shadow:var(--shadow-soft)
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:26px
}

.btn{
  border:none;
  border-radius:999px;
  padding:14px 24px;
  font-size:15px;
  font-weight:700;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  text-decoration:none;
  touch-action:manipulation
}

.btn-primary{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  box-shadow:0 10px 22px rgba(200,164,175,.28)
}

.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(200,164,175,.35)
}

.btn-secondary{
  background:var(--surface-strong);
  color:var(--text);
  border:1px solid var(--border)
}

.btn-secondary:hover{
  background:var(--accent-soft);
  transform:translateY(-2px)
}

.hero-card,
.glass-card,
.monthly-favorites,
.episode-card{
  position:relative;
  overflow:hidden
}

.hero-card::after,
.glass-card::after,
.monthly-favorites::after,
.episode-card::after{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:42%;
  height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.32),transparent);
  transform:translateX(-130%) skewX(-14deg);
  pointer-events:none;
  opacity:0
}

.hero-card:hover::after,
.glass-card:hover::after,
.monthly-favorites::after,
.episode-card:hover::after{
  animation:shimmerSweep 1s ease
}

.hero-card,
.glass-card{
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow)
}

.hero-card{padding:30px}

.hero-card::before,
.glass-card::before{
  content:"";
  position:absolute;
  inset:auto -40px -70px auto;
  width:180px;
  height:180px;
  background:radial-gradient(circle,rgba(249,215,225,.35) 0%,transparent 68%);
  pointer-events:none
}

.hero-card:hover,
.glass-card:hover,
.episode-card:hover{
  box-shadow:var(--shadow-glow)
}

.section{
  padding:80px 0;
  scroll-margin-top:110px
}

.section-header{
  text-align:center;
  margin-bottom:42px
}

.section-header h2{
  font-family:"Playfair Display",Georgia,serif;
  font-size:clamp(2.2rem,5vw,3.2rem);
  margin-bottom:10px;
  color:var(--heading)
}

.section-header p{
  max-width:620px;
  margin:0 auto;
  color:var(--text-muted);
  font-size:16px
}

.monthly-favorites{
  padding:28px;
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  border-radius:30px;
  box-shadow:var(--shadow)
}

.monthly-favorites-head{
  text-align:center;
  margin-bottom:24px
}

.monthly-favorites-head h3{
  font-family:"Playfair Display",Georgia,serif;
  font-size:32px;
  margin-bottom:8px;
  color:var(--heading)
}

.monthly-favorites-head p{
  color:var(--text-muted);
  font-size:15px
}

.favorites-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px
}

.favorite-mini-card{
  background:linear-gradient(135deg,rgba(249,215,225,.24),rgba(240,224,227,.22));
  border:1px solid var(--border);
  border-radius:24px;
  padding:18px;
  box-shadow:var(--shadow-soft);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease
}

.favorite-mini-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-glow);
  border-color:rgba(249,215,225,.38)
}

.favorite-mini-icon{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#4a3040;
  font-size:22px;
  margin-bottom:14px
}

.favorite-mini-card label{
  display:block;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text-muted);
  font-weight:800;
  margin-bottom:8px
}

.favorite-mini-card h4{
  font-size:17px;
  color:var(--heading);
  margin-bottom:6px
}

.favorite-mini-card p{
  color:var(--text-muted);
  font-size:14px;
  line-height:1.7
}

.podcast-slider-wrapper{
  position:relative;
  max-width:100%;
  margin:0 auto
}

.podcast-slider-nav{
  display:flex;
  align-items:center;
  gap:16px
}

.podcast-arrow{
  flex-shrink:0;
  width:52px;
  height:52px;
  border-radius:50%;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--heading);
  font-size:20px;
  cursor:pointer;
  transition:all .25s ease;
  display:grid;
  place-items:center;
  box-shadow:var(--shadow-soft);
  z-index:5
}

.podcast-arrow:hover{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  border-color:transparent;
  transform:scale(1.05)
}

.podcast-track{
  display:flex;
  gap:24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-padding-left:16px;
  scroll-behavior:smooth;
  padding:12px 16px 34px;
  scrollbar-width:none;
  -ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  cursor:grab
}

.podcast-track:active{cursor:grabbing}
.podcast-track::-webkit-scrollbar{display:none}

.episode-card{
  flex:0 0 300px;
  scroll-snap-align:start;
  display:flex;
  flex-direction:column;
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease;
  position:relative
}

.episode-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-glow)
}

.episode-art{
  width:100%;
  height:200px;
  position:relative;
  overflow:hidden
}

.episode-art img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .5s ease
}

.episode-card:hover .episode-art img{transform:scale(1.05)}

.episode-play-overlay{
  position:absolute;
  inset:0;
  background:rgba(51,34,2,.15);
  display:grid;
  place-items:center;
  opacity:0;
  transition:opacity .3s ease;
  cursor:pointer
}

.episode-card:hover .episode-play-overlay{opacity:1}

.play-btn-circle{
  width:60px;
  height:60px;
  border-radius:50%;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(10px);
  display:grid;
  place-items:center;
  font-size:24px;
  color:#3e2731;
  box-shadow:0 8px 20px rgba(0,0,0,.15);
  border:1px solid rgba(255,255,255,.5)
}

.episode-body{
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:8px;
  flex-grow:1
}

.episode-kicker{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:800;
  color:var(--accent-strong)
}

.episode-title-card{
  font-family:"Playfair Display",Georgia,serif;
  font-size:19px;
  line-height:1.3;
  color:var(--heading);
  font-weight:600
}

.episode-desc-card{
  font-size:13px;
  color:var(--text-muted);
  line-height:1.6;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  line-clamp: 2;
  -webkit-line-clamp:2;
  overflow:hidden;
  margin-bottom:auto
}

.episode-meta-card{
  display:flex;
  gap:10px;
  font-size:12px;
  color:var(--text-muted);
  padding-top:12px;
  border-top:1px solid var(--border);
  margin-top:14px
}

.coming-badge{
  position:absolute;
  top:16px;
  left:16px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  color:var(--heading);
  font-size:11px;
  font-weight:800;
  letter-spacing:.04em;
  backdrop-filter:blur(10px);
  box-shadow:0 4px 10px rgba(0,0,0,.1)
}

@media(max-width:768px){
  .podcast-slider-nav{
    display:block;
  }

  .podcast-arrow{
    display:none;
  }

  .podcast-track{
    gap:16px;
    padding:8px calc((100% - min(86vw, 320px)) / 2) 24px;
    scroll-snap-type:x mandatory;
    scroll-padding-inline:calc((100% - min(86vw, 320px)) / 2);
  }

  .episode-card{
    flex:0 0 min(86vw, 320px);
    scroll-snap-align:center;
  }

  .episode-art{
    height:190px;
  }
}

.player-wrapper{max-width:900px;margin:0 auto}

.player-card-new{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  border-radius:var(--radius-xl);
  padding:40px;
  border:1px solid rgba(255,255,255,.4);
  box-shadow:0 20px 50px rgba(214,147,177,.25);
  display:grid;
  grid-template-columns:1fr;
  gap:30px;
  position:relative;
  overflow:hidden
}

@media(min-width:700px){
  .player-card-new{
    grid-template-columns:180px 1fr;
    align-items:center
  }
}

.player-art-new{
  width:180px;
  height:180px;
  background:var(--surface);
  border-radius:var(--radius-lg);
  margin:0 auto;
  box-shadow:0 10px 30px rgba(0,0,0,.05);
  display:grid;
  place-items:center;
  border:1px solid var(--border);
  overflow:hidden
}

.player-art-new img{width:100%;height:100%;object-fit:cover}

.player-content-new{text-align:center}
@media(min-width:700px){.player-content-new{text-align:left}}

.player-status-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 12px;
  background:rgba(255,255,255,.5);
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  color:#6d4c5a;
  margin-bottom:16px
}

.player-status-dot{
  width:8px;
  height:8px;
  background:#e91e63;
  border-radius:50%;
  animation:pulse 2s infinite
}

.player-title-new{
  font-family:"Playfair Display",serif;
  font-size:clamp(24px,5vw,32px);
  color:#4a3040;
  margin-bottom:8px;
  line-height:1.2
}

.player-desc-new{
  font-size:15px;
  color:#6d4c5a;
  line-height:1.6;
  margin-bottom:24px;
  max-width:500px
}

@media(min-width:700px){
  .player-desc-new{
    margin-right:auto;
    margin-bottom:24px
  }
}

.progress-wrap-new{width:100%;margin-bottom:20px}

.progress-times{
  display:flex;
  justify-content:space-between;
  font-size:12px;
  font-weight:600;
  color:#6d4c5a;
  margin-bottom:8px
}

.progress-bar-new{
  width:100%;
  height:8px;
  background:rgba(255,255,255,.5);
  border-radius:999px;
  overflow:hidden;
  cursor:pointer
}

.progress-fill-new{
  height:100%;
  background:#fff;
  width:0%;
  border-radius:999px;
  transition:width .1s linear
}

.controls-new{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px
}

@media(min-width:700px){
  .controls-new{justify-content:flex-start}
}

.ctrl-btn{
  background:rgba(255,255,255,.4);
  border:none;
  width:50px;
  height:50px;
  border-radius:50%;
  font-size:18px;
  cursor:pointer;
  color:#4a3040;
  display:grid;
  place-items:center;
  transition:background .2s;
  touch-action:manipulation
}

.ctrl-btn:hover{background:rgba(255,255,255,.6)}

.ctrl-btn-main{
  width:70px;
  height:70px;
  background:#fff;
  font-size:24px;
  box-shadow:0 8px 20px rgba(143,115,126,.2)
}

.sticker{
  position:absolute;
  font-size:28px;
  filter:drop-shadow(2px 4px 6px rgba(51,34,2,.15));
  pointer-events:none;
  z-index:5;
  opacity:.9;
  animation:floatSticker 6s ease-in-out infinite
}

.sticker-stationery{animation:none}

.segment-control{
  display:flex;
  flex-wrap:wrap;
  gap:10px
}

.segment-btn{
  padding:10px 18px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.65);
  color:var(--text);
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:all .25s ease;
  box-shadow:0 2px 6px rgba(143,115,126,.06);
  white-space:nowrap
}

.segment-btn:hover{
  background:rgba(255,255,255,.9);
  transform:translateY(-1px);
  box-shadow:var(--shadow-soft)
}

.segment-btn.active{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  border-color:transparent;
  box-shadow:0 6px 14px rgba(200,164,175,.25)
}

.search-box{
  width:100%;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--bg-alt);
  color:var(--text);
  padding:14px 18px;
  font-size:15px;
  outline:none;
  margin-bottom:18px;
  transition:border-color .2s ease,box-shadow .2s ease
}

.search-box:focus{
  border-color:rgba(249,215,225,.5);
  box-shadow:0 0 0 4px rgba(249,215,225,.18)
}

.search-box::placeholder{color:var(--text-muted)}

.newsletter-card{padding:34px}

.newsletter-form{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:28px;
  box-shadow:var(--shadow-soft);
  padding:24px;
  display:grid;
  gap:18px
}

.newsletter-form h4{
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text-muted)
}

.newsletter-form-row{display:grid;gap:8px}

.newsletter-form label{
  font-size:13px;
  font-weight:700;
  color:var(--text)
}

.newsletter-input,
.newsletter-textarea{
  width:100%;
  border-radius:18px;
  border:1px solid var(--border);
  background:var(--bg-alt);
  color:var(--text);
  padding:14px 16px;
  font-size:15px;
  outline:none;
  transition:border-color .2s ease,box-shadow .2s ease
}

.newsletter-textarea{
  min-height:120px;
  resize:vertical;
  border-radius:20px
}

.newsletter-input:focus,
.newsletter-textarea:focus{
  border-color:rgba(249,215,225,.5);
  box-shadow:0 0 0 4px rgba(249,215,225,.18)
}

.newsletter-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center
}

.newsletter-btn{
  border-radius:999px;
  padding:14px 20px;
  font-size:14px;
  font-weight:800;
  cursor:pointer;
  transition:transform .2s ease,background .2s ease;
  touch-action:manipulation
}

.newsletter-btn.primary{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  box-shadow:var(--shadow-soft)
}

.newsletter-btn.secondary{
  background:var(--surface-strong);
  border:1px solid var(--border);
  color:var(--text)
}

.newsletter-btn:hover{transform:translateY(-2px)}

.newsletter-note{
  font-size:13px;
  color:var(--text-muted)
}

.about-card{padding:34px}

.about-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:24px;
  align-items:center
}

.about-visual{
  min-height:280px;
  border-radius:28px;
  background:
    radial-gradient(circle at 25% 25%,rgba(255,255,255,.85),transparent 20%),
    radial-gradient(circle at 70% 30%,rgba(255,255,255,.35),transparent 22%),
    radial-gradient(circle at 50% 70%,rgba(255,255,255,.25),transparent 18%),
    linear-gradient(135deg,rgba(249,215,225,.8),rgba(240,224,227,.9));
  border:1px solid var(--border);
  box-shadow:var(--shadow-soft);
  position:relative;
  overflow:hidden;
  display:grid;
  place-items:center
}

.about-visual::before,
.about-visual::after{
  content:"";
  position:absolute;
  border-radius:50%;
  border:1px dashed rgba(51,34,2,.15)
}

.about-visual::before{
  width:180px;
  height:180px;
  animation:spinVinyl 18s linear infinite
}

.about-visual::after{
  width:250px;
  height:250px;
  animation:counterSpin 28s linear infinite
}

.about-image{
  width:160px;
  height:160px;
  border-radius:50%;
  object-fit:cover;
  border:4px solid rgba(255,255,255,.6);
  box-shadow:0 10px 30px rgba(143,115,126,.2);
  z-index:2;
  position:relative
}

.about-copy h3{
  font-family:"Playfair Display",Georgia,serif;
  font-size:34px;
  line-height:1.1;
  margin-bottom:14px;
  color:var(--heading)
}

.about-copy p{
  color:var(--text-muted);
  font-size:15px;
  line-height:1.85;
  margin-bottom:14px;
  max-width:640px
}

.about-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:10px
}

.about-tag{
  padding:9px 14px;
  border-radius:999px;
  background:var(--accent-soft);
  border:1px solid var(--border);
  font-size:12px;
  font-weight:800;
  color:var(--text)
}

.floating-heart-wrap{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:130;
  display:grid;
  justify-items:end;
  gap:10px
}

.heart-sheet{
  width:min(280px,calc(100vw - 30px));
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  border-radius:24px;
  padding:14px;
  display:grid;
  gap:8px;
  transform:translateY(12px) scale(.98);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease,transform .22s ease
}

.heart-sheet.open{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto
}

.heart-sheet-title{
  font-family:"Playfair Display",Georgia,serif;
  font-size:20px;
  color:var(--heading);
  padding:2px 6px 8px
}

.heart-sheet-btn{
  width:100%;
  text-align:left;
  border-radius:18px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.18);
  color:var(--text);
  padding:12px 14px;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  transition:background .2s ease,transform .2s ease;
  touch-action:manipulation
}

.heart-sheet-btn:hover{
  background:var(--accent-soft);
  transform:translateX(-2px)
}

.floating-heart-btn{
  width:62px;
  height:62px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  display:grid;
  place-items:center;
  box-shadow:0 16px 35px rgba(200,164,175,.3);
  cursor:pointer;
  font-size:26px;
  transition:transform .2s ease;
  touch-action:manipulation
}

.floating-heart-btn:hover{transform:translateY(-3px) scale(1.03)}

.toast-wrap{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  z-index:150;
  display:grid;
  gap:10px;
  pointer-events:none;
  width:min(100%,520px);
  padding:0 14px
}

.toast{
  background:var(--surface);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  color:var(--text);
  box-shadow:var(--shadow);
  border-radius:999px;
  padding:14px 18px;
  font-size:14px;
  font-weight:700;
  text-align:center;
  transform:translateY(16px);
  opacity:0;
  transition:opacity .25s ease,transform .25s ease
}

.toast.show{
  opacity:1;
  transform:translateY(0)
}

.footer{
  padding:40px 0 12px;
  text-align:center;
  color:var(--text-muted);
  font-size:14px
}

.stars{
  --rating:0;
  --star-size:15px;
  position:relative;
  display:inline-block;
  font-size:var(--star-size);
  line-height:1;
  letter-spacing:3px
}

.stars::before{
  content:"\2605\2605\2605\2605\2605";
  color:rgba(51,34,2,.18)
}

.stars::after{
  content:"\2605\2605\2605\2605\2605";
  color:#f2b84b;
  position:absolute;
  left:0;
  top:0;
  width:calc((var(--rating)/5)*100%);
  overflow:hidden;
  white-space:nowrap
}

.detail-meta-pill{
  font-size:11px;
  font-weight:800;
  padding:6px 10px;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--text);
  border:1px solid var(--border)
}

.detail-badge{
  padding:8px 13px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  font-size:12px;
  font-weight:800;
  box-shadow:var(--shadow-soft)
}

.progress-wrap{margin-top:8px}

.progress-label{
  font-size:12px;
  font-weight:700;
  color:var(--text-muted);
  margin-bottom:8px
}

.progress-bar{
  width:100%;
  height:10px;
  border-radius:999px;
  background:rgba(51,34,2,.08);
  overflow:hidden;
  border:1px solid var(--border)
}

.progress-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft))
}

@media(max-width:1080px){
  .about-grid{grid-template-columns:1fr}
}

@media(max-width:980px){
  .hero,
  .favorites-strip{grid-template-columns:1fr}
  .hero{gap:28px;min-height:auto}
  .hero-content,
  .section-header{text-align:center}
  .hero-content p{margin-left:auto;margin-right:auto}
  .hero-tags,
  .hero-actions,
  .about-tags{justify-content:center}
  .mobile-nav-wrap{display:block}
  .about-copy{text-align:center}
}

@media(max-width:720px){
  .mobile-nav-wrap{display:none!important}
  .main{padding-top:100px}
  .hero-content h1{font-size:clamp(2.7rem,13vw,4.2rem)}
  .hero-content p{font-size:16px}
  .hero-card,
  .about-card,
  .newsletter-card,
  .monthly-favorites{padding:22px}
  .newsletter-actions{flex-direction:column;align-items:stretch}
  .newsletter-btn{width:100%;text-align:center}
  .floating-heart-wrap{right:14px;bottom:14px}
  .floating-heart-btn{width:58px;height:58px}
}

.main,.nav,.mobile-nav-wrap,.floating-heart-wrap{position:relative;z-index:10}
.hero-card::after,.glass-card::after,.monthly-favorites::after,.episode-card::after,.sticker{pointer-events:none}
button,a,.segment-btn,.nav-link,.mobile-nav-link{touch-action:manipulation;cursor:pointer}
button:active{transform:scale(.96)}
.podcast-track.dragging{cursor:grabbing;scroll-behavior:auto}
.podcast-track,.mobile-nav-scroll{-webkit-overflow-scrolling:touch}

@media(max-width:768px){
  .segment-control{
    display:flex;
    flex-wrap:nowrap;
    overflow-x:auto;
    gap:10px;
    padding:6px 4px 10px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none
  }
  .segment-control::-webkit-scrollbar{display:none}
  .segment-btn{
    flex:0 0 auto;
    white-space:nowrap;
    padding:10px 16px;
    font-size:13px;
    border-radius:999px
  }
}

.profile-switcher{display:flex;align-items:center}

.profile-avatar{
  width:38px;
  height:38px;
  border-radius:50%;
  border:2.5px solid var(--surface-strong);
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  font-size:14px;
  font-weight:800;
  cursor:pointer;
  display:grid;
  place-items:center;
  overflow:hidden;
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
  position:relative;
  touch-action:manipulation;
  padding:0;
  font-family:"Playfair Display",Georgia,serif
}

.profile-avatar:not(:first-child){margin-left:-10px}

.profile-avatar:hover{
  transform:scale(1.12);
  z-index:2
}

.profile-avatar.active{
  border-color:var(--heading);
  box-shadow:0 0 0 2.5px var(--accent-strong);
  z-index:3
}

.profile-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  position:absolute;
  inset:0;
  padding:0;
}

.social-links-list{
  display:flex;
  flex-direction:column;
  gap:10px
}

.social-link-row{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  border-radius:18px;
  background:var(--surface-strong);
  border:1px solid var(--border);
  text-decoration:none;
  color:inherit;
  transition:all .25s ease;
  touch-action:manipulation
}

.social-link-row:hover{
  transform:translateX(4px);
  border-color:rgba(249,215,225,.4);
  box-shadow:var(--shadow-glow)
}

.social-link-icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  font-size:20px;
  flex-shrink:0
}

.social-link-text h4{
  font-size:14px;
  font-weight:700;
  color:var(--heading);
  margin-bottom:1px
}

.social-link-text p{
  font-size:12px;
  color:var(--text-muted)
}

.social-link-arrow{
  margin-left:auto;
  color:var(--text-muted);
  font-size:14px;
  transition:transform .2s ease
}

.social-link-row:hover .social-link-arrow{
  transform:translateX(3px);
  color:var(--heading)
}

.hero-social-title{
  font-family:"Playfair Display",Georgia,serif;
  font-size:22px;
  color:var(--heading);
  margin-bottom:4px
}

.hero-social-subtitle{
  font-size:13px;
  color:var(--text-muted);
  margin-bottom:18px
}

/* ===== YOUTUBE SECTION — PRETTIER ===== */
.yt-section{padding:50px 0 0}
.yt-card-outer{position:relative}
.yt-card-glow{
  position:absolute;
  inset:-2px;
  border-radius:34px;
  background:linear-gradient(135deg,rgba(249,215,225,.6),rgba(240,224,227,.5),rgba(162,93,150,.25));
  filter:blur(1px);
  z-index:0
}

.yt-card{
  position:relative;
  z-index:1;
  background:linear-gradient(160deg,rgba(255,248,250,.95),rgba(255,243,246,.9));
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid rgba(249,215,225,.35);
  border-radius:32px;
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .4s ease,box-shadow .4s ease;
  cursor:pointer;
  text-decoration:none;
  color:inherit;
  display:block
}

.yt-card:hover{
  transform:translateY(-6px) scale(1.01);
  box-shadow:0 24px 50px rgba(200,164,175,.22),0 0 0 1px rgba(249,215,225,.5)
}

.yt-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(249,215,225,.18) 100%);
  pointer-events:none;
  z-index:1
}

.yt-thumb-wrap{position:relative;overflow:hidden}

.yt-thumb{
  width:100%;
  height:240px;
  object-fit:cover;
  transition:transform .6s ease;
  display:block
}

.yt-card:hover .yt-thumb{transform:scale(1.05)}

.yt-thumb-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(51,34,2,.25) 100%);
  display:grid;
  place-items:center;
  z-index:2
}

.yt-play-btn{
  width:72px;
  height:72px;
  border-radius:50%;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  display:grid;
  place-items:center;
  font-size:30px;
  color:#3e2731;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
  border:2px solid rgba(255,255,255,.6);
  transition:transform .3s ease,box-shadow .3s ease
}

.yt-card:hover .yt-play-btn{
  transform:scale(1.1);
  box-shadow:0 14px 40px rgba(0,0,0,.22)
}

.yt-body{
  position:relative;
  z-index:2;
  padding:24px 28px 28px;
  display:flex;
  align-items:center;
  gap:18px
}

.yt-icon-wrap{
  width:60px;
  height:60px;
  border-radius:20px;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  display:grid;
  place-items:center;
  font-size:26px;
  flex-shrink:0;
  box-shadow:0 8px 20px rgba(200,164,175,.2);
  border:1px solid rgba(249,215,225,.4)
}

.yt-info h4{
  font-family:"Playfair Display",Georgia,serif;
  font-size:22px;
  font-weight:600;
  color:var(--heading);
  margin-bottom:3px;
  line-height:1.2
}

.yt-info p{
  font-size:14px;
  color:var(--text-muted);
  line-height:1.6
}

.yt-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 16px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  font-size:12px;
  font-weight:800;
  border:1px solid rgba(249,215,225,.5);
  margin-left:auto;
  white-space:nowrap;
  box-shadow:var(--shadow-soft);
  transition:transform .2s ease;
  letter-spacing:.02em
}

.yt-card:hover .yt-badge{transform:translateX(2px)}

.yt-decorations{
  position:absolute;
  top:14px;
  right:14px;
  z-index:3;
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-end
}

.yt-deco{
  font-size:20px;
  animation:gentlePulse 3s ease-in-out infinite;
  filter:drop-shadow(1px 2px 4px rgba(51,34,2,.1))
}

.yt-deco:nth-child(2){animation-delay:.5s}
.yt-deco:nth-child(3){animation-delay:1s}

@media(max-width:720px){
  .yt-thumb{height:180px}
  .yt-body{padding:18px 20px 22px;gap:14px}
  .yt-icon-wrap{width:50px;height:50px;font-size:22px;border-radius:16px}
  .yt-info h4{font-size:18px}
  .yt-badge{padding:6px 12px;font-size:11px}
  .yt-decorations{top:10px;right:10px}
  .yt-deco{font-size:16px}
}

/* ===== BOOKS ===== */
.books-wrapper-new{
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  border-radius:32px;
  overflow:hidden;
  box-shadow:var(--shadow);
  position:relative
}

.books-header-new{
  padding:28px 28px 0;
  position:relative;
  z-index:1
}

.books-header-new h3{
  font-family:"Playfair Display",Georgia,serif;
  font-size:31px;
  color:var(--heading);
  margin-bottom:6px
}

.books-header-new>p{
  color:var(--text-muted);
  font-size:15px;
  margin-bottom:18px
}

.books-filters-new{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-bottom:24px;
  border-bottom:1px solid var(--border)
}

.books-search-new{
  padding:0 28px;
  margin-top:18px
}

.books-grid-new{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:20px;
  padding:24px 28px 28px
}

.book-grid-card{
  background:rgba(255,255,255,.68);
  border:1px solid var(--border);
  border-radius:24px;
  padding:20px;
  cursor:pointer;
  transition:all .25s ease;
  display:flex;
  gap:16px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  touch-action:manipulation
}

[data-theme="night"] .book-grid-card{background:rgba(255,240,246,.06)}

.book-grid-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-glow);
  border-color:rgba(249,215,225,.4)
}

.book-grid-card::after{
  content:"\2661";
  position:absolute;
  right:16px;
  top:16px;
  font-size:16px;
  opacity:.3;
  color:var(--text-muted);
  pointer-events:none
}

.book-grid-cover{
  width:80px;
  height:120px;
  border-radius:16px;
  flex-shrink:0;
  overflow:hidden;
  background:linear-gradient(180deg,#fff9fb 0%,var(--pink-main) 100%);
  border:1px solid var(--border);
  box-shadow:0 8px 16px rgba(143,115,126,.12);
  display:grid;
  place-items:center
}

.book-grid-cover img{width:100%;height:100%;object-fit:cover}

.book-grid-info{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px
}

.book-grid-info h4{
  font-size:16px;
  font-weight:800;
  color:var(--heading);
  line-height:1.25
}

.book-grid-info .author{
  font-size:13px;
  color:var(--text-muted)
}

.book-grid-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px
}

.book-grid-badge{
  font-size:10px;
  font-weight:800;
  padding:4px 10px;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--text);
  text-transform:uppercase;
  letter-spacing:.06em;
  border:1px solid var(--border)
}

.book-grid-note{
  font-size:13px;
  color:var(--text-muted);
  line-height:1.6;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  line-clamp: 2;
  -webkit-line-clamp:2;
  overflow:hidden
}

.book-modal-overlay{
  position:fixed;
  inset:0;
  z-index:200;
  background:rgba(51,34,2,.35);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:grid;
  place-items:center;
  padding:20px;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease
}

.book-modal-overlay.open{
  opacity:1;
  pointer-events:auto
}

.book-modal{
  width:min(680px,100%);
  max-height:85vh;
  background:var(--surface-strong);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  border-radius:32px;
  box-shadow:var(--shadow-glow);
  overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(249,215,225,.3) transparent;
  transform:translateY(20px) scale(.97);
  transition:transform .3s ease;
  position:relative
}

.book-modal-overlay.open .book-modal{transform:translateY(0) scale(1)}

.book-modal::-webkit-scrollbar{width:8px}
.book-modal::-webkit-scrollbar-thumb{
  background:rgba(249,215,225,.3);
  border-radius:999px
}

.book-modal-close{
  position:sticky;
  top:16px;
  float:right;
  margin:16px 16px 0 0;
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--surface-strong);
  border:1px solid var(--border);
  color:var(--text);
  font-size:18px;
  cursor:pointer;
  display:grid;
  place-items:center;
  z-index:5;
  transition:transform .2s ease,background .2s ease;
  touch-action:manipulation
}

.book-modal-close:hover{
  transform:scale(1.08);
  background:var(--accent-soft)
}

.book-modal-inner{
  padding:28px 32px 36px;
  display:grid;
  gap:22px
}

.book-modal-top{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:22px;
  align-items:start
}

.book-modal-cover{
  width:140px;
  border-radius:20px;
  overflow:hidden;
  background:linear-gradient(180deg,#fff9fb 0%,var(--pink-main) 100%);
  border:1px solid var(--border);
  box-shadow:0 12px 28px rgba(143,115,126,.15);
  aspect-ratio:2/3
}

.book-modal-cover img{width:100%;height:100%;object-fit:cover}

.book-modal-meta h4{
  font-family:"Playfair Display",Georgia,serif;
  font-size:28px;
  line-height:1.15;
  color:var(--heading);
  margin-bottom:6px
}

.book-modal-author{
  font-size:15px;
  color:var(--text-muted);
  margin-bottom:12px
}

.book-modal-badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px
}

.book-modal-box{
  background:rgba(255,255,255,.55);
  border:1px solid var(--border);
  border-radius:22px;
  padding:18px;
  box-shadow:var(--shadow-soft)
}

[data-theme="night"] .book-modal-box{background:rgba(255,240,246,.06)}

.book-modal-box h5{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text-muted);
  margin-bottom:10px;
  font-weight:800
}

.book-modal-box p{
  font-size:15px;
  color:var(--text);
  white-space:pre-wrap;
  line-height:1.8
}

.book-modal-box p.quote-box{font-style:italic}

.book-modal-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px
}

.book-modal-grid .book-modal-box p{
  font-size:14px;
  line-height:1.75
}

.book-empty-state{
  padding:60px 28px;
  text-align:center
}

.book-empty-icon{
  width:88px;
  height:88px;
  margin:0 auto 18px;
  border-radius:28px;
  display:grid;
  place-items:center;
  font-size:36px;
  background:linear-gradient(135deg,rgba(249,215,225,.45),rgba(240,224,227,.65));
  border:1px solid var(--border);
  box-shadow:var(--shadow-soft)
}

.book-empty-state h4{
  font-family:"Playfair Display",Georgia,serif;
  font-size:26px;
  color:var(--heading);
  margin-bottom:8px
}

.book-empty-state p{
  font-size:15px;
  color:var(--text-muted);
  line-height:1.8;
  max-width:360px;
  margin:0 auto
}

.contact-extras{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:18px
}

.contact-extra-card{
  display:flex;
  align-items:center;
  gap:14px;
  padding:18px;
  border-radius:20px;
  background:linear-gradient(135deg,rgba(249,215,225,.24),rgba(240,224,227,.22));
  border:1px solid var(--border);
  text-decoration:none;
  color:inherit;
  transition:transform .2s ease,box-shadow .2s ease;
  touch-action:manipulation
}

.contact-extra-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-glow)
}

.contact-extra-icon{
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  font-size:20px;
  flex-shrink:0
}

.contact-extra-text strong{
  display:block;
  font-size:14px;
  color:var(--heading);
  margin-bottom:1px
}

.contact-extra-text span{
  font-size:12px;
  color:var(--text-muted)
}

.podcast-extras-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px
}

.podcast-extra-card{
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
  padding:24px;
  transition:transform .3s ease,box-shadow .3s ease;
  position:relative;
  overflow:hidden
}

.podcast-extra-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-glow)
}

.podcast-extra-card::before{
  content:"";
  position:absolute;
  inset:auto -30px -50px auto;
  width:140px;
  height:140px;
  background:radial-gradient(circle,rgba(249,215,225,.3) 0%,transparent 68%);
  pointer-events:none
}

.podcast-extra-icon{
  width:52px;
  height:52px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  font-size:24px;
  margin-bottom:16px;
  box-shadow:var(--shadow-soft)
}

.podcast-extra-card h4{
  font-family:"Playfair Display",Georgia,serif;
  font-size:20px;
  color:var(--heading);
  margin-bottom:8px;
  line-height:1.2
}

.podcast-extra-card p{
  font-size:14px;
  color:var(--text-muted);
  line-height:1.75
}

.podcast-extra-card .pink-quote{
  font-style:italic;
  font-size:16px;
  line-height:1.8;
  color:var(--heading);
  opacity:.85;
  margin-top:4px
}

.podcast-listen-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px
}

.podcast-listen-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  border-radius:999px;
  background:var(--accent-soft);
  border:1px solid var(--border);
  font-size:13px;
  font-weight:700;
  color:var(--text);
  text-decoration:none;
  transition:all .2s ease;
  touch-action:manipulation
}

.podcast-listen-pill:hover{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  border-color:transparent;
  transform:translateY(-1px)
}

.podcast-stats-row{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  margin-top:12px
}

.podcast-stat{
  padding:8px 14px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(249,215,225,.3),rgba(240,224,227,.25));
  border:1px solid var(--border);
  font-size:12px;
  font-weight:800;
  color:var(--text)
}

.topic-tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 14px;
  border-radius:999px;
  background:var(--accent-soft);
  border:1px solid var(--border);
  font-size:12px;
  font-weight:700;
  color:var(--text)
}

.topics-grid{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px
}

@media(max-width:720px){
  .contact-extras{grid-template-columns:1fr}
  .book-modal-top{grid-template-columns:1fr}
  .book-modal-cover{width:120px;margin:0 auto}
  .book-modal-meta{text-align:center}
  .book-modal-badges{justify-content:center}
  .book-modal-grid{grid-template-columns:1fr}
  .books-grid-new{grid-template-columns:1fr;padding:18px 16px 22px}
  .books-header-new{padding:22px 16px 0}
  .books-search-new{padding:0 16px;margin-top:14px}
  .podcast-extras-grid{grid-template-columns:1fr}
}
/* ===== YOUTUBE SHOWCASE LAYOUT ===== */
.yt-section{
  padding:50px 0 0;
}

.yt-showcase{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(290px,.9fr);
  gap:24px;
  align-items:stretch;
}

.yt-feature-card,
.yt-playlists-card{
  background:var(--surface);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);
  border-radius:32px;
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
}

.yt-feature-card{
  padding:24px;
}

.yt-playlists-card{
  padding:24px;
  background:linear-gradient(180deg,rgba(255,244,247,.96),rgba(255,238,243,.92));
}

.yt-feature-card::before,
.yt-playlists-card::before{
  content:"";
  position:absolute;
  inset:auto -35px -55px auto;
  width:150px;
  height:150px;
  background:radial-gradient(circle,rgba(249,215,225,.34) 0%,transparent 68%);
  pointer-events:none;
}

.yt-feature-top{
  margin-bottom:18px;
}

.yt-feature-kicker{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 12px;
  border-radius:999px;
  background:var(--accent-soft);
  border:1px solid var(--border);
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--text);
  margin-bottom:12px;
}

.yt-feature-top h3,
.yt-playlists-head h3{
  font-family:"Playfair Display",Georgia,serif;
  font-size:30px;
  line-height:1.1;
  color:var(--heading);
  margin-bottom:8px;
}

.yt-feature-top p,
.yt-playlists-head p{
  font-size:14px;
  line-height:1.75;
  color:var(--text-muted);
}

.yt-playlists-head{
  margin-bottom:18px;
}

.yt-embed-shell{
  width:100%;
  aspect-ratio:16/9;
  border-radius:26px;
  overflow:hidden;
  border:1px solid rgba(249,215,225,.35);
  background:linear-gradient(135deg,#f9d7e1,#f0e0e3);
  box-shadow:var(--shadow-soft);
}

.yt-embed-shell iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}

.yt-empty-state{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:28px;
  background:
    radial-gradient(circle at top,rgba(255,255,255,.6),transparent 45%),
    linear-gradient(135deg,rgba(249,215,225,.92),rgba(240,224,227,.94));
}

.yt-empty-inner{
  max-width:420px;
}

.yt-empty-icon{
  font-size:42px;
  margin-bottom:12px;
}

.yt-empty-state h4{
  font-family:"Playfair Display",Georgia,serif;
  font-size:28px;
  color:var(--heading);
  margin-bottom:8px;
}

.yt-empty-state p{
  font-size:15px;
  line-height:1.8;
  color:#6d5860;
}

.yt-feature-actions{
  margin-top:18px;
}

.yt-watch-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 18px;
  border-radius:999px;
  text-decoration:none;
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  color:#3e2731;
  font-size:13px;
  font-weight:800;
  border:1px solid rgba(249,215,225,.45);
  box-shadow:var(--shadow-soft);
  transition:transform .2s ease,box-shadow .2s ease;
}

.yt-watch-btn:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-glow);
}

.yt-genre-list{
  display:grid;
  gap:12px;
}

.yt-genre-btn{
  width:100%;
  display:flex;
  align-items:center;
  gap:14px;
  text-align:left;
  padding:15px 16px;
  border-radius:22px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.6);
  cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease;
  touch-action:manipulation;
}

.yt-genre-btn:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
  background:rgba(255,255,255,.86);
}

.yt-genre-btn.active{
  background:linear-gradient(135deg,var(--pink-main),var(--pink-soft));
  border-color:transparent;
  box-shadow:0 10px 24px rgba(200,164,175,.24);
}

.yt-genre-icon{
  width:50px;
  height:50px;
  border-radius:16px;
  display:grid;
  place-items:center;
  flex-shrink:0;
  background:rgba(255,255,255,.7);
  font-size:22px;
}

.yt-genre-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.yt-genre-text strong{
  font-size:15px;
  color:var(--heading);
}

.yt-genre-text small{
  font-size:12px;
  color:var(--text-muted);
}

.yt-suggestion-box{
  margin-top:18px;
  padding:18px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(249,215,225,.36),rgba(240,224,227,.28));
  border:1px solid var(--border);
}

.yt-suggestion-box h4{
  font-family:"Playfair Display",Georgia,serif;
  font-size:22px;
  color:var(--heading);
  margin-bottom:8px;
}

.yt-suggestion-box p{
  font-size:14px;
  line-height:1.75;
  color:var(--text-muted);
  margin-bottom:14px;
}

@media(max-width:980px){
  .yt-showcase{
    grid-template-columns:1fr;
  }
}

@media(max-width:720px){
  .yt-feature-card,
  .yt-playlists-card{
    padding:18px;
    border-radius:26px;
  }

  .yt-feature-top h3,
  .yt-playlists-head h3,
  .yt-empty-state h4{
    font-size:24px;
  }

  .yt-genre-btn{
    padding:13px 14px;
    border-radius:18px;
  }

  .yt-genre-icon{
    width:44px;
    height:44px;
    font-size:20px;
  }
}