/* ============================================================
   hayden.science — warm theme (shared)
   Palette + type bridged from the Meal Panda layout into
   Hayden's own colors (coral / teal / plum / berry) + Fraunces.
   ============================================================ */
:root{
  --paper:#FBF3EA;
  --paper-2:#F3E7D6;
  --ink:#2A1E2C;
  --char:#2A1E2C;
  --grey:#7c6f78;
  --coral:#FF6F61;
  --teal:#43B9B2;
  --plum:#6E3A7D;
  --berry:#D94F8A;
  --amber:#F2A65A;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Source Serif 4',Georgia,serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(rgba(110,58,125,0.06) 1.3px, transparent 1.3px);
  background-size:24px 24px;
  animation:meltIn .55s cubic-bezier(.2,.7,.2,1) both;
}

/* smooth cross-page navigation on the web (Chrome) — fades/morphs between pages
   so the font-load reflow no longer "jumps" before settling */
@view-transition{ navigation:auto }
::view-transition-old(root){ animation:vtOut .32s ease both }
::view-transition-new(root){ animation:vtIn .42s cubic-bezier(.2,.7,.2,1) both }
@keyframes meltIn{ from{opacity:0;transform:translateY(14px) scale(.992);filter:blur(5px)} to{opacity:1;transform:none;filter:none} }
@keyframes vtOut{ to{opacity:0;filter:blur(4px)} }
@keyframes vtIn{ from{opacity:0;transform:translateY(12px) scale(.994);filter:blur(5px)} to{opacity:1;transform:none;filter:none} }

.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.display{font-family:'Fraunces',Georgia,serif;font-weight:900;line-height:1.0;letter-spacing:-0.015em}
.mono{font-family:'Courier Prime',monospace}
a{color:inherit}

/* eyebrow chip */
.chip{
  display:inline-block;font-family:'Fraunces',serif;font-weight:700;
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  background:var(--teal);color:#0c2f2d;padding:6px 13px;border:2px solid var(--ink);
  border-radius:40px;transform:rotate(-1deg);box-shadow:3px 3px 0 var(--ink);
}

/* ---------- NAV ---------- */
.nav{position:sticky;top:0;z-index:60;background:rgba(251,243,234,0.90);backdrop-filter:blur(9px);
  border-bottom:2px solid var(--ink);box-shadow:0 4px 0 rgba(42,30,44,.06)}
.nav-in{max-width:1180px;margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:11px 24px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);
  font-family:'Fraunces';font-weight:900;font-size:1.1rem;letter-spacing:-.01em}
.brand svg{width:30px;height:30px;display:block}
.brand .dot{color:var(--coral)}
.nav-links{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.nav-links a{font-family:'Fraunces';font-weight:700;font-size:.92rem;text-decoration:none;color:var(--plum);
  padding:7px 15px;border-radius:30px;border:2px solid transparent;transition:transform .14s,box-shadow .14s,background .14s}
.nav-links a:hover{background:#fff;border-color:var(--ink);box-shadow:2px 2px 0 var(--ink);transform:translate(-1px,-1px)}
.nav-links a.active{background:var(--coral);color:#fff;border-color:var(--ink);box-shadow:2px 2px 0 var(--ink)}

/* ---------- PAGE HEADER (inner pages) ---------- */
.page-head{padding:54px 0 8px}
.page-head .chip{margin-bottom:16px}
.page-head h1{font-family:'Fraunces';font-weight:900;font-size:clamp(2.2rem,5.5vw,3.6rem);line-height:1.0}
.page-head h1 em{font-style:italic;color:var(--coral);font-weight:500}
.page-head p.lede{margin-top:14px;max-width:60ch;font-size:1.12rem;color:#4a4148}

/* ---------- COVER (home) ---------- */
.cover{background:linear-gradient(140deg,#2A1E2C,#3a2440 70%,#4a2a4f);color:var(--paper);position:relative;overflow:hidden;border-bottom:3px solid var(--ink)}
.cover::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(255,111,97,0.25),transparent 40%),radial-gradient(circle at 15% 90%,rgba(67,185,178,0.22),transparent 40%);z-index:1}
.cover .wrap{padding-top:60px;padding-bottom:72px;position:relative;z-index:2}
.cover .chip{background:var(--teal);color:#0c2f2d;border-color:var(--paper)}
.cover-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:36px;align-items:center;margin-top:26px}
.cover h1{font-size:clamp(2.9rem,8vw,5.4rem);color:var(--paper);font-family:'Fraunces';font-weight:900;line-height:1.0;letter-spacing:-.015em}
.cover h1 em{font-style:italic;color:var(--coral);display:block;font-weight:500}
.cover .tag{margin-top:20px;font-size:clamp(1.05rem,2.4vw,1.4rem);max-width:34ch;color:#ece2dd;font-weight:400}
.cover .meta{margin-top:26px;display:flex;gap:10px;flex-wrap:wrap}
.pill{font-size:.82rem;border:1.5px solid #6a5868;color:#e3d7df;padding:5px 13px;border-radius:40px;font-weight:600}
.mascot{position:relative;justify-self:center;width:100%;max-width:300px}
.mascot svg{width:100%;height:auto;filter:drop-shadow(7px 9px 0 rgba(0,0,0,.30))}
/* face-in-the-atom: my photo at the centre with electrons orbiting it */
.me-atom{aspect-ratio:1/1}
.me-atom .orbits{position:absolute;inset:0;width:100%;height:100%;overflow:visible;filter:none;z-index:1}
.me-atom .me-face{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2}
.me-atom .me-face::before{content:"";position:absolute;width:60%;height:60%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,111,97,.5),transparent 70%);filter:blur(7px)}
.me-atom .me-face img{position:relative;width:60%;height:auto;filter:drop-shadow(3px 5px 0 rgba(0,0,0,.32))}
.mascot .name-tape{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%) rotate(-2deg);
  background:var(--coral);color:#fff;font-family:'Fraunces';font-weight:700;padding:6px 18px;border:2px solid var(--ink);
  border-radius:30px;font-size:1rem;letter-spacing:.01em;white-space:nowrap}

/* ---------- SECTIONS (home) ---------- */
section.band{padding:62px 0;border-bottom:2px dashed #d9c8b8}
.sec-label{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.sec-num{font-family:'Fraunces';font-weight:900;font-size:.95rem;background:var(--plum);color:var(--paper);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.sec-title{font-family:'Fraunces';font-weight:700;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey)}
h2.big{font-size:clamp(1.8rem,4vw,2.7rem);max-width:22ch;font-weight:900;font-family:'Fraunces'}

.strat{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:30px}
.card{background:#fff;border:2px solid var(--ink);box-shadow:6px 6px 0 var(--plum);padding:26px;border-radius:18px}
.card:nth-child(2){box-shadow:6px 6px 0 var(--teal)}
.card h3{font-family:'Fraunces';font-weight:700;font-size:1.25rem;margin-bottom:8px}
.card p{color:#4a4148;font-size:1rem}
.card .k{font-family:'Fraunces';font-weight:900;font-size:2.6rem;color:var(--coral);line-height:1}
.card:nth-child(2) .k{color:var(--berry)}
.enemy{margin-top:30px;background:var(--plum);color:#fff;padding:28px 30px;border:2px solid var(--ink);box-shadow:6px 6px 0 var(--coral);border-radius:18px}
.enemy .lead{font-family:'Fraunces';font-weight:700;font-size:1.05rem;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.enemy p{font-size:1.2rem;font-weight:400;max-width:62ch;color:#f3e9ef}
.enemy strong{color:#ffd9a0;font-weight:700}

.browser{background:#fff;border:2px solid var(--ink);box-shadow:8px 8px 0 var(--berry);margin-top:8px;overflow:hidden;border-radius:18px}
.bar{background:var(--paper-2);border-bottom:2px solid var(--ink);padding:11px 14px;display:flex;align-items:center;gap:7px}
/* traffic-light dots — scoped to the browser bar so they don't hit the brand wordmark's period */
.bar .dot{width:11px;height:11px;border-radius:50%;border:1.5px solid var(--ink)}
.url{margin-left:10px;background:#fff;border:1.5px solid var(--ink);border-radius:30px;font-size:.8rem;padding:3px 14px;color:var(--grey);font-weight:600}
.hero{display:grid;grid-template-columns:1.25fr .75fr;gap:18px;padding:42px 38px;align-items:center}
.hero .eb{font-family:'Fraunces';font-weight:700;letter-spacing:.12em;font-size:.82rem;color:var(--plum);text-transform:uppercase}
.hero h3{font-family:'Fraunces';font-weight:900;font-size:clamp(1.8rem,3.6vw,2.8rem);line-height:1.04;margin:12px 0 14px}
.hero h3 mark{background:linear-gradient(transparent 58%, var(--teal) 58%);padding:0 2px;color:inherit}
.hero p.sub{color:#4a4148;font-size:1.05rem;max-width:44ch}
.cta{display:inline-block;margin-top:20px;background:linear-gradient(135deg,var(--coral),var(--berry));color:#fff;font-family:'Fraunces';font-weight:700;font-size:1.1rem;padding:14px 28px;border:2px solid var(--ink);box-shadow:4px 4px 0 var(--ink);border-radius:40px;text-decoration:none;cursor:pointer;transition:transform .12s,box-shadow .12s}
.cta:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.cta.ghost{background:#fff;color:var(--plum);margin-left:10px}
.microcopy{margin-top:10px;font-size:.85rem;color:var(--grey);font-weight:600}
.hero-mascot{justify-self:center;width:100%;max-width:170px}
.hero-mascot svg{width:100%;height:auto}

.voice{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:26px;border:2px solid var(--ink);box-shadow:6px 6px 0 var(--plum);background:#fff;border-radius:18px;overflow:hidden}
.voice .col{padding:26px 28px}
.voice .col:first-child{border-right:2px solid var(--ink)}
.voice h4{font-family:'Fraunces';font-weight:700;font-size:1.1rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.voice .yes h4{color:#1f7a72}
.voice .no h4{color:var(--coral)}
.voice ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.voice li{font-size:1rem;padding-left:18px;position:relative;color:#43393f}
.voice li::before{content:"";position:absolute;left:0;top:10px;width:8px;height:8px;border-radius:50%}
.voice .yes li::before{background:var(--teal)}
.voice .no li::before{background:var(--coral)}
.voice li em{font-style:italic;color:#000;font-weight:600}

.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:26px}
.post{background:#fff;border:2px solid var(--ink);box-shadow:6px 6px 0 var(--ink);display:flex;flex-direction:column;overflow:hidden;border-radius:18px}
.post:nth-child(2){box-shadow:6px 6px 0 var(--teal)}
.post:nth-child(3){box-shadow:6px 6px 0 var(--berry)}
.post .ph{aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;position:relative;border-bottom:2px solid var(--ink);padding:18px;text-align:center}
.post .badge{position:absolute;top:10px;left:10px;font-family:'Fraunces';font-weight:700;font-size:.68rem;letter-spacing:.08em;background:var(--ink);color:var(--paper);padding:3px 9px;text-transform:uppercase;border-radius:20px}
.post .vis{font-family:'Fraunces';font-weight:700;font-size:1.1rem;color:var(--ink);line-height:1.15}
.post .vis span{display:block;font-family:'Source Serif 4';font-weight:400;font-size:.8rem;color:var(--grey);margin-top:8px}
.post .cap{padding:16px 18px;font-size:.92rem;color:#43393f}
.post .cap b{color:var(--ink);font-weight:700}
.post .ovl{position:absolute;bottom:10px;right:10px;background:var(--coral);color:#fff;font-family:'Fraunces';font-weight:700;font-size:.68rem;padding:4px 10px;border:1.5px solid var(--ink);border-radius:20px;transform:rotate(-3deg)}
.ph-a{background:linear-gradient(135deg,#6E3A7D,#D94F8A)}
.ph-a .vis{color:#fff}
.ph-b{background:linear-gradient(135deg,#43b9b2,#7de0c2)}
.ph-c{background:linear-gradient(135deg,#ff8d6a,#ffb347)}

.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:30px;margin-top:26px;align-items:start}
.receipt{background:#fff;border:1px solid #e0d2c4;box-shadow:4px 6px 16px rgba(42,30,44,.16);padding:26px 22px;font-family:'Courier Prime',monospace;font-size:.88rem;color:#33282f;position:relative;max-width:340px;margin:0 auto}
.receipt::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:8px;background:linear-gradient(135deg,transparent 33%,#fff 33%,#fff 66%,transparent 66%) repeat-x;background-size:14px 14px}
.receipt .rh{text-align:center;font-weight:700;letter-spacing:.06em}
.receipt .rsub{text-align:center;font-size:.74rem;color:var(--plum);margin-bottom:12px;font-weight:700}
.receipt .row{display:flex;justify-content:space-between;padding:2px 0;gap:10px}
.receipt .rule{border-top:1px dashed #b9a99c;margin:9px 0}
.receipt .tot{font-weight:700}
.receipt .tot .big{color:var(--coral)}
.receipt .foot{text-align:center;margin-top:14px;font-size:.76rem;color:#8a7c84}
.receipt .paw{font-size:1.1rem;margin-top:4px;color:var(--plum)}
.emails h3{font-family:'Fraunces';font-weight:700;font-size:1.2rem;margin-bottom:6px}
.emails .note{color:var(--grey);font-size:.9rem;margin-bottom:16px}
.mail{background:#fff;border:2px solid var(--ink);padding:14px 16px;margin-bottom:11px;display:flex;align-items:center;gap:13px;box-shadow:3px 3px 0 var(--plum);border-radius:14px}
.mail:nth-child(even){box-shadow:3px 3px 0 var(--teal)}
.mail .av{width:36px;height:36px;flex:0 0 36px;border-radius:50%;background:linear-gradient(135deg,var(--plum),var(--berry));color:#fff;font-family:'Fraunces';font-weight:900;display:flex;align-items:center;justify-content:center;font-size:.95rem}
.mail .body{flex:1;min-width:0}
.mail .from{font-size:.76rem;color:var(--grey);font-weight:600}
.mail .subj{font-weight:700;font-size:1rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---------- SHARED FOOTER ---------- */
.site-foot{background:linear-gradient(140deg,#2A1E2C,#3a2440);color:var(--paper);padding:54px 0;position:relative;overflow:hidden;border-top:3px solid var(--ink)}
.site-foot::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 110%,rgba(255,111,97,0.22),transparent 45%);z-index:1}
.site-foot .wrap{position:relative;z-index:2}
.site-foot .chip{border-color:var(--paper)}
.site-foot h2{font-family:'Fraunces';font-weight:900;font-size:clamp(1.5rem,3.4vw,2.2rem);color:var(--paper);margin:16px 0 20px;max-width:24ch}
.nxt{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.nxt .blk h4{font-family:'Fraunces';font-weight:700;color:var(--teal);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px}
.nxt ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.nxt li{font-size:1rem;color:#e4d9e0;padding-left:20px;position:relative}
.nxt li::before{content:"\2192";position:absolute;left:0;color:var(--coral);font-weight:800}
.signoff{margin-top:28px;font-size:.9rem;color:#a596a0;font-style:italic}
.foot-links{margin-top:22px;display:flex;gap:10px;flex-wrap:wrap}
.foot-links a{font-family:'Fraunces';font-weight:700;font-size:.9rem;text-decoration:none;color:#fff;border:2px solid #6a5868;border-radius:30px;padding:8px 16px;transition:.15s}
.foot-links a:hover{border-color:var(--coral);background:rgba(255,111,97,.15)}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-hero{position:relative;overflow:hidden;color:var(--paper);
  background:linear-gradient(115deg,#241a2b 0%,#5b2c63 32%,#b8417e 64%,#F2A65A 120%);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 72px),0 100%)}
.about-hero::before{content:"";position:absolute;inset:0;z-index:1;
  background:repeating-linear-gradient(115deg,rgba(255,255,255,.08) 0 8px,transparent 8px 88px),
             radial-gradient(circle at 14% 22%,rgba(67,185,178,.40),transparent 40%),
             radial-gradient(circle at 92% 10%,rgba(255,207,107,.34),transparent 40%)}
.about-hero .wrap{position:relative;z-index:2;padding:60px 24px 112px}
/* big floating decorative blobs/atoms for flash */
.about-hero .orb{position:absolute;border-radius:50%;z-index:1;filter:blur(1px);opacity:.55}
.about-hero .orb.o1{width:120px;height:120px;background:radial-gradient(circle at 35% 30%,#7DE0C2,#43B9B2);left:-26px;bottom:90px}
.about-hero .orb.o2{width:74px;height:74px;background:radial-gradient(circle at 35% 30%,#ffd9a0,#FF6F61);right:42%;top:24px}
.about-grid{display:grid;grid-template-columns:1.02fr 1.1fr;gap:34px;align-items:center;margin-top:18px}
.about-copy .chip{background:var(--coral);color:#fff;border-color:var(--paper)}
.about-copy h1{font-family:'Fraunces';font-weight:900;font-size:clamp(2.6rem,6.4vw,4.6rem);line-height:.98;color:var(--paper);margin-top:18px}
.about-copy h1 em{font-style:italic;color:var(--teal);display:block;font-weight:500;font-size:.62em}
.about-copy .who{margin-top:18px;font-size:clamp(1.05rem,2.2vw,1.32rem);color:#ece2dd;max-width:32ch;font-weight:400}
.about-copy .facts{margin-top:22px;display:flex;gap:9px;flex-wrap:wrap}
.about-copy .facts span{font-family:'Fraunces';font-weight:600;font-size:.8rem;border:1.5px solid #7a6676;color:#efe6ec;border-radius:30px;padding:6px 13px}

/* photo collage — each polaroid gets a strip of "washi tape" at the top via ::before */
.collage{position:relative;height:440px}
.frame{position:absolute;background:#fff;padding:10px 10px 38px;border:2px solid var(--ink);
  box-shadow:0 16px 34px rgba(0,0,0,.34);border-radius:4px}
.frame::before{content:"";position:absolute;top:-13px;left:50%;width:96px;height:27px;
  transform:translateX(-50%) rotate(-5deg);background:rgba(255,248,236,.5);
  border:1px solid rgba(255,255,255,.55);box-shadow:0 2px 6px rgba(0,0,0,.16);z-index:9}
.frame .photo{width:100%;height:100%;display:block;border-radius:3px;overflow:hidden;background:#eadfce}
.frame .photo svg{width:100%;height:100%;display:block}
.frame .photo img{width:100%;height:100%;object-fit:cover;object-position:50% 16%;display:block}
.frame .cap{position:absolute;left:0;right:0;bottom:11px;text-align:center;font-family:'Fraunces';font-weight:700;
  font-size:.82rem;color:var(--plum)}
.frame.f1{width:224px;height:272px;left:1%;top:30px;transform:rotate(-6deg);z-index:3}
.frame.f1::before{background:rgba(67,185,178,.45);transform:translateX(-50%) rotate(-7deg)}
.frame.f2{width:206px;height:244px;right:3%;top:10px;transform:rotate(5deg);z-index:2}
.frame.f2::before{background:rgba(255,111,97,.42);transform:translateX(-50%) rotate(7deg)}
.frame.f3{width:206px;height:236px;left:22%;bottom:4px;transform:rotate(3deg);z-index:4}
.frame.f3::before{background:rgba(242,166,90,.5);transform:translateX(-50%) rotate(4deg)}
.frame.f4{width:190px;height:222px;right:1%;bottom:18px;transform:rotate(-4deg);z-index:1}
.frame.f4::before{background:rgba(217,79,138,.42);transform:translateX(-50%) rotate(-6deg)}
.sparkle{position:absolute;z-index:7;font-size:1.5rem;color:#fff;filter:drop-shadow(0 2px 3px rgba(0,0,0,.3))}

/* markdown bio */
.bio-wrap{padding:56px 0}
.bio{max-width:74ch;margin:0 auto;font-size:1.12rem;line-height:1.78;color:#3a3138}
.bio .md-note{font-family:'Courier Prime',monospace;font-size:.78rem;color:var(--grey);background:#fff;border:1.5px dashed #d3c2b3;
  border-radius:10px;padding:8px 12px;margin-bottom:26px;display:inline-block}
.bio h2{font-family:'Fraunces';font-weight:900;font-size:1.75rem;margin:34px 0 10px;color:var(--ink);
  display:flex;align-items:center;gap:10px}
.bio h2::before{content:"";width:16px;height:16px;border-radius:50%;background:var(--coral);flex:0 0 16px}
.bio h2.t::before{background:var(--teal)}
.bio h2.p::before{background:var(--plum)}
.bio h2.b::before{background:var(--berry)}
.bio p{margin:14px 0}
.bio strong{color:var(--plum);font-weight:700}
.bio a{color:var(--berry);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:2px}
.bio blockquote{margin:24px 0;padding:16px 22px;background:#fff;border-left:6px solid var(--teal);
  border-radius:0 14px 14px 0;font-style:italic;color:var(--plum);box-shadow:4px 4px 0 rgba(110,58,125,.12)}
.bio ul{margin:14px 0 14px 4px;list-style:none;display:flex;flex-direction:column;gap:8px}
.bio ul li{padding-left:24px;position:relative}
.bio ul li::before{content:"\2192";position:absolute;left:0;color:var(--coral);font-weight:800}
.bio h1{font-family:'Fraunces';font-weight:900;font-size:2rem;margin:6px 0 10px;color:var(--ink)}
.bio pre{background:#171022;color:#e7ddf0;border:2px solid var(--ink);border-radius:12px;padding:16px 18px;overflow:auto;
  font-family:'Courier Prime',monospace;font-size:.86rem;margin:18px 0;box-shadow:5px 5px 0 rgba(110,58,125,.18)}
.bio pre code{background:none;border:none;color:inherit;padding:0}
.bio code{background:#f1e6d6;border:1px solid #e0cdb6;border-radius:6px;padding:1px 6px;font-family:'Courier Prime',monospace;font-size:.9em;color:var(--plum)}
.bio img{max-width:100%;border:2px solid var(--ink);border-radius:10px;margin:16px 0}
.backlink{display:inline-block;font-family:'Fraunces';font-weight:700;color:var(--plum);text-decoration:none;margin-bottom:8px;font-size:.92rem}
.backlink:hover{color:var(--coral)}

/* ============================================================
   STATS PAGE
   ============================================================ */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:30px}
.chart-card{background:#fff;border:2px solid var(--ink);border-radius:18px;padding:22px 22px 16px;box-shadow:6px 6px 0 var(--plum)}
.chart-card:nth-child(2){box-shadow:6px 6px 0 var(--teal)}
.chart-card:nth-child(3){box-shadow:6px 6px 0 var(--berry)}
.chart-card:nth-child(4){box-shadow:6px 6px 0 var(--amber)}
.chart-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:6px}
.chart-head h3{font-family:'Fraunces';font-weight:800;font-size:1.25rem}
.chart-head .now{font-family:'Fraunces';font-weight:900;font-size:1.5rem}
.chart-sub{font-size:.86rem;color:var(--grey);margin-bottom:10px}
.chart-holder svg{width:100%;height:auto;display:block}
.chart-foot{display:flex;justify-content:space-between;font-family:'Courier Prime',monospace;font-size:.74rem;color:var(--grey);margin-top:4px}
.placeholder-tag{font-family:'Courier Prime',monospace;font-size:.7rem;color:#fff;background:var(--plum);
  border-radius:20px;padding:2px 9px;letter-spacing:.04em}

.case-wrap{margin-top:30px;margin-bottom:80px;background:#fff;border:2px solid var(--ink);border-radius:18px;box-shadow:8px 8px 0 var(--plum);overflow:hidden}
.case-head{padding:20px 24px;border-bottom:2px dashed #d9c8b8;display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.case-head h3{font-family:'Fraunces';font-weight:900;font-size:1.4rem}
.case-head p{color:var(--grey);font-size:.9rem}
.case-holder{padding:18px 20px 24px}
.case-holder svg{width:100%;height:auto;display:block}

/* last read / last watched */
.lastmedia .media-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;padding:26px 24px 30px}
.media-card{display:flex;flex-direction:column;align-items:center;text-align:center}
.media-kicker{font-family:'Fraunces';font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--plum);margin-bottom:14px}
.media-card .cover{position:relative;border:2px solid var(--ink);overflow:hidden;box-shadow:9px 11px 0 rgba(42,30,44,.18);background:#eadfce}
.book-cover{width:204px;height:300px;border-radius:5px 9px 9px 5px;transform:rotate(-2deg)}
.screen-cover{width:212px;height:300px;border-radius:8px;transform:rotate(2deg)}
.book-cover .cover-spine{position:absolute;left:0;top:0;bottom:0;width:14px;z-index:3;
  background:linear-gradient(90deg,rgba(0,0,0,.34),rgba(0,0,0,.06));border-right:1px solid rgba(0,0,0,.2)}
.cover-sticker{position:absolute;top:10px;right:-6px;z-index:4;font-family:'Fraunces';font-weight:800;font-size:.66rem;
  letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--coral);border:2px solid var(--ink);
  border-radius:20px;padding:3px 10px;transform:rotate(6deg);box-shadow:2px 2px 0 var(--ink)}
.cover-sticker.alt{background:var(--teal);color:#0c2f2d}
.cover-img{width:100%;height:100%}
.cover-img img{width:100%;height:100%;object-fit:cover;display:block}
.cover-fallback{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px;
  background:linear-gradient(150deg,var(--plum),var(--berry));color:#fff}
.screen-card .cover-fallback{background:linear-gradient(150deg,#243a8a,#43B9B2)}
.cf-title{font-family:'Fraunces';font-weight:900;font-size:1.5rem;line-height:1.04}
.cf-by{font-size:.85rem;opacity:.88;font-style:italic}
.media-meta{margin-top:18px}
.media-title{font-family:'Fraunces';font-weight:800;font-size:1.18rem}
.media-by{color:var(--grey);font-size:.92rem}
/* main + "before that" cluster */
.cover-cluster{display:flex;align-items:flex-end;justify-content:center;gap:20px}
.cover-col{display:flex;flex-direction:column;align-items:center}
.cover-col.prev{opacity:.95}
.cover-col.prev .media-title{font-size:.98rem}
.cover-col.prev .media-by{font-size:.8rem}
.cover-col .before{display:block;font-family:'Fraunces';font-weight:700;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--grey);margin-bottom:3px}
.book-cover.sm{width:128px;height:190px;transform:rotate(2.5deg)}
.screen-cover.sm{width:132px;height:188px;transform:rotate(-2.5deg)}
.cover.sm .cf-title{font-size:1rem}
.cover.sm .cf-by{font-size:.7rem}
.cover.sm .cover-spine{width:10px}

/* ============================================================
   PROJECTS PAGE
   ============================================================ */
.legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:22px}
.legend span{display:inline-flex;align-items:center;gap:8px;font-family:'Fraunces';font-weight:700;font-size:.84rem;
  background:#fff;border:2px solid var(--ink);border-radius:30px;padding:7px 14px;box-shadow:2px 2px 0 var(--ink)}
.legend i{width:14px;height:14px;border-radius:4px;display:inline-block}

.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:30px;margin-bottom:80px}
.module{border:2px solid var(--ink);border-radius:18px;overflow:hidden;background:#fff;display:flex;flex-direction:column;
  text-decoration:none;color:inherit;cursor:pointer;transition:transform .16s ease, box-shadow .16s ease}
.module:hover{transform:translateY(-5px)}
.module:focus-visible{outline:3px solid var(--berry);outline-offset:3px}
.module .m-open{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-family:'Fraunces';font-weight:700;font-size:.82rem;color:var(--berry)}
.module .m-foot{padding:16px 18px;border-top:2px solid var(--ink);background:#fff}
.module .m-foot h3{font-family:'Fraunces';font-weight:800;font-size:1.18rem;margin-bottom:4px}
.module .m-foot p{font-size:.92rem;color:#4a4148}
.m-tags{margin-top:10px;display:flex;gap:7px;flex-wrap:wrap}
.m-tags span{font-family:'Courier Prime',monospace;font-size:.7rem;border:1.5px solid var(--ink);border-radius:20px;padding:2px 9px;color:var(--plum)}

/* CODE module — terminal/computer container */
.module.code{box-shadow:7px 7px 0 var(--teal)}
.term{background:#171022;color:#e7ddf0;font-family:'Courier Prime',monospace;font-size:.84rem;min-height:230px}
.term-bar{background:#241733;border-bottom:2px solid var(--ink);display:flex;align-items:center;gap:7px;padding:9px 13px}
.term-bar .tdot{width:11px;height:11px;border-radius:50%}
.term-bar .ttitle{margin-left:8px;color:#b9a7cc;font-size:.76rem}
.term-body{padding:16px 18px;line-height:1.7}
.term-body .ln{white-space:pre-wrap;word-break:break-word}
.term-body .pr{color:#43B9B2}
.term-body .cm{color:#7e6f8f}
.term-body .ok{color:#9be36b}
.term-body .str{color:#ffb37a}
.term-body .cur{display:inline-block;width:9px;height:1.05em;background:#43B9B2;vertical-align:-2px;animation:blink 1.05s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* STORY module — book */
.module.story{box-shadow:7px 7px 0 var(--berry)}
.book-stage{background:linear-gradient(160deg,#f6ecdc,#e9d7c1);min-height:230px;display:flex;align-items:center;justify-content:center;padding:26px}
.book{position:relative;width:200px;height:182px;perspective:none;animation:bookBob 5s cubic-bezier(.5,-0.3,.5,1.3) infinite}
.book .cover-face{position:absolute;inset:0;background:linear-gradient(135deg,var(--plum),#4f2a5b);border:2px solid var(--ink);
  border-radius:6px 12px 12px 6px;box-shadow:10px 12px 22px rgba(0,0,0,.28);padding:20px 18px 18px 26px;color:#fff;overflow:hidden}
.book .spine{position:absolute;left:0;top:0;bottom:0;width:16px;background:linear-gradient(#3a1f43,#2a1630);border-right:2px solid var(--ink);border-radius:6px 0 0 6px}
.book .pages{position:absolute;right:-6px;top:8px;bottom:8px;width:8px;background:repeating-linear-gradient(#fff,#fff 2px,#e7dccb 2px,#e7dccb 4px);border:1.5px solid var(--ink);border-left:none;border-radius:0 4px 4px 0}
.book .ribbon{position:absolute;right:34px;top:-3px;width:18px;height:66px;background:var(--coral);border:2px solid var(--ink);border-top:none;z-index:5;transform-origin:top center;animation:ribbonSway 3.8s cubic-bezier(.5,-0.3,.5,1.3) infinite}
/* fishtail notch cut into the bottom of the bookmark (matches the cover so it reads as a V) */
.book .ribbon::after{content:"";position:absolute;left:50%;bottom:-1px;transform:translateX(-50%);width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:11px solid #4f2a5b}
.book .ktag{font-family:'Fraunces';font-weight:700;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal)}
.book .btitle{font-family:'Fraunces';font-weight:900;font-size:1.25rem;line-height:1.05;margin-top:10px}
.book .byline{margin-top:auto;font-size:.74rem;color:#e3cfe8;font-style:italic;position:absolute;left:26px;bottom:16px}

/* LIFE module — grassy */
.module.life{box-shadow:7px 7px 0 var(--amber)}
.life-stage{position:relative;min-height:230px;background:linear-gradient(#bfe8ff,#e6f7ef 60%);overflow:hidden}
.life-stage svg{position:absolute;inset:0;width:100%;height:100%}
.life-sign{position:absolute;left:50%;top:42px;transform:translateX(-50%);z-index:3;background:#fff;border:2px solid var(--ink);
  border-radius:12px;box-shadow:4px 5px 0 rgba(42,30,44,.25);padding:10px 16px;text-align:center;max-width:78%;
  animation:signFloat 5s cubic-bezier(.5,-0.3,.5,1.3) infinite}
.life-sign .lk{font-family:'Fraunces';font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal)}
.life-sign .lt{font-family:'Fraunces';font-weight:900;font-size:1.12rem;line-height:1.05;margin-top:3px;color:var(--ink)}

/* gentle, continuous motion so book + life feel as alive as the terminal cursor */
.life-stage svg .g-sun{transform-box:fill-box;transform-origin:50% 50%;animation:sunPulse 4.2s ease-in-out infinite}
.life-stage svg .g-blades{transform-box:fill-box;transform-origin:50% 100%;animation:sway 3.4s cubic-bezier(.45,-0.4,.55,1.4) infinite}
.life-stage svg .g-flowers{transform-box:fill-box;transform-origin:50% 100%;animation:swayF 4.6s cubic-bezier(.45,-0.4,.55,1.4) infinite}
/* ~35% larger amplitude + overshoot easing for a bouncier, livelier feel */
@keyframes bookBob{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(-1.4deg)}}
@keyframes ribbonSway{0%,100%{transform:rotate(0)}50%{transform:rotate(3.4deg)}}
@keyframes sway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
@keyframes swayF{0%,100%{transform:rotate(3.4deg)}50%{transform:rotate(-3.4deg)}}
@keyframes sunPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.095)}}
@keyframes signFloat{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-6.75px)}}

/* ---------- responsive ---------- */
@media(max-width:880px){
  .cover-grid,.strat,.hero,.voice,.posts,.split,.nxt,.about-grid,.stats-grid,.proj-grid{grid-template-columns:1fr}
  .hero-mascot{max-width:120px;order:-1}
  .voice .col:first-child{border-right:none;border-bottom:2px solid var(--ink)}
  .mascot{max-width:230px;margin-bottom:10px}
  .collage{height:520px;max-width:460px;margin:0 auto}
}
@media(prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto;animation:none!important}
  .reveal-ready .reveal{opacity:1!important;transform:none!important}
}

/* ============================================================
   DECORATIONS & MOTION  (shared, all pages)
   Everything here is opt-in via a class or a JS-injected layer,
   and fully neutralized by the prefers-reduced-motion block above.
   ============================================================ */

/* ---- scroll reveal ----
   Gated by .reveal-ready (added to <body> by shared.js). With JS off,
   nothing is hidden; with reduced motion, reveals are forced visible. */
.reveal-ready .reveal{opacity:0;transform:translateY(26px);
  transition:opacity .72s cubic-bezier(.2,.7,.2,1),transform .72s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}
.reveal-ready .reveal.in{opacity:1;transform:none}
.reveal-ready .reveal.pop{transform:translateY(20px) scale(.95)}
.reveal-ready .reveal.pop.in{transform:none}
.reveal-ready .reveal.r-d1{transition-delay:.07s}
.reveal-ready .reveal.r-d2{transition-delay:.14s}
.reveal-ready .reveal.r-d3{transition-delay:.21s}
.reveal-ready .reveal.r-d4{transition-delay:.28s}
.reveal-ready .reveal.r-d5{transition-delay:.35s}

/* ---- floating decorative layer (injected by shared.js) ---- */
.decor{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}
.decor>*{position:absolute;will-change:transform;opacity:.9}
.decor svg{display:block;width:100%;height:100%;overflow:visible}
.decor .blob{border-radius:50%;filter:blur(26px);opacity:.5}
.d-spin{animation:dSpin 32s linear infinite}
.d-spin.rev{animation-direction:reverse}
.d-float{animation:dFloat 7s ease-in-out infinite}
.d-float.s{animation-duration:9.5s}
.d-float.f{animation-duration:5.5s}
.d-bob{animation:dBob 6s ease-in-out infinite}
.d-tw{animation:dTwinkle 3.6s ease-in-out infinite}
.d-drift{animation:dDrift 16s ease-in-out infinite}
@keyframes dSpin{to{transform:rotate(360deg)}}
@keyframes dFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes dBob{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-13px) rotate(4deg)}}
@keyframes dTwinkle{0%,100%{opacity:.2;transform:scale(.75)}50%{opacity:1;transform:scale(1.18)}}
@keyframes dDrift{0%,100%{transform:translate(0,0)}33%{transform:translate(16px,-12px)}66%{transform:translate(-12px,10px)}}

/* keep page content above the decor layer */
.cover .wrap,.site-foot .wrap,.about-hero .wrap,.page-head{position:relative;z-index:2}

/* ---- edge wave (dark panel → paper) ---- */
.edge-wave{position:absolute;left:0;right:0;bottom:-1px;width:100%;height:52px;z-index:4;pointer-events:none}
.edge-wave path{fill:var(--paper)}
.cover .edge-wave path{fill:var(--plum)}   /* flows the dark cover into the plum ticker below */
.cover{padding-bottom:0}

/* ---- interest marquee ---- */
.marquee{position:relative;overflow:hidden;background:var(--plum);color:var(--paper);
  border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:64px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--plum),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--plum),transparent)}
.marquee .track{display:flex;width:max-content;align-items:center;animation:marq 34s linear infinite;padding:12px 0}
.marquee:hover .track{animation-play-state:paused}
.marquee .track b{font-family:'Fraunces';font-weight:800;font-size:1.05rem;letter-spacing:.01em;
  white-space:nowrap;padding:0 4px}
.marquee .track i{color:var(--amber);font-style:normal;padding:0 22px;font-size:1.1rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---- universal hover-lift on cards ---- */
a.post{text-decoration:none;color:inherit;cursor:pointer}
a.post:focus-visible{outline:3px solid var(--berry);outline-offset:3px}
.card,.post,.chart-card,.mail,.receipt,.media-card,.legend span{transition:transform .2s ease,box-shadow .2s ease}
.card:hover,.post:hover,.chart-card:hover{transform:translate(-3px,-4px)}
.mail:hover{transform:translateX(4px)}
.receipt:hover{transform:rotate(-1deg) translateY(-3px)}
.legend span:hover{transform:translateY(-2px)}
.enemy{transition:transform .2s ease}
.enemy:hover{transform:translateY(-3px)}

/* ---- button sheen ---- */
.cta{position:relative;overflow:hidden}
.cta::after{content:"";position:absolute;top:0;left:-160%;width:55%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.5),transparent);
  transform:skewX(-18deg);animation:sheen 5s ease-in-out infinite}
.cta.ghost::after{background:linear-gradient(110deg,transparent,rgba(110,58,125,.18),transparent)}
@keyframes sheen{0%,55%{left:-160%}78%,100%{left:170%}}

/* ---- shimmering accent headings ---- */
.cover h1 em,.about-copy h1 em,.page-head h1 em{
  background:linear-gradient(95deg,var(--coral),var(--amber) 35%,var(--berry) 70%,var(--coral));
  background-size:280% 100%;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;animation:shimmer 9s linear infinite}
.about-copy h1 em{background-image:linear-gradient(95deg,var(--teal),#7DE0C2 40%,var(--amber) 80%,var(--teal))}
@keyframes shimmer{to{background-position:280% 0}}

/* ---- nav flourishes ---- */
.brand svg{transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.brand:hover svg{transform:rotate(180deg) scale(1.08)}
.nav-links a{position:relative}
.nav-links a:not(.active)::after{content:"";position:absolute;left:14px;right:14px;bottom:3px;height:2px;
  background:var(--coral);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .2s ease}
.nav-links a:not(.active):hover::after{transform:scaleX(1)}

/* ---- chip wobble ---- */
.chip{transition:transform .18s ease}
.chip:hover{transform:rotate(2deg) scale(1.04)}

/* ---- home hero: face bob + glow pulse ---- */
.me-atom .me-face img{animation:faceBob 6.5s ease-in-out infinite}
.me-atom .me-face::before{animation:glowPulse 4.4s ease-in-out infinite}
@keyframes faceBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes glowPulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.14)}}
.name-tape{transition:transform .2s ease}
.mascot:hover .name-tape{transform:translateX(-50%) rotate(-2deg) scale(1.06)}

/* ---- about: float the hero orbs + twinkle sparkles, tilt frames ---- */
.about-hero .orb.o1{animation:dFloat 8.5s ease-in-out infinite}
.about-hero .orb.o2{animation:dFloat 6.2s ease-in-out infinite}
.sparkle{animation:dTwinkle 3.2s ease-in-out infinite}
.sparkle:nth-of-type(2){animation-delay:.7s}
.sparkle:nth-of-type(3){animation-delay:1.3s}
.frame{transition:transform .26s cubic-bezier(.2,.7,.2,1),box-shadow .26s ease}
.frame:hover{transform:scale(1.06) rotate(0deg)!important;z-index:9;box-shadow:0 24px 46px rgba(0,0,0,.42)}

/* ---- chart line draws itself in ---- */
.chart-holder .spark,.case-holder .spark{stroke-dasharray:1600;stroke-dashoffset:1600;
  animation:draw 1.9s cubic-bezier(.4,.08,.2,1) forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ---- project module inner motion on hover ---- */
.module:hover{box-shadow:11px 12px 0 rgba(42,30,44,.16)}
.module.code:hover{box-shadow:11px 12px 0 var(--teal)}
.module.story:hover{box-shadow:11px 12px 0 var(--berry)}
.module.life:hover{box-shadow:11px 12px 0 var(--amber)}
.module.story:hover .book{animation-duration:2.6s}
.module.life:hover .g-blades{animation-duration:1.8s}

/* ---- dotted-divider gets a tiny pulse marker ---- */
section.band{position:relative}
section.band+section.band::before{content:"✦";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  color:var(--amber);font-size:1rem;background:var(--paper);padding:0 10px;animation:dTwinkle 4s ease-in-out infinite}
