/* ---------- Dumb Bitch Academy — shared stylesheet ---------- */
:root{
  --ivory:#f6f1e8;
  --ivory-2:#efe7d6;
  --ink:#1a1a1a;
  --ink-soft:#3a3530;
  --camel:#b08b5a;
  --camel-dark:#8a6b40;
  --teal:#2f5d62;
  --rule:rgba(26,26,26,.18);
  --rule-strong:rgba(26,26,26,.55);
  --serif:"Playfair Display", "Cormorant Garamond", Georgia, serif;
  --sans:"Inter", "Helvetica Neue", Arial, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- top masthead ---------- */
.masthead{
  border-bottom:1px solid var(--rule);
  background:var(--ivory);
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(6px);
}
.masthead-inner{
  max-width:1400px;margin:0 auto;
  padding:14px 40px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;
}
.mast-left, .mast-right{display:flex;gap:28px;font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.mast-right{justify-content:flex-end}
.mast-left a, .mast-right a{position:relative;padding:6px 0;color:var(--ink-soft)}
.mast-left a:hover, .mast-right a:hover{color:var(--ink)}
.mast-left a.active::after, .mast-right a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--ink);
}
.wordmark{
  font-family:var(--serif);
  font-weight:900;
  font-size:28px;
  letter-spacing:.02em;
  text-align:center;
  line-height:1;
}
.wordmark .tiny{display:block;font-family:var(--sans);font-weight:500;font-size:9px;letter-spacing:.4em;color:var(--ink-soft);margin-top:6px;text-transform:uppercase}

/* ---------- top strip (issue / date) ---------- */
.issue-strip{
  background:var(--ink);color:var(--ivory);
  font-family:var(--sans);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  padding:8px 40px;display:flex;justify-content:space-between;align-items:center;
}
.issue-strip .dots{display:flex;gap:24px}

/* ---------- hero ---------- */
.hero{
  position:relative;
  min-height:calc(100vh - 90px);
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:0;
  border-bottom:1px solid var(--rule);
}
.hero-photo{
  position:relative;overflow:hidden;
  background:#222;
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo .photo-caption{
  position:absolute;left:24px;bottom:24px;color:#fff;
  font-family:var(--sans);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  background:rgba(0,0,0,.35);padding:6px 10px;
}
.hero-copy{
  padding:80px 72px;display:flex;flex-direction:column;justify-content:center;
}
.eyebrow{
  font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--camel-dark);margin-bottom:28px;
  display:flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--camel)}
.hero h1{
  font-family:var(--serif);
  font-weight:900;
  font-size:clamp(56px, 7.2vw, 108px);
  line-height:.92;
  letter-spacing:-.02em;
  margin:0 0 28px;
}
.hero h1 em{font-style:italic;font-weight:400;color:var(--ink-soft)}
.hero .deck{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:22px;line-height:1.4;max-width:500px;color:var(--ink-soft);
  margin:0 0 40px;
}
.hero-cta{display:flex;gap:16px;align-items:center;margin-bottom:48px}
.btn{
  display:inline-block;font-family:var(--sans);font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;padding:18px 28px;border:1px solid var(--ink);
  transition:background .2s,color .2s;cursor:pointer;background:none;
}
.btn-primary{background:var(--ink);color:var(--ivory)}
.btn-primary:hover{background:var(--camel);border-color:var(--camel);color:#fff}
.btn-ghost:hover{background:var(--ink);color:var(--ivory)}
.hero-facts{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  border-top:1px solid var(--rule);padding-top:28px;
}
.fact .num{font-family:var(--serif);font-size:44px;line-height:1;font-weight:900}
.fact .lbl{font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}

/* ---------- section scaffolding ---------- */
.section{padding:120px 40px;border-bottom:1px solid var(--rule)}
.section-inner{max-width:1400px;margin:0 auto}
.sec-head{
  display:grid;grid-template-columns:240px 1fr;gap:40px;
  border-top:1px solid var(--ink);padding-top:24px;margin-bottom:64px;
}
.sec-num{font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase}
.sec-num b{font-family:var(--serif);font-weight:900;font-size:48px;display:block;margin-bottom:6px;letter-spacing:0}
.sec-title{font-family:var(--serif);font-weight:900;font-size:clamp(42px,5vw,72px);line-height:.95;letter-spacing:-.02em;margin:0}
.sec-title em{font-style:italic;font-weight:400;color:var(--ink-soft)}
.sec-sub{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--ink-soft);margin-top:18px;max-width:560px}

/* ---------- pillars / curriculum cards ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule)}
.pillar{
  background:var(--ivory);padding:40px 32px;display:flex;flex-direction:column;gap:20px;
  min-height:480px;transition:background .3s;
}
.pillar:hover{background:var(--ivory-2)}
.pillar .pillar-photo{height:220px;overflow:hidden;background:#222;margin:-40px -32px 0}
.pillar .pillar-photo img{width:100%;height:100%;object-fit:cover}
.pillar-num{font-family:var(--sans);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--camel-dark);margin-top:24px}
.pillar-title{font-family:var(--serif);font-weight:900;font-size:28px;line-height:1.05;margin:0}
.pillar-body{font-size:15px;color:var(--ink-soft);line-height:1.6;margin:0}
.pillar-meta{margin-top:auto;padding-top:20px;border-top:1px solid var(--rule);font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);display:flex;justify-content:space-between}

/* ---------- founders ---------- */
.founders-split{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--rule)}
.founder{padding:0;display:grid;grid-template-rows:420px auto}
.founder + .founder{border-left:1px solid var(--rule)}
.founder-photo{overflow:hidden;background:#222}
.founder-photo img{width:100%;height:100%;object-fit:cover}
.founder-body{padding:36px 40px 40px}
.founder-kicker{font-family:var(--sans);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--camel-dark);margin-bottom:10px}
.founder-name{font-family:var(--serif);font-weight:900;font-size:48px;line-height:.95;margin:0 0 10px}
.founder-name em{font-style:italic;font-weight:400}
.founder-handle{font-family:var(--mono);font-size:12px;color:var(--ink-soft);margin-bottom:20px}
.founder-quote{font-family:var(--serif);font-style:italic;font-size:20px;line-height:1.4;color:var(--ink);margin:0 0 20px;border-left:2px solid var(--camel);padding-left:18px}
.founder-bio{font-size:14px;color:var(--ink-soft);line-height:1.6}
.founder-bio .finelink{color:var(--ink-soft);border-bottom:1px dotted var(--rule-strong);cursor:help}

/* ---------- scarcity banner ---------- */
.scarcity{
  background:var(--ink);color:var(--ivory);
  padding:56px 40px;text-align:center;
}
.scarcity .sm{font-family:var(--sans);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--camel);margin-bottom:16px}
.scarcity h3{font-family:var(--serif);font-weight:900;font-size:clamp(32px,4vw,56px);line-height:1;margin:0 0 22px}
.scarcity h3 em{font-style:italic;font-weight:400;color:#e6d2b3}
.countdown{display:inline-flex;gap:24px;margin:18px 0 26px;font-family:var(--serif)}
.cd{display:flex;flex-direction:column;align-items:center;min-width:84px}
.cd .n{font-size:56px;font-weight:900;line-height:1;letter-spacing:-.02em}
.cd .l{font-family:var(--sans);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#c9b088;margin-top:6px}
.scarcity .micro{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#a08866}

/* ---------- Instagram grid ---------- */
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:2px}
.ig-grid .ig-cell{position:relative;aspect-ratio:1;overflow:hidden;background:#222}
.ig-grid .ig-cell img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.ig-grid .ig-cell:hover img{transform:scale(1.05)}
.ig-cell .ig-cap{
  position:absolute;inset:auto 0 0 0;padding:12px 14px;
  background:linear-gradient(transparent,rgba(0,0,0,.75));
  color:#fff;font-family:var(--sans);font-size:11px;letter-spacing:.06em;
  opacity:0;transition:opacity .25s;
}
.ig-cell:hover .ig-cap{opacity:1}

/* ---------- footer ---------- */
.footer{background:var(--ink);color:#c9bfa9;padding:80px 40px 40px;font-family:var(--sans)}
.footer-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px}
.footer .wordmark{color:var(--ivory);text-align:left;font-size:36px}
.footer .wordmark .tiny{color:#8a7d60;text-align:left}
.footer h5{font-family:var(--sans);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--ivory);margin:0 0 16px}
.footer ul{list-style:none;padding:0;margin:0;font-size:13px;line-height:2}
.footer a:hover{color:var(--camel)}
.footer .blurb{font-family:var(--serif);font-style:italic;font-size:16px;color:#c9bfa9;margin:20px 0 0;max-width:340px;line-height:1.5}
.footer-bottom{max-width:1400px;margin:60px auto 0;border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;font-size:11px;color:#6f6650;letter-spacing:.08em}
.footer-bottom .fineprint{max-width:760px;font-family:var(--sans);font-size:10px;line-height:1.8;color:#6f6650;letter-spacing:.02em;text-transform:none}
.footer-bottom .fineprint em{color:#8a7d60}

/* ---------- utility ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.dropcap::first-letter{
  font-family:var(--serif);font-weight:900;font-size:96px;float:left;line-height:.85;padding:6px 12px 0 0;color:var(--camel-dark);
}
.rule{height:1px;background:var(--rule);margin:40px 0}
.smallcaps{font-family:var(--sans);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft)}
.pullquote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(32px,3.6vw,52px);line-height:1.15;letter-spacing:-.01em;
  text-align:center;max-width:1100px;margin:0 auto;
}
.pullquote .attr{display:block;margin-top:28px;font-family:var(--sans);font-style:normal;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- responsive fallback ---------- */
@media (max-width: 980px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-copy{padding:60px 32px}
  .pillars, .three-col{grid-template-columns:1fr}
  .founders-split{grid-template-columns:1fr}
  .founder + .founder{border-left:none;border-top:1px solid var(--rule)}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
  .mast-left,.mast-right{display:none}
  .sec-head{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr;gap:40px}
}

/* ---------- tweaks panel ---------- */
.tweaks-panel{
  position:fixed;right:20px;bottom:20px;z-index:100;
  background:var(--ivory);border:1px solid var(--ink);
  padding:18px 20px;width:280px;font-family:var(--sans);font-size:12px;
  box-shadow:0 20px 50px rgba(0,0,0,.15);
  display:none;
}
.tweaks-panel.on{display:block}
.tweaks-panel h6{margin:0 0 12px;font-size:10px;letter-spacing:.3em;text-transform:uppercase}
.tweaks-panel label{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-top:1px solid var(--rule);gap:12px}
.tweaks-panel label:first-of-type{border-top:none}
.tweaks-panel select, .tweaks-panel input[type=range]{font-family:inherit;font-size:12px}
.tweaks-panel .hint{font-size:10px;color:var(--ink-soft);margin-top:10px;line-height:1.5}

/* satire dial */
body[data-satire="obvious"] .satire-easter{display:inline !important}
body[data-satire="obvious"] .founder-bio .finelink{color:var(--camel-dark);border-bottom:1px solid var(--camel)}
.satire-easter{display:none}
