/* ══════════════════════════════════════════════════════════
   Economic Democracy — Shared Stylesheet
   ══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;0,8..60,600;1,8..60,300;1,8..60,400&family=IBM+Plex+Mono:wght@400;500&display=swap');

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

/* ── Variables ── */
:root{
  --black:#0d0d0d;
  --ink:#1a1a1a;
  --charcoal:#2d2d2d;
  --mid:#5a5a5a;
  --muted:#8a8a8a;
  --rule:#d0ccc6;
  --paper:#f7f5f0;
  --cream:#efede7;
  --warm:#e8e4db;
  --white:#ffffff;
  --gold:#8a6f3e;
}

/* ── Base ── */
html{font-size:16px;scroll-behavior:smooth;}
body{
  font-family:'Source Serif 4',Georgia,serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}

/* ── Skip to Content (Accessibility) ── */
.skip-link{
  position:absolute;
  top:-100%;
  left:1rem;
  background:var(--black);
  color:var(--white);
  padding:.5rem 1rem;
  font-family:'IBM Plex Mono',monospace;
  font-size:.75rem;
  z-index:200;
  transition:top .15s;
}
.skip-link:focus{
  top:.5rem;
}

/* ══════════════════════════════════════════════════════════
   NAVIGATION
   ══════════════════════════════════════════════════════════ */

.site-nav{
  border-bottom:2px solid var(--black);
  padding:.75rem 0;
  position:sticky;
  top:0;
  background:var(--paper);
  z-index:100;
}
.nav-inner{
  max-width:1100px;
  margin:0 auto;
  padding:0 2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  flex-wrap:wrap;
}
.nav-home{
  font-family:'Playfair Display',serif;
  font-size:.95rem;
  font-weight:700;
  color:var(--black);
  white-space:nowrap;
  display:flex;
  flex-direction:column;
  gap:.05rem;
}
.nav-home span{
  font-family:'IBM Plex Mono',monospace;
  font-size:.58rem;
  color:var(--muted);
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:400;
}
.nav-links{
  display:flex;
  gap:1.5rem;
  flex-wrap:wrap;
  align-items:center;
}
.nav-links a{
  font-family:'IBM Plex Mono',monospace;
  font-size:.65rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--mid);
  transition:color .15s;
}
.nav-links a:hover{color:var(--black);}
.nav-links a.active{
  color:var(--black);
  border-bottom:1.5px solid var(--black);
}
.nav-cta{
  background:var(--black) !important;
  color:var(--white) !important;
  padding:.4rem .9rem;
  font-size:.62rem !important;
}
.nav-cta:hover{background:var(--charcoal) !important;}

/* ── Hamburger Toggle ── */
.nav-toggle{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  padding:.25rem;
  flex-direction:column;
  gap:4px;
}
.nav-toggle span{
  display:block;
  width:20px;
  height:2px;
  background:var(--black);
  transition:transform .2s, opacity .2s;
}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

@media(max-width:768px){
  .nav-toggle{display:flex;}
  .nav-links{
    display:none;
    flex-direction:column;
    width:100%;
    gap:0;
    border-top:1px solid var(--rule);
    padding-top:.75rem;
    margin-top:.5rem;
  }
  .nav-links.open{display:flex;}
  .nav-links a{
    padding:.6rem 0;
    font-size:.72rem;
    border-bottom:1px solid var(--rule);
    width:100%;
  }
  .nav-links a:last-child{border-bottom:none;}
  .nav-cta{
    margin-top:.5rem;
    text-align:center;
    display:block !important;
  }
}

/* ══════════════════════════════════════════════════════════
   PAGE WRAPPERS
   ══════════════════════════════════════════════════════════ */

.page{max-width:960px;margin:0 auto;padding:0 2rem 5rem;}
.page-wide{max-width:1100px;margin:0 auto;padding:0 2.5rem 5rem;}

/* ══════════════════════════════════════════════════════════
   SHARED TYPOGRAPHY
   ══════════════════════════════════════════════════════════ */

.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.75rem;
}
.display-title{
  font-family:'Playfair Display',serif;
  font-weight:900;
  color:var(--black);
  line-height:1.05;
  letter-spacing:-.02em;
}
.section-rule{border:none;border-top:1px solid var(--rule);margin:2.5rem 0;}

/* ══════════════════════════════════════════════════════════
   HERO (Inner Pages)
   ══════════════════════════════════════════════════════════ */

.hero{
  padding:3.5rem 0 2.5rem;
  border-bottom:3px solid var(--black);
  margin-bottom:2.5rem;
}
.hero-eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.75rem;
}
.hero-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,4vw,3rem);
  font-weight:900;
  color:var(--black);
  line-height:1.05;
  letter-spacing:-.02em;
  margin-bottom:.75rem;
}
.hero-sub{
  font-size:1rem;
  font-weight:300;
  color:var(--mid);
  max-width:580px;
  line-height:1.7;
}

/* ══════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════ */

.site-footer{
  border-top:2px solid var(--black);
  padding:1.5rem 2rem;
  max-width:1100px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:.5rem;
}
.footer-left{
  font-family:'Source Serif 4',serif;
  font-size:.8rem;
  color:var(--charcoal);
  font-weight:600;
}
.footer-right{
  font-family:'IBM Plex Mono',monospace;
  font-size:.65rem;
  color:var(--muted);
  letter-spacing:.05em;
}

/* ══════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════ */

.btn-primary{
  background:var(--black);
  color:var(--white);
  font-family:'IBM Plex Mono',monospace;
  font-size:.68rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:.75rem 1.5rem;
  display:inline-block;
  transition:background .15s;
}
.btn-primary:hover{background:var(--charcoal);}

.btn-secondary{
  font-family:'IBM Plex Mono',monospace;
  font-size:.68rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--mid);
  border-bottom:1px solid var(--rule);
  padding-bottom:.1rem;
  transition:color .15s,border-color .15s;
}
.btn-secondary:hover{color:var(--black);border-color:var(--black);}

/* ══════════════════════════════════════════════════════════
   BACK TO TOP
   ══════════════════════════════════════════════════════════ */

.back-to-top{
  position:fixed;
  bottom:2rem;
  right:2rem;
  background:var(--black);
  color:var(--white);
  width:2.5rem;
  height:2.5rem;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.1rem;
  cursor:pointer;
  border:none;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s;
  z-index:50;
}
.back-to-top.visible{
  opacity:1;
  pointer-events:auto;
}
.back-to-top:hover{background:var(--charcoal);}

/* ══════════════════════════════════════════════════════════
   PRINT
   ══════════════════════════════════════════════════════════ */

@media print{
  .site-nav,.back-to-top,.nav-toggle{display:none !important;}
  body{background:white;}
  .page,.page-wide{max-width:100%;padding:0;}
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE
   ══════════════════════════════════════════════════════════ */

@media(max-width:600px){
  .page{padding:0 1rem 3rem;}
  .page-wide{padding:0 1rem 3rem;}
  .site-footer{padding:1rem 1rem;flex-direction:column;align-items:flex-start;gap:.25rem;}
}
