:root{
  --purple-deep:#1e1530;
  --purple-mid:#3d2b54;
  --orange-burnt:#a8481f;
  --mustard:#c1902f;
  --pink-accent:#b8436f;
  --cream:#efe3c2;
  --ink:#1e1530;
  --font-groovy:'Shrikhand', cursive;
  --font-groovy-shade:'Bungee Shade', cursive;
  --font-body:'Alegreya', serif;
  --font-label:'Special Elite', monospace;
}

*, *::before, *::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; font-size:18px; }

body{
  margin:0;
  min-height:100vh;
  font-family:var(--font-body);
  color:var(--ink);
  overflow-x:hidden;
  position:relative;
  background:var(--purple-deep);
}

ul{ margin:0; padding:0; list-style:none; }
img{ max-width:100%; }

/* ---------- muted, slow-moving backdrop ---------- */

.blob-bg{
  position:fixed;
  inset:0;
  z-index:0;
  overflow:hidden;
  background:linear-gradient(150deg, var(--purple-deep), var(--purple-mid) 55%, var(--orange-burnt) 125%);
  background-size:300% 300%;
  animation:swirl 34s ease-in-out infinite;
}

@keyframes swirl{
  0%{ background-position:0% 30%; }
  50%{ background-position:100% 70%; }
  100%{ background-position:0% 30%; }
}

.blob{
  position:absolute;
  border-radius:50%;
  filter:blur(100px);
  opacity:.26;
  mix-blend-mode:soft-light;
}

.blob-a{ width:560px; height:560px; background:var(--mustard); top:-140px; left:-120px; animation:float1 28s ease-in-out infinite; }
.blob-b{ width:480px; height:480px; background:var(--pink-accent); bottom:-140px; right:-120px; animation:float2 34s ease-in-out infinite; }

@keyframes float1{ 0%,100%{ transform:translate(0,0) scale(1); } 50%{ transform:translate(70px,60px) scale(1.1); } }
@keyframes float2{ 0%,100%{ transform:translate(0,0) scale(1); } 50%{ transform:translate(-60px,-40px) scale(1.08); } }

/* ---------- floating psychedelic mushrooms ---------- */

.shroom-layer{
  position:fixed;
  inset:0;
  z-index:1;
  pointer-events:none;
  transition:transform .3s ease-out;
  will-change:transform;
}

.shroom{ position:absolute; opacity:.5; }
.shroom.s1{ width:120px; height:156px; top:12%; left:4%; animation:drift 22s ease-in-out infinite; }
.shroom.s2{ width:80px; height:104px; top:38%; right:6%; animation:drift 18s ease-in-out infinite reverse; opacity:.4; }
.shroom.s3{ width:150px; height:195px; bottom:14%; left:8%; animation:drift 26s ease-in-out infinite; opacity:.35; }
.shroom.s4{ width:70px; height:91px; top:64%; right:14%; animation:drift 20s ease-in-out infinite; opacity:.45; }
.shroom.s5{ width:100px; height:130px; top:6%; right:22%; animation:drift 30s ease-in-out infinite reverse; opacity:.3; }

@keyframes drift{
  0%,100%{ transform:translate(0,0) rotate(-6deg); }
  33%{ transform:translate(24px,-30px) rotate(5deg); }
  66%{ transform:translate(-18px,20px) rotate(-3deg); }
}

/* ---------- moscoso / kelley op-art: lightly vibrating rings ---------- */

.opart{
  position:fixed;
  inset:-25%;
  z-index:0;
  pointer-events:none;
  opacity:.07;
  mix-blend-mode:overlay;
  background:
    repeating-radial-gradient(circle at 50% 42%, var(--pink-accent) 0 11px, transparent 11px 22px),
    repeating-radial-gradient(circle at 50% 42%, var(--mustard) 6px 12px, transparent 12px 24px);
  animation:vibrate .8s steps(2) infinite, opaspin 160s linear infinite;
  will-change:transform;
}

@keyframes vibrate{
  0%{ transform:translate(0,0); }
  100%{ transform:translate(1.5px,-1.5px); }
}
@keyframes opaspin{
  0%{ transform:rotate(0deg); }
  100%{ transform:rotate(360deg); }
}

/* rotating sunray burst behind the masthead (family-dog poster vibe) */
.cover::before{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:150vmax;
  height:150vmax;
  transform:translate(-50%,-45%);
  z-index:-1;
  pointer-events:none;
  background:repeating-conic-gradient(from 0deg at 50% 50%,
    rgba(193,144,47,.14) 0deg 5deg,
    transparent 5deg 10deg);
  -webkit-mask-image:radial-gradient(circle, #000 0 32%, transparent 62%);
          mask-image:radial-gradient(circle, #000 0 32%, transparent 62%);
  animation:sunspin 120s linear infinite;
}

@keyframes sunspin{
  0%{ transform:translate(-50%,-45%) rotate(0deg); }
  100%{ transform:translate(-50%,-45%) rotate(360deg); }
}

/* ---------- grain + halftone print texture ---------- */

.grain-overlay{
  position:fixed;
  inset:0;
  z-index:2;
  pointer-events:none;
  opacity:.3;
  mix-blend-mode:overlay;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"),
    radial-gradient(circle, rgba(0,0,0,.5) 1px, transparent 1.4px);
  background-size:180px 180px, 6px 6px;
}

main, header.cover, footer.cta-footer, .top-bar{ position:relative; z-index:3; }

/* ---------- top bar (issue no. at the very top) ---------- */

.top-bar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  padding:.6rem 1.4rem;
  font-family:var(--font-label);
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:.72rem;
  color:var(--purple-deep);
  background:var(--mustard);
  border-bottom:3px solid var(--purple-deep);
}
.top-name{ text-align:right; opacity:.85; }

/* ---------- cover / masthead ---------- */

.cover{ text-align:center; padding:3rem 1.5rem 2.5rem; position:relative; }

.cover-kicker{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  justify-content:center;
  align-items:center;
  font-family:var(--font-label);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:.9rem;
  margin:0 auto .8rem;
  border-top:2px solid rgba(239,227,194,.4);
  border-bottom:2px solid rgba(239,227,194,.4);
  padding:.6rem 0;
  max-width:680px;
}
.cover-kicker a{ color:var(--cream); text-decoration:none; transition:color .2s ease; }
.cover-kicker a:hover{ color:var(--mustard); }
.cover-kicker span{ color:var(--pink-accent); }

.masthead{
  font-family:var(--font-groovy);
  font-size:clamp(3rem, 13vw, 8.5rem);
  text-transform:uppercase;
  color:var(--mustard);
  text-shadow:4px 4px 0 var(--pink-accent), 8px 8px 0 var(--purple-deep);
  margin:.4rem 0 0;
  line-height:.9;
  letter-spacing:.01em;
}

.masthead-sub{
  font-family:var(--font-groovy-shade);
  color:var(--cream);
  text-transform:uppercase;
  font-size:clamp(1rem, 3.5vw, 2rem);
  letter-spacing:.06em;
  margin:.2rem 0 0;
}

.cover-line{
  font-family:var(--font-body);
  font-size:clamp(1.2rem, 3vw, 1.9rem);
  color:var(--cream);
  margin:1rem auto 0;
  max-width:640px;
  font-style:italic;
}

#girl-name{
  font-family:var(--font-groovy);
  font-style:normal;
  color:var(--pink-accent);
  text-shadow:2px 2px 0 var(--purple-deep);
}

.cover-teasers{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  justify-content:center;
  margin-top:1.8rem;
}

.teaser{
  font-family:var(--font-label);
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--purple-deep);
  background:var(--cream);
  padding:.5rem .9rem;
  border:2px solid var(--purple-deep);
  box-shadow:3px 3px 0 var(--purple-deep);
  text-decoration:none;
  cursor:pointer;
}
.teaser.t1{ transform:rotate(-2deg); background:var(--mustard); }
.teaser.t2{ transform:rotate(1.5deg); }
.teaser.t3{ transform:rotate(-1deg); background:var(--pink-accent); color:var(--cream); }
.teaser:hover{ animation:wiggle .35s ease-in-out infinite; }

@keyframes wiggle{
  0%,100%{ transform:rotate(-4deg) scale(1.06); }
  50%{ transform:rotate(4deg) scale(1.06); }
}

/* offset anchor jumps a touch */
#insights, #funny, #audit, #online, #gallery{ scroll-margin-top:1.5rem; }

/* ---------- wavy cards ---------- */

.wavy-card{
  background-color:var(--cream);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-blend-mode:multiply;
  border:4px solid var(--purple-deep);
  border-radius:255px 15px 225px 15px / 15px 225px 15px 255px;
  box-shadow:12px 12px 0 var(--purple-deep);
  padding:2.6rem;
  position:relative;
}

.dropcap{
  position:absolute;
  top:-28px;
  left:26px;
  font-family:var(--font-groovy);
  font-size:3rem;
  color:var(--pink-accent);
  text-shadow:2px 2px 0 var(--purple-deep);
  transform:rotate(-8deg);
}
.dropcap.alt{ color:var(--mustard); left:auto; right:26px; transform:rotate(8deg); }

.section-title{
  font-family:var(--font-groovy);
  text-transform:uppercase;
  color:var(--purple-deep);
  font-size:clamp(1.8rem, 4.5vw, 2.8rem);
  margin:0 0 1.5rem;
  text-align:left;
}

.section-title.center{
  text-align:center;
  color:var(--cream);
  text-shadow:3px 3px 0 var(--pink-accent), 5px 5px 0 var(--purple-deep);
}

/* ---------- asymmetric photo + facts spreads ---------- */

main{ max-width:1200px; margin:0 auto; padding:0 1.5rem; }

.spread{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
  align-items:center;
  margin:3rem 0;
}

.facts-list{ display:grid; gap:1.15rem; }

.facts-list li{
  position:relative;
  padding-left:2.1rem;
  font-size:1.35rem;
  line-height:1.5;
}

.facts-list li::before{
  content:"✦";
  position:absolute;
  left:0;
  top:.05em;
  color:var(--pink-accent);
  font-size:1.1em;
}

.funny-card{ border-color:var(--orange-burnt); }
.funny-card .facts-list li::before{ color:var(--mustard); }

/* subject: value stat sheet */
.stat-list{ gap:.85rem; }
.stat-list li{ padding-left:0; font-size:1.2rem; }
.stat-list li::before{ content:none; }
.stat-list b{
  font-family:var(--font-label);
  text-transform:uppercase;
  letter-spacing:.04em;
  font-size:.82em;
  color:var(--orange-burnt);
  margin-right:.5rem;
}
.stat-list b::after{ content:":"; }

/* photo frames */
.frame{
  margin:0;
  background:#fdf8ec;
  padding:.9rem;
  box-shadow:8px 8px 0 rgba(30,21,48,.55), 0 16px 26px rgba(0,0,0,.4);
  transition:transform .35s ease, box-shadow .35s ease;
}
.frame img{
  display:block;
  width:100%;
  object-fit:cover;
  filter:sepia(.15) contrast(1.05) saturate(1.12);
}

.feature-photo{ width:100%; max-width:560px; margin:0 auto; }
.feature-photo img{ aspect-ratio:4/5; }

@media(min-width:860px){
  .spread{ grid-template-columns:1.15fr .95fr; gap:0; }

  .spread-a .photo-1{ transform:rotate(-3deg); justify-self:start; margin-right:-4rem; z-index:2; }
  .spread-a .card-overlap-left{ transform:rotate(1.2deg); z-index:3; }

  .spread-b{ grid-template-columns:.95fr 1.15fr; }
  .spread-b .card-overlap-right{ transform:rotate(-1.2deg); z-index:3; margin-right:-4rem; }
  .spread-b .photo-2{ transform:rotate(3deg); justify-self:end; z-index:2; }

  .feature-photo{ max-width:480px; }
  .frame:hover{ transform:rotate(0deg) scale(1.03); }
}

/* ---------- animated wave divider ---------- */

.wave-divider{ line-height:0; margin:1rem 0; }
.wave-divider svg{ width:100%; height:70px; display:block; }
.wave-divider path{ fill:var(--cream); opacity:.22; animation:waveflow 8s ease-in-out infinite; transform-origin:center; }

@keyframes waveflow{
  0%,100%{ transform:translateX(0) scaleY(1); }
  50%{ transform:translateX(-40px) scaleY(1.3); }
}

/* ---------- pull quote + duckman sticker ---------- */

.pull-quote-wrap{
  position:relative;
  max-width:820px;
  margin:1rem auto 3.5rem;
  padding:1rem 2rem;
  text-align:center;
}

.pull-quote{
  font-family:var(--font-groovy-shade);
  color:var(--cream);
  font-size:clamp(1.5rem, 4.5vw, 2.6rem);
  line-height:1.3;
  transform:rotate(-1.5deg);
  margin:0;
}

.duckman-sticker{
  display:block;
  width:110px;
  margin:1.4rem auto 0;
  transform:rotate(-8deg);
  filter:drop-shadow(4px 6px 6px rgba(0,0,0,.5));
  animation:duckbob 6s ease-in-out infinite;
}

@keyframes duckbob{
  0%,100%{ transform:rotate(-8deg) translateY(0); }
  50%{ transform:rotate(-4deg) translateY(-12px); }
}

@media(min-width:860px){
  .duckman-sticker{
    position:absolute;
    width:140px;
    right:-6px;
    bottom:-46px;
    margin:0;
    z-index:4;
  }
}

/* ---------- what we could do together ---------- */

.together-section{ max-width:1040px; margin:3rem auto; padding:1.5rem 0; }

.together-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.4rem;
  margin-top:1.5rem;
}

@media(min-width:760px){ .together-grid{ grid-template-columns:repeat(3, 1fr); } }

.together-card{
  background:var(--cream);
  border:4px solid var(--purple-deep);
  border-radius:15px 200px 15px 200px / 200px 15px 200px 15px;
  box-shadow:8px 8px 0 var(--purple-deep);
  padding:2rem 1.8rem;
  font-size:1.25rem;
  line-height:1.45;
  font-style:italic;
}
.together-card:nth-child(1){ transform:rotate(-1.5deg); }
.together-card:nth-child(2){ transform:rotate(1deg); }
.together-card:nth-child(3){ transform:rotate(-.5deg); }

/* ---------- music strip ---------- */

.music-strip{
  max-width:900px;
  margin:1rem auto 3rem;
  padding:2rem 2.4rem;
  text-align:center;
  background:var(--purple-mid);
  border:3px dashed var(--mustard);
  border-radius:40px 12px 40px 12px / 12px 40px 12px 40px;
  transform:rotate(-.6deg);
}
.music-eyebrow{
  font-family:var(--font-label);
  text-transform:uppercase;
  letter-spacing:.24em;
  color:var(--mustard);
  font-size:.85rem;
  margin:0 0 .5rem;
}
.music-blurb{
  font-family:var(--font-body);
  font-style:italic;
  color:var(--cream);
  font-size:1.25rem;
  margin:0 0 1.2rem;
}
.music-links{ display:flex; gap:1.4rem; justify-content:center; flex-wrap:wrap; }
.music-links a{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.15rem;
  font-family:var(--font-groovy);
  font-size:1.15rem;
  color:var(--purple-deep);
  background:var(--cream);
  padding:.7rem 1.3rem;
  border:3px solid var(--purple-deep);
  border-radius:30px 8px 30px 8px / 8px 30px 8px 30px;
  text-decoration:none;
  transition:transform .2s ease, background .2s ease;
}
.music-links a small{
  font-family:var(--font-body);
  font-style:italic;
  font-size:.78rem;
  opacity:.75;
}
.music-links a:hover{ transform:translateY(-3px) rotate(-2deg); background:var(--mustard); }

/* ---------- heavy rotation chart ---------- */

.charts-section{ max-width:820px; margin:3.5rem auto; padding:1.5rem; }
.charts-sub{
  text-align:center;
  font-family:var(--font-label);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.82rem;
  color:var(--cream);
  opacity:.85;
  margin:-.6rem 0 1.6rem;
}

.charts{
  list-style:none;
  margin:0;
  padding:0;
  background:var(--cream);
  background-blend-mode:multiply;
  border:4px solid var(--purple-deep);
  border-radius:20px 180px 20px 180px / 180px 20px 180px 20px;
  box-shadow:12px 12px 0 var(--purple-deep);
  overflow:hidden;
  transform:rotate(-.5deg);
}

.charts li{
  display:flex;
  align-items:center;
  gap:1.2rem;
  padding:1rem 1.8rem;
  border-bottom:2px dashed rgba(30,21,48,.25);
  transition:background .2s ease, padding-left .2s ease;
}
.charts li:last-child{ border-bottom:none; }
.charts li:hover{ background:rgba(184,67,111,.14); padding-left:2.3rem; }

.charts .rank{
  font-family:var(--font-groovy);
  font-size:2rem;
  color:var(--pink-accent);
  text-shadow:2px 2px 0 var(--purple-deep);
  min-width:2.4ch;
  text-align:center;
}
.charts .genre{
  font-family:var(--font-body);
  font-weight:700;
  font-size:1.35rem;
  color:var(--ink);
}
.charts .genre em{
  display:block;
  font-weight:400;
  font-size:.9rem;
  font-style:italic;
  opacity:.7;
}
.charts li.sub{ padding-left:3rem; background:rgba(193,144,47,.12); }
.charts li.sub .rank{ font-size:1.5rem; color:var(--orange-burnt); }
.charts li.sub .genre{ font-size:1.1rem; }

/* ---------- pros & cons ---------- */

.audit-section{ max-width:1040px; margin:3.5rem auto; padding:1.5rem 0; }

.audit-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.6rem;
  margin-top:1.5rem;
}

@media(min-width:700px){
  .audit-grid{ grid-template-columns:1fr 1fr; gap:1rem; }
  .pros-card{ transform:rotate(1.5deg); z-index:2; margin-right:-1rem; }
  .cons-card{ transform:rotate(-1.5deg); z-index:1; margin-left:-1rem; }
}

.pros-card{ background-color:var(--mustard); background-blend-mode:multiply; }
.cons-card{ background-color:var(--orange-burnt); background-blend-mode:multiply; }
.cons-card, .cons-card .audit-heading{ color:var(--cream); }
.cons-card li::before{ color:var(--cream) !important; }

.audit-heading{
  font-family:var(--font-groovy);
  text-transform:uppercase;
  font-size:1.9rem;
  margin:0 0 1rem;
  color:var(--purple-deep);
}

.pros-card ul, .cons-card ul{ display:grid; gap:1rem; font-size:1.2rem; line-height:1.45; }
.pros-card li::before{ content:"+ "; font-weight:bold; color:var(--purple-deep); }
.cons-card li::before{ content:"- "; font-weight:bold; }

/* ---------- editorial magazine gallery ---------- */

.gallery-section{ max-width:1200px; margin:3.5rem auto 4rem; padding:1.5rem 0; }

/* masonry columns: images keep their full aspect ratio, no cropping */
.gallery{
  columns:3;
  column-gap:18px;
  padding:1rem 0 2rem;
}

.tile{
  margin:0 0 18px;
  break-inside:avoid;
  overflow:hidden;
  background:#fdf8ec;
  border:6px solid #fdf8ec;
  box-shadow:0 12px 22px rgba(0,0,0,.4);
  transition:transform .35s ease, box-shadow .35s ease;
}
.tile:nth-child(2n){ transform:rotate(-1.2deg); }
.tile:nth-child(3n){ transform:rotate(1.2deg); }

.tile img, .tile video{
  width:100%;
  height:auto;
  display:block;
  filter:sepia(.16) contrast(1.05) saturate(1.14);
  transition:filter .4s ease;
}
.tile:hover{ transform:rotate(0deg) scale(1.03); box-shadow:0 18px 30px rgba(0,0,0,.5); }
.tile:hover img, .tile:hover video{ filter:none; }

@media(max-width:900px){ .gallery{ columns:2; } }
@media(max-width:560px){ .gallery{ columns:1; } }

/* ---------- footer / cta ---------- */

.cta-footer{ text-align:center; padding:3.5rem 1.5rem 6rem; }

.cta-note{
  font-family:var(--font-label);
  color:var(--cream);
  font-size:1.05rem;
  margin:0 0 2rem;
  letter-spacing:.03em;
}

.cta-button{
  display:inline-block;
  font-family:var(--font-groovy);
  text-transform:uppercase;
  font-size:clamp(1.2rem, 3vw, 1.9rem);
  color:var(--purple-deep);
  background:linear-gradient(120deg, var(--mustard), var(--pink-accent), var(--orange-burnt));
  background-size:200% 200%;
  padding:1.2rem 2.6rem;
  border-radius:60px 20px 60px 20px / 20px 60px 20px 60px;
  border:4px solid var(--purple-deep);
  text-decoration:none;
  animation:pulse-glow 2.8s ease-in-out infinite, gradient-shift 7s ease infinite;
  transition:transform .25s ease;
}

.cta-button:hover{ transform:scale(1.06) rotate(-1deg); }

@keyframes pulse-glow{
  0%,100%{ box-shadow:0 0 18px 3px rgba(184,67,111,.45), 8px 8px 0 var(--purple-deep); }
  50%{ box-shadow:0 0 38px 12px rgba(184,67,111,.7), 8px 8px 0 var(--purple-deep); }
}

@keyframes gradient-shift{
  0%,100%{ background-position:0% 50%; }
  50%{ background-position:100% 50%; }
}

.footer-socials{
  margin-top:1.6rem;
  font-family:var(--font-label);
  letter-spacing:.1em;
  color:var(--cream);
  font-size:.95rem;
}
.footer-socials a{ color:var(--cream); text-decoration:none; border-bottom:1px solid var(--mustard); padding-bottom:2px; }
.footer-socials a:hover{ color:var(--mustard); }
.footer-socials span{ margin:0 .8rem; opacity:.6; }

.byline{
  margin-top:1.8rem;
  font-family:var(--font-body);
  font-style:italic;
  color:var(--cream);
  opacity:.7;
  font-size:.95rem;
}

/* ---------- small screens ---------- */

@media(max-width:600px){
  .wavy-card{ padding:1.8rem; box-shadow:7px 7px 0 var(--purple-deep); }
  .cover{ padding:3rem 1rem 2rem; }
  .shroom.s2, .shroom.s5{ display:none; }
}

@media(prefers-reduced-motion:reduce){
  .shroom, .duckman-sticker, .wave-divider path, .blob, .cta-button,
  .opart, .cover::before{ animation:none; }
}
