/* ─── TERAPUSH SHARED STYLES ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 18px; }

:root {
  --bg:        #000000;
  --bg2:       #0a0a0a;
  --bg3:       #111111;
  --border:    rgba(255,255,255,0.08);
  --border2:   rgba(255,255,255,0.15);
  --text:      #ffffff;
  --text2:     rgba(255,255,255,0.7);
  --text3:     rgba(255,255,255,0.48);
  --input-bg:  rgba(255,255,255,0.04);
  --card-bg:   rgba(255,255,255,0.03);
  --cta-bg:    #ffffff;
  --cta-text:  #000000;
  --transition: 0.5s cubic-bezier(0.23,1,0.32,1);
}
[data-theme="light"] {
  --bg:        #ffffff;
  --bg2:       #f5f5f7;
  --bg3:       #ebebeb;
  --border:    rgba(0,0,0,0.07);
  --border2:   rgba(0,0,0,0.13);
  --text:      #000000;
  --text2:     rgba(0,0,0,0.62);
  --text3:     rgba(0,0,0,0.42);
  --input-bg:  rgba(0,0,0,0.03);
  --card-bg:   rgba(0,0,0,0.02);
  --cta-bg:    #000000;
  --cta-text:  #ffffff;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'League Spartan', sans-serif;
  font-weight: 300;
  min-height: 100vh;
  overflow-x: hidden;
  transition: background var(--transition), color var(--transition);
}

/* ─── CURSOR ─── */
.cursor { position:fixed; width:8px; height:8px; background:var(--text); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); mix-blend-mode:difference; }
.cursor-ring { position:fixed; width:32px; height:32px; border:1px solid var(--text); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); mix-blend-mode:difference; opacity:0.5; transition:width 0.3s,height 0.3s,opacity 0.3s; }

@media (max-width:900px) {
  .cursor, .cursor-ring { display:none !important; }
}

/* ─── NAV ─── */
nav {
  position: fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding: 0 48px; height: 64px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  transition: background var(--transition), border-color var(--transition), backdrop-filter 0.3s;
}
nav.scrolled {
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter: blur(20px) saturate(1.8);
  -webkit-backdrop-filter: blur(20px) saturate(1.8);
}
.logo { font-family:'League Spartan',sans-serif; font-weight:700; font-size:1.4rem; letter-spacing:-0.02em; color:var(--text); text-decoration:none; transition:color var(--transition); }
.nav-links { display:flex; align-items:center; gap:32px; }
.nav-links a { font-size:0.88rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text2); text-decoration:none; font-weight:500; transition:color 0.2s; }
.nav-links a:hover, .nav-links a.active { color:var(--text); }
.nav-right { display:flex; align-items:center; gap:20px; }
.theme-toggle { display:flex; align-items:center; gap:8px; cursor:pointer; }
.toggle-label { font-size:0.9rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--text2); font-weight:400; user-select:none; }
.toggle-track { position:relative; width:40px; height:22px; background:rgba(255,255,255,0.1); border:1px solid var(--border2); border-radius:100px; cursor:pointer; transition:background 0.3s; }
.toggle-thumb { position:absolute; top:2px; left:2px; width:16px; height:16px; background:var(--text); border-radius:50%; transition:transform 0.35s cubic-bezier(0.34,1.56,0.64,1); }
[data-theme="light"] .toggle-thumb { transform:translateX(18px); }
.nav-pill { font-size:0.8rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--text2); border:1px solid var(--border2); padding:7px 18px; border-radius:100px; font-weight:500; }

/* ─── MOBILE NAV HAMBURGER ─── */
.nav-hamburger {
  display: none;
  align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border: 1px solid var(--border2);
  border-radius: 8px;
  background: var(--input-bg);
  cursor: pointer;
  padding: 0;
  z-index: 1100;
  transition: background 0.2s, border-color 0.2s;
  flex-shrink: 0;
}
.nav-hamburger:hover { background: var(--card-bg); border-color: var(--text3); }
.nav-hamburger.open { background: var(--card-bg); border-color: var(--text3); }

/* Icon — two lines that cross into X */
.nav-hamburger .bar {
  position: relative;
  width: 16px; height: 16px;
}
.nav-hamburger .bar span {
  display: block;
  position: absolute;
  left: 0; right: 0;
  height: 1.5px;
  background: var(--text);
  border-radius: 2px;
  transition: transform 0.35s cubic-bezier(0.23,1,0.32,1), opacity 0.25s, top 0.35s cubic-bezier(0.23,1,0.32,1);
}
.nav-hamburger .bar span:nth-child(1) { top: 4px; }
.nav-hamburger .bar span:nth-child(2) { top: 10px; width: 10px; }

/* Open state → X */
.nav-hamburger.open .bar span:nth-child(1) { top: 7px; transform: rotate(45deg); }
.nav-hamburger.open .bar span:nth-child(2) { top: 7px; width: 16px; transform: rotate(-45deg); opacity: 1; }

/* Mobile drawer */
.mobile-drawer {
  display:flex;
  flex-direction:column;
  position:fixed; top:64px; left:0; right:0; bottom:0;
  background:var(--bg);
  z-index:999;
  padding:24px 20px 40px;
  border-top:1px solid var(--border);
  transform:translateY(-12px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity 0.35s cubic-bezier(0.23,1,0.32,1), transform 0.35s cubic-bezier(0.23,1,0.32,1), visibility 0.35s;
  overflow-y:auto;
}
.mobile-drawer.open {
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:all;
}
.mobile-drawer-links { display:flex; flex-direction:column; gap:8px; flex:1; margin-bottom:16px; }
.mobile-drawer-links a {
  display:flex; align-items:center; justify-content:space-between;
  font-family:'League Spartan',sans-serif;
  font-size:0.95rem; font-weight:600; letter-spacing:0.05em;
  color:var(--text); text-decoration:none;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:6px;
  transition:color 0.2s, background 0.2s, border-color 0.2s;
}
.mobile-drawer-links a:hover { color:var(--text2); background:var(--bg2); }
.mobile-drawer-links a svg { opacity:0.3; flex-shrink:0; }
.mobile-drawer-bottom {
  display:flex; flex-direction:column; gap:12px;
  padding-top:0; padding-bottom:env(safe-area-inset-bottom, 0px);
  margin-top:auto;
}
.mobile-drawer-cta {
  display:block; text-align:center;
  padding:10px 20px;
  background:var(--cta-bg); color:var(--cta-text);
  font-family:'League Spartan',sans-serif;
  font-size:0.72rem; font-weight:600; letter-spacing:0.12em; text-transform:uppercase;
  border-radius:6px; text-decoration:none;
  transition:opacity 0.2s;
}
.mobile-drawer-cta:hover { opacity:0.85; }
.mobile-drawer-theme {
  display:flex; flex-direction:column; align-items:flex-start; gap:10px;
  padding:12px 0; border-top:1px solid var(--border);
}
.mobile-drawer-theme-label { font-size:0.78rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text2); display:flex; align-items:center; gap:6px; font-weight:500; }
.mobile-drawer-theme-label svg { opacity:0.5; }

/* Redesigned mobile theme toggle pill */
.mobile-theme-pill {
  display:flex; align-items:center; gap:0;
  border:1px solid var(--border2); border-radius:8px;
  overflow:hidden; background:var(--input-bg);
  width:100%; max-width:160px;
}
.mobile-theme-pill button {
  display:flex; align-items:center; justify-content:center; gap:4px;
  padding:8px 12px;
  background:transparent; border:none; cursor:pointer;
  font-family:'League Spartan',sans-serif;
  font-size:0.74rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--text2);
  transition:background 0.2s, color 0.2s;
  border-radius:6px;
  flex:1;
}
.mobile-theme-pill button.active {
  background:var(--cta-bg); color:var(--cta-text);
}
.mobile-theme-pill button svg { width:11px; height:11px; flex-shrink:0; }


/* ─── PAGE HERO ─── */
.page-hero {
  padding: 140px 48px 80px;
  max-width: 1080px; margin: 0 auto;
  border-bottom: 1px solid var(--border);
}
.page-kicker { font-size:0.9rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--text2); font-weight:500; margin-bottom:24px; }
.page-title {
  font-family:'Instrument Serif',serif; font-size:clamp(3rem,7vw,6.5rem);
  font-weight:400; line-height:1.0; letter-spacing:-0.025em; color:var(--text);
  margin-bottom:24px; transition:color var(--transition);
}
.page-title em { font-style:italic; color:var(--text2); }
.page-desc { font-size:1.35rem; color:var(--text2); max-width:520px; line-height:1.7; font-weight:400; }

/* ─── SECTION ─── */
.section { max-width:1080px; margin:0 auto; padding:80px 48px; }
.section-kicker { font-size:0.92rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--text2); font-weight:500; margin-bottom:16px; }
.section-heading { font-family:'Instrument Serif',serif; font-size:clamp(1.8rem,3.5vw,3rem); font-weight:400; line-height:1.1; letter-spacing:-0.02em; color:var(--text); margin-bottom:56px; transition:color var(--transition); }
.section-heading em { font-style:italic; color:var(--text2); }

/* ─── MARQUEE ─── */
.marquee-section { border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:18px 0; overflow:hidden; background:var(--bg2); transition:background var(--transition); }
.marquee-track { display:flex; animation:marquee 22s linear infinite; white-space:nowrap; }
.marquee-item { display:inline-flex; align-items:center; gap:14px; padding:0 28px; font-size:0.82rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--text2); flex-shrink:0; }
.marquee-dot { width:3px; height:3px; border-radius:50%; background:var(--text3); }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ─── FOOTER ─── */
.site-footer {
  border-top:1px solid var(--border);
  background: var(--bg2);
  transition: background var(--transition), border-color var(--transition);
}
.footer-main {
  max-width:1080px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr;
  gap:48px; padding:64px 48px 48px;
}
.footer-brand .footer-logo { font-family:'League Spartan',sans-serif; font-weight:700; font-size:1.2rem; letter-spacing:-0.01em; color:var(--text); text-decoration:none; display:block; margin-bottom:16px; }
.footer-brand p { font-size:0.97rem; color:var(--text2); line-height:1.7; max-width:260px; }
.footer-col h4 { font-size:0.92rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--text2); font-weight:500; margin-bottom:20px; }
.footer-col a, .footer-col p { display:block; font-size:0.98rem; color:var(--text2); text-decoration:none; margin-bottom:10px; line-height:1.6; transition:color 0.2s; }
.footer-col a:hover { color:var(--text); }
.footer-social { display:flex; gap:12px; margin-top:4px; }
.footer-social a { display:inline-flex; align-items:center; gap:6px; font-size:0.92rem; color:var(--text2); text-decoration:none; border:1px solid var(--border); padding:8px 16px; border-radius:100px; transition:border-color 0.2s, color 0.2s; }
.footer-social a:hover { border-color:var(--border2); color:var(--text); }
.footer-address { font-size:0.95rem; color:var(--text2); line-height:1.75; }
.footer-map { margin-top:16px; border-radius:8px; overflow:hidden; border:1px solid var(--border); }
.footer-map iframe { display:block; width:100%; height:120px; filter:grayscale(1) contrast(1.1); border:none; transition:filter 0.3s; }
.footer-map iframe:hover { filter:grayscale(0.4); }
.footer-bottom { border-top:1px solid var(--border); padding:20px 48px; max-width:1080px; margin:0 auto; }
.footer-bottom-inner { display:flex; align-items:flex-start; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.footer-copy { font-size:0.82rem; color:var(--text2); }
.footer-legal-links { display:flex; gap:20px; }
.footer-legal-links a { font-size:0.82rem; color:var(--text2); text-decoration:none; letter-spacing:0.08em; text-transform:uppercase; transition:color 0.2s; }
.footer-legal-links a:hover { color:var(--text2); }
.footer-disclaimer { font-size:0.88rem; color:var(--text2); line-height:1.65; max-width:680px; margin-top:12px; padding-top:12px; border-top:1px solid var(--border); }

/* ─── ENTRANCE ANIMATIONS (pure CSS, no JS) ─── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}

/* Apply to common content containers automatically */
.section-kicker,
.section-heading,
.value-card,
.founder-card,
.service-item,
.timeline-item,
.bento-card,
.cta-strip-heading,
.cta-strip-sub,
.cta-strip-btn,
.mission-block > div,
.app-preview-block > div,
.sitemap-group,
.sitemap-xml-box,
.pitch-info-label,
.pitch-info-heading,
.pitch-info-body,
.pitch-criteria,
.pitch-form-wrap {
  animation: fadeUp 0.7s cubic-bezier(0.23,1,0.32,1) both;
}

/* Stagger children inside grids */
.values-grid .value-card:nth-child(1),
.founders-grid .founder-card:nth-child(1),
.bento-grid .bento-card:nth-child(1),
.service-item:nth-child(1),
.sitemap-group:nth-child(1) { animation-delay: 0.05s; }

.values-grid .value-card:nth-child(2),
.founders-grid .founder-card:nth-child(2),
.bento-grid .bento-card:nth-child(2),
.service-item:nth-child(2),
.sitemap-group:nth-child(2) { animation-delay: 0.12s; }

.values-grid .value-card:nth-child(3),
.founders-grid .founder-card:nth-child(3),
.bento-grid .bento-card:nth-child(3),
.service-item:nth-child(3) { animation-delay: 0.19s; }

.values-grid .value-card:nth-child(4),
.service-item:nth-child(4) { animation-delay: 0.1s; }
.values-grid .value-card:nth-child(5),
.service-item:nth-child(5) { animation-delay: 0.17s; }
.values-grid .value-card:nth-child(6),
.service-item:nth-child(6) { animation-delay: 0.24s; }

.timeline-item:nth-child(1) { animation-delay: 0.05s; }
.timeline-item:nth-child(2) { animation-delay: 0.13s; }
.timeline-item:nth-child(3) { animation-delay: 0.21s; }
.timeline-item:nth-child(4) { animation-delay: 0.29s; }

.section-heading  { animation-delay: 0.08s; }
.cta-strip-sub    { animation-delay: 0.1s; }
.cta-strip-btn    { animation-delay: 0.18s; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ─── CTA STRIP ─── */
.cta-strip { border-top:1px solid var(--border); padding:100px 48px; text-align:center; }
.cta-strip-heading { font-family:'Instrument Serif',serif; font-size:clamp(2rem,5vw,4rem); font-weight:400; font-style:italic; color:var(--text); margin-bottom:16px; letter-spacing:-0.02em; transition:color var(--transition); }
.cta-strip-sub { font-size:0.97rem; color:var(--text3); margin-bottom:36px; }
.cta-strip-btn { display:inline-block; padding:14px 36px; background:var(--cta-bg); color:var(--cta-text); font-family:'League Spartan',sans-serif; font-size:0.92rem; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; border:none; border-radius:100px; cursor:pointer; text-decoration:none; transition:opacity 0.2s, transform 0.2s, background var(--transition), color var(--transition); }
.cta-strip-btn:hover { opacity:0.85; transform:translateY(-1px); }



@media (max-width:900px) {
  nav { padding:0 16px; height:56px; gap:12px; }
  .logo { font-size:1.1rem; flex-shrink:0; }
  .nav-links { display:none; }
  .nav-right { display:none; }
  .nav-hamburger { display:flex; margin-left:auto; }
  .mobile-drawer { top:56px; }
  .mobile-drawer-links a { font-size:clamp(1rem,5vw,1.3rem); padding:16px 0; }
  .mobile-drawer-bottom { gap:16px; padding-top:24px; }
  .page-hero { padding:110px 24px 56px; }
  .section { padding:60px 24px; }
  .footer-main { grid-template-columns:1fr; gap:36px; padding:48px 24px 36px; }
  .footer-bottom { padding:16px 24px; }
  .footer-bottom-inner { flex-direction:column; }
  .cta-strip { padding:70px 24px; }
}
