/*
Theme Name: A dolan thing.
Theme URI: https://redmoon.media
Author: Red Moon Media
Author URI: https://redmoon.media
Description: A people-first community lifestyle theme for Dolan Auto Group. Living mosaic hero, query-driven content (Events, Podcast, Galleries, Programs, Partners). Built by Red Moon Media.
Version: 1.3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
Text Domain: a-dolan-thing
*/

/* ============================================================
   FONTS
   Gotham is licensed (Hoefler & Co) and not on a free CDN.
   Drop the licensed web-font files into /assets/fonts/ and
   uncomment the @font-face below. Until then, the wordmark
   falls back to Montserrat (a close geometric match).
   ------------------------------------------------------------
   @font-face{
     font-family:'Gotham';
     src:url('assets/fonts/Gotham-Bold.woff2') format('woff2');
     font-weight:700;font-display:swap;
   }
   ============================================================ */

  :root{
    --bone:#F5EDDF;
    --bone-2:#EFE4D2;
    --ink:#241D15;
    --ink-soft:#4A4034;
    --ember:#D9591F;
    --ember-deep:#B8430F;
    --gold:#E2A53A;
    --pine:#28392E;
    --pine-deep:#1B2922;
    --clay:#B26A45;
    --line:rgba(36,29,21,.14);
    --cream:#FBF7EF;
    --shadow:0 24px 60px -28px rgba(36,29,21,.45);
    --maxw:1240px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--bone);
    color:var(--ink);
    font-family:'Hanken Grotesk',sans-serif;
    font-size:18px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  body::after{
    content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:600;line-height:1.02;letter-spacing:-.015em}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
  .eyebrow{
    font-family:'Hanken Grotesk';font-weight:700;font-size:13px;letter-spacing:.22em;
    text-transform:uppercase;color:var(--ember);display:inline-flex;align-items:center;gap:10px;
  }
  .eyebrow::before{content:"";width:26px;height:2px;background:var(--ember);display:inline-block}

  /* ---------- nav ---------- */
  header.nav{position:sticky;top:0;z-index:1000;background:rgba(245,237,223,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
  .nav__inner{display:flex;align-items:center;justify-content:space-between;height:74px}
  .brand{display:flex;align-items:center;line-height:1}
  .brand b{font-family:'Gotham','Montserrat',sans-serif;font-weight:800;font-size:22px;letter-spacing:-.005em}
  .nav__links{display:flex;gap:30px;align-items:center}
  .nav__links a{font-weight:600;font-size:15px;position:relative;padding:4px 0}
  .nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--ember);transition:width .3s ease}
  .nav__links a:hover::after{width:100%}
  .btn{background:var(--ember);color:var(--cream);padding:11px 22px;border-radius:100px;font-weight:700;font-size:14px;letter-spacing:.02em;transition:transform .25s ease,background .25s ease;border:none;cursor:pointer}
  .btn:hover{background:var(--ember-deep);transform:translateY(-2px)}
  .nav__toggle{display:none;background:none;border:none;cursor:pointer;font-size:26px;color:var(--ink)}

  /* ---------- hero: living collage ---------- */
  .hero{position:relative;padding:34px 0 60px}
  .hero__grid{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    grid-auto-rows:176px;
    gap:16px;
    grid-template-areas:
      "hl hl a  c  d"
      "hl hl b  e  d"
      "hl hl i  i  g";
  }
  .hl{grid-area:hl;display:flex;flex-direction:column;justify-content:center;padding-right:26px;opacity:0;animation:hlIn .85s cubic-bezier(.2,.7,.2,1) forwards}
  .hl h1{font-family:'Fraunces';font-weight:900;font-size:clamp(40px,5.2vw,82px);line-height:.96;letter-spacing:-.03em;color:var(--ink);margin-top:18px}
  .hl h1 em{font-style:italic;font-weight:500;color:var(--ember)}
  .hl__sub{margin-top:20px;color:var(--ink-soft);font-size:17px;max-width:330px;font-weight:500}
  .hl__hint{margin-top:24px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;color:var(--clay);display:inline-flex;align-items:center;gap:11px}
  .hl__hint::after{content:"↓";font-size:14px}

  .htile{position:relative;display:block;border-radius:14px;overflow:hidden;text-decoration:none;opacity:0;animation:tileIn .55s ease forwards;transform:translate(var(--px,0),var(--py,0));transition:transform .4s ease,box-shadow .45s ease;will-change:transform}
  .htile .ph{position:absolute;inset:0;border-radius:14px;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
  .htile .ph::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,15,10,0) 40%,rgba(20,15,10,.66))}
  .htile:hover{box-shadow:0 26px 54px -22px rgba(20,15,10,.62);z-index:6}
  .htile:not(.kb):hover .ph{transform:scale(1.09)}
  .htile.kb .ph{animation:kb 17s ease-in-out infinite alternate}
  .htile__meta{position:absolute;left:0;bottom:0;z-index:2;padding:13px 15px;color:#fff}
  .htile__cat{display:block;font-family:'Hanken Grotesk';font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
  .htile__title{display:block;font-family:'Fraunces';font-weight:600;font-size:clamp(15px,1.35vw,21px);line-height:1.08;margin-top:4px;color:#fff}
  .htile__go{position:absolute;top:11px;right:11px;z-index:3;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;opacity:0;transform:translateY(-6px);transition:opacity .35s ease,transform .35s ease,background .35s ease}
  .htile:hover .htile__go{opacity:1;transform:none;background:var(--ember)}
  .htile__live{position:absolute;top:11px;left:11px;z-index:3;display:inline-flex;align-items:center;gap:6px;background:var(--ember);color:#fff;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border-radius:100px}
  .htile__live i{width:6px;height:6px;border-radius:50%;background:#fff;animation:pulse 1.5s ease-in-out infinite}
  .htile__chip{display:inline-block;margin-top:8px;background:rgba(255,255,255,.18);backdrop-filter:blur(3px);color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em;padding:4px 9px;border-radius:7px}
  @keyframes kb{from{transform:scale(1)}to{transform:scale(1.14)}}
  @keyframes tileIn{from{opacity:0}to{opacity:1}}
  @keyframes hlIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
  @keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

  /* ---------- placeholder system ---------- */
  .ph{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--clay),var(--ember-deep));display:flex;align-items:flex-end}
  .ph.v2{background:linear-gradient(135deg,#5d7a63,var(--pine))}
  .ph.v3{background:linear-gradient(135deg,var(--gold),var(--clay))}
  .ph.v4{background:linear-gradient(135deg,#3a4a52,#1f2b30)}
  .ph::before{content:"";position:absolute;inset:0;opacity:.16;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
  .ph__label{position:relative;z-index:1;margin:14px;font-family:'Hanken Grotesk';font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.92);background:rgba(20,15,10,.42);backdrop-filter:blur(3px);padding:6px 11px;border-radius:6px;display:inline-flex;align-items:center;gap:7px}
  .ph__label::before{content:"▣";font-size:13px;opacity:.8}
  .ph.vid .ph__label::before{content:"►"}

  /* ---------- section base ---------- */
  section{position:relative}
  .pad{padding:120px 0}
  .sec-head{max-width:720px;margin-bottom:54px}
  .sec-head h2{font-size:clamp(34px,5vw,60px);margin-top:18px}
  .sec-head p{margin-top:18px;color:var(--ink-soft);font-size:19px;max-width:580px}

  /* collage (moved under hero) */
  .collage{padding:66px 0 26px}

  /* events */
  .events__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .ecard{background:var(--cream);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:transform .35s ease,box-shadow .35s ease;cursor:pointer}
  .ecard:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
  .ecard .ph{aspect-ratio:4/3}
  .ecard__body{padding:22px}
  .ecard__date{display:inline-flex;flex-direction:column;align-items:center;background:var(--ink);color:var(--cream);border-radius:11px;padding:8px 13px;line-height:1;position:absolute;top:14px;left:14px;z-index:2}
  .ecard__date b{font-family:'Fraunces';font-size:24px;font-weight:700}
  .ecard__date span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-top:4px;color:var(--gold)}
  .ecard h3{font-size:23px;margin-bottom:8px}
  .ecard .meta{font-size:14px;color:var(--ink-soft);font-weight:600;display:flex;gap:8px;align-items:center}
  .ecard .meta span{color:var(--ember)}
  .events__note{margin-top:34px;font-size:14px;color:var(--ink-soft);display:flex;align-items:center;gap:10px;font-weight:600}
  .events__note b{background:var(--bone-2);border:1px solid var(--line);padding:4px 10px;border-radius:6px;color:var(--ink)}

  /* giving — photo galleries */
  .giving{background:var(--pine);color:var(--bone)}
  .giving .eyebrow{color:var(--gold)}.giving .eyebrow::before{background:var(--gold)}
  .giving .sec-head h2{color:var(--bone)}
  .giving .sec-head p{color:rgba(245,237,223,.7)}
  .galleries{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .gcard{background:var(--cream);border:1px solid rgba(255,255,255,.1);border-radius:18px;overflow:hidden;transition:transform .35s ease,box-shadow .35s ease;cursor:pointer}
  .gcard:hover{transform:translateY(-8px);box-shadow:0 28px 60px -26px rgba(0,0,0,.6)}
  .gcard .ph{aspect-ratio:4/3}
  .gcard__body{padding:20px 22px}
  .gcard h3{font-size:23px;margin-bottom:10px;color:var(--ink)}
  .gcard .link-arrow{color:var(--ember)}
  .gcount{position:absolute;top:14px;left:14px;z-index:2;background:rgba(20,15,10,.55);backdrop-filter:blur(3px);color:var(--cream);font-size:12px;font-weight:700;letter-spacing:.04em;padding:6px 11px;border-radius:8px}

  /* signature programs */
  .programs{background:var(--ink);color:var(--bone)}
  .programs .eyebrow{color:var(--gold)}
  .programs .eyebrow::before{background:var(--gold)}
  .programs .sec-head h2{color:var(--bone)}
  .programs .sec-head p{color:rgba(245,237,223,.66)}
  .prog{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:70px}
  .prog:nth-child(odd) .prog__media{order:2}
  .prog__media .ph{aspect-ratio:5/4;border-radius:20px}
  .prog h3{font-size:clamp(34px,4.4vw,56px);margin:0 0 18px;color:var(--bone)}
  .prog p{color:rgba(245,237,223,.74);font-size:18px;margin-bottom:26px}
  .link-arrow{font-weight:700;color:var(--gold);display:inline-flex;align-items:center;gap:9px;font-size:15px;letter-spacing:.02em}
  .link-arrow span{transition:transform .3s ease}
  .link-arrow:hover span{transform:translateX(6px)}

  /* podcast */
  .podcast{background:var(--pine-deep);color:var(--bone);overflow:hidden;position:relative}
  .podcast__glow{position:absolute;left:-10%;bottom:-20%;width:50vw;height:50vw;background:radial-gradient(circle,rgba(217,89,31,.32),transparent 60%);pointer-events:none}
  .podcast .wrap{position:relative;z-index:2;display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
  .pod__art{aspect-ratio:1;border-radius:22px;box-shadow:0 30px 70px -20px rgba(0,0,0,.7);position:relative}
  .pod__play{position:absolute;inset:0;margin:auto;width:84px;height:84px;background:var(--ember);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:3;box-shadow:0 14px 40px rgba(217,89,31,.55);transition:transform .3s ease;cursor:pointer}
  .pod__play:hover{transform:scale(1.08)}
  .pod__play::after{content:"";border-left:22px solid var(--cream);border-top:13px solid transparent;border-bottom:13px solid transparent;margin-left:5px}
  .podcast .eyebrow{color:var(--gold)}.podcast .eyebrow::before{background:var(--gold)}
  .pod__epi{font-family:'Hanken Grotesk';font-weight:800;letter-spacing:.2em;font-size:13px;color:var(--gold);text-transform:uppercase}
  .podcast h2{font-size:clamp(32px,4.6vw,54px);color:var(--bone);margin:14px 0 16px}
  .podcast .desc{color:rgba(245,237,223,.76);font-size:18px;max-width:520px;margin-bottom:24px}
  .pod__hosts{display:flex;align-items:center;gap:14px;margin-bottom:30px}
  .pod__hosts .av{width:46px;height:46px;border-radius:50%;border:2px solid var(--gold)}
  .pod__hosts .av:nth-child(2){margin-left:-18px}
  .pod__hosts em{font-style:normal;font-size:15px;color:rgba(245,237,223,.85);font-weight:600;margin-left:6px}
  .pod__player{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:14px;padding:16px 18px;display:flex;align-items:center;gap:16px;margin-bottom:22px}
  .pod__bar{flex:1;height:5px;background:rgba(255,255,255,.18);border-radius:4px;position:relative}
  .pod__bar::after{content:"";position:absolute;left:0;top:0;height:100%;width:34%;background:var(--ember);border-radius:4px}
  .pod__platforms{display:flex;gap:12px;flex-wrap:wrap}
  .chip{border:1px solid rgba(255,255,255,.22);border-radius:100px;padding:8px 16px;font-size:13px;font-weight:700;color:rgba(245,237,223,.9);transition:all .25s ease}
  .chip:hover{background:var(--bone);color:var(--ink)}

  /* people mosaic — composed collage, dramatic size variance, gap-free */
  .mosaic{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    grid-auto-rows:120px;
    gap:14px;
    grid-template-areas:
      "t1 t1 t1 t2 t2 t3"
      "t1 t1 t1 t2 t2 t4"
      "t1 t1 t1 t5 t6 t4"
      "t7 t7 t8 t8 t8 t9"
      "t10 t11 t8 t8 t8 t9"
      "t10 t11 t12 t12 t13 t13";
  }
  .mosaic .ph{height:100%;border-radius:14px}
  .mosaic .ph:nth-child(1){grid-area:t1}
  .mosaic .ph:nth-child(2){grid-area:t2}
  .mosaic .ph:nth-child(3){grid-area:t3}
  .mosaic .ph:nth-child(4){grid-area:t4}
  .mosaic .ph:nth-child(5){grid-area:t5}
  .mosaic .ph:nth-child(6){grid-area:t6}
  .mosaic .ph:nth-child(7){grid-area:t7}
  .mosaic .ph:nth-child(8){grid-area:t8}
  .mosaic .ph:nth-child(9){grid-area:t9}
  .mosaic .ph:nth-child(10){grid-area:t10}
  .mosaic .ph:nth-child(11){grid-area:t11}
  .mosaic .ph:nth-child(12){grid-area:t12}
  .mosaic .ph:nth-child(13){grid-area:t13}

  /* partners */
  .partners{background:var(--bone-2);text-align:center}
  .partners h2{font-size:clamp(26px,3vw,40px);margin-bottom:14px}
  .partners p{color:var(--ink-soft);margin-bottom:46px}
.plogos{margin-top:46px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
  .plogos__track{display:flex;gap:22px;width:max-content;animation:logoscroll 55s linear infinite}
  .plogos:hover .plogos__track{animation-play-state:paused}
  @keyframes logoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  .plogo{flex:0 0 auto;width:220px;height:128px;border:1px solid var(--line);border-radius:16px;background:var(--cream);display:flex;align-items:center;justify-content:center;padding:26px;transition:transform .3s ease,box-shadow .3s ease}
  .plogo:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(36,29,21,.4)}
  .plogo img{max-width:100%;max-height:74px;width:auto;height:auto;object-fit:contain;display:block}
  .plogo--ph{border-style:dashed}
  .plogo__name{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-align:center}
  @media(prefers-reduced-motion:reduce){.plogos{-webkit-mask-image:none;mask-image:none}.plogos__track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}}

  /* footer */
  footer{background:var(--ink);color:var(--bone);padding:72px 0 40px}
  .foot__top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.12)}
  .foot__brand b{font-family:'Gotham','Montserrat',sans-serif;font-weight:800;font-size:30px;display:block;letter-spacing:-.01em}
  .foot__brand small{color:rgba(245,237,223,.6);font-size:13px;letter-spacing:.06em}
  .foot__cols{display:flex;gap:64px;flex-wrap:wrap}
  .foot__col h5{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-family:'Hanken Grotesk';font-weight:800}
  .foot__col a{display:block;color:rgba(245,237,223,.78);font-size:15px;margin-bottom:9px;transition:color .2s}
  .foot__col a:hover{color:var(--bone)}
  .foot__bottom{padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:rgba(245,237,223,.5)}

  /* reveal animation */
  .reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}

  /* responsive */
  @media(max-width:900px){
    .nav__links{display:none}
    .nav__toggle{display:block}
    .prog,.podcast .wrap{grid-template-columns:1fr;gap:36px}
    .prog:nth-child(odd) .prog__media{order:0}
    .events__grid,.galleries{grid-template-columns:1fr}
    .hero__grid{
      grid-template-columns:repeat(2,1fr);
      grid-auto-rows:128px;
      grid-template-areas:
        "hl hl"
        "hl hl"
        "i  i"
        "d  c"
        "d  c"
        "a  b"
        "e  g";
    }
    .hl{padding-right:0}
    .pad{padding:80px 0}
    .wrap{padding:0 22px}
  }

  /* ============================================================
     THEME ADDITIONS (WordPress)
     ============================================================ */

  /* real photos drop into any .ph placeholder */
  .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
  .ecard .ph img,.gcard .ph img,.prog__media .ph img,.pod__art img{border-radius:inherit}

  /* WP core helpers */
  .screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
  .alignwide{max-width:1100px;margin-left:auto;margin-right:auto}
  .alignfull{width:100%}
  img.aligncenter{display:block;margin:0 auto}
  .wp-caption-text{font-size:13px;color:var(--ink-soft);margin-top:6px}

  /* "view all" ghost button */
  .btn-ghost{display:inline-flex;align-items:center;gap:9px;border:1.5px solid currentColor;border-radius:100px;padding:11px 22px;font-weight:700;font-size:14px;transition:all .25s ease}
  .btn-ghost:hover{background:var(--ember);border-color:var(--ember);color:var(--cream)}
  .sec-actions{margin-top:40px}

  /* ---------- interior pages ---------- */
  .page-hero{padding:56px 0 36px}
  .page-hero .eyebrow{margin-bottom:16px}
  .page-hero h1{font-size:clamp(36px,5.4vw,72px);color:var(--ink);line-height:1}
  .page-hero h1 em{font-style:italic;color:var(--ember);font-weight:500}
  .meta-row{margin-top:22px;display:flex;flex-wrap:wrap;gap:10px 22px;color:var(--ink-soft);font-weight:600;font-size:15px}
  .meta-row b{color:var(--ember);font-weight:700;margin-right:6px}
  .back-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--ember);margin-bottom:26px;letter-spacing:.02em}
  .back-link:hover{gap:12px}
  .entry{padding:40px 0 110px}
  .entry-cover{aspect-ratio:16/8;border-radius:20px;overflow:hidden;margin-bottom:46px}
  .entry-content{max-width:760px;font-size:19px;color:var(--ink)}
  .entry-content p{margin-bottom:22px}
  .entry-content h2,.entry-content h3{margin:36px 0 14px}
  .entry-content a{color:var(--ember);text-decoration:underline;text-underline-offset:3px}

  /* responsive video embeds */
  .embed{position:relative;aspect-ratio:16/9;border-radius:18px;overflow:hidden;margin:40px 0;background:var(--ink)}
  .embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

  /* single gallery — masonry */
  .gallery-grid{columns:3;column-gap:14px;margin-top:20px}
  .gallery-grid a{display:block;break-inside:avoid;margin:0 0 14px;border-radius:12px;overflow:hidden}
  .gallery-grid img{width:100%;display:block;transition:transform .5s ease}
  .gallery-grid a:hover img{transform:scale(1.05)}
  .gallery-embed{margin:20px 0}
  .gallery-embed iframe{width:100%;min-height:560px;border:0;border-radius:14px}

  /* archive grid */
  .archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;padding:50px 0 100px}

  @media(max-width:900px){
    .gallery-grid{columns:2}
    .archive-grid{grid-template-columns:1fr}
    .entry{padding:30px 0 80px}
  }

  /* ---------- featured announcement band ---------- */
  .announce{padding:60px 0}
  .announce__inner{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--cream);border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
  .announce__media .ph{height:100%;min-height:360px;border-radius:0}
  .announce__body{padding:46px 50px;display:flex;flex-direction:column;justify-content:center}
  .announce__flag{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;background:var(--ember);color:#fff;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:100px}
  .announce__flag i{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.5s ease-in-out infinite}
  .announce__kicker{display:block;margin-top:18px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--clay)}
  .announce h2{font-size:clamp(28px,3.6vw,46px);margin:8px 0 14px;color:var(--ink)}
  .announce p{color:var(--ink-soft);font-size:18px;margin-bottom:26px}
  .announce .btn{align-self:flex-start}
  .announce .more{margin-top:16px;font-size:13px;font-weight:700;color:var(--clay)}
  .announce .more:hover{color:var(--ember)}

  /* ---------- podcast overview page ---------- */
  .podpage{background:var(--pine-deep);color:var(--bone)}
  .podpage .eyebrow{color:var(--gold)} .podpage .eyebrow::before{background:var(--gold)}
  .podpage__intro{color:rgba(245,237,223,.8);max-width:640px;font-size:19px;margin-top:18px}
  .podpage__platforms{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}
  .ep-list{display:grid;gap:16px;margin-top:50px}
  .ep-row{display:grid;grid-template-columns:96px 1fr auto;gap:24px;align-items:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px;transition:background .3s ease}
  .ep-row:hover{background:rgba(255,255,255,.09)}
  .ep-row__art{position:relative;width:96px;height:96px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}
  .ep-row__n{font-family:'Hanken Grotesk';font-weight:800;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
  .ep-row h3{font-family:'Fraunces';font-size:22px;margin:4px 0 6px;line-height:1.1}
  .ep-row p{color:rgba(245,237,223,.7);font-size:15px}
  .ep-row__cta{white-space:nowrap}
  @media(max-width:700px){
    .announce__inner{grid-template-columns:1fr}
    .announce__body{padding:32px 26px}
    .announce__media .ph{min-height:230px}
    .ep-row{grid-template-columns:64px 1fr}
    .ep-row__art{width:64px;height:64px}
    .ep-row__cta{grid-column:1 / -1}
  }

  /* ---------- gallery horizontal scroller ---------- */
  .gscroll-wrap{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 32px}
  .gallery-scroll{display:flex;gap:26px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .gallery-scroll::-webkit-scrollbar{display:none}
  .gallery-scroll .gcard{flex:0 0 340px;scroll-snap-align:start}
  .gscroll-btn{position:absolute;top:42%;z-index:5;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(20,15,10,.55);backdrop-filter:blur(6px);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s ease,opacity .25s ease}
  .gscroll-btn:hover{background:var(--ember)}
  .gscroll-prev{left:6px} .gscroll-next{right:6px}
  @media(max-width:760px){.gscroll-btn{display:none}.gallery-scroll .gcard{flex:0 0 80%}}

  /* event additional details box */
  .detail-box{max-width:760px;margin:28px 0;background:var(--bone-2);border-left:3px solid var(--ember);border-radius:0 12px 12px 0;padding:22px 26px;font-size:17px;color:var(--ink)}
  .detail-box p{margin-bottom:12px}
  .detail-box > :last-child{margin-bottom:0}

  /* podcast overview header with cover */
  .podpage__head{display:flex;gap:36px;align-items:center;flex-wrap:wrap}
  .podpage__cover{width:200px;height:200px;border-radius:20px;object-fit:cover;box-shadow:0 26px 60px -22px rgba(0,0,0,.7);flex:0 0 auto}
  .podpage__headtext{flex:1;min-width:280px}
  @media(max-width:600px){.podpage__cover{width:140px;height:140px}}

  /* ============================================================
     CLASS PROJECT LANDING PAGE
     ============================================================ */
  .cp-hero{padding:56px 0 0}
  .cp-hero .eyebrow{margin-bottom:16px}
  .cp-hero h1{font-size:clamp(40px,6vw,84px);color:var(--ink);line-height:.98;letter-spacing:-.025em}
  .cp-hero .cp-tag{margin-top:20px;font-family:'Fraunces';font-style:italic;font-weight:500;font-size:clamp(18px,2.2vw,25px);color:var(--ink-soft);max-width:640px}
  .cp-hero .cp-cover{margin-top:46px;border-radius:22px;overflow:hidden;aspect-ratio:16/8}
  .cp-hero .cp-cover img{width:100%;height:100%;object-fit:cover;display:block}

  .cp-statement{padding:100px 0}
  .cp-statement.cream{background:var(--bone-2)}
  .cp-statement.dark{background:var(--ink);color:var(--bone)}
  .cp-statement.pine{background:var(--pine);color:var(--bone)}
  .cp-statement.deep{background:var(--pine-deep);color:var(--bone)}
  .cp-statement h2{font-size:clamp(30px,4.6vw,58px);max-width:20ch;line-height:1.04;margin-bottom:22px;color:var(--ink)}
  .cp-statement h2 em{font-style:italic;font-weight:500;color:var(--ember)}
  .cp-statement p{font-size:19px;max-width:62ch;color:var(--ink-soft)}
  .cp-statement.dark h2,.cp-statement.pine h2,.cp-statement.deep h2{color:var(--bone)}
  .cp-statement.dark h2 em,.cp-statement.pine h2 em,.cp-statement.deep h2 em{color:var(--gold)}
  .cp-statement.dark p,.cp-statement.pine p,.cp-statement.deep p{color:rgba(245,237,223,.78)}
  .cp-statement.dark .eyebrow,.cp-statement.pine .eyebrow,.cp-statement.deep .eyebrow{color:var(--gold)}
  .cp-statement.dark .eyebrow::before,.cp-statement.pine .eyebrow::before,.cp-statement.deep .eyebrow::before{background:var(--gold)}

  .cp-bone2{background:var(--bone-2)}
  .cp-pinebg{background:var(--pine);color:var(--bone)}
  .cp-pinebg .eyebrow{color:var(--gold)} .cp-pinebg .eyebrow::before{background:var(--gold)}
  .cp-pinebg .sec-head h2{color:var(--bone)}
  .cp-justgetting{color:rgba(245,237,223,.85);font-family:'Fraunces';font-style:italic;font-size:22px;margin-top:6px}

  .cp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:10px}
  .cp-step{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:32px 28px}
  .cp-step .n{font-family:'Fraunces';font-weight:700;font-size:40px;color:var(--ember);line-height:1;margin-bottom:14px}
  .cp-step h3{font-size:22px;margin-bottom:8px}
  .cp-step p{font-size:16px;color:var(--ink-soft)}

  .cp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px}
  .cp-grid.two{grid-template-columns:1fr 1fr}
  .cp-grid.four{grid-template-columns:repeat(4,1fr)}
  .cp-card{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:28px 26px}
  .cp-card h3{font-size:21px;margin-bottom:8px;color:var(--ink)}
  .cp-card p{font-size:16px;color:var(--ink-soft)}
  .cp-card .k{display:block;margin-bottom:10px;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--clay)}

  .cp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin:10px 0 26px;border-top:1px solid rgba(255,255,255,.16);border-bottom:1px solid rgba(255,255,255,.16);padding:46px 0}
  .cp-stat .num{font-family:'Fraunces';font-size:clamp(38px,4.6vw,66px);font-weight:700;color:var(--gold);line-height:1}
  .cp-stat .lbl{margin-top:10px;font-size:15px;color:rgba(245,237,223,.78);font-weight:600}

  .cp-milestone{background:linear-gradient(135deg,var(--ember),var(--ember-deep));color:#fff;padding:90px 0}
  .cp-milestone .eyebrow{color:#fff} .cp-milestone .eyebrow::before{background:rgba(255,255,255,.8)}
  .cp-milestone h2{color:#fff;font-size:clamp(28px,4vw,50px);margin-bottom:8px;max-width:20ch}
  .cp-milestone .big{font-family:'Fraunces';font-weight:700;font-size:clamp(58px,10vw,128px);line-height:1;margin:6px 0 6px}
  .cp-milestone > .wrap > p{color:rgba(255,255,255,.92);font-size:19px;max-width:60ch}
  .cp-milestone .tiers{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px;max-width:820px}
  .cp-tier{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);border-radius:16px;padding:24px 26px}
  .cp-tier b{font-family:'Fraunces';font-size:30px;display:block;margin-bottom:6px}
  .cp-tier span{font-size:15px;color:rgba(255,255,255,.9)}

  .cp-cta{background:var(--pine-deep);color:var(--bone);text-align:center;padding:90px 0}
  .cp-cta .eyebrow{justify-content:center;color:var(--gold)} .cp-cta .eyebrow::before{background:var(--gold)}
  .cp-cta h2{color:var(--bone);font-size:clamp(28px,4vw,48px);margin:16px 0 26px}

  @media(max-width:900px){
    .cp-steps,.cp-grid,.cp-grid.two,.cp-grid.four{grid-template-columns:1fr}
    .cp-stats{grid-template-columns:repeat(2,1fr);gap:24px}
    .cp-milestone .tiers{grid-template-columns:1fr}
    .cp-statement{padding:70px 0}
  }

  /* 3-up stat bar variant (Reno Rodeo) */
  .cp-stats.cols-3{grid-template-columns:repeat(3,1fr)}
  @media(max-width:760px){ .cp-stats.cols-3{grid-template-columns:1fr} }

  /* ---------- episode page: Listen On buttons ---------- */
  .ep-listen{margin-top:40px;padding-top:32px;border-top:1px solid var(--line)}
  .ep-listen .eyebrow{margin-bottom:16px}
  .ep-listen__row{display:flex;flex-wrap:wrap;gap:12px}
  .ep-chip{display:inline-flex;align-items:center;gap:9px;padding:13px 22px;border-radius:100px;border:1.5px solid var(--ink);color:var(--ink);font-weight:700;font-size:15px;letter-spacing:.01em;transition:all .25s ease;background:transparent}
  .ep-chip span{transition:transform .3s ease}
  .ep-chip:hover{background:var(--ink);color:var(--bone)}
  .ep-chip:hover span{transform:translateX(4px)}
  .ep-chip--spotify:hover{background:#1DB954;border-color:#1DB954;color:#fff}
  .ep-chip--apple-podcasts:hover{background:#9933CC;border-color:#9933CC;color:#fff}
  .ep-chip--youtube:hover{background:#FF0000;border-color:#FF0000;color:#fff}
  @media(max-width:520px){ .ep-chip{flex:1 1 100%;justify-content:center} }
