/*
Theme Name: I AM — in the Age of Machines
Theme URI: https://penker.com/i-am
Author: Magnus Penker
Author URI: https://penker.com
Description: Custom theme for the podcast & Substack "I Am in the Age of Machines" — a warm-library editorial design in deep navy and amber. Built as a sub-site theme for penker.com. Edit links and key text under Appearance → Customize → "I AM — Settings".
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: i-am
*/

:root{
  --ink:#0a0c14;
  --ink-2:#0f1220;
  --cream:#efe6d2;
  --cream-soft:#c9c0ad;
  --cream-dim:#8c8676;
  --ember:#e2a64c;
  --ember-deep:#b87a2c;
  --line:rgba(239,230,210,0.14);
  --line-soft:rgba(239,230,210,0.07);
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--ink);color:var(--cream);
  font-family:'Spectral',Georgia,serif;font-weight:400;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 600px at 72% -8%, rgba(226,166,76,0.16), transparent 60%),
    radial-gradient(700px 500px at 8% 18%, rgba(226,166,76,0.06), transparent 55%),
    radial-gradient(1200px 800px at 50% 120%, rgba(40,46,72,0.5), transparent 60%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}

.eyebrow{font-family:'Spectral',serif;text-transform:uppercase;letter-spacing:0.34em;font-size:0.72rem;color:var(--ember);font-weight:500}
h1,h2,h3{font-family:'Fraunces',serif;font-weight:400;line-height:1.04;letter-spacing:-0.01em}

/* NAV */
.site-nav{position:relative;z-index:5;display:flex;align-items:center;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:26px 28px}
.brandmark{font-family:'Fraunces',serif;font-size:1.05rem;letter-spacing:0.08em;color:var(--cream)}
.brandmark b{color:var(--ember);font-weight:500}
.nav-links{display:flex;gap:30px;font-size:0.82rem;letter-spacing:0.04em;color:var(--cream-soft);list-style:none;margin:0;padding:0}
.nav-links a{transition:color .3s}
.nav-links a:hover{color:var(--ember)}
.nav-toggle{display:none;background:none;border:0;color:var(--cream);font-size:1.4rem;cursor:pointer}
@media(max-width:820px){
  .nav-links{display:none;position:absolute;top:72px;right:28px;left:28px;flex-direction:column;gap:18px;background:var(--ink-2);border:1px solid var(--line);padding:22px;border-radius:4px}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
}

/* HERO */
.hero-wrap{position:relative;padding:60px 0 90px;overflow:hidden}
.hero{max-width:920px}
.iam{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(5rem,18vw,14rem);line-height:0.82;letter-spacing:-0.04em;margin:.12em 0 .04em}
.iam .am{color:var(--ember);font-style:italic;font-weight:400}
.iam span{display:inline-block;opacity:0;animation:rise 1s forwards}
.iam .w2{animation-delay:.16s}
.sub-line{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(1.5rem,3.4vw,2.6rem);color:var(--cream);line-height:1.12;max-width:18ch;margin:.2em 0 .7em;opacity:0;animation:rise 1s .3s forwards}
.sub-line em{color:var(--ember);font-style:italic}
.lede{font-size:1.12rem;color:var(--cream-soft);max-width:54ch;font-weight:300;opacity:0;animation:rise 1s .44s forwards}
.cta-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:36px;opacity:0;animation:rise 1s .58s forwards}
.btn{font-family:'Spectral',serif;font-size:0.92rem;letter-spacing:0.06em;padding:15px 30px;border-radius:2px;transition:all .35s ease;cursor:pointer;display:inline-flex;align-items:center;gap:10px}
.btn-primary{background:var(--ember);color:#1a1305;font-weight:500}
.btn-primary:hover{background:var(--cream);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line);color:var(--cream)}
.btn-ghost:hover{border-color:var(--ember);color:var(--ember)}


/* launch note */
.launch-note{display:inline-block;margin:6px 0 0;font-size:0.82rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--ember);border:1px solid var(--line);padding:9px 18px;border-radius:40px;opacity:0;animation:rise 1s .5s forwards}

/* SECTIONS */
.sec{position:relative;padding:92px 0}
.rule{height:1px;background:var(--line-soft);max-width:var(--maxw);margin:0 auto}
.sec-head{max-width:62ch;margin-bottom:50px}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.2rem);margin:.28em 0 .4em}
.sec-head p{color:var(--cream-soft);font-size:1.08rem;font-weight:300}

/* QUESTION */
.question{text-align:center;padding:116px 0}
.question .mark{font-family:'Fraunces',serif;font-style:italic;color:var(--ember);font-size:2rem;opacity:.6}
.question blockquote{font-family:'Fraunces',serif;font-weight:300;font-style:italic;font-size:clamp(1.8rem,4.6vw,3.4rem);line-height:1.18;max-width:18ch;margin:.4em auto;letter-spacing:-0.015em}
.question cite{display:block;font-style:normal;color:var(--cream-dim);font-size:0.86rem;letter-spacing:0.12em;text-transform:uppercase;margin-top:1.6em}
.ehyeh{margin:34px auto 0;color:var(--cream-soft);font-size:1.02rem;font-weight:300;max-width:48ch}
.ehyeh b{font-family:'Fraunces',serif;font-weight:400;color:var(--ember);font-style:italic}

.format-note{margin-top:14px;color:var(--cream-soft);font-weight:300;font-size:1.0rem}
.format-note strong{color:var(--cream);font-weight:500}

/* GRID */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
@media(max-width:720px){.grid{grid-template-columns:1fr}}
.cell{background:var(--ink);padding:40px 38px;transition:background .4s}
.cell:hover{background:var(--ink-2)}
.cell .n{font-family:'Fraunces',serif;color:var(--ember);font-size:0.9rem;letter-spacing:0.1em}
.cell h3{font-size:1.5rem;margin:.5em 0 .45em}
.cell p{color:var(--cream-soft);font-weight:300;font-size:1.01rem;margin:0}

/* HOST */
.host{display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:start}
@media(max-width:860px){.host{grid-template-columns:1fr;gap:40px}}
.host p{color:var(--cream-soft);font-weight:300;font-size:1.08rem;margin:0 0 1.1em}
.host p strong{color:var(--cream);font-weight:500}
.host-photo{width:100%;border-radius:3px;display:block;margin-bottom:18px;border:1px solid var(--line-soft);filter:saturate(1.02)}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.stat{background:var(--ink);padding:28px 24px}
.stat .num{font-family:'Fraunces',serif;font-size:2.6rem;color:var(--ember);font-weight:300;line-height:1}
.stat .lbl{font-size:0.74rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--cream-dim);margin-top:8px}

/* EPISODES */
.ep{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:baseline;padding:26px 0;border-top:1px solid var(--line-soft);transition:padding-left .35s}
.ep:hover{padding-left:14px}
.ep:last-child{border-bottom:1px solid var(--line-soft)}
.ep .epn{font-family:'Fraunces',serif;color:var(--ember);font-size:0.95rem;min-width:2.4em}
.ep h3{font-size:1.34rem;font-weight:400;margin:0}
.ep .q{color:var(--cream-dim);font-weight:300;font-size:0.98rem;margin-top:.3em;font-style:italic;font-family:'Fraunces',serif}
.ep .guest{color:var(--cream-soft);font-size:0.82rem;letter-spacing:0.04em;text-align:right;min-width:9em}
@media(max-width:720px){.ep{grid-template-columns:auto 1fr}.ep .guest{display:none}}

/* WORLDS */
.worlds{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:760px){.worlds{grid-template-columns:1fr}}
.world{border:1px solid var(--line-soft);padding:34px 30px;border-radius:2px;transition:border-color .4s,transform .4s}
.world:hover{border-color:var(--ember);transform:translateY(-4px)}
.world .eyebrow{font-size:0.66rem}
.world h3{font-size:1.4rem;margin:.7em 0 .5em}
.world p{color:var(--cream-soft);font-weight:300;font-size:0.96rem;margin:0}
.world .names{margin-top:16px;color:var(--cream-dim);font-size:0.84rem;font-style:italic;font-family:'Fraunces',serif}

/* POSTS / ESSAYS */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:820px){.posts{grid-template-columns:1fr}}
.pcard{border:1px solid var(--line-soft);padding:30px 28px;border-radius:2px;transition:border-color .4s,transform .4s;display:block}
.pcard:hover{border-color:var(--ember);transform:translateY(-4px)}
.pcard .date{font-size:0.74rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--cream-dim)}
.pcard h3{font-size:1.3rem;margin:.5em 0 .4em}
.pcard p{color:var(--cream-soft);font-weight:300;font-size:0.95rem;margin:0}

/* SUBSCRIBE */
.subscribe{text-align:center;background:linear-gradient(180deg,transparent,rgba(226,166,76,0.05))}
.subscribe h2{font-size:clamp(2.2rem,5vw,3.6rem);max-width:16ch;margin:0 auto .5em}
.subscribe p{color:var(--cream-soft);font-weight:300;max-width:48ch;margin:0 auto 32px;font-size:1.08rem}
.platforms{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.chip{border:1px solid var(--line);padding:12px 22px;border-radius:40px;font-size:0.84rem;letter-spacing:0.05em;color:var(--cream-soft);transition:all .35s}
.chip:hover{border-color:var(--ember);color:var(--ember)}


/* elsewhere row */
.elsewhere{margin-top:24px;color:var(--cream-dim);font-size:0.9rem;letter-spacing:0.02em}
.elsewhere a{color:var(--cream-soft);border-bottom:1px solid var(--line-soft);padding-bottom:1px;transition:color .3s,border-color .3s}
.elsewhere a:hover{color:var(--ember);border-color:var(--ember)}
.elsewhere .sep{margin:0 10px;color:var(--cream-dim)}

/* GENERIC CONTENT (pages, posts, archives) */
.content-wrap{max-width:760px;margin:0 auto;padding:70px 28px 90px}
.content-wrap h1.entry-title{font-size:clamp(2.2rem,5vw,3.4rem);margin:.2em 0 .4em}
.content-wrap h2{font-size:1.7rem;margin:1.4em 0 .5em;color:var(--cream)}
.content-wrap h3{font-size:1.3rem;margin:1.2em 0 .4em;color:var(--cream)}
.content-wrap p,.content-wrap li{color:var(--cream-soft);font-weight:300;font-size:1.1rem}
.content-wrap a{color:var(--ember);text-decoration:underline;text-underline-offset:3px}
.entry-meta{color:var(--cream-dim);font-size:0.82rem;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:30px}
.entry-content blockquote{border-left:3px solid var(--ember);margin:1.4em 0;padding:.3em 0 .3em 24px;font-style:italic;color:var(--cream)}
.back-link{display:inline-block;margin-top:40px;color:var(--ember);letter-spacing:0.06em}

/* FOOTER */
.site-footer{position:relative;z-index:1;padding:58px 0 50px;border-top:1px solid var(--line-soft);margin-top:40px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;color:var(--cream-dim);font-size:0.82rem}
.foot a:hover{color:var(--ember)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s ease,transform 1s ease}
.reveal.in{opacity:1;transform:none}
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}


/* badge / misc */
.badge{display:inline-block;font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;color:#1a1305;background:var(--ember);padding:4px 12px;border-radius:40px;font-weight:600}
.ep .q{max-width:60ch}
.pagination,.nav-links a.current{color:var(--ember)}
.page-numbers{color:var(--cream-soft);padding:6px 12px;border:1px solid var(--line-soft);border-radius:3px;margin-right:6px}
.page-numbers.current{border-color:var(--ember);color:var(--ember)}

/* WP core alignment helpers */
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.alignright{float:right;margin:0 0 1em 1.5em}
.alignleft{float:left;margin:0 1.5em 1em 0}
.wp-caption-text{color:var(--cream-dim);font-size:.85rem}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
