/* ============================================================
   THE COMPASS PROJECT — shared styles
   ============================================================ */

:root{
  --paper: #EFE8D8;
  --paper-warm: #E7DEC7;
  --paper-deep: #DDD1B3;
  --ink: #23261E;
  --ink-soft: #4A4C3F;
  --forest: #1F3A2E;
  --forest-deep: #142720;
  --forest-mid: #2E4E3E;
  --clay: #A8502B;
  --gold: #B78A3E;
  --line: rgba(35,38,30,0.16);
  --line-soft: rgba(35,38,30,0.08);
  --max: 1120px;
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Inter', sans-serif;
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.01ms !important; transition-duration:0.01ms !important;}
}
a{color:inherit;}
img,svg{display:block; max-width:100%;}

.eyebrow{
  font-family:'JetBrains Mono', monospace;
  font-size:12.5px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--clay);
  font-weight:500;
}
h1,h2,h3{
  font-family:'Fraunces', serif;
  font-weight:600;
  letter-spacing:-0.01em;
  color:var(--forest-deep);
}
.wrap{max-width:var(--max); margin:0 auto; padding:0 32px;}

/* ---------- topo texture ---------- */
.topo-bg{position:fixed; inset:0; z-index:0; pointer-events:none; opacity:0.5;}

/* ---------- nav ---------- */
nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:18px 32px;
  background:rgba(239,232,216,0);
  border-bottom:1px solid rgba(35,38,30,0);
  transition:background 0.4s ease, border-color 0.4s ease, padding 0.4s ease;
}
nav.solid{
  background:rgba(239,232,216,0.94);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
  padding:12px 32px;
}
.nav-inner{
  max-width:var(--max); margin:0 auto; width:100%;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-family:'Fraunces', serif; font-weight:600; font-size:16.5px;
  color:var(--forest-deep); letter-spacing:0.01em; text-decoration:none;
}
.brand .compass-mark{width:26px; height:26px; flex-shrink:0;}
.nav-links{display:flex; align-items:center; gap:28px; font-size:14px;}
.nav-links a{text-decoration:none; color:var(--ink-soft); transition:color 0.2s ease;}
.nav-links a:hover{color:var(--clay);}
@media (max-width:800px){ .nav-links a:not(.btn){display:none;} }

.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'JetBrains Mono', monospace; font-size:12.5px;
  letter-spacing:0.06em; text-transform:uppercase; text-decoration:none;
  padding:10px 18px; border-radius:2px; border:1px solid var(--forest-deep);
  color:var(--forest-deep); background:transparent;
  transition:all 0.25s ease; cursor:pointer; font-weight:500;
}
.btn:hover{background:var(--forest-deep); color:var(--paper);}
.btn-solid{background:var(--forest-deep); color:var(--paper);}
.btn-solid:hover{background:var(--clay); border-color:var(--clay); color:var(--paper);}

/* ---------- hero ---------- */
.hero{
  position:relative; min-height:88vh; display:flex; flex-direction:column;
  justify-content:center; padding-top:100px; overflow:hidden;
}
.ridgeline{position:absolute; bottom:0; left:0; right:0; width:100%; z-index:1;}
.hero-content{position:relative; z-index:2; max-width:820px;}
.hero h1{
  font-size:clamp(2.6rem, 6.6vw, 5rem);
  line-height:1.04;
  margin-bottom:22px;
}
.hero-sub{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-weight:400;
  font-size:clamp(1.15rem, 2vw, 1.5rem);
  color:var(--ink-soft);
  max-width:36ch;
  margin-bottom:40px;
}
.hero-ctas{display:flex; gap:16px; flex-wrap:wrap;}

/* ---------- section base ---------- */
section{position:relative; z-index:2; padding:100px 0;}
section.tight{padding:72px 0;}
.section-head{max-width:640px; margin-bottom:48px;}
.section-head .eyebrow{margin-bottom:16px; display:block;}
.section-head h2{font-size:clamp(1.9rem, 3.4vw, 2.6rem); line-height:1.1;}
.section-head p{color:var(--ink-soft); margin-top:14px; font-size:16.5px; max-width:56ch;}

.reveal{opacity:0; transform:translateY(24px); transition:opacity 0.8s cubic-bezier(.2,.7,.2,1), transform 0.8s cubic-bezier(.2,.7,.2,1);}
.reveal.in-view{opacity:1; transform:translateY(0);}

/* ---------- our vision ---------- */
#vision{background:var(--paper-warm); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.vision-inner{max-width:680px;}
.vision-inner h2{font-size:clamp(1.9rem,3.6vw,2.6rem); margin-bottom:20px;}
.vision-inner p{color:var(--ink-soft); font-size:17.5px; margin-bottom:16px; max-width:58ch;}
.vision-founder{
  margin-top:28px; padding-top:24px; border-top:1px solid var(--line);
  font-size:15px; color:var(--ink-soft); max-width:58ch;
}

/* ---------- why panels ---------- */
#why .panels{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line);
}
.panel{background:var(--paper); padding:36px 30px;}
.panel .num{font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--clay); margin-bottom:16px; display:block;}
.panel h3{font-size:19px; margin-bottom:12px;}
.panel p{color:var(--ink-soft); font-size:15px;}
.panel.belief{background:var(--forest-deep); color:var(--paper); display:flex; flex-direction:column; justify-content:center;}
.panel.belief .num{color:var(--gold);}
.panel.belief blockquote{font-family:'Fraunces', serif; font-style:italic; font-size:21px; line-height:1.4; color:var(--paper);}
@media (max-width:820px){ #why .panels{grid-template-columns:1fr;} }

/* ---------- manifesto teaser (home) ---------- */
#manifesto-teaser{text-align:center;}
#manifesto-teaser .wrap{max-width:640px;}
#manifesto-teaser p.line{
  font-family:'Fraunces', serif; font-style:italic; font-weight:400;
  font-size:clamp(1.4rem,3vw,2rem); color:var(--forest-deep); line-height:1.4;
}
#manifesto-teaser a.discover{
  display:inline-block; margin-top:28px; font-size:13px;
  color:var(--clay); text-decoration:none; border-bottom:1px solid var(--clay);
  padding-bottom:2px; font-family:'JetBrains Mono', monospace; letter-spacing:0.04em;
}

/* ---------- compass method (vertical flow) ---------- */
#method{background:var(--forest-deep); color:var(--paper); text-align:center;}
#method .section-head{margin-left:auto; margin-right:auto;}
#method .section-head h2{color:var(--paper);}
#method .section-head p{color:rgba(239,232,216,0.7); margin-left:auto; margin-right:auto;}
.method-flow{max-width:520px; margin:0 auto;}
.method-step{padding:0 0 8px;}
.method-step h3{
  color:var(--paper); font-size:clamp(1.7rem,3.4vw,2.3rem); font-weight:500;
  margin-bottom:10px;
}
.method-step p{color:rgba(239,232,216,0.68); font-size:16px; max-width:38ch; margin:0 auto;}
.method-connector{
  width:1px; height:52px; margin:26px auto;
  background:linear-gradient(to bottom, rgba(239,232,216,0.4), rgba(239,232,216,0.05));
  position:relative;
}
.method-connector::after{
  content:''; position:absolute; bottom:-4px; left:50%; transform:translateX(-50%);
  width:7px; height:7px; border-right:1px solid var(--gold); border-bottom:1px solid var(--gold);
  transform:translateX(-50%) rotate(45deg);
}

/* ---------- journal ---------- */
#journal{background:var(--paper);}
.journal-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:26px;}
.essay-card{
  background:var(--paper-warm); border:1px solid var(--line); padding:30px 26px;
  display:flex; flex-direction:column; min-height:140px;
}
.essay-card .tag{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--gold); margin-bottom:16px;}
.essay-card h4{font-family:'Fraunces', serif; font-weight:500; font-size:18px; color:var(--forest-deep); line-height:1.32; margin-top:auto;}
@media (max-width:820px){ .journal-grid{grid-template-columns:1fr 1fr;} }
@media (max-width:560px){ .journal-grid{grid-template-columns:1fr;} }

/* ---------- field notes ---------- */
#fieldnotes{background:var(--paper-deep); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.fieldnotes-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.fn-card{background:var(--paper); padding:32px 26px;}
.fn-card .fn-icon{width:28px; height:28px; margin-bottom:20px; color:var(--forest);}
.fn-card h4{font-size:16.5px; margin-bottom:10px; color:var(--forest-deep); font-family:'Fraunces', serif; font-weight:500;}
.fn-card p{font-size:14px; color:var(--ink-soft);}
@media (max-width:900px){ .fieldnotes-grid{grid-template-columns:1fr 1fr;} }
@media (max-width:560px){ .fieldnotes-grid{grid-template-columns:1fr;} }

/* ---------- newsletter: Stay on Course ---------- */
#dispatch{background:var(--forest-deep); color:var(--paper);}
.dispatch-grid{display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;}
#dispatch h2{color:var(--paper); font-size:clamp(1.9rem,3.4vw,2.4rem); margin-bottom:14px;}
#dispatch .section-copy p{color:rgba(239,232,216,0.72); font-size:16px; max-width:46ch;}
form.signup{display:flex; flex-direction:column; gap:12px;}
.signup label{font-family:'JetBrains Mono', monospace; font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; color:rgba(239,232,216,0.7);}
.signup input[type=email]{
  padding:14px 16px; border:1px solid rgba(239,232,216,0.4); background:rgba(239,232,216,0.05);
  font-family:'Inter', sans-serif; font-size:15px; color:var(--paper); border-radius:2px;
}
.signup input[type=email]::placeholder{color:rgba(239,232,216,0.4);}
.signup input[type=email]:focus{outline:2px solid var(--gold); outline-offset:2px;}
.signup button{margin-top:6px; align-self:flex-start; border-color:var(--gold); color:var(--paper);}
.signup button:hover{background:var(--gold); border-color:var(--gold);}
.signup .fine{font-size:12.5px; color:rgba(239,232,216,0.55); margin-top:4px;}
@media (max-width:820px){ .dispatch-grid{grid-template-columns:1fr;} }

/* ---------- footer ---------- */
footer{background:var(--paper-deep); color:var(--ink-soft); padding:56px 0 28px; border-top:1px solid var(--line);}
.footer-statement{
  font-family:'Fraunces', serif; font-style:italic; font-weight:400;
  font-size:clamp(1.3rem,2.6vw,1.8rem); color:var(--forest-deep);
  max-width:20ch; line-height:1.35; margin-bottom:44px;
}
.footer-top{
  display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:32px;
  padding-bottom:36px; border-bottom:1px solid var(--line); margin-bottom:24px;
}
.footer-brand{display:flex; align-items:center; gap:12px; color:var(--forest-deep); font-family:'Fraunces', serif; font-size:17px; font-weight:600; text-decoration:none;}
.footer-brand .compass-mark{width:28px; height:28px;}
.footer-cols{display:flex; gap:56px; flex-wrap:wrap;}
.footer-col h5{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--clay); margin-bottom:14px;}
.footer-col a{display:block; text-decoration:none; color:var(--ink-soft); font-size:14px; margin-bottom:10px; transition:color 0.2s ease;}
.footer-col a:hover{color:var(--forest-deep);}
.footer-bottom{display:flex; justify-content:space-between; font-size:12.5px; color:var(--ink-soft); opacity:0.7; flex-wrap:wrap; gap:12px;}

/* ---------- generic page header (Start Here) ---------- */
.page-hero{padding:150px 0 60px;}
.page-hero h1{font-size:clamp(2.4rem,6vw,4rem); margin-bottom:22px;}
.page-hero .lede p{
  font-family:'Fraunces', serif; font-style:italic; font-size:19px; color:var(--ink-soft);
  max-width:34ch; line-height:1.5; margin-bottom:4px;
}
.page-section{padding:64px 0; border-top:1px solid var(--line);}
.page-section h2{font-size:clamp(1.5rem,2.6vw,2rem); margin-bottom:16px;}
.page-section p{color:var(--ink-soft); font-size:16.5px; max-width:62ch;}

/* ---------- WHY editorial page ---------- */
.why-nav{
  position:fixed; top:0; left:0; right:0; z-index:100; padding:26px 32px;
  display:flex; justify-content:space-between; align-items:center;
  mix-blend-mode:difference;
}
.why-nav a{text-decoration:none; color:#fff; font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:0.06em; text-transform:uppercase; opacity:0.75;}
.why-nav a:hover{opacity:1;}

.why-body{background:var(--forest-deep); color:var(--paper);}

.why-hero{
  min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:120px 32px 80px; position:relative; overflow:hidden;
}
.why-hero .scape{position:absolute; inset:0; z-index:0; opacity:0.9;}
.why-hero-content{position:relative; z-index:2;}
.why-hero .eyebrow{color:var(--gold); display:block; margin-bottom:26px;}
.why-hero h1{
  font-size:clamp(3rem, 9vw, 7.5rem); color:var(--paper); line-height:0.96; font-weight:600;
}

.statement-block{
  min-height:85vh; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:80px 32px; position:relative; overflow:hidden;
}
.statement-block .scape{position:absolute; inset:0; z-index:0;}
.statement-block .statement-content{position:relative; z-index:2; max-width:900px;}
.statement-block p{
  font-family:'Fraunces', serif; font-weight:400; font-style:italic;
  font-size:clamp(1.8rem, 4.6vw, 3.4rem); line-height:1.28; color:var(--paper);
}
.statement-block p.dim{color:rgba(239,232,216,0.45);}
.statement-block p.emph{color:var(--gold); font-style:normal; font-weight:500;}

.why-belief-block{
  min-height:56vh; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:48px 32px; border-top:1px solid rgba(239,232,216,0.08);
}
.why-belief-block p{
  font-family:'Fraunces', serif; font-style:italic; font-weight:400;
  font-size:clamp(1.6rem,4.4vw,2.6rem); line-height:1.32; max-width:16ch; color:var(--paper);
}
.why-belief-block.close-pair p{font-style:normal; color:rgba(239,232,216,0.6); font-size:clamp(1.3rem,3vw,1.9rem);}

.why-section{
  padding:130px 32px; border-top:1px solid rgba(239,232,216,0.1);
}
.why-section-inner{max-width:760px; margin:0 auto;}
.why-section .eyebrow{color:var(--gold); display:block; margin-bottom:22px;}
.why-section h2{
  color:var(--paper); font-size:clamp(2.2rem,5vw,3.6rem); line-height:1.08; margin-bottom:34px;
}
.why-section p{
  color:rgba(239,232,216,0.72); font-size:clamp(1.05rem,1.6vw,1.25rem); line-height:1.75; margin-bottom:20px; max-width:62ch;
}

.belief-words{
  display:flex; flex-wrap:wrap; gap:16px 40px; margin-top:36px;
}
.belief-words span{
  font-family:'Fraunces', serif; font-size:clamp(1.6rem,3vw,2.2rem); color:var(--paper); font-weight:500;
  position:relative; padding-bottom:8px;
}
.belief-words span::after{content:''; position:absolute; left:0; bottom:0; width:100%; height:1px; background:var(--gold); opacity:0.5;}

.why-final{
  min-height:80vh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:80px 32px; border-top:1px solid rgba(239,232,216,0.1);
}
.why-final p{font-family:'Fraunces', serif; font-weight:600; font-size:clamp(2rem,5.4vw,3.4rem); color:var(--gold); line-height:1.25;}
.why-final p + p{color:var(--paper); margin-top:6px;}
.why-final .btn{margin-top:48px;}

/* ---------- manifesto page ---------- */
.manifesto-nav{
  position:fixed; top:0; left:0; right:0; z-index:100; padding:26px 32px;
  display:flex; justify-content:space-between; align-items:center;
}
.manifesto-nav a{text-decoration:none; color:var(--paper); font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:0.06em; text-transform:uppercase; opacity:0.7;}
.manifesto-nav a:hover{opacity:1;}
.manifesto-body{background:var(--forest-deep); color:var(--paper);}
.belief-block{
  min-height:64vh; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:60px 32px; border-bottom:1px solid rgba(239,232,216,0.08);
}
.belief-block p{
  font-family:'Fraunces', serif; font-style:italic; font-weight:400;
  font-size:clamp(1.8rem,5vw,3.2rem); line-height:1.3; max-width:16ch; color:var(--paper);
}
.belief-block:nth-child(odd){background:rgba(239,232,216,0.02);}
.manifesto-close{
  min-height:70vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:60px 32px;
}
.manifesto-close p{font-family:'Fraunces', serif; font-weight:600; font-size:clamp(1.8rem,4.4vw,2.8rem); color:var(--gold); line-height:1.3;}
.manifesto-close p + p{color:var(--paper); margin-top:8px;}
.manifesto-close .btn{margin-top:40px;}
