/*
Theme Name: Anatomy of Experience
Theme URI: https://anatomyofexperience.com
Author: Howard A. Rose
Author URI: https://howardrose.net
Description: Custom theme for the Anatomy of Experience podcast and blog. Dark, cinematic, serif-led identity (crimson to aubergine gradient) with a host-forward homepage, podcast episode pages, and long-form article layouts. Fully self-contained — no parent theme required. Hero, host bio, photo, About link, podcast platform links and newsletter are editable in Appearance > Customize.
Version: 1.0.4
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: anatomy-of-experience
*/

:root{
  --crimson:#7e1f3e; --magenta:#6b2150; --aubergine:#32213f; --ink:#1c1437; --panel:#281b46;
  --cream:#f6ece8; --muted:#bda7c0; --rose:#e57aa0; --gold:#e2b06a; --read:#e9dfe4;
  --line:rgba(246,236,232,.12);
  /* Brand gradient — matched to the YouTube banner: warm crimson glow easing through magenta to deep aubergine. Tune the stops here and it updates every hero band. */
  --hero-grad:
    radial-gradient(105% 150% at 86% -28%, #c8536d 0%, rgba(200,83,109,0) 52%),
    radial-gradient(80% 120% at 2% 115%, #3a2a57 0%, rgba(58,42,87,0) 55%),
    linear-gradient(112deg, #842748 0%, #6c2353 38%, #472a4f 70%, #281f3d 100%);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);background:var(--ink);color:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1080px;margin:0 auto;padding:0 40px}
.measure{max-width:680px;margin:0 auto}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:var(--rose);color:#33101f;padding:10px 16px;border-radius:8px;z-index:100}

/* ---------- Nav ---------- */
.site-nav{position:sticky;top:0;z-index:30;background:rgba(25,16,34,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px;gap:20px}
.brand{font-family:var(--serif);font-weight:700;font-size:19px;letter-spacing:.3px;color:var(--cream)}
.brand:hover{color:var(--cream)}
.main-menu{display:flex;gap:28px;list-style:none;margin:0;padding:0;font-size:14px;color:var(--muted)}
.main-menu a{color:var(--muted)}
.main-menu a:hover{color:var(--cream)}
.main-menu .current-menu-item>a{color:var(--cream)}
.nav-cta{background:var(--rose);color:#33101f;padding:9px 20px;border-radius:40px;font-size:13.5px;font-weight:600;white-space:nowrap}
.nav-toggle{display:none;background:none;border:1px solid var(--line);color:var(--cream);border-radius:8px;padding:6px 10px;font-size:18px;cursor:pointer}

/* ---------- Hero ---------- */
.hero{background:var(--hero-grad)}
.hero-in{padding:70px 0 64px;display:grid;grid-template-columns:1fr 380px;gap:50px;align-items:start}
.eyebrow{display:flex;align-items:center;gap:12px;font-size:12.5px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:22px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--rose);box-shadow:0 0 0 4px rgba(229,122,160,.2)}
.hero h1{font-family:var(--serif);font-weight:700;font-size:56px;line-height:1.03;margin:0}
.tagline{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--cream);opacity:.9;margin-top:14px}
.lede{color:var(--muted);font-size:16.5px;max-width:520px;margin-top:22px;line-height:1.75}
.platforms{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.platforms a{display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:rgba(246,236,232,.05);padding:11px 20px;border-radius:40px;font-size:14px;font-weight:500;color:var(--cream)}
.platforms a:hover{border-color:var(--rose)}

/* host card */
.host{display:flex;flex-direction:column;border:1px solid rgba(226,176,106,.4);border-radius:18px;overflow:hidden;background:var(--panel);box-shadow:0 18px 50px rgba(141,35,71,.35)}
.host .photo{aspect-ratio:4/3;position:relative;background:linear-gradient(160deg,#8d2347,#2c1d3c);background-size:cover;background-position:center 20%;display:flex;align-items:center;justify-content:center}
.host .photo .ph{font-family:var(--serif);font-weight:700;font-size:64px;color:rgba(246,236,232,.5)}
.host .photo .flag{position:absolute;top:14px;left:14px;background:var(--gold);color:#3a2406;font-size:10.5px;letter-spacing:2px;text-transform:uppercase;font-weight:600;padding:6px 12px;border-radius:20px}
.host .hbody{padding:22px 24px 26px}
.host .hkick{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--rose);font-weight:600}
.host h2{font-family:var(--serif);font-weight:600;font-size:24px;line-height:1.15;margin:9px 0 10px}
.host p{font-size:14px;color:var(--muted);line-height:1.7;margin:0}
.host .hcta{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-size:14px;font-weight:600;color:var(--cream);border-bottom:2px solid var(--rose);padding-bottom:3px}

/* ---------- Sections ---------- */
.section{padding:66px 0}
.section.tight{padding:60px 0}
.sec-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:28px;margin:0}
.sec-head .all{font-size:13.5px;color:var(--rose);font-weight:500}

/* episodes list */
.ep{display:grid;grid-template-columns:auto auto 1fr auto;gap:22px;align-items:center;padding:24px 4px;border-top:1px solid var(--line);color:var(--cream)}
.ep:hover{background:rgba(246,236,232,.03)}
.ep .num{font-family:var(--serif);font-size:22px;color:var(--muted);width:34px}
.ep .play{width:50px;height:50px;border-radius:50%;background:rgba(246,236,232,.08);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--rose);font-size:17px;flex-shrink:0}
.ep:hover .play{background:var(--rose);color:#33101f;border-color:var(--rose)}
.ep h3{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.2;margin:0}
.ep .sub{font-size:13.5px;color:var(--muted);margin-top:5px}
.ep .guest{color:var(--gold)}
.ep .dur{font-size:13px;color:var(--muted);white-space:nowrap}

/* writing grid */
.writing-band{background:var(--panel);border-top:1px solid var(--line)}
.wgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:30px}
.wcard{display:block;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:rgba(246,236,232,.02);color:var(--cream)}
.wcard:hover{transform:translateY(-3px);transition:transform .2s}
.wcard .th{display:block;width:100%;aspect-ratio:3/2;background-size:cover;background-position:center;background-color:#2c1d3c}
.wcard .wb{display:block;padding:16px 16px 20px}
.wcard .k{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:600}
.wcard h3{font-family:var(--serif);font-weight:600;font-size:16.5px;line-height:1.25;margin:8px 0 0}

/* newsletter */
.signup{text-align:center;padding:72px 0;background:radial-gradient(120% 130% at 50% 122%,rgba(141,35,71,.42),rgba(141,35,71,0) 62%)}
.signup h2{font-family:var(--serif);font-weight:600;font-size:32px;margin:0}
.signup p{color:var(--muted);max-width:480px;margin:14px auto 28px;font-size:16px}
.field{display:flex;gap:10px;max-width:420px;margin:0 auto}
.field input{flex:1;background:rgba(246,236,232,.06);border:1px solid var(--line);border-radius:40px;padding:13px 20px;color:var(--cream);font-family:var(--sans);font-size:15px}
.field input::placeholder{color:var(--muted)}
.field button{background:var(--rose);color:#33101f;border:none;border-radius:40px;padding:13px 26px;font-weight:600;font-family:var(--sans);font-size:15px;cursor:pointer}

/* ---------- Episode (single) ---------- */
.ehero{background:var(--hero-grad);padding:40px 0 56px}
.crumb{font-size:12.5px;color:var(--muted);letter-spacing:1px;margin-bottom:26px}
.crumb a:hover{color:var(--cream)}
.ehead{display:grid;grid-template-columns:200px 1fr;gap:34px;align-items:start}
.ecover{aspect-ratio:1/1;border-radius:16px;border:1px solid rgba(226,176,106,.4);background:linear-gradient(150deg,#8d2347,#2c1d3c);background-size:cover;background-position:center;overflow:hidden}
.ep-num{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:600}
.ehead h1{font-family:var(--serif);font-weight:700;font-size:36px;line-height:1.1;margin:14px 0 14px}
.edek{color:var(--muted);font-size:17px;max-width:600px;line-height:1.7}
.emeta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-top:20px}
.player{display:flex;align-items:center;gap:18px;background:rgba(246,236,232,.05);border:1px solid var(--line);border-radius:14px;padding:16px 20px;margin-top:26px}
.player audio{width:100%}
.plats2{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.plats2 a{border:1px solid var(--line);background:rgba(246,236,232,.04);padding:9px 16px;border-radius:30px;font-size:13px;font-weight:500;color:var(--cream)}
.plats2 a:hover{border-color:var(--rose)}
.body-grid{display:grid;grid-template-columns:1fr 300px;gap:50px;padding:58px 0}
.section-t{font-family:var(--serif);font-weight:600;font-size:23px;margin:0 0 18px}
.guest{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px;position:sticky;top:90px}
.guest .gtag{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);font-weight:600}
.guest .gpic{width:100%;aspect-ratio:1/1;border-radius:12px;background:linear-gradient(160deg,#8d2347,#2c1d3c);background-size:cover;background-position:center;margin:14px 0 16px;border:1px solid var(--line)}
.guest h3{font-family:var(--serif);font-weight:600;font-size:21px;margin:0}
.guest .grole{font-size:13.5px;color:var(--gold);margin-top:4px}
.guest .gbio{font-size:14px;color:var(--muted);margin-top:14px;line-height:1.7}

/* ---------- Article (single post / page) ---------- */
.ahero{background:var(--hero-grad);padding:46px 0 40px}
.kicker{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:600;text-align:center}
.ahero h1{font-family:var(--serif);font-weight:700;font-size:44px;line-height:1.08;text-align:center;margin:16px 0 18px}
.adek{font-family:var(--serif);font-style:italic;font-size:20px;color:#e8d3dc;text-align:center;line-height:1.5}
.byline{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:28px;font-size:13.5px;color:var(--muted)}
.byline .av{width:38px;height:38px;border-radius:50%;background:#2c1d3c;background-size:cover;background-position:center;border:1px solid var(--line)}
.byline b{color:var(--cream);font-weight:600}
.ahimg{max-width:480px;aspect-ratio:4/3;margin:32px auto 0;border-radius:14px;border:1px solid var(--line);background:#2c1d3c;background-size:cover;background-position:center}
.entry{padding:50px 0 20px}
.entry p,.entry li{font-size:18px;color:var(--read);line-height:1.85}
.entry p{margin:0 0 24px}
.entry h2{font-family:var(--serif);font-weight:600;font-size:27px;margin:42px 0 16px;color:var(--cream)}
.entry h3{font-family:var(--serif);font-weight:600;font-size:21px;margin:32px 0 12px;color:var(--cream)}
.entry a{color:var(--rose);text-decoration:underline;text-underline-offset:3px}
.entry img{border-radius:12px;margin:30px 0}
.entry blockquote{font-family:var(--serif);font-style:italic;font-size:24px;line-height:1.45;color:var(--cream);border-left:3px solid var(--gold);padding:8px 0 8px 24px;margin:34px 0}
.entry ul,.entry ol{padding-left:22px;margin:0 0 24px}
.tags{display:flex;gap:10px;flex-wrap:wrap;margin:34px 0}
.tags a{font-size:12.5px;border:1px solid var(--line);padding:6px 14px;border-radius:24px;color:var(--muted)}
.author-box{display:flex;gap:18px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px;margin:24px auto 0}
.author-box .ap{width:64px;height:64px;border-radius:50%;flex-shrink:0;background:#2c1d3c;background-size:cover;background-position:center;border:1px solid var(--line)}
.author-box h4{font-family:var(--serif);font-weight:600;font-size:19px;margin:0}
.author-box .arole{font-size:13px;color:var(--gold);margin:3px 0 10px}
.author-box p{font-size:14.5px;color:var(--muted);line-height:1.7;margin:0}

/* related */
.related{border-top:1px solid var(--line);padding:54px 0;margin-top:54px}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rcard{display:block;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:rgba(246,236,232,.02);color:var(--cream)}
.rcard:hover{border-color:var(--rose)}
.rcard .th{display:block;width:100%;aspect-ratio:3/2;background-size:cover;background-position:center;background-color:#2c1d3c}
.rcard .rb{display:block;padding:16px 18px 20px}
.rcard .k{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:600}
.rcard h3{font-family:var(--serif);font-weight:600;font-size:17px;line-height:1.25;margin:8px 0 0}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);padding:44px 0 58px;color:var(--muted);font-size:13.5px}
.foot-in{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;align-items:center}
.foot-menu{display:flex;gap:18px;list-style:none;margin:0;padding:0}
.foot-menu a:hover{color:var(--cream)}

/* pagination */
.pagination{display:flex;gap:10px;justify-content:center;padding:30px 0 0;flex-wrap:wrap}
.pagination .page-numbers{border:1px solid var(--line);padding:8px 14px;border-radius:8px;color:var(--cream);font-size:14px}
.pagination .current{background:var(--rose);color:#33101f;border-color:var(--rose)}

/* ---------- Responsive ---------- */
@media(max-width:840px){
  .hero-in,.wgrid,.ehead,.body-grid,.rgrid{grid-template-columns:1fr}
  .guest{position:static}
  .ep{grid-template-columns:auto 1fr auto}
  .ep .num{display:none}
  .hero h1{font-size:42px}
  .ahero h1{font-size:32px}
  .entry p,.entry li{font-size:17px}
  .main-menu,.nav-cta{display:none}
  .main-menu.open{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;background:var(--ink);border-bottom:1px solid var(--line);padding:18px 40px;gap:16px}
  .nav-toggle{display:block}
  .wrap{padding:0 24px}
}
