/* ===========================================================================
   Vibeshots — shared stylesheet for blog, guides, and legal pages.
   Matches the homepage design system: solid dark, hairline borders, lime accent.
   =========================================================================== */
:root{
  --bg:#0a0a0b;
  --surface:#121214;
  --surface-2:#1a1a1d;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.045);
  --text:#f3f3ef;
  --muted:#9b9b94;
  --muted-2:#62625d;
  --accent:#c9ff3a;
  --accent-2:#b6ec2c;
  --accent-dim:rgba(201,255,58,.12);
  --ink:#0a0c05;
  --font-display:'Clash Display',sans-serif;
  --font-body:'Satoshi',-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --maxw:1180px;
  --readw:760px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);font-family:var(--font-body);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
::selection{background:var(--accent);color:var(--ink)}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--font-mono)}
.accent{color:var(--accent)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.read{max-width:var(--readw);margin:0 auto;padding:0 28px}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;line-height:1.1}
.eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent);display:inline-block;opacity:.7}

/* ---------- NAV ---------- */
header{position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  background:rgba(10,10,11,.72);border-bottom:1px solid var(--line)}
nav{max-width:var(--maxw);margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;font-size:19px;letter-spacing:-.01em}
.brand img{width:30px;height:30px;border-radius:8px;box-shadow:inset 0 0 0 1px var(--line)}
.nav-links{display:flex;gap:26px;margin-left:auto;font-size:14.5px;color:var(--muted)}
.nav-links a{transition:color .2s}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--text)}
.btn{font-family:var(--font-mono);font-size:13.5px;font-weight:500;display:inline-flex;align-items:center;gap:9px;
  cursor:pointer;border:none;padding:11px 18px;border-radius:10px;transition:transform .15s,background .2s}
.btn-primary{background:var(--accent);color:var(--ink);font-weight:700}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-1px)}
.btn-ghost{background:var(--surface);color:var(--text);box-shadow:inset 0 0 0 1px var(--line)}
.btn-ghost:hover{background:var(--surface-2)}
.nav .btn{margin-left:6px;padding:9px 16px}
@media(max-width:760px){.nav-links{display:none}}

/* ---------- BREADCRUMB ---------- */
.crumbs{font-family:var(--font-mono);font-size:12px;color:var(--muted-2);margin-bottom:22px;display:flex;
  flex-wrap:wrap;gap:8px;align-items:center}
.crumbs a:hover{color:var(--text)}
.crumbs span{color:var(--muted-2)}

/* ---------- ARTICLE / POST ---------- */
.post{padding:46px 0 30px}
.post h1{font-size:clamp(30px,4.6vw,46px);margin:14px 0 0}
.post .lede{color:var(--muted);font-size:19px;margin-top:18px}
.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:24px;
  padding-top:20px;border-top:1px solid var(--line);font-size:14px;color:var(--muted)}
.post-meta .who{display:flex;align-items:center;gap:10px}
.post-meta .av{width:34px;height:34px;border-radius:50%;background:var(--accent-dim);
  display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:var(--accent);box-shadow:inset 0 0 0 1px rgba(201,255,58,.25)}
.post-meta b{color:var(--text);font-weight:600}
.post-meta .dot{color:var(--muted-2)}
.badge-year{font-family:var(--font-mono);font-size:11.5px;color:var(--accent);background:var(--accent-dim);
  padding:3px 9px;border-radius:20px;box-shadow:inset 0 0 0 1px rgba(201,255,58,.3)}

/* answer capsule (TL;DR) */
.answer-capsule{font-size:18px;line-height:1.6;color:var(--text);background:var(--surface);
  border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;
  padding:18px 22px;margin:30px 0}
.answer-capsule strong{color:var(--accent)}

/* prose */
.prose{font-size:17.5px;line-height:1.75;color:#dcdcd6}
.prose h2{font-size:27px;margin:46px 0 14px;color:var(--text);scroll-margin-top:90px}
.prose h3{font-size:20px;margin:32px 0 10px;color:var(--text)}
.prose p{margin:0 0 18px}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(201,255,58,.4)}
.prose a:hover{text-decoration-color:var(--accent)}
/* buttons & cards inside prose must not inherit link color/underline */
.prose a.btn{text-decoration:none}
.prose a.btn-primary{color:var(--ink)}
.prose a.btn-ghost{color:var(--text)}
.prose a.rel-card{text-decoration:none;color:inherit}
.rel-card h4{color:var(--text)}
.prose ul,.prose ol{margin:0 0 18px 22px}
.prose li{margin:0 0 9px}
.prose strong{color:var(--text)}
.prose code{font-family:var(--font-mono);font-size:14px;background:var(--surface-2);
  padding:2px 7px;border-radius:6px;box-shadow:inset 0 0 0 1px var(--line);color:#e9eadf}
.prose figure{margin:26px 0}
.prose figcaption{font-size:13.5px;color:var(--muted-2);margin-top:8px;text-align:center}
.prose hr{border:none;border-top:1px solid var(--line);margin:38px 0}

/* keycaps */
.kbd{font-family:var(--font-mono);font-size:13px;font-weight:600;display:inline-flex;align-items:center;
  padding:3px 8px;border-radius:6px;background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--line);color:var(--text)}

/* branded blockquote */
.prose blockquote{margin:30px 0;padding:20px 24px;background:var(--surface);border:1px solid var(--line);
  border-left:3px solid var(--accent);border-radius:12px;font-size:18px;line-height:1.6;color:#e7e7e1;font-style:normal}
.prose blockquote cite{display:block;margin-top:10px;font-family:var(--font-mono);font-size:12.5px;
  color:var(--muted-2);font-style:normal}

/* tables */
.tbl-wrap{overflow-x:auto;margin:26px 0;border:1px solid var(--line);border-radius:14px}
.prose table{width:100%;border-collapse:collapse;font-size:15px;min-width:520px}
.prose caption{caption-side:top;text-align:left;font-family:var(--font-mono);font-size:12px;
  letter-spacing:.04em;color:var(--muted-2);padding:14px 16px 0;text-transform:uppercase}
.prose th,.prose td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line)}
.prose thead th{font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--muted);background:var(--surface-2)}
.prose tbody tr:last-child td{border-bottom:none}
.prose td:first-child{color:var(--text);font-weight:500}
.prose .yes{color:var(--accent)}
.prose .no{color:var(--muted-2)}

/* stats attribution note */
.stats-note{font-family:var(--font-mono);font-size:12.5px;color:var(--muted-2);line-height:1.6;
  border-left:2px solid var(--line);padding:4px 0 4px 14px;margin:8px 0 22px}

/* FAQ (details/summary) */
.faq{margin:18px 0 0}
.faq details{border:1px solid var(--line);border-radius:12px;padding:0 18px;margin-bottom:10px;background:var(--surface)}
.faq summary{cursor:pointer;list-style:none;padding:16px 0;font-weight:600;font-size:16.5px;color:var(--text);
  display:flex;justify-content:space-between;gap:14px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--font-mono);color:var(--accent);font-size:20px;flex:none}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq .a{padding:14px 0 18px;color:var(--muted);font-size:16px;line-height:1.65}

/* author card */
.author-card{display:flex;gap:16px;align-items:flex-start;margin:40px 0 0;padding:22px;
  background:var(--surface);border:1px solid var(--line);border-radius:16px}
.author-card .av{width:52px;height:52px;border-radius:50%;flex:none;background:var(--accent-dim);
  display:grid;place-items:center;font-family:var(--font-display);font-weight:600;font-size:20px;color:var(--accent);
  box-shadow:inset 0 0 0 1px rgba(201,255,58,.25)}
.author-card h4{font-size:16px;margin-bottom:2px}
.author-card .role{font-family:var(--font-mono);font-size:12px;color:var(--accent);margin-bottom:8px}
.author-card p{font-size:14.5px;color:var(--muted);line-height:1.6}

/* CTA block */
.cta-block{margin:44px 0 0;padding:32px;background:var(--surface);border:1px solid var(--line);
  border-radius:18px;text-align:center}
.cta-block h3{font-size:24px;margin-bottom:8px}
.cta-block p{color:var(--muted);margin-bottom:20px}

/* related posts */
.related{margin:50px 0 0}
.related h2{font-size:22px;margin-bottom:18px}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.rel-card{display:block;padding:20px;background:var(--surface);border:1px solid var(--line);border-radius:14px;
  transition:transform .25s,border-color .25s,background .25s}
.rel-card:hover{transform:translateY(-3px);border-color:rgba(201,255,58,.28);background:#15151a}
.rel-card .tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2)}
.rel-card h4{font-size:16.5px;margin:8px 0 6px;line-height:1.25}
.rel-card p{font-size:13.5px;color:var(--muted)}

/* blog index hub */
.hub{padding:64px 0 20px}
.hub h1{font-size:clamp(34px,5vw,54px);margin:16px 0 0}
.hub .lede{color:var(--muted);font-size:19px;margin:18px 0 0;max-width:60ch}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-top:46px}
.post-card{display:flex;flex-direction:column;padding:26px;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;transition:transform .25s,border-color .25s,background .25s;height:100%}
.post-card:hover{transform:translateY(-4px);border-color:rgba(201,255,58,.28);background:#15151a}
.post-card .tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.post-card h2{font-size:20px;margin:12px 0 10px;line-height:1.2}
.post-card p{font-size:14.5px;color:var(--muted);flex:1}
.post-card .meta{margin-top:16px;font-family:var(--font-mono);font-size:12px;color:var(--muted-2)}

/* legal pages */
.legal{padding:54px 0}
.legal h1{font-size:clamp(30px,4vw,42px)}
.legal .updated{font-family:var(--font-mono);font-size:13px;color:var(--muted-2);margin-top:10px}
.legal h2{font-size:22px;margin:36px 0 12px}
.legal p,.legal li{color:#cfcfc9;font-size:16px;line-height:1.7}
.legal ul{margin:0 0 18px 22px}
.legal a{color:var(--accent);text-underline-offset:3px;text-decoration:underline}

/* footer */
footer{border-top:1px solid var(--line);padding:40px 0;margin-top:80px}
.foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap;color:var(--muted-2);font-size:13.5px}
.foot .brand{font-size:16px;color:var(--text)}
.foot .sp{margin-left:auto}
.foot a:hover{color:var(--text)}
.foot .updated{font-family:var(--font-mono);font-size:12px}

@media(max-width:600px){
  body{font-size:16px}
  .wrap,.read{padding:0 20px}
  nav{padding:12px 20px;gap:10px}
  .post,.legal{padding-left:0;padding-right:0}
  .prose{font-size:16.5px}
}
