/* ============================================
   ALXSIDR.COM - Ghost Theme Stylesheet
   Blueprint Aesthetic
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Libre+Franklin:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=IBM+Plex+Mono:wght@300;400;500&family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;1,9..144,400&display=swap');

:root {
  --navy-deep: #080e1a;
  --navy: #0c1a30;
  --navy-mid: #11253f;
  --navy-light: #183560;
  --blue: #4b8df8;
  --blue-glow: #6da3fa;
  --blue-pale: #a2c4fd;
  --cyan: #2fd4e8;
  --white: #f2f4fb;
  --white-dim: #d8dfed;
  --white-muted: #b0bbd0;
  --grid: rgba(75,141,248,0.04);
  --grid-s: rgba(75,141,248,0.08);
  --body: 'Libre Franklin', sans-serif;
  --mono: 'IBM Plex Mono', monospace;
  --display: 'Fraunces', serif;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
img { max-width: 100%; height: auto; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--body);
  background: var(--navy-deep);
  color: var(--white);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  font-weight: 300;
}

/* ---- Background ---- */
.bg-grid {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px),
    linear-gradient(var(--grid-s) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-s) 1px, transparent 1px);
  background-size: 24px 24px, 24px 24px, 120px 120px, 120px 120px;
}
.nodes { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.nd {
  position: absolute; width: 3px; height: 3px; background: var(--blue);
  border-radius: 50%; opacity: 0; animation: nf 14s infinite ease-in-out;
}
.nd::after {
  content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 14px; height: 14px;
  background: radial-gradient(circle, rgba(75,141,248,0.2), transparent 70%);
  border-radius: 50%;
}
@keyframes nf {
  0%,100% { opacity: 0; transform: translateY(0) scale(.5); }
  25% { opacity: .4; }
  50% { opacity: .7; transform: translateY(-30px) scale(1); }
  75% { opacity: .2; }
}
.scan {
  position: fixed; top: 0; left: 0; width: 100%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--blue), transparent);
  opacity: .08; z-index: 1; animation: sd 12s linear infinite; pointer-events: none;
}
@keyframes sd { 0% { top: -1px; } 100% { top: 100vh; } }
.content { position: relative; z-index: 2; }

/* ---- Navigation ---- */
.site-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: .9rem 3rem;
  display: flex; align-items: center; justify-content: space-between;
  backdrop-filter: blur(16px);
  background: rgba(8,14,26,.75);
  border-bottom: 1px solid rgba(75,141,248,.05);
  transition: .3s;
}
.nav-name { text-decoration: none; color: var(--white); font-size: 1rem; font-weight: 500; letter-spacing: .02em; }
.nav-name span { font-weight: 300; color: var(--blue-pale); margin-left: .25rem; }
.nav-links {
  display: flex; gap: 2.8rem; list-style: none;
  position: fixed; top: 0; right: 3rem; height: auto; z-index: 101;
  padding: .9rem 0; align-items: center;
}
.nav-links a {
  color: var(--white-muted); text-decoration: none; font-size: .7rem;
  font-weight: 400; letter-spacing: .08em; text-transform: uppercase; transition: .25s;
}
.nav-links a:hover { color: var(--white-dim); }

/* ---- Shared Components ---- */
.kicker {
  font-family: var(--mono); font-size: .62rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--blue); margin-bottom: 1rem; font-weight: 400;
}
.badge {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .35rem .9rem; border: 1px solid rgba(75,141,248,.15);
  border-radius: 2px; font-family: var(--mono); font-size: .6rem;
  letter-spacing: .1em; text-transform: uppercase; color: var(--blue-pale);
  background: rgba(75,141,248,.03);
}
.badge::before {
  content: ''; width: 5px; height: 5px; background: var(--blue);
  border-radius: 50%; animation: pulse 3s infinite;
}
@keyframes pulse {
  0%,100% { opacity: 1; box-shadow: 0 0 0 0 rgba(75,141,248,.3); }
  50% { opacity: .6; box-shadow: 0 0 0 5px rgba(75,141,248,0); }
}
.divider { height: 1px; max-width: 1100px; margin: 0 auto; background: rgba(75,141,248,.05); }

/* Buttons */
.btn-p {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .72rem 1.7rem; background: var(--blue); color: var(--navy-deep);
  font-family: var(--body); font-size: .8rem; font-weight: 600;
  border: none; border-radius: 3px; cursor: pointer; text-decoration: none;
  transition: .2s; letter-spacing: .01em;
}
.btn-p:hover { background: var(--blue-glow); box-shadow: 0 4px 20px rgba(75,141,248,.2); }
.btn-s {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .72rem 1.7rem; background: transparent; color: var(--white-dim);
  font-family: var(--body); font-size: .8rem; font-weight: 400;
  border: 1px solid rgba(255,255,255,.08); border-radius: 3px;
  cursor: pointer; text-decoration: none; transition: .2s;
}
.btn-s:hover { border-color: rgba(255,255,255,.2); color: var(--white); }
.btn-o {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .55rem 1.3rem; border: 1px solid rgba(75,141,248,.15);
  border-radius: 3px; color: var(--white-muted); font-family: var(--body);
  font-size: .75rem; font-weight: 400; text-decoration: none; transition: .2s;
}
.btn-o:hover { border-color: rgba(75,141,248,.3); color: var(--white-dim); }

/* Tags */
.tag { padding: .15rem .5rem; border: 1px solid rgba(75,141,248,.08); border-radius: 2px; font-family: var(--mono); font-size: .55rem; color: var(--white-muted); letter-spacing: .03em; }
.mt { display: inline-flex; align-items: center; padding: .12rem .4rem; border-radius: 2px; font-family: var(--mono); font-size: .5rem; letter-spacing: .06em; font-weight: 400; }
.mt.l2 { background: rgba(75,141,248,.06); color: #6da3fa; border: 1px solid rgba(75,141,248,.12); }
.mt.l3 { background: rgba(152,80,230,.06); color: #b07ce8; border: 1px solid rgba(152,80,230,.12); }
.mt.l4 { background: rgba(230,140,50,.06); color: #e8a050; border: 1px solid rgba(230,140,50,.12); }
.mt.l5 { background: rgba(47,212,232,.06); color: #2fd4e8; border: 1px solid rgba(47,212,232,.12); }

/* Reveal animation */
.reveal { opacity: 0; transform: translateY(20px); transition: .6s cubic-bezier(.25,.9,.35,1); }
.reveal.v { opacity: 1; transform: translateY(0); }
@keyframes fu { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

/* ---- Hero Section ---- */
.hero {
  min-height: 100vh; display: flex; align-items: center;
  padding: 9rem 3rem 5rem; position: relative; overflow: hidden;
}
.hero-inner {
  max-width: 1100px; margin: 0 auto; width: 100%;
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 5rem; align-items: center;
}
.hero .badge { animation: fu .7s ease-out; margin-bottom: 1.8rem; }
.hero h1 {
  font-family: var(--display); font-size: clamp(3.2rem, 5.8vw, 5.2rem);
  font-weight: 400; line-height: .97; letter-spacing: -.03em;
  margin-bottom: .8rem; animation: fu .7s ease-out .12s both;
}
.hero .tagline {
  font-family: var(--mono); font-size: .75rem; letter-spacing: .04em;
  color: var(--blue-pale); margin-bottom: .4rem;
  animation: fu .7s ease-out .22s both; font-weight: 300;
}
.hero-desc {
  font-size: .92rem; line-height: 1.75; color: var(--white-muted);
  max-width: 480px; margin-bottom: 2.8rem;
  animation: fu .7s ease-out .38s both; font-weight: 300;
}
.hero-cta-group { display: inline-flex; flex-direction: column; gap: .6rem; animation: fu .7s ease-out .48s both; }
.hero-ctas { display: flex; gap: .8rem; }
.btn-io {
  display: block; text-align: center;
  padding: .65rem 1.5rem;
  background: rgba(47,212,232,.08); color: var(--cyan);
  font-family: var(--mono); font-size: .7rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
  border: 1px solid rgba(47,212,232,.2); border-radius: 4px;
  transition: all .25s ease;
}
.btn-io:hover {
  background: rgba(47,212,232,.15); border-color: rgba(47,212,232,.4);
  box-shadow: 0 4px 20px rgba(47,212,232,.12); color: #fff;
}
.hero-schematic { animation: fu .7s ease-out .55s both; }

/* ---- Post Feed (index) ---- */
.post-feed {
  max-width: 1100px; margin: 0 auto; padding: 2rem 3rem 4rem;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
}
.post-card {
  background: rgba(12,26,48,.4); border: 1px solid rgba(75,141,248,.05);
  border-radius: 4px; padding: 1.8rem; transition: .25s;
  text-decoration: none; color: var(--white); display: block;
}
.post-card:hover { border-color: rgba(75,141,248,.12); background: rgba(12,26,48,.55); }
.post-card.latest { border-color: rgba(47,212,232,.12); background: rgba(47,212,232,.03); }
.post-card.latest:hover { border-color: rgba(47,212,232,.25); background: rgba(47,212,232,.06); }
.post-card .latest-badge {
  display: inline-block; font-family: var(--mono); font-size: .48rem; letter-spacing: .06em;
  color: var(--navy-deep); background: var(--cyan);
  padding: .1rem .4rem; border-radius: 2px; text-transform: uppercase; font-weight: 500;
  margin-bottom: .5rem;
}
.post-card .tag-row { display: flex; gap: .3rem; margin-bottom: .8rem; }
.post-card h2 {
  font-size: .92rem; font-weight: 500; margin-bottom: .4rem; letter-spacing: -.01em;
}
.post-card p {
  font-size: .78rem; line-height: 1.65; color: var(--white-muted);
  font-weight: 300; margin-bottom: .8rem;
}
.post-card .meta {
  font-family: var(--mono); font-size: .52rem; color: var(--white-muted);
  letter-spacing: .06em; font-weight: 300;
}

/* ---- Single Post ---- */
.post-header {
  max-width: 740px; margin: 0 auto; padding: 9rem 3rem 2rem; text-align: center;
}
.post-header .kicker { margin-bottom: .8rem; }
.post-header h1 {
  font-family: var(--display); font-size: clamp(1.8rem, 3vw, 2.8rem);
  font-weight: 400; line-height: 1.15; letter-spacing: -.02em; margin-bottom: 1rem;
}
.post-header .post-meta {
  font-family: var(--mono); font-size: .58rem; color: var(--white-muted);
  letter-spacing: .06em; font-weight: 300;
}
.post-content {
  max-width: 740px; margin: 0 auto; padding: 2rem 3rem 4rem;
  font-size: .92rem; line-height: 1.85; color: var(--white-dim); font-weight: 300;
}
.post-content h2 {
  font-family: var(--display); font-size: 1.5rem; font-weight: 400;
  margin: 2.5rem 0 1rem; letter-spacing: -.01em; color: var(--white);
}
.post-content h3 {
  font-size: 1.1rem; font-weight: 500; margin: 2rem 0 .8rem; color: var(--white);
}
.post-content p { margin-bottom: 1.3rem; }
.post-content a { color: var(--blue-pale); text-decoration: none; border-bottom: 1px solid rgba(75,141,248,.15); }
.post-content a:hover { color: var(--white); border-color: rgba(75,141,248,.3); }
.post-content code {
  font-family: var(--mono); font-size: .82rem; background: rgba(75,141,248,.05);
  padding: .12rem .35rem; border-radius: 2px; color: var(--blue-pale);
}
.post-content pre {
  background: rgba(12,26,48,.5); border: 1px solid rgba(75,141,248,.06);
  border-radius: 4px; padding: 1.2rem; overflow-x: auto; margin: 1.5rem 0;
}
.post-content pre code { background: none; padding: 0; font-size: .78rem; }
.post-content blockquote {
  border-left: 1px solid rgba(75,141,248,.15); padding-left: 1.2rem;
  margin: 1.5rem 0; color: var(--white-muted); font-style: italic;
}
.post-content img { max-width: 100%; height: auto; border-radius: 4px; margin: 1.5rem 0 0; }
.post-content figcaption {
  font-family: var(--mono); font-size: .65rem; letter-spacing: .03em;
  color: var(--white-muted); opacity: .6; text-align: center;
  margin-top: .35rem; margin-bottom: 1.5rem; font-weight: 300;
}
.post-content strong { color: var(--white); font-weight: 500; }

/* Ghost content width classes (required) */
.kg-width-wide { max-width: 1040px; margin-left: auto; margin-right: auto; }
.kg-width-full { max-width: none; margin-left: -3rem; margin-right: -3rem; }
.kg-width-full img { max-width: 100%; height: auto; }
.kg-card { margin: 1.5rem 0; }
.kg-image-card img { max-width: 100%; border-radius: 4px; }
.kg-gallery-card { margin: 1.5rem 0; }
.kg-bookmark-card { background: rgba(12,26,48,.4); border: 1px solid rgba(75,141,248,.06); border-radius: 4px; padding: 1.2rem; margin: 1.5rem 0; }
.kg-bookmark-title { font-size: .9rem; font-weight: 500; color: var(--white); margin-bottom: .3rem; }
.kg-bookmark-description { font-size: .78rem; color: var(--white-muted); font-weight: 300; }
.kg-bookmark-metadata { font-family: var(--mono); font-size: .55rem; color: var(--white-muted); margin-top: .5rem; }
.kg-embed-card { margin: 1.5rem 0; }
.kg-embed-card iframe { width: 100%; border-radius: 4px; }

/* ---- Page (About etc) ---- */
.page-header {
  max-width: 1100px; margin: 0 auto; padding: 9rem 3rem 3rem;
}
.page-header h1 {
  font-family: var(--display); font-size: clamp(2.4rem, 4vw, 3.6rem);
  font-weight: 400; line-height: 1; letter-spacing: -.03em; margin-bottom: .6rem;
}
.page-content {
  max-width: 1100px; margin: 0 auto; padding: 0 3rem 4rem;
}

/* ---- CTA / Subscribe ---- */
.cta {
  padding: 5rem 3rem 6rem; text-align: center;
  position: relative; overflow: hidden;
}
.cta-inner { max-width: 500px; margin: 0 auto; }
.cta h2 {
  font-family: var(--display); font-size: clamp(1.5rem, 2.3vw, 2rem);
  font-weight: 400; margin-bottom: .7rem; letter-spacing: -.01em;
}
.cta p {
  color: var(--white-muted); font-size: .85rem; margin-bottom: 2rem;
  font-weight: 300; line-height: 1.7;
}
.subscribe-form { max-width: 440px; margin: 0 auto; }
.subscribe-row {
  display: flex; gap: .5rem;
}
.subscribe-row input[type="email"] {
  flex: 1; padding: .7rem 1rem;
  background: rgba(12,26,48,.6); border: 1px solid rgba(75,141,248,.12);
  border-radius: 3px; color: var(--white); font-family: var(--body);
  font-size: .85rem; font-weight: 300; outline: none; transition: .2s;
}
.subscribe-row input[type="email"]::placeholder { color: var(--white-muted); }
.subscribe-row input[type="email"]:focus { border-color: rgba(75,141,248,.4); }
.subscribe-msg {
  font-size: .78rem; color: var(--white-muted); margin-top: .6rem; font-weight: 300;
  min-height: 1.2em;
}

/* ---- Footer ---- */
.site-footer {
  padding: 2rem 3rem; border-top: 1px solid rgba(75,141,248,.03);
}
.footer-inner {
  max-width: 1100px; margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center;
}
.footer-left { font-size: .7rem; color: var(--white-muted); font-weight: 300; }
.footer-links { display: flex; gap: 2rem; list-style: none; }
.footer-links a { color: var(--white-muted); text-decoration: none; font-size: .7rem; transition: .2s; font-weight: 300; }
.footer-links a:hover { color: var(--white-dim); }
.footer-right { font-family: var(--mono); font-size: .65rem; color: var(--white-muted); font-weight: 300; }

/* ---- Newsletter Strip (homepage) ---- */
.nl-strip { padding: 2.5rem 3rem; position: relative; overflow: hidden; }
.nl-strip::before {
  content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 600px; height: 200px; background: radial-gradient(ellipse, rgba(47,212,232,.03), transparent 70%);
  pointer-events: none;
}
.nl-strip-inner { max-width: 1100px; margin: 0 auto; }
.nl-strip-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.2rem; }
.nl-strip-left { display: flex; align-items: center; gap: .6rem; }
.nl-pulse {
  width: 6px; height: 6px; border-radius: 50%; background: var(--cyan);
  box-shadow: 0 0 8px rgba(47,212,232,.4); animation: nlPulse 2s ease-in-out infinite;
}
@keyframes nlPulse { 0%,100% { opacity:.6; } 50% { opacity:1; box-shadow: 0 0 12px rgba(47,212,232,.5); } }
.nl-strip-label {
  font-family: var(--mono); font-size: .62rem; letter-spacing: .08em;
  color: var(--cyan); text-transform: uppercase; font-weight: 400;
}
.nl-strip-link {
  font-family: var(--mono); font-size: .62rem; letter-spacing: .04em;
  color: var(--white-muted); text-decoration: none;
  border-bottom: 1px solid rgba(75,141,248,.1); padding-bottom: 1px; transition: color .2s, border-color .2s;
}
.nl-strip-link:hover { color: var(--blue-pale); border-color: rgba(75,141,248,.3); }

.nl-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.nl-card {
  position: relative; padding: 1.2rem 1.3rem;
  background: rgba(75,141,248,.025); border: 1px solid rgba(75,141,248,.08);
  border-radius: 8px; text-decoration: none; color: inherit;
  display: flex; flex-direction: column; transition: border-color .25s, background .25s, transform .2s;
}
.nl-card:hover { border-color: rgba(75,141,248,.2); background: rgba(75,141,248,.05); transform: translateY(-2px); }
.nl-card.latest { border-color: rgba(47,212,232,.15); background: rgba(47,212,232,.025); }
.nl-card.latest:hover { border-color: rgba(47,212,232,.3); background: rgba(47,212,232,.05); }

.nl-card-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: .5rem; }
.nl-card-num { font-family: var(--mono); font-size: .6rem; letter-spacing: .05em; color: var(--blue); font-weight: 500; }
.nl-card.latest .nl-card-num { color: var(--cyan); }
.nl-card-badge {
  font-family: var(--mono); font-size: .48rem; letter-spacing: .06em;
  color: var(--navy-deep); background: var(--cyan);
  padding: .12rem .4rem; border-radius: 2px; text-transform: uppercase; font-weight: 500;
}
.nl-card-title { font-family: var(--body); font-size: .82rem; font-weight: 400; color: var(--white-dim); line-height: 1.4; flex: 1; margin-bottom: .6rem; }
.nl-card-meta { display: flex; align-items: center; gap: .6rem; margin-top: auto; }
.nl-card-date { font-family: var(--mono); font-size: .56rem; color: var(--white-muted); letter-spacing: .03em; opacity: .7; }
.nl-card-tag {
  font-family: var(--mono); font-size: .52rem; letter-spacing: .04em;
  color: var(--blue-pale); padding: .12rem .4rem;
  border: 1px solid rgba(75,141,248,.12); border-radius: 3px; text-transform: uppercase;
}
.nl-card.latest .nl-card-tag { color: var(--cyan); border-color: rgba(47,212,232,.15); }

/* ---- Newsletter Page ---- */
.nl-page-header {
  max-width: 1100px; margin: 0 auto; padding: 9rem 3rem 3rem;
  display: grid; grid-template-columns: 1fr 380px; gap: 4rem; align-items: start;
}
.nl-page-left h1 {
  font-family: var(--display); font-size: clamp(2.2rem, 3.5vw, 3.2rem);
  font-weight: 400; line-height: 1.05; letter-spacing: -.02em; margin-bottom: 1rem;
}
.nl-page-desc {
  font-size: .92rem; line-height: 1.75; color: var(--white-muted);
  max-width: 520px; font-weight: 300; margin-bottom: 1.5rem;
}
.nl-stats { display: flex; gap: 2.5rem; }
.nl-stat-num { font-family: var(--display); font-size: 1.6rem; font-weight: 400; color: var(--white); margin-bottom: .15rem; }
.nl-stat-label { font-family: var(--mono); font-size: .55rem; letter-spacing: .08em; color: var(--white-muted); text-transform: uppercase; }

.nl-subscribe-panel {
  padding: 2rem 1.8rem; background: rgba(75,141,248,.03);
  border: 1px solid rgba(75,141,248,.12); border-radius: 10px;
  position: sticky; top: 5rem;
}
.nl-subscribe-title { font-family: var(--display); font-size: 1.15rem; font-weight: 400; margin-bottom: .6rem; line-height: 1.35; }
.nl-subscribe-desc { font-size: .8rem; line-height: 1.7; color: var(--white-muted); margin-bottom: 1.5rem; font-weight: 300; }

.nl-email-form { display: flex; flex-direction: column; gap: .6rem; margin-bottom: 1.2rem; }
.nl-email-form input[type="email"] {
  width: 100%; padding: .65rem .9rem;
  background: rgba(12,26,48,.6); border: 1px solid rgba(75,141,248,.12);
  border-radius: 4px; color: var(--white); font-family: var(--body); font-size: .82rem; font-weight: 300;
  outline: none; transition: border-color .2s;
}
.nl-email-form input[type="email"]::placeholder { color: var(--white-muted); opacity: .5; }
.nl-email-form input[type="email"]:focus { border-color: rgba(75,141,248,.4); }
.nl-email-form .btn-p { width: 100%; text-align: center; }

.nl-or-divider { display: flex; align-items: center; gap: .8rem; margin-bottom: 1.2rem; }
.nl-or-line { flex: 1; height: 1px; background: rgba(75,141,248,.08); }
.nl-or-text { font-family: var(--mono); font-size: .58rem; letter-spacing: .06em; color: var(--white-muted); opacity: .5; text-transform: uppercase; }

.nl-linkedin {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  width: 100%; padding: .6rem 1rem;
  border: 1px solid rgba(75,141,248,.12); border-radius: 4px;
  text-decoration: none; color: var(--white-dim);
  font-family: var(--mono); font-size: .68rem; letter-spacing: .03em;
  background: transparent; cursor: pointer; transition: border-color .2s, background .2s;
}
.nl-linkedin:hover { border-color: rgba(75,141,248,.25); background: rgba(75,141,248,.04); }
.nl-linkedin svg { width: 14px; height: 14px; fill: var(--blue-pale); opacity: .7; flex-shrink: 0; }
.nl-frequency { font-family: var(--mono); font-size: .55rem; color: var(--white-muted); opacity: .5; text-align: center; margin-top: 1rem; letter-spacing: .03em; }
.nl-subscribe-msg { font-size: .78rem; color: var(--white-muted); margin-top: .6rem; font-weight: 300; min-height: 1.2em; text-align: center; }

.nl-issues-section {
  max-width: 1100px; margin: 0 auto; padding: 3rem 3rem 5rem;
  display: grid; grid-template-columns: 1fr 380px; gap: 4rem; align-items: start;
}
.nl-year-group { margin-bottom: 2.5rem; }
.nl-year-label {
  font-family: var(--mono); font-size: .6rem; letter-spacing: .1em;
  color: var(--white-muted); text-transform: uppercase; margin-bottom: 1rem;
  padding-bottom: .4rem; border-bottom: 1px solid rgba(75,141,248,.06);
}

.nl-issue {
  display: grid; grid-template-columns: 3rem 1fr auto; gap: 1rem; align-items: start;
  padding: 1rem .6rem; border-bottom: 1px solid rgba(75,141,248,.04);
  text-decoration: none; color: inherit; transition: background .2s; border-radius: 4px;
}
.nl-issue:hover { background: rgba(75,141,248,.03); }
.nl-issue:last-child { border-bottom: none; }
.nl-issue-num { font-family: var(--mono); font-size: .62rem; letter-spacing: .04em; color: var(--blue); font-weight: 500; padding-top: .15rem; }
.nl-issue-title { font-size: .9rem; font-weight: 400; color: var(--white-dim); line-height: 1.4; margin-bottom: .35rem; transition: color .2s; }
.nl-issue:hover .nl-issue-title { color: var(--white); }
.nl-issue-excerpt { font-size: .76rem; color: var(--white-muted); font-weight: 300; line-height: 1.6; margin-bottom: .45rem; }
.nl-issue-tags { display: flex; gap: .4rem; flex-wrap: wrap; }
.nl-issue-tag {
  font-family: var(--mono); font-size: .5rem; letter-spacing: .04em;
  color: var(--blue-pale); padding: .12rem .4rem;
  border: 1px solid rgba(75,141,248,.1); border-radius: 3px; text-transform: uppercase;
}
.nl-issue-right { text-align: right; padding-top: .15rem; }
.nl-issue-date { font-family: var(--mono); font-size: .58rem; color: var(--white-muted); letter-spacing: .03em; opacity: .7; white-space: nowrap; }

.nl-issue.latest {
  background: rgba(47,212,232,.02); border: 1px solid rgba(47,212,232,.1);
  border-radius: 8px; padding: 1.2rem 1rem; margin-bottom: .5rem;
}
.nl-issue.latest .nl-issue-num { color: var(--cyan); }
.nl-issue.latest .nl-issue-tag { color: var(--cyan); border-color: rgba(47,212,232,.15); }
.nl-latest-badge {
  display: inline-block; font-family: var(--mono); font-size: .48rem; letter-spacing: .06em;
  color: var(--navy-deep); background: var(--cyan);
  padding: .1rem .4rem; border-radius: 2px; text-transform: uppercase; font-weight: 500;
  margin-bottom: .4rem;
}

.nl-sidebar { position: sticky; top: 5rem; }
.nl-topics-card {
  padding: 1.5rem 1.4rem; background: rgba(75,141,248,.025);
  border: 1px solid rgba(75,141,248,.08); border-radius: 8px;
}
.nl-topics-title { font-family: var(--mono); font-size: .6rem; letter-spacing: .08em; color: var(--blue); text-transform: uppercase; margin-bottom: 1rem; }
.nl-topic-item { display: flex; align-items: center; justify-content: space-between; padding: .4rem 0; border-bottom: 1px solid rgba(75,141,248,.04); }
.nl-topic-item:last-child { border-bottom: none; }
.nl-topic-name { font-size: .78rem; color: var(--white-dim); font-weight: 300; }
.nl-topic-count { font-family: var(--mono); font-size: .58rem; color: var(--white-muted); opacity: .6; }

/* ---- Orchestration Maturity Spectrum ---- */
.spectrum { padding: 5rem 3rem; }
.spectrum-inner { max-width: 1100px; margin: 0 auto; }
.spectrum-h {
  font-family: var(--display); font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 400; margin-bottom: .6rem; letter-spacing: -.01em;
}
.spectrum-desc {
  font-size: .88rem; color: var(--white-muted); font-weight: 300;
  line-height: 1.7; max-width: 600px; margin-bottom: 3rem;
}
.spectrum-track {
  position: relative;
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.2rem;
  padding-top: 2rem;
}
.spectrum-line {
  position: absolute; top: 2.35rem; left: 2rem; right: 2rem;
  height: 1px;
  background: linear-gradient(90deg, #4ade80, #6da3fa, #b07ce8, #e8a050, #2fd4e8);
  opacity: .2;
}
.spectrum-level { text-align: center; position: relative; }
.spectrum-dot {
  width: 14px; height: 14px; border-radius: 50%;
  margin: 0 auto .8rem; position: relative; z-index: 1;
}
.sl1 { background: rgba(74,222,128,.2); border: 1px solid rgba(74,222,128,.4); }
.sl2 { background: rgba(109,163,250,.2); border: 1px solid rgba(109,163,250,.4); }
.sl3 { background: rgba(176,124,232,.2); border: 1px solid rgba(176,124,232,.4); }
.sl4 { background: rgba(232,160,80,.2); border: 1px solid rgba(232,160,80,.4); }
.sl5 { background: rgba(47,212,232,.2); border: 1px solid rgba(47,212,232,.4); }
.spectrum-label {
  font-family: var(--mono); font-size: .5rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--white-muted); margin-bottom: .3rem;
}
.spectrum-name {
  font-size: .85rem; font-weight: 500; color: var(--white); margin-bottom: .4rem;
}
.spectrum-detail {
  font-size: .7rem; color: var(--white-muted); font-weight: 300;
  line-height: 1.6;
}
.spectrum-cta { margin-top: 2.5rem; text-align: center; }

/* ---- Modal ---- */
.modal-overlay {
  display: none; position: fixed; inset: 0; z-index: 200;
  background: rgba(8,14,26,.85); backdrop-filter: blur(8px);
  align-items: center; justify-content: center;
}
.modal-overlay.open { display: flex; }
.modal-box {
  background: var(--navy); border: 1px solid rgba(75,141,248,.1);
  border-radius: 6px; padding: 2.5rem; width: 90%; max-width: 440px;
  position: relative;
}
.modal-close {
  position: absolute; top: 1rem; right: 1.2rem;
  background: none; border: none; color: var(--white-muted);
  font-size: 1.5rem; cursor: pointer; line-height: 1; transition: .2s;
}
.modal-close:hover { color: var(--white); }
.modal-title {
  font-family: var(--display); font-size: 1.3rem; font-weight: 400;
  margin-bottom: .4rem; letter-spacing: -.01em;
}
.modal-desc {
  font-size: .78rem; color: var(--white-muted); font-weight: 300;
  line-height: 1.5; margin-bottom: 1.5rem;
}
.modal-form input {
  width: 100%; padding: .7rem 1rem; margin-bottom: .6rem;
  background: rgba(12,26,48,.6); border: 1px solid rgba(75,141,248,.1);
  border-radius: 3px; color: var(--white); font-family: var(--body);
  font-size: .8rem; font-weight: 300; outline: none; transition: .2s;
}
.modal-form input::placeholder { color: var(--white-muted); }
.modal-form input:focus { border-color: rgba(75,141,248,.3); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; }
.form-row input { margin-bottom: 0; }
.modal-form .btn-p { margin-top: .4rem; }

/* ---- TOMS Spectrum Page ---- */
.toms { --l1:#3dd68c;--l1-bg:rgba(61,214,140,0.07);--l1-border:rgba(61,214,140,0.20);--l2:#388bfd;--l2-bg:rgba(56,139,253,0.07);--l2-border:rgba(56,139,253,0.22);--l3:#a78bfa;--l3-bg:rgba(167,139,250,0.07);--l3-border:rgba(167,139,250,0.22);--l4:#f4a333;--l4-bg:rgba(244,163,51,0.07);--l4-border:rgba(244,163,51,0.22);--l5:#39d0d8;--l5-bg:rgba(57,208,216,0.07);--l5-border:rgba(57,208,216,0.22);--dim:#2a3f58;--navy-card:#0f1c30; }

.toms-masthead { max-width:1100px;margin:0 auto;padding:9rem 3rem 2.5rem;border-bottom:1px solid rgba(75,141,248,.06); }
.toms-eyebrow { font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--l2);margin-bottom:14px;display:flex;align-items:center;gap:10px; }
.toms-eyebrow::before { content:'';display:block;width:20px;height:1px;background:var(--l2);opacity:.5; }
.toms-tagline { margin-top:14px;font-size:14px;color:#566880;font-weight:300;max-width:560px;line-height:1.7; }

/* TOMS Intro (SEO) */
.toms-intro {
  max-width: 1100px; margin: 0 auto; padding: 7rem 3rem 0;
}
.toms-definition {
  font-size: 1.05rem; line-height: 1.75; color: var(--white-dim); margin-bottom: 1rem;
}
.toms-definition strong { color: var(--white); }
.toms-intro-text {
  font-size: .88rem; font-weight: 300; color: var(--white-muted); line-height: 1.8; margin-bottom: .75rem;
}
.toms-intro-text a { color: var(--blue-pale); text-decoration: none; border-bottom: 1px solid rgba(75,141,248,.15); }
.toms-intro-text a:hover { color: var(--blue-glow); }

/* TOMS Assessment */
.toms-assessment {
  max-width: 640px; margin: 3rem auto; padding: 2.5rem;
  border: 1px solid rgba(75,141,248,.1); border-radius: 6px;
  background: rgba(75,141,248,.02);
}
.assess-q-label {
  font-family: var(--display); font-size: 1.05rem; font-weight: 400;
  color: var(--white); margin-bottom: 1.25rem; text-align: center;
}
.assess-options { display: flex; flex-direction: column; gap: .5rem; }
.assess-opt {
  display: block; width: 100%; text-align: left;
  font-family: var(--body); font-size: .82rem; font-weight: 300; color: var(--white-muted);
  background: rgba(75,141,248,.03); border: 1px solid rgba(75,141,248,.08);
  border-radius: 4px; padding: .75rem 1rem; cursor: pointer; transition: all .2s;
}
.assess-opt:hover { border-color: rgba(75,141,248,.25); color: var(--white-dim); background: rgba(75,141,248,.06); }
.assess-opt.selected { border-color: var(--blue); color: var(--white); background: rgba(75,141,248,.1); }
.assess-result { text-align: center; padding: 1rem 0; }
.assess-result-level { font-family: var(--mono); font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--blue); margin-bottom: .5rem; }
.assess-result-name { font-family: var(--display); font-size: 1.8rem; font-weight: 400; color: var(--white); margin-bottom: .75rem; }
.assess-result-desc { font-size: .88rem; font-weight: 300; color: var(--white-muted); line-height: 1.7; max-width: 480px; margin: 0 auto; }

/* TOMS Summary Table */
.toms-table-wrap {
  max-width: 1100px; margin: 2rem auto; padding: 0 3rem;
}
.toms-summary-table {
  width: 100%; border-collapse: collapse; font-size: .78rem;
}
.toms-summary-table th {
  font-family: var(--mono); font-size: .6rem; font-weight: 500; letter-spacing: .12em;
  text-transform: uppercase; color: var(--blue); text-align: left;
  padding: .7rem .75rem; border-bottom: 1px solid rgba(75,141,248,.15);
}
.toms-summary-table td {
  font-weight: 300; color: var(--white-muted); padding: .6rem .75rem;
  border-bottom: 1px solid rgba(75,141,248,.04);
}
.toms-summary-table tr:hover td { color: var(--white-dim); }

/* Level Transition Guide */
.level-transition {
  margin-top: 1.5rem; padding: 1rem 1.25rem;
  border-left: 2px solid var(--blue); background: rgba(75,141,248,.03);
  font-size: .82rem; font-weight: 300; color: var(--white-muted); line-height: 1.7;
}
.level-transition strong { color: var(--blue-pale); font-weight: 500; }
.level-transition a { color: var(--blue-pale); text-decoration: none; }

/* TOMS FAQ */
.toms-faq {
  max-width: 1100px; margin: 0 auto; padding: 3rem 3rem 2rem;
  border-top: 1px solid rgba(75,141,248,.06);
}
.faq-item { margin-bottom: 1.5rem; }
.faq-item h3 {
  font-family: var(--body); font-size: .92rem; font-weight: 500;
  color: var(--white-dim); margin-bottom: .5rem;
}
.faq-item p {
  font-size: .85rem; font-weight: 300; color: var(--white-muted); line-height: 1.75;
}
.faq-item a { color: var(--blue-pale); text-decoration: none; border-bottom: 1px solid rgba(75,141,248,.15); }
.faq-item a:hover { color: var(--blue-glow); }

.level-nav { max-width:1100px;margin:0 auto;padding:2rem 3rem;display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1rem; }
.lnav-pill { font-family:var(--mono);font-size:9px;letter-spacing:.12em;padding:5px 12px;border-radius:2px;border:1px solid;cursor:pointer;transition:opacity .2s;text-decoration:none; }
.lnav-pill:hover { opacity:.75; }
.lnav-1{color:var(--l1);border-color:var(--l1-border);background:var(--l1-bg);}
.lnav-2{color:var(--l2);border-color:var(--l2-border);background:var(--l2-bg);}
.lnav-3{color:var(--l3);border-color:var(--l3-border);background:var(--l3-bg);}
.lnav-4{color:var(--l4);border-color:var(--l4-border);background:var(--l4-bg);}
.lnav-5{color:var(--l5);border-color:var(--l5-border);background:var(--l5-bg);}

.spine-row { max-width:1100px;margin:0 auto;padding:0 3rem;display:flex;align-items:center;gap:12px;margin-bottom:3.5rem; }
.spine-seg { flex:1;height:2px;border-radius:1px;position:relative; }
.spine-seg::after { content:attr(data-label);position:absolute;top:8px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:8px;letter-spacing:.1em;white-space:nowrap;color:var(--dim); }
.spine-dot { width:10px;height:10px;border-radius:50%;flex-shrink:0;border:2px solid #0c1526; }

.toms-levels { max-width:1100px;margin:0 auto;padding:0 3rem; }
.level-section { margin-bottom:4rem; }
.level-header { display:flex;align-items:center;gap:20px;margin-bottom:20px; }
.level-num { font-family:var(--display);font-size:64px;font-weight:700;line-height:1;letter-spacing:-.04em;opacity:.12;flex-shrink:0; }
.level-badge { font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;padding:3px 10px;border-radius:2px;border:1px solid;display:inline-block;margin-bottom:8px; }
.level-name { font-family:var(--display);font-size:26px;font-weight:600;line-height:1.1;letter-spacing:-.01em; }
.level-sub { font-size:12px;color:#566880;margin-top:4px;font-weight:300;font-style:italic; }

.level-body { border:1px solid;border-radius:6px;overflow:hidden; }
.level-desc { padding:20px 24px;border-bottom:1px solid;font-size:13px;line-height:1.75;color:#566880;font-weight:300; }
.level-desc strong { color:var(--white-dim);font-weight:400; }

.level-grid { display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid; }
.level-grid-item { padding:18px 20px;border-right:1px solid; }
.level-grid-item:last-child { border-right:none; }
.grid-label { font-family:var(--mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-bottom:8px; }
.grid-value { font-size:12px;color:var(--white-dim);font-weight:400;line-height:1.5; }

.level-usecase { display:grid;grid-template-columns:180px 1fr; }
.usecase-label { padding:20px;border-right:1px solid;display:flex;flex-direction:column;justify-content:center;gap:6px; }
.usecase-tag { font-family:var(--mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim); }
.usecase-title { font-size:11px;font-weight:600;line-height:1.4; }
.usecase-pills { padding:16px 20px;display:flex;flex-wrap:wrap;gap:7px;align-items:center; }
.uc-pill { font-family:var(--mono);font-size:9px;padding:4px 10px;border-radius:2px;border:1px solid rgba(75,141,248,.1);color:#566880;background:var(--navy-card);letter-spacing:.05em; }

.level-signals { display:grid;grid-template-columns:180px 1fr;border-top:1px solid; }
.signals-content { padding:16px 20px;display:flex;flex-wrap:wrap;gap:7px;align-items:center; }
.sig-pill { font-size:10px;padding:3px 10px;border-radius:2px;border:1px solid;letter-spacing:.02em;font-family:var(--mono); }

.level-ct { display:grid;grid-template-columns:180px 1fr;border-top:1px solid; }
.ct-content { padding:16px 20px;font-size:12px;color:#566880;font-weight:300;line-height:1.65; }
.ct-content strong { color:var(--white-dim);font-weight:400; }

.automation-bar { margin-top:12px;display:flex;align-items:center;gap:10px;padding:0 24px 20px; }
.abar-label { font-family:var(--mono);font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);flex-shrink:0;width:120px; }
.abar-track { flex:1;height:3px;background:rgba(75,141,248,.1);border-radius:2px;overflow:visible;position:relative; }
.abar-fill { height:100%;border-radius:2px;position:relative; }
.abar-fill::after { content:'';position:absolute;right:-1px;top:-3px;width:9px;height:9px;border-radius:50%;border:2px solid #0c1526; }
.abar-pct { font-family:var(--mono);font-size:9px;color:#566880;flex-shrink:0;width:34px;text-align:right; }

/* TOMS level color themes */
.l1-theme .level-num{color:var(--l1)}.l1-theme .level-badge{color:var(--l1);border-color:var(--l1-border);background:var(--l1-bg)}.l1-theme .level-name{color:var(--l1)}.l1-theme .level-body{border-color:var(--l1-border)}.l1-theme .level-desc{border-color:var(--l1-border);background:rgba(61,214,140,.02)}.l1-theme .level-grid{border-color:var(--l1-border)}.l1-theme .level-grid-item{border-color:var(--l1-border)}.l1-theme .level-usecase{border-color:var(--l1-border)}.l1-theme .usecase-label{border-color:var(--l1-border)}.l1-theme .level-signals{border-color:var(--l1-border)}.l1-theme .level-ct{border-color:var(--l1-border)}.l1-theme .usecase-title{color:var(--l1)}.l1-theme .abar-fill{background:var(--l1)}.l1-theme .abar-fill::after{background:var(--l1)}.l1-theme .sig-pill{color:var(--l1);border-color:var(--l1-border);background:var(--l1-bg)}
.l2-theme .level-num{color:var(--l2)}.l2-theme .level-badge{color:var(--l2);border-color:var(--l2-border);background:var(--l2-bg)}.l2-theme .level-name{color:var(--l2)}.l2-theme .level-body{border-color:var(--l2-border)}.l2-theme .level-desc{border-color:var(--l2-border);background:rgba(56,139,253,.02)}.l2-theme .level-grid{border-color:var(--l2-border)}.l2-theme .level-grid-item{border-color:var(--l2-border)}.l2-theme .level-usecase{border-color:var(--l2-border)}.l2-theme .usecase-label{border-color:var(--l2-border)}.l2-theme .level-signals{border-color:var(--l2-border)}.l2-theme .level-ct{border-color:var(--l2-border)}.l2-theme .usecase-title{color:var(--l2)}.l2-theme .abar-fill{background:var(--l2)}.l2-theme .abar-fill::after{background:var(--l2)}.l2-theme .sig-pill{color:var(--l2);border-color:var(--l2-border);background:var(--l2-bg)}
.l3-theme .level-num{color:var(--l3)}.l3-theme .level-badge{color:var(--l3);border-color:var(--l3-border);background:var(--l3-bg)}.l3-theme .level-name{color:var(--l3)}.l3-theme .level-body{border-color:var(--l3-border)}.l3-theme .level-desc{border-color:var(--l3-border);background:rgba(167,139,250,.02)}.l3-theme .level-grid{border-color:var(--l3-border)}.l3-theme .level-grid-item{border-color:var(--l3-border)}.l3-theme .level-usecase{border-color:var(--l3-border)}.l3-theme .usecase-label{border-color:var(--l3-border)}.l3-theme .level-signals{border-color:var(--l3-border)}.l3-theme .level-ct{border-color:var(--l3-border)}.l3-theme .usecase-title{color:var(--l3)}.l3-theme .abar-fill{background:var(--l3)}.l3-theme .abar-fill::after{background:var(--l3)}.l3-theme .sig-pill{color:var(--l3);border-color:var(--l3-border);background:var(--l3-bg)}
.l4-theme .level-num{color:var(--l4)}.l4-theme .level-badge{color:var(--l4);border-color:var(--l4-border);background:var(--l4-bg)}.l4-theme .level-name{color:var(--l4)}.l4-theme .level-body{border-color:var(--l4-border)}.l4-theme .level-desc{border-color:var(--l4-border);background:rgba(244,163,51,.02)}.l4-theme .level-grid{border-color:var(--l4-border)}.l4-theme .level-grid-item{border-color:var(--l4-border)}.l4-theme .level-usecase{border-color:var(--l4-border)}.l4-theme .usecase-label{border-color:var(--l4-border)}.l4-theme .level-signals{border-color:var(--l4-border)}.l4-theme .level-ct{border-color:var(--l4-border)}.l4-theme .usecase-title{color:var(--l4)}.l4-theme .abar-fill{background:var(--l4)}.l4-theme .abar-fill::after{background:var(--l4)}.l4-theme .sig-pill{color:var(--l4);border-color:var(--l4-border);background:var(--l4-bg)}
.l5-theme .level-num{color:var(--l5)}.l5-theme .level-badge{color:var(--l5);border-color:var(--l5-border);background:var(--l5-bg)}.l5-theme .level-name{color:var(--l5)}.l5-theme .level-body{border-color:var(--l5-border)}.l5-theme .level-desc{border-color:var(--l5-border);background:rgba(57,208,216,.02)}.l5-theme .level-grid{border-color:var(--l5-border)}.l5-theme .level-grid-item{border-color:var(--l5-border)}.l5-theme .level-usecase{border-color:var(--l5-border)}.l5-theme .usecase-label{border-color:var(--l5-border)}.l5-theme .level-signals{border-color:var(--l5-border)}.l5-theme .level-ct{border-color:var(--l5-border)}.l5-theme .usecase-title{color:var(--l5)}.l5-theme .abar-fill{background:var(--l5)}.l5-theme .abar-fill::after{background:var(--l5)}.l5-theme .sig-pill{color:var(--l5);border-color:var(--l5-border);background:var(--l5-bg)}

/* ---- GitHub Request Box ---- */
.github-request {
  max-width: 740px; margin: 3rem auto 0; padding: 0 3rem;
}
.github-request-inner {
  display: flex; align-items: center; gap: 1.5rem;
  padding: 1.5rem 2rem;
  background: rgba(12,26,48,.4); border: 1px solid rgba(75,141,248,.08);
  border-radius: 4px;
}
.github-icon { flex-shrink: 0; }
.github-request-title {
  font-size: .88rem; font-weight: 500; color: var(--white); margin-bottom: .2rem;
}
.github-request-desc {
  font-size: .75rem; color: var(--white-muted); font-weight: 300; line-height: 1.5; margin: 0;
}
.github-request-btn { flex-shrink: 0; white-space: nowrap; }

/* ---- Hamburger Toggle ---- */
body.nav-open { overflow: hidden; }
.nav-toggle {
  display: none;
  background: none; border: none; cursor: pointer;
  width: 28px; height: 20px; position: relative; z-index: 160;
}
.nav-toggle span {
  display: block; width: 100%; height: 1px; background: var(--white-dim);
  position: absolute; left: 0; transition: .25s;
}
.nav-toggle span:nth-child(1) { top: 0; }
.nav-toggle span:nth-child(2) { top: 9px; }
.nav-toggle span:nth-child(3) { top: 18px; }
.nav-toggle.open span:nth-child(1) { top: 9px; transform: rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { top: 9px; transform: rotate(-45deg); }

/* ---- About Page ---- */
.about-hero { padding: 9rem 3rem 4rem; position: relative; overflow: hidden; }
.about-hero-inner { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 280px; gap: 5rem; align-items: start; }
.about-headshot { width: 180px; height: 180px; object-fit: cover; border-radius: 50%; border: 1px solid rgba(75,141,248,.12); margin-bottom: 1.5rem; opacity: .9; }
.about-name { font-family: var(--display); font-size: clamp(2.4rem, 4vw, 3.6rem); font-weight: 400; line-height: 1; letter-spacing: -.03em; margin-bottom: .6rem; }
.about-role { font-family: var(--mono); font-size: .72rem; color: var(--blue-pale); letter-spacing: .04em; font-weight: 300; margin-bottom: .3rem; }
.about-mission { font-family: var(--mono); font-size: .65rem; color: var(--white-muted); letter-spacing: .04em; font-weight: 300; margin-bottom: 2rem; }
.about-lead { font-size: 1.02rem; line-height: 1.85; color: var(--white-dim); font-weight: 300; max-width: 580px; }
.about-lead strong { color: var(--white); font-weight: 500; }

.about-sidebar { background: rgba(12,26,48,.4); border: 1px solid rgba(75,141,248,.04); border-radius: 4px; padding: 1.8rem; position: sticky; top: 6rem; }
.sidebar-title { font-family: var(--mono); font-size: .55rem; letter-spacing: .14em; text-transform: uppercase; color: var(--blue); margin-bottom: 1rem; font-weight: 400; }
.sidebar-label { font-family: var(--mono); font-size: .52rem; color: var(--white-muted); letter-spacing: .1em; text-transform: uppercase; margin-top: 1.2rem; margin-bottom: .4rem; font-weight: 400; opacity: .6; }
.sidebar-label:first-of-type { margin-top: .4rem; }
.sidebar-val { font-size: .78rem; color: var(--white-dim); font-weight: 300; line-height: 1.5; }
.sidebar-sub { font-size: .68rem; color: var(--white-muted); font-weight: 300; }
.lang-row { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .6rem; }
.lang-tag { font-size: .68rem; color: var(--white-muted); font-weight: 300; padding: .2rem .5rem; border: 1px solid rgba(75,141,248,.04); border-radius: 2px; }
.sidebar-cta { margin-top: 1.5rem; }

.about-thesis { padding: 5rem 3rem; position: relative; overflow: hidden; }
.about-thesis-inner { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.about-thesis-h { font-family: var(--display); font-size: clamp(1.6rem, 2.5vw, 2.2rem); font-weight: 400; line-height: 1.15; margin-bottom: 1.2rem; letter-spacing: -.01em; }
.about-thesis-h em { font-style: italic; color: var(--blue-pale); }
.about-thesis-text { font-size: .88rem; line-height: 1.85; color: var(--white-muted); font-weight: 300; }
.about-thesis-text p { margin-bottom: 1.3rem; }

.about-skills { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.skill-box { padding: 1.4rem; background: rgba(12,26,48,.4); border: 1px solid rgba(75,141,248,.04); border-radius: 4px; }
.skill-title { font-family: var(--mono); font-size: .55rem; letter-spacing: .14em; text-transform: uppercase; color: var(--blue); margin-bottom: .8rem; font-weight: 400; }
.skill-box ul { list-style: none; padding: 0; }
.skill-box li { font-size: .76rem; color: var(--white-muted); padding: .22rem 0; font-weight: 300; }
.skill-box li::before { content: '- '; opacity: .3; }

.about-track { padding: 5rem 3rem; position: relative; }
.about-track-inner { max-width: 1100px; margin: 0 auto; }
.about-track-h { font-family: var(--display); font-size: clamp(1.6rem, 2.5vw, 2.2rem); font-weight: 400; margin-bottom: 2.5rem; letter-spacing: -.01em; }

.impact-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; margin-bottom: 4rem; }
.impact-item { padding: 1.4rem; background: rgba(12,26,48,.35); border: 1px solid rgba(75,141,248,.04); border-radius: 4px; }
.impact-num { font-family: var(--display); font-size: 2rem; font-weight: 400; color: var(--white); line-height: 1; margin-bottom: .3rem; letter-spacing: -.02em; }
.impact-unit { font-family: var(--mono); font-size: .5rem; color: var(--blue); letter-spacing: .08em; text-transform: uppercase; font-weight: 400; }
.impact-desc { font-size: .7rem; color: var(--white-muted); margin-top: .5rem; line-height: 1.5; font-weight: 300; }

.timeline { position: relative; padding-left: 2.5rem; }
.t-line { position: absolute; left: 0; top: .5rem; bottom: .5rem; width: 1px; background: rgba(75,141,248,.06); }
.t-entry { padding: 0 0 3rem 0; position: relative; }
.t-entry:last-child { padding-bottom: 0; }
.t-dot { position: absolute; left: -2.5rem; top: .45rem; width: 7px; height: 7px; border-radius: 50%; background: rgba(75,141,248,.15); border: 1px solid rgba(75,141,248,.25); }
.t-current .t-dot { background: var(--blue); border-color: var(--blue); }
.t-period { font-family: var(--mono); font-size: .55rem; color: var(--white-muted); letter-spacing: .06em; font-weight: 300; margin-bottom: .3rem; }
.t-role { font-size: .95rem; font-weight: 500; color: var(--white); margin-bottom: .15rem; }
.t-company { font-size: .82rem; color: var(--white-dim); font-weight: 300; margin-bottom: .1rem; }
.t-location { font-family: var(--mono); font-size: .55rem; color: var(--white-muted); letter-spacing: .04em; font-weight: 300; margin-bottom: .6rem; }
.t-desc { font-size: .78rem; line-height: 1.75; color: var(--white-muted); font-weight: 300; max-width: 600px; }
.t-industries { font-family: var(--mono); font-size: .52rem; color: var(--white-muted); letter-spacing: .04em; margin-top: .5rem; opacity: .6; }

.about-connect { padding: 4rem 3rem 5rem; text-align: center; }
.about-connect-inner { max-width: 500px; margin: 0 auto; }
.about-connect h2 { font-family: var(--display); font-size: clamp(1.4rem, 2vw, 1.8rem); font-weight: 400; margin-bottom: .6rem; letter-spacing: -.01em; }
.about-connect p { font-size: .85rem; color: var(--white-muted); font-weight: 300; margin-bottom: 1.5rem; line-height: 1.7; }
.connect-links { display: flex; gap: .6rem; justify-content: center; flex-wrap: wrap; }

/* ---- Workshop Page ---- */
.workshop-grid {
  max-width: 1100px; margin: 0 auto; padding: 3rem 3rem 5rem;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem;
}
.product-card {
  background: rgba(12,26,48,.5); border: 1px solid rgba(75,141,248,.06);
  border-radius: 8px; padding: 2rem; position: relative;
  transition: border-color .3s, transform .2s; overflow: hidden;
  display: flex; flex-direction: column;
}
.product-card:hover { border-color: rgba(75,141,248,.15); transform: translateY(-2px); }
.product-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; }
.card-flowigator::before { background: linear-gradient(90deg, var(--cyan), transparent); }
.card-automatiqa::before { background: linear-gradient(90deg, var(--blue), transparent); }
.card-constructor::before { background: linear-gradient(90deg, #a78bfa, transparent); }
.card-synthax::before { background: linear-gradient(90deg, #f59e0b, transparent); }
.card-riskmaster::before { background: linear-gradient(90deg, #3dd68c, transparent); }

.product-icon {
  width: 40px; height: 40px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center; margin-bottom: 1.2rem;
}
.card-flowigator .product-icon { background: rgba(47,212,232,.1); color: var(--cyan); }
.card-automatiqa .product-icon { background: rgba(75,141,248,.1); color: var(--blue); }
.card-constructor .product-icon { background: rgba(167,139,250,.1); color: #a78bfa; }
.card-synthax .product-icon { background: rgba(245,158,11,.1); color: #f59e0b; }
.card-riskmaster .product-icon { background: rgba(61,214,140,.1); color: #3dd68c; }

.ws-product-name { font-family: var(--display); font-size: 1.3rem; font-weight: 400; letter-spacing: -.01em; margin-bottom: .3rem; }
.ws-tm { font-size: .7rem; color: var(--white-muted); vertical-align: super; }

.ws-status {
  display: inline-block; font-family: var(--mono); font-size: .6rem; letter-spacing: .08em;
  text-transform: uppercase; padding: .2rem .5rem; border-radius: 2px;
}
.ws-status-live { background: rgba(47,212,232,.1); color: var(--cyan); }
.ws-status-dev { background: rgba(75,141,248,.1); color: var(--blue-pale); }
.ws-status-concept { background: rgba(167,139,250,.1); color: #a78bfa; }
.ws-status-deployed { background: rgba(61,214,140,.12); color: #3dd68c; }

.ws-badges { display: flex; gap: .4rem; align-items: center; margin-bottom: .8rem; flex-wrap: wrap; }
.ws-toms-badge {
  font-family: var(--mono); font-size: .55rem; letter-spacing: .1em;
  text-transform: uppercase; padding: .2rem .5rem; border-radius: 2px;
  text-decoration: none; transition: opacity .2s;
}
.ws-toms-badge:hover { opacity: .75; }
.toms-l1 { background: rgba(61,214,140,.07); color: #3dd68c; border: 1px solid rgba(61,214,140,.2); }
.toms-l2 { background: rgba(56,139,253,.07); color: #388bfd; border: 1px solid rgba(56,139,253,.22); }
.toms-l3 { background: rgba(167,139,250,.07); color: #a78bfa; border: 1px solid rgba(167,139,250,.22); }
.toms-l4 { background: rgba(244,163,51,.07); color: #f4a333; border: 1px solid rgba(244,163,51,.22); }
.toms-l5 { background: rgba(57,208,216,.07); color: #39d0d8; border: 1px solid rgba(57,208,216,.22); }

/* Challenge / How it helps me */
.ws-context { margin-bottom: 1rem; }
.ws-context-item {
  display: flex; gap: .6rem; margin-bottom: .5rem;
  font-size: .78rem; line-height: 1.6; color: var(--white-muted); font-weight: 300;
}
.ws-context-label {
  font-family: var(--mono); font-size: .55rem; letter-spacing: .1em;
  text-transform: uppercase; flex-shrink: 0; padding-top: .15rem; width: 90px;
}

.ws-desc { font-size: .78rem; color: #566880; font-weight: 300; line-height: 1.7; margin-bottom: 1.2rem; }

.ws-section { margin-bottom: .8rem; }
.ws-section:last-child { margin-bottom: 0; }
.ws-section-label {
  font-family: var(--mono); font-size: .55rem; letter-spacing: .15em;
  text-transform: uppercase; margin-bottom: .4rem; padding-bottom: .3rem;
  border-bottom: 1px solid rgba(75,141,248,.06);
}
.card-flowigator-label { color: var(--cyan); }
.card-automatiqa-label { color: var(--blue); }
.card-constructor-label { color: #a78bfa; }
.card-synthax-label { color: #f59e0b; }
.card-riskmaster-label { color: #3dd68c; }

.ws-pills { display: flex; flex-wrap: wrap; gap: .3rem; }
.ws-pill {
  font-family: var(--mono); font-size: .55rem; padding: .18rem .5rem;
  border-radius: 2px; border: 1px solid rgba(75,141,248,.08);
  color: #566880; background: rgba(12,26,48,.4); letter-spacing: .03em;
}

/* OODAA */
.oodaa-section { padding: 4rem 3rem; text-align: center; }
.oodaa-inner { max-width: 700px; margin: 0 auto; }
.oodaa-inner h2 { font-family: var(--display); font-size: clamp(1.4rem, 2.5vw, 1.8rem); font-weight: 400; letter-spacing: -.01em; margin-bottom: .8rem; }
.oodaa-inner p { font-size: .85rem; color: var(--white-muted); font-weight: 300; line-height: 1.7; }
.oodaa-strip { max-width: 1100px; margin: 0 auto; padding: 0 3rem 4rem; display: flex; justify-content: center; gap: 0; align-items: center; }
.oodaa-node { text-align: center; }
.oodaa-dot { width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(75,141,248,.15); display: flex; align-items: center; justify-content: center; margin: 0 auto .4rem; font-family: var(--mono); font-size: .65rem; font-weight: 500; }
.oodaa-label { font-family: var(--mono); font-size: .58rem; color: var(--white-muted); letter-spacing: .05em; }
.oodaa-arrow { width: 32px; display: flex; align-items: center; justify-content: center; color: rgba(75,141,248,.2); font-size: .7rem; padding-bottom: 1.2rem; }

/* ---- Responsive ---- */
@media (max-width: 900px) {
  /* Nav hamburger */
  .nav-toggle { display: block; }
  .nav-links {
    display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(8,14,26,.98); backdrop-filter: blur(20px);
    flex-direction: column; align-items: center; justify-content: flex-start;
    gap: 2.5rem; z-index: 150; padding: 5rem 1.5rem 3rem; overflow-y: auto;
  }
  .nav-links.open { display: flex; }
  .nav-links a { font-size: 1rem; letter-spacing: .06em; }
  .site-nav { padding: .8rem 1.5rem; }

  /* Homepage */
  .hero-inner { grid-template-columns: 1fr; }
  .hero-schematic { display: none; }
  .hero { padding: 7rem 1.5rem 3rem; }
  .hero-desc { max-width: 100%; }
  .post-feed { grid-template-columns: 1fr; padding-left: 1.5rem; padding-right: 1.5rem; }

  /* Posts & Pages */
  .post-header { padding: 7rem 1.5rem 2rem; }
  .post-content { padding-left: 1.5rem; padding-right: 1.5rem; }
  .page-header { padding: 7rem 1.5rem 2rem; }
  .page-content { padding-left: 1.5rem; padding-right: 1.5rem; }

  /* About page */
  .about-hero { padding: 7rem 1.5rem 3rem; }
  .about-hero-inner { grid-template-columns: 1fr; gap: 2rem; }
  .about-sidebar { position: static; }
  .about-headshot { width: 140px; height: 140px; }

  .about-thesis { padding: 3rem 1.5rem; }
  .about-thesis-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .about-skills { grid-template-columns: 1fr; }

  .about-track { padding: 3rem 1.5rem; }
  .impact-grid { grid-template-columns: repeat(2, 1fr); }
  .timeline { padding-left: 2rem; }
  .t-dot { left: -2rem; }
  .t-desc { max-width: 100%; }

  .about-connect { padding: 3rem 1.5rem 4rem; }

  /* Newsletter Strip */
  .nl-strip { padding: 2rem 1.5rem; }
  .nl-cards { grid-template-columns: 1fr; }
  .nl-strip-header { flex-direction: column; align-items: flex-start; gap: .5rem; }

  /* Newsletter Page */
  .nl-page-header { grid-template-columns: 1fr; padding: 7rem 1.5rem 2rem; gap: 2rem; }
  .nl-subscribe-panel { position: static; }
  .nl-issues-section { grid-template-columns: 1fr; padding: 2rem 1.5rem 3rem; gap: 2rem; }
  .nl-sidebar { position: static; }
  .nl-issue { grid-template-columns: 2.5rem 1fr; }
  .nl-issue-right { display: none; }

  /* Spectrum */
  .spectrum { padding: 3rem 1.5rem; }
  .spectrum-track { grid-template-columns: 1fr; gap: .8rem; padding-top: 0; }
  .spectrum-line { display: none; }
  .spectrum-level {
    text-align: left; display: grid;
    grid-template-columns: 14px auto 1fr; grid-template-rows: auto auto;
    gap: 0 .8rem; align-items: center;
    padding: .8rem 0; border-bottom: 1px solid rgba(75,141,248,.03);
  }
  .spectrum-level:last-child { border-bottom: none; }
  .spectrum-dot { margin: 0; grid-row: 1 / 3; }
  .spectrum-label { grid-column: 2; text-align: left; margin: 0; }
  .spectrum-name { grid-column: 3; text-align: left; margin: 0; font-size: .82rem; }
  .spectrum-detail { grid-column: 2 / 4; text-align: left; margin-top: .3rem; }

  /* TOMS Spectrum page */
  .toms-masthead { padding: 7rem 1.5rem 2rem; }
  .toms-intro { padding: 5rem 1.5rem 0; }
  .toms-assessment { margin: 2rem 1.5rem; padding: 1.5rem; }
  .toms-table-wrap { padding: 0 1.5rem; overflow-x: auto; }
  .toms-summary-table { font-size: .68rem; }
  .toms-faq { padding: 2rem 1.5rem; }
  .level-nav { padding: 1.5rem; }
  .spine-row { display: none; }
  .toms-levels { padding: 0 1.5rem; }
  .level-grid { grid-template-columns: repeat(2, 1fr); }
  .level-usecase, .level-signals, .level-ct { grid-template-columns: 1fr; }
  .usecase-label { border-right: none; border-bottom: 1px solid; }
  .level-num { font-size: 48px; }
  .automation-bar { flex-wrap: wrap; padding: 0 16px 16px; }
  .abar-label { width: auto; }

  /* Modal */
  .modal-box { padding: 2rem 1.5rem; }
  .form-row { grid-template-columns: 1fr; }

  /* Workshop */
  .workshop-grid { grid-template-columns: 1fr; padding: 2rem 1.5rem; }
  .oodaa-strip { flex-wrap: wrap; gap: .5rem; padding: 0 1.5rem 3rem; }
  .oodaa-arrow { display: none; }
  .oodaa-section { padding: 3rem 1.5rem; }

  /* CTA & Footer */
  .cta { padding: 3rem 1.5rem 4rem; }

  /* GitHub request box */
  .github-request { padding: 0 1.5rem; }
  .github-request-inner { flex-direction: column; text-align: center; gap: 1rem; padding: 1.5rem; }

  .footer-inner { flex-direction: column; gap: 1rem; text-align: center; }
  .footer-links { flex-wrap: wrap; justify-content: center; gap: 1rem .8rem; }
  .site-footer { padding: 2rem 1.5rem; }

  /* Section headers on homepage */
  .post-feed + .divider + section { padding-left: 1.5rem; padding-right: 1.5rem; }

  /* Manifesto mobile */
  .manifesto-layout { grid-template-columns: 1fr; }
  .manifesto-nav { display: none; }
  .manifesto-hero h1 { font-size: 3rem; }
  .manifesto-links { grid-template-columns: 1fr; }
  .manifesto-table { font-size: .72rem; }
  .manifesto-table th, .manifesto-table td { padding: .5rem .6rem; }
}

/* ============================================
   MANIFESTO PAGE
   ============================================ */
.manifesto-page { max-width: 1200px; margin: 0 auto; padding: 0 3rem; }

.manifesto-hero {
  padding: 8rem 0 4rem;
  border-bottom: 1px solid rgba(75,141,248,.08);
  margin-bottom: 3rem;
}
.manifesto-hero h1 {
  color: var(--white);
  margin-bottom: 1.5rem;
}
.manifesto-sub {
  font-family: var(--body);
  font-size: 1.05rem;
  font-weight: 300;
  color: var(--white-muted);
  max-width: 540px;
  line-height: 1.7;
}

.manifesto-layout {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 4rem;
  align-items: start;
}

/* Sticky sidebar */
.manifesto-nav {
  position: sticky;
  top: 5rem;
  padding-top: 0.5rem;
}
.manifesto-nav-inner {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.manifesto-nav-label {
  font-family: var(--mono);
  font-size: .58rem;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 1rem;
}
.manifesto-nav-link {
  display: block;
  font-family: var(--body);
  font-size: .72rem;
  font-weight: 300;
  color: var(--white-muted);
  text-decoration: none;
  padding: .4rem 0 .4rem .75rem;
  border-left: 1px solid rgba(75,141,248,.06);
  transition: all .2s;
}
.manifesto-nav-link:hover {
  color: var(--white-dim);
  border-left-color: rgba(75,141,248,.2);
}
.manifesto-nav-link.active {
  color: var(--white);
  border-left-color: var(--blue);
  font-weight: 400;
}
.manifesto-nav-divider {
  height: 1px;
  background: rgba(75,141,248,.08);
  margin: 1rem 0;
}
.manifesto-nav-btn {
  font-size: .65rem;
  padding: .5rem 1rem;
  text-align: center;
  margin-top: .4rem;
}

/* Content */
.manifesto-content { max-width: 720px; padding-bottom: 6rem; }
.manifesto-section { margin-bottom: 3.5rem; }
.manifesto-section h2 {
  font-family: var(--display);
  font-size: 1.6rem;
  font-weight: 400;
  color: var(--white);
  margin-bottom: 1.25rem;
  line-height: 1.2;
}
.manifesto-section h3 {
  font-family: var(--body);
  font-size: 1rem;
  font-weight: 500;
  color: var(--white-dim);
  margin: 2rem 0 .75rem;
}
.manifesto-section p {
  font-size: .92rem;
  font-weight: 300;
  color: var(--white-muted);
  line-height: 1.85;
  margin-bottom: 1rem;
}
.manifesto-section ul {
  list-style: none;
  padding: 0;
  margin: 1rem 0 1.5rem;
}
.manifesto-section li {
  font-size: .92rem;
  font-weight: 300;
  color: var(--white-muted);
  line-height: 1.75;
  padding: .5rem 0 .5rem 1.25rem;
  border-left: 1px solid rgba(75,141,248,.1);
  margin-bottom: .25rem;
}
.manifesto-section li strong {
  color: var(--white-dim);
  font-weight: 500;
}
.manifesto-section a {
  color: var(--blue-pale);
  text-decoration: none;
  border-bottom: 1px solid rgba(75,141,248,.15);
  transition: .2s;
}
.manifesto-section a:hover { color: var(--blue-glow); border-bottom-color: var(--blue); }
.manifesto-lead {
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--white-dim);
  margin-bottom: 1.25rem;
}
.manifesto-lead strong { color: var(--white); font-weight: 500; }

/* TOMS table */
.manifesto-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: .8rem;
}
.manifesto-table th {
  font-family: var(--mono);
  font-size: .62rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--blue);
  text-align: left;
  padding: .75rem .85rem;
  border-bottom: 1px solid rgba(75,141,248,.15);
}
.manifesto-table td {
  font-weight: 300;
  color: var(--white-muted);
  padding: .65rem .85rem;
  border-bottom: 1px solid rgba(75,141,248,.04);
}
.manifesto-table tr:hover td { color: var(--white-dim); }

/* Closing CTAs */
.manifesto-cta-group {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin: 2rem 0;
}
.manifesto-close-line {
  font-family: var(--display);
  font-size: 1.15rem;
  font-style: italic;
  color: var(--white-dim);
  margin-top: 2rem;
}

/* Subscribe */
.manifesto-subscribe {
  padding: 2.5rem;
  border: 1px solid rgba(75,141,248,.08);
  border-radius: 4px;
  text-align: center;
}
.manifesto-subscribe p {
  text-align: center;
  margin-bottom: 1.5rem;
}
.manifesto-subscribe-form {
  display: flex;
  max-width: 380px;
  margin: 0 auto;
}
.manifesto-subscribe-form input {
  flex: 1;
  font-family: var(--body);
  font-size: .85rem;
  color: var(--white);
  background: rgba(75,141,248,.04);
  border: 1px solid rgba(75,141,248,.1);
  border-right: none;
  border-radius: 3px 0 0 3px;
  padding: .7rem 1rem;
  outline: none;
}
.manifesto-subscribe-form input::placeholder { color: var(--white-muted); }
.manifesto-subscribe-form input:focus { border-color: var(--blue); }
.manifesto-subscribe-form .btn-p { border-radius: 0 3px 3px 0; }

/* FAQ */
.manifesto-faq h3 { margin-top: 1.5rem; }
.manifesto-faq p { margin-bottom: 1.5rem; }

