/* ============================================================
   Risk Ready Solutions — Shared Stylesheet
   ============================================================ */

/* --- Design Tokens --- */
:root{
  --bg:#FAFAF8;--bg-alt:#F4F5F8;--bg-dark:#0A0F1E;
  --text:#0D1117;--text-muted:#5A6070;--text-light:#9AA0B0;
  --accent:#00338D;--accent-mid:#0047BB;--accent-light:#E8EEF8;--accent-dark:#002266;
  --border:#E2E5EC;--border-mid:#C8CCDA;--white:#FFFFFF;
  --serif:'Fraunces',Georgia,serif;--sans:'DM Sans',system-ui,sans-serif;
  --radius:3px;--radius-lg:8px;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased}

/* --- Nav (shared across all pages) --- */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(250,250,248,0.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1140px;margin:0 auto;padding:0 2rem;height:66px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{text-decoration:none;display:flex;align-items:center;gap:12px}
.nav-logo-img{height:36px;width:auto}
.nav-logo-text{display:flex;flex-direction:column;gap:1px}
.nav-logo-primary{font-family:var(--serif);font-weight:400;font-size:17px;color:var(--text);letter-spacing:-0.01em;line-height:1.2}
.nav-logo-sub{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-light)}
.nav-back{font-size:14px;color:var(--text-muted);text-decoration:none;display:flex;align-items:center;gap:6px;transition:color 0.15s}
.nav-back:hover{color:var(--text)}
.nav-back svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* --- Footer (shared base) --- */
footer{background:var(--bg-dark);padding:3rem 2rem;text-align:center}
.footer-logo{font-family:var(--serif);font-size:16px;font-weight:300;color:#5A6070;margin-bottom:0.5rem}
.footer-sub{font-size:12px;color:#3A4050}

/* --- Article Layout (used by article pages) --- */
.article-hero{padding:120px 2rem 64px;max-width:760px;margin:0 auto}
.article-tag{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem}
.tag-line{display:block;width:24px;height:1.5px;background:var(--accent)}
.article-meta{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;font-size:13px;color:var(--text-light)}
.article-meta span{display:flex;align-items:center;gap:5px}
.article-hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(32px,4vw,52px);line-height:1.15;letter-spacing:-0.02em;color:var(--text);margin-bottom:1.25rem}
.article-hero h1 em{font-style:italic;color:var(--accent)}
.article-deck{font-size:18px;color:var(--text-muted);font-weight:300;line-height:1.75;border-left:3px solid var(--accent);padding-left:1.25rem}
.article-body{max-width:760px;margin:0 auto;padding:0 2rem 80px}
.article-section{margin-bottom:3rem}
.section-num{font-family:var(--serif);font-size:12px;font-weight:400;color:var(--accent);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:0.5rem}
.article-section h2{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.5vw,30px);line-height:1.25;letter-spacing:-0.015em;color:var(--text);margin-bottom:1.25rem}
.article-section p{font-size:16px;color:var(--text-muted);line-height:1.8;margin-bottom:1.1rem}
.article-section p strong{color:var(--text);font-weight:500}
.article-section p:last-child{margin-bottom:0}

/* Pull quote */
.pull-quote{background:var(--bg-dark);border-radius:var(--radius-lg);padding:2rem 2.5rem;margin:2.5rem 0;position:relative}
.pull-quote::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-mid);border-radius:3px 0 0 3px}
.pull-quote p{font-family:var(--serif);font-size:20px;font-weight:300;line-height:1.5;color:#F0F2F8;font-style:italic;margin:0}

/* Failure list (Capital One + Uber articles) */
.failure-list{list-style:none;display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}
.failure-list li{display:grid;grid-template-columns:2rem 1fr;gap:0.75rem;align-items:start;padding:1.25rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--white)}
.failure-num{font-family:var(--serif);font-size:14px;color:var(--accent);font-weight:400;padding-top:2px}
.failure-content strong{display:block;font-size:14px;font-weight:500;color:var(--text);margin-bottom:4px}
.failure-content span{font-size:13px;color:var(--text-muted);line-height:1.6}

/* Gap blocks (governance-gaps article) */
.gap-block{border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;margin:2rem 0;background:var(--white);border-left:3px solid var(--accent)}
.gap-block-num{font-family:var(--serif);font-size:11px;font-weight:400;color:var(--accent);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:0.5rem}
.gap-block h3{font-family:var(--serif);font-weight:300;font-size:20px;line-height:1.3;color:var(--text);margin-bottom:1rem;letter-spacing:-0.01em}
.gap-block p{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:0.9rem}
.gap-block p:last-child{margin-bottom:0}
.gap-block p strong{color:var(--text);font-weight:500}

/* Article divider + subscribe + back link */
.article-divider{border:none;border-top:1px solid var(--border);margin:3rem 0}
.article-subscribe{background:var(--bg-dark);border-radius:var(--radius-lg);padding:3rem;margin:3rem 0;text-align:center}
.subscribe-label{font-size:11px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:#6B8AE0;margin-bottom:1rem}
.article-subscribe h3{font-family:var(--serif);font-weight:300;font-size:26px;color:#F0F2F8;margin-bottom:0.75rem;line-height:1.3}
.article-subscribe p{font-size:15px;color:#8A9AB8;margin-bottom:2rem;max-width:420px;margin-left:auto;margin-right:auto}
.beehiiv-embed{width:100%;max-width:480px;margin:0 auto}
.article-back{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--text-muted);text-decoration:none;padding-bottom:2px;margin-bottom:3rem;transition:color 0.15s}
.article-back:hover{color:var(--text)}
.article-back svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* --- Article mobile --- */
@media(max-width:680px){
  .article-hero,.article-body{padding-left:1.25rem;padding-right:1.25rem}
  .pull-quote,.gap-block{padding:1.5rem}
}
