/* ═══════════════════════════════════════════════════════════════
   MANNY'S FUND — mannys.fund
   Seat at the Table · SamuelJon Media LLC
   Shared Stylesheet
═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;1,400;1,500&family=Mulish:wght@300;400;500;600;700&display=swap');

/* ─── DESIGN TOKENS ─── */
:root {
  --ww:    #FAFAF8;
  --g50:   #F4F3F0;
  --g100:  #ECEAE6;
  --g150:  #E2E0DB;
  --g200:  #D5D2CC;
  --g300:  #BBB8B0;
  --g400:  #9E9B93;
  --g500:  #7E7B73;
  --g600:  #5C5A54;
  --coal:  #2E2C28;
  --red:   #C0272D;
  --red2:  #A01F24;
  --redbg: #F8ECEC;
  --rose:  #D4999C;
  --sl:    #5B7083;
  --slbg:  #EBF0F4;
  --sg:    #7A9B8A;
  --sgbg:  #EBF2EE;
  --max:   1040px;
  --nav-h: 72px;
}

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:'Mulish', sans-serif;
  font-weight:300;
  color:var(--coal);
  background:var(--ww);
  font-size:16px;
  line-height:1.75;
  overflow-x:hidden;
}
img, video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }

/* ─── NAVIGATION ─── */
.site-nav {
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  height:var(--nav-h);
  background:rgba(250,250,248,0.95);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--g150);
  display:flex;
  align-items:center;
}
.nav-inner {
  max-width:var(--max);
  margin:0 auto;
  padding:0 48px;
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.nav-brand {
  display:flex;
  align-items:stretch;
  align-self:stretch;
}
.nav-logo {
  height:var(--nav-h);
  width:auto;
  display:block;
}
.nav-brand-primary { display:none; }
.nav-brand-sub { display:none; }
.nav-links {
  display:flex;
  align-items:center;
  gap:36px;
  list-style:none;
}
.nav-links a {
  font-size:12.5px;
  font-weight:500;
  letter-spacing:0.04em;
  color:var(--g500);
  transition:color 0.2s;
}
.nav-links a:hover { color:var(--coal); }
.nav-links a.active { color:var(--coal); }
.nav-cta {
  background:var(--red);
  color:#fff !important;
  padding:9px 20px;
  font-size:12px !important;
  font-weight:600 !important;
  letter-spacing:0.06em;
  transition:background 0.2s !important;
}
.nav-cta:hover { background:var(--red2) !important; }

.nav-mobile-toggle {
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:4px;
}
.nav-mobile-toggle span {
  display:block;
  width:22px;
  height:2px;
  background:var(--coal);
  transition:all 0.25s;
}

/* ─── PAGE WRAPPER ─── */
.page-body {
  padding-top:var(--nav-h);
}

/* ─── SECTION UTILITY ─── */
.section {
  padding:80px 0;
}
.section-inner {
  max-width:var(--max);
  margin:0 auto;
  padding:0 48px;
}
.section-divider {
  border:none;
  border-top:1px solid var(--g100);
  margin:0;
}

/* ─── SECTION TAGS ─── */
.stag {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.stag-dot {
  width:6px; height:6px;
  border-radius:50%;
  background:var(--red);
  flex-shrink:0;
}
.stag-dot.sl { background:var(--sl); }
.stag-dot.sg { background:var(--sg); }
.stag-txt {
  font-size:10px;
  font-weight:700;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--red);
}
.stag-txt.sl { color:var(--sl); }
.stag-txt.sg { color:var(--sg); }

/* ─── HEADINGS ─── */
.s-ttl {
  font-family:'Playfair Display', serif;
  font-size:clamp(28px, 4vw, 42px);
  font-weight:400;
  line-height:1.15;
  color:var(--coal);
  margin-bottom:20px;
}
.s-ttl em { font-style:italic; color:var(--g400); }
.s-ttl.sl em { color:var(--sl); }
.s-ttl.red em { color:var(--red); }
.s-ttl.sg em { color:var(--sg); }

.s-sub {
  font-size:17px;
  color:var(--g500);
  line-height:1.8;
  max-width:620px;
  margin-bottom:48px;
}

/* ─── BODY TEXT ─── */
.body-text {
  font-size:16px;
  color:var(--g600);
  line-height:1.9;
  margin-bottom:18px;
  max-width:680px;
}
.body-text:last-child { margin-bottom:0; }
.body-text.wide { max-width:none; }

/* ─── CALLOUT ─── */
.callout {
  background:var(--redbg);
  border-left:3px solid var(--red);
  padding:24px 28px;
  margin:28px 0;
  max-width:680px;
}
.callout p {
  font-family:'Playfair Display', serif;
  font-style:italic;
  font-size:18px;
  color:var(--coal);
  line-height:1.7;
}

/* ─── INFO BOX ─── */
.info-box {
  background:var(--slbg);
  border:1px solid rgba(91,112,131,0.2);
  border-left:3px solid var(--sl);
  padding:22px 26px;
  margin:24px 0;
  max-width:680px;
}
.info-box-label {
  font-size:10px; font-weight:700;
  letter-spacing:0.15em; text-transform:uppercase;
  color:var(--sl); margin-bottom:10px;
}
.info-box p { font-size:15px; color:var(--g600); line-height:1.8; }

/* ─── FOOTER ─── */
.site-footer {
  background:var(--coal);
  padding:56px 0 40px;
}
.footer-inner {
  max-width:var(--max);
  margin:0 auto;
  padding:0 48px;
}
.footer-top {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:48px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.footer-brand .fb-name {
  font-family:'Playfair Display', serif;
  font-size:20px;
  font-weight:400;
  color:#fff;
  margin-bottom:6px;
}
.footer-brand .fb-name em { font-style:italic; color:#fff; }
.footer-brand .fb-sub {
  font-size:11px;
  font-weight:600;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.35);
  margin-bottom:18px;
}
.footer-brand p {
  font-size:14px;
  color:rgba(255,255,255,0.45);
  line-height:1.8;
  max-width:280px;
}
.footer-col-title {
  font-size:10px;
  font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.3);
  margin-bottom:18px;
}
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-col ul li a {
  font-size:14px;
  color:rgba(255,255,255,0.55);
  transition:color 0.2s;
}
.footer-col ul li a:hover { color:#fff; }
.footer-bottom {
  padding-top:28px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.footer-bottom p {
  font-size:12px;
  color:rgba(255,255,255,0.25);
  line-height:1.6;
}

/* ─── BUTTONS ─── */
.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 28px;
  font-size:13px;
  font-weight:600;
  letter-spacing:0.05em;
  cursor:pointer;
  transition:all 0.2s;
  border:none;
  font-family:'Mulish', sans-serif;
}
.btn-red {
  background:var(--red);
  color:#fff;
}
.btn-red:hover { background:var(--red2); }
.btn-outline {
  background:transparent;
  color:var(--coal);
  border:1.5px solid var(--g300);
}
.btn-outline:hover { border-color:var(--coal); }
.btn-outline-white {
  background:transparent;
  color:#fff;
  border:1.5px solid rgba(255,255,255,0.3);
}
.btn-outline-white:hover { border-color:#fff; }

/* ─── CHIPS ─── */
.chip {
  background:var(--ww);
  border:1px solid var(--g150);
  padding:8px 16px;
  font-size:12px;
  font-weight:500;
  letter-spacing:0.04em;
  color:var(--g600);
}
.chip span { color:var(--red); font-weight:600; }

/* ─── SPONSOR TIER CARDS ─── */
.tier-grid {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:2px;
  margin:40px 0;
}
.tier-card {
  background:var(--g50);
  border:1px solid var(--g150);
  padding:32px 28px;
}
.tier-card.featured {
  background:var(--redbg);
  border-color:var(--rose);
}
.tier-label {
  font-size:10px;
  font-weight:700;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--red);
  margin-bottom:8px;
}
.tier-label.sl { color:var(--sl); }
.tier-label.sg { color:var(--sg); }
.tier-name {
  font-family:'Playfair Display', serif;
  font-size:20px;
  font-weight:400;
  color:var(--coal);
  line-height:1.2;
  margin-bottom:12px;
}
.tier-price {
  font-size:28px;
  font-weight:700;
  color:var(--coal);
  margin-bottom:4px;
}
.tier-price span {
  font-size:13px;
  font-weight:400;
  color:var(--g400);
  margin-left:4px;
}
.tier-desc {
  font-size:14px;
  color:var(--g500);
  line-height:1.8;
  margin-bottom:20px;
  border-top:1px solid var(--g150);
  padding-top:16px;
}
.tier-includes {
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.tier-includes li {
  font-size:13.5px;
  color:var(--g600);
  display:grid;
  grid-template-columns:16px 1fr;
  gap:8px;
  align-items:start;
}
.tier-includes li::before {
  content:'✓';
  color:var(--red);
  font-weight:700;
  font-size:11px;
  padding-top:3px;
}

/* ─── EPISODE ARC TIMELINE ─── */
.arc { display:flex; flex-direction:column; gap:0; }
.arc-item {
  display:grid;
  grid-template-columns:110px 28px 1fr;
  gap:16px;
  align-items:start;
  padding:20px 0;
  border-bottom:1px solid var(--g100);
}
.arc-item:last-child { border-bottom:none; }
.arc-time {
  font-size:11px;
  font-weight:700;
  letter-spacing:0.09em;
  color:var(--red);
  padding-top:3px;
}
.arc-dc { display:flex; flex-direction:column; align-items:center; padding-top:6px; }
.arc-dot { width:8px; height:8px; border-radius:50%; background:var(--g300); flex-shrink:0; }
.arc-ln { flex:1; width:1px; background:var(--g200); margin-top:4px; min-height:24px; }
.arc-body strong { display:block; font-size:15px; font-weight:600; color:var(--coal); margin-bottom:4px; }
.arc-body span { font-size:14px; color:var(--g500); line-height:1.7; }

/* ─── FORM STYLES ─── */
.form-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
.form-group {
  display:flex;
  flex-direction:column;
  gap:7px;
}
.form-group.full { grid-column:1 / -1; }
.form-label {
  font-size:11px;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--g500);
}
.form-label .req { color:var(--red); margin-left:2px; }
.form-input,
.form-select,
.form-textarea {
  width:100%;
  background:var(--ww);
  border:1.5px solid var(--g200);
  padding:13px 16px;
  font-family:'Mulish', sans-serif;
  font-size:15px;
  font-weight:300;
  color:var(--coal);
  outline:none;
  transition:border-color 0.2s;
  border-radius:0;
  -webkit-appearance:none;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color:var(--red);
}
.form-textarea {
  resize:vertical;
  min-height:120px;
  line-height:1.7;
}
.form-hint {
  font-size:12px;
  color:var(--g400);
  line-height:1.6;
}
.form-section-label {
  font-size:10px;
  font-weight:700;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--sl);
  margin-bottom:20px;
  padding-bottom:12px;
  border-bottom:1px solid var(--g150);
  grid-column:1 / -1;
}
.form-divider {
  grid-column:1 / -1;
  border:none;
  border-top:1px solid var(--g100);
  margin:8px 0;
}

/* ─── EPISODE CARD ─── */
.episode-card {
  background:var(--g50);
  border:1px solid var(--g150);
  padding:32px;
  display:grid;
  grid-template-columns:80px 1fr auto;
  gap:24px;
  align-items:center;
}
.ep-num {
  font-family:'Playfair Display', serif;
  font-size:42px;
  font-weight:400;
  color:var(--g200);
  line-height:1;
}
.ep-label {
  font-size:10px;
  font-weight:700;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--g400);
  margin-bottom:6px;
}
.ep-title {
  font-family:'Playfair Display', serif;
  font-size:22px;
  font-weight:400;
  color:var(--coal);
  margin-bottom:4px;
}
.ep-meta {
  font-size:13px;
  color:var(--g400);
}
.ep-badge {
  padding:6px 14px;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.06em;
  text-transform:uppercase;
}
.ep-badge.coming {
  background:var(--g100);
  color:var(--g500);
}
.ep-badge.live {
  background:var(--sgbg);
  color:var(--sg);
  border:1px solid rgba(122,155,138,0.3);
}

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .tier-grid { grid-template-columns:1fr; gap:16px; }
  .footer-top { grid-template-columns:1fr 1fr; gap:36px; }
}

@media (max-width: 680px) {
  :root { --nav-h: 64px; }
  .nav-inner { padding:0 24px; }
  .nav-links { display:none; }
  .nav-links.open {
    display:flex;
    flex-direction:column;
    position:fixed;
    top:64px; left:0; right:0;
    background:var(--ww);
    border-bottom:1px solid var(--g150);
    padding:24px;
    gap:20px;
  }
  .nav-mobile-toggle { display:flex; }
  .section { padding:56px 0; }
  .section-inner { padding:0 24px; }
  .form-grid { grid-template-columns:1fr; }
  .arc-item { grid-template-columns:90px 20px 1fr; gap:10px; }
  .footer-top { grid-template-columns:1fr; gap:28px; }
  .footer-inner { padding:0 24px; }
  .episode-card { grid-template-columns:1fr; gap:16px; }
  .ep-num { font-size:28px; }
}
