/* M42 · Stylesheet v1.0 · Single source of truth for web surfaces */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --night-1:#0A0E1A;
  --night-2:#141A2E;
  --night-3:#1F2742;
  --ink:#F5F1E8;
  --ink-dim:#B5B0A2;
  --ink-mute:#6B6657;
  --dawn:#D4A574;
  --dawn-dim:#A3825C;
  --betelgeuse:#E8B08A;
  --serif:'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --unit:8px;
  --max:1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{background:var(--night-1);color:var(--ink);font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{min-height:100vh;position:relative;overflow-x:hidden}

/* Celestial vault · fixed background, slow 6-minute rotation */
.vault{position:fixed;inset:-30%;z-index:-1;pointer-events:none;opacity:0.65;animation:vault-rotate 360s linear infinite;will-change:transform;transform-origin:50% 50%}
.vault .milky-way{position:absolute;inset:0;background:radial-gradient(ellipse 62% 10% at 50% 50%,rgba(220,228,255,0.10) 0%,rgba(212,165,116,0.05) 35%,transparent 72%);transform:rotate(-28deg);filter:blur(42px);pointer-events:none}
.vault .stars{position:absolute;inset:0}
.vault .star{position:absolute;width:1px;height:1px;background:var(--ink);border-radius:50%;box-shadow:0 0 2px rgba(245,241,232,0.8)}
.vault .star.big{width:2px;height:2px;box-shadow:0 0 4px rgba(245,241,232,0.6);animation:vault-twinkle 5s ease-in-out infinite}
.vault .star.warm{background:var(--dawn);box-shadow:0 0 3px rgba(212,165,116,0.7)}
@keyframes vault-rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes vault-twinkle{0%,100%{opacity:1}50%{opacity:0.35}}
/* Legacy fallback for SSR/no-JS: keep 14 static stars visible */
.starfield{position:fixed;inset:0;z-index:-1;opacity:0.4;pointer-events:none}
.starfield .star{position:absolute;width:1px;height:1px;background:var(--ink);border-radius:50%;box-shadow:0 0 2px rgba(245,241,232,0.8)}

/* Layout */
.wrap{max-width:var(--max);margin:0 auto;padding:0 48px}
main{padding:120px 0 160px}

/* Nav */
nav.site{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 48px;background:rgba(10,14,26,0.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(245,241,232,0.06)}
nav.site .inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between}
nav.site a.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
nav.site a.brand img{height:28px;width:auto}
nav.site a.brand span{font-family:var(--serif);font-size:20px;letter-spacing:-0.02em}
nav.site ul{list-style:none;display:flex;gap:32px;align-items:center}
nav.site a,nav.site ul a{border:0}
nav.site ul a{color:var(--ink-dim);text-decoration:none;font-size:14px;transition:color .2s}
nav.site ul a:hover,nav.site ul a.active{color:var(--dawn)}
nav.site ul a.cta{background:var(--dawn);color:var(--night-1);padding:8px 18px;border-radius:2px;font-weight:500}
nav.site ul a.cta:hover{background:var(--ink);color:var(--night-1)}

/* Typography */
h1,h2,h3,h4,h5{font-family:var(--serif);font-weight:400;letter-spacing:-0.015em;color:var(--ink)}
h1{font-size:clamp(48px,7vw,104px);line-height:1;margin-bottom:32px}
h2{font-size:clamp(32px,4vw,56px);line-height:1.05;margin-bottom:24px}
h3{font-size:clamp(24px,2.4vw,32px);line-height:1.15;margin-bottom:16px}
h4{font-size:20px;line-height:1.25;margin-bottom:12px}
p{max-width:68ch;margin-bottom:16px;color:var(--ink-dim)}
p.lede{font-size:clamp(18px,1.6vw,22px);color:var(--ink);max-width:58ch;line-height:1.45}

.eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--dawn);margin-bottom:20px;display:inline-block}
.dot{color:var(--dawn);padding:0 6px;font-weight:400}
em{font-style:italic;color:var(--dawn)}
strong{font-weight:500;color:var(--ink)}
a{color:var(--dawn);text-decoration:none;border-bottom:1px solid rgba(212,165,116,0.3);transition:border-color .2s}
a:hover{border-bottom-color:var(--dawn)}

/* Hero */
.hero{min-height:88vh;display:flex;flex-direction:column;justify-content:center;position:relative;padding:80px 0}
.hero::before{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(ellipse at center,rgba(212,165,116,0.15) 0%,transparent 55%);pointer-events:none;z-index:0}
.hero > *{position:relative;z-index:1}
.hero .tagline{font-family:var(--serif);font-size:clamp(22px,2.4vw,32px);color:var(--ink-dim);font-style:italic;max-width:44ch;margin-top:24px;line-height:1.3}
.hero h1 em{color:var(--ink)}
.hero .scroll-hint{margin-top:64px;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-mute)}

/* Sections */
section.band{padding:120px 0;border-top:1px solid rgba(245,241,232,0.06);position:relative}
section.band:first-of-type{border-top:none}

/* Verbs block */
.verbs{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:64px;margin-top:64px}
.verb .n{font-family:var(--serif);font-size:14px;color:var(--dawn);letter-spacing:0.3em;margin-bottom:8px}
.verb h3{font-family:var(--serif);font-size:48px;color:var(--ink);line-height:1;margin-bottom:16px}
.verb p{font-size:15px;color:var(--ink-dim);max-width:32ch}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:48px}
.card{background:var(--night-2);border:1px solid rgba(245,241,232,0.08);padding:40px 32px;transition:border-color .25s,transform .25s}
.card:hover{border-color:rgba(212,165,116,0.3);transform:translateY(-2px)}
.card h4{font-family:var(--serif);font-size:24px;color:var(--ink);margin-bottom:12px}
.card p{font-size:14px;color:var(--ink-dim);margin-bottom:0}
.card .kicker{display:block;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--dawn);margin-bottom:16px}

/* Pairs (founders) */
.pairs{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:48px;margin-top:64px}
.founder{background:var(--night-2);border:1px solid rgba(245,241,232,0.08);padding:48px}
.founder .name{font-family:var(--serif);font-size:40px;color:var(--ink);line-height:1.1;margin-bottom:8px}
.founder .role{font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--dawn);margin-bottom:32px}
.founder ul{list-style:none;padding:0;margin:0;border-top:1px solid rgba(245,241,232,0.08)}
.founder li{padding:14px 0;border-bottom:1px solid rgba(245,241,232,0.06);font-size:14px;color:var(--ink-dim);line-height:1.5}
.founder li:last-child{border:0}
.founder li strong{color:var(--ink);display:block;margin-bottom:2px;font-size:13px;letter-spacing:0.04em;text-transform:uppercase}

/* CTA block */
.cta-band{text-align:center;padding:120px 0;background:linear-gradient(180deg,var(--night-1) 0%,var(--night-3) 100%);margin:0 -48px;border-top:1px solid rgba(212,165,116,0.15)}
.cta-band h2{max-width:22ch;margin-left:auto;margin-right:auto}
.cta-band .actions{display:flex;gap:16px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.btn{display:inline-block;padding:14px 28px;background:var(--dawn);color:var(--night-1);font-family:var(--sans);font-size:14px;font-weight:500;letter-spacing:0.04em;text-decoration:none;border:0;border-radius:2px;transition:background .2s}
.btn:hover{background:var(--ink);color:var(--night-1)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid rgba(245,241,232,0.25)}
.btn.ghost:hover{background:var(--ink);color:var(--night-1);border-color:var(--ink)}

/* Tables */
table.clean{width:100%;border-collapse:collapse;margin-top:32px}
table.clean th,table.clean td{text-align:left;padding:16px 0;border-bottom:1px solid rgba(245,241,232,0.08);font-size:14px;color:var(--ink-dim)}
table.clean th{font-weight:500;color:var(--ink);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--dawn)}

/* Session list (services) */
.sessions{counter-reset:session;margin-top:64px}
.session{display:grid;grid-template-columns:80px 1fr;gap:32px;padding:32px 0;border-bottom:1px solid rgba(245,241,232,0.08);align-items:start}
.session::before{counter-increment:session;content:counter(session,decimal-leading-zero);font-family:var(--serif);font-size:32px;color:var(--dawn);line-height:1}
.session h4{font-family:var(--serif);font-size:28px;color:var(--ink);margin-bottom:8px;line-height:1.15}
.session p{font-size:14px;color:var(--ink-dim);max-width:60ch;margin-bottom:0}
.session .meta{display:block;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-mute);margin-top:10px}

/* Footer */
footer.site{padding:64px 48px 48px;border-top:1px solid rgba(245,241,232,0.08);margin-top:120px;background:var(--night-2)}
footer.site .inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:48px;padding-bottom:32px;border-bottom:1px solid rgba(245,241,232,0.06)}
footer.site h5{font-family:var(--sans);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--dawn);margin-bottom:16px}
footer.site ul{list-style:none;padding:0}
footer.site li{padding:6px 0;font-size:13px}
footer.site li a{color:var(--ink-dim);border:0}
footer.site li a:hover{color:var(--ink)}
footer.site .colophon{max-width:var(--max);margin:32px auto 0;display:flex;justify-content:space-between;align-items:center;font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-mute)}

/* Preview banner */
.preview-banner{position:fixed;top:0;left:0;right:0;background:#8B3A3A;color:#FFF;padding:6px 16px;text-align:center;font-family:var(--sans);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;z-index:999;font-weight:500}

/* Split layout (2-col desktop, 1-col mobile) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}

/* Forms */
form.contact{max-width:560px;margin-top:48px}
form.contact .row{margin-bottom:24px}
form.contact label{display:block;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--dawn);margin-bottom:8px}
form.contact input,form.contact textarea{width:100%;padding:14px 16px;background:var(--night-2);border:1px solid rgba(245,241,232,0.15);color:var(--ink);font-family:var(--sans);font-size:15px;border-radius:2px;transition:border-color .2s}
form.contact input:focus,form.contact textarea:focus{outline:0;border-color:var(--dawn)}
form.contact textarea{min-height:140px;resize:vertical}
form.contact button{margin-top:8px}

@media (max-width:720px){
  nav.site{padding:14px 20px}
  nav.site a.brand span{font-size:18px}
  nav.site ul{gap:14px}
  nav.site ul li.hide-mobile{display:none}
  nav.site ul a{font-size:13px}
  nav.site ul a.cta{padding:6px 12px}
  .wrap,footer.site{padding-left:24px;padding-right:24px}
  .cta-band{margin:0 -24px}
  .founder,.card{padding:32px 24px}
  .session{grid-template-columns:1fr;gap:16px}
  .session::before{font-size:24px}
  .split{grid-template-columns:1fr;gap:48px}
  footer.site .inner{grid-template-columns:1fr;gap:32px}
  footer.site .colophon{flex-direction:column;gap:12px;text-align:center}
  main{padding:96px 0 96px}
  section.band{padding:72px 0}
  .cta-band{padding:80px 0}
}
