/* ============================================================
   Capital & Compass — editorial finance/business theme
   Aesthetic: parchment paper, forest ink, warm ochre accent.
   Distinctive serif display (Fraunces) + grotesk body.
   ============================================================ */

:root{
  --paper:#F6F1E7;
  --paper-2:#EFE7D6;
  --ink:#1C2A24;
  --ink-soft:#37463E;
  --muted:#6E7A71;
  --line:#D8CCB4;
  --forest:#1F5E45;
  --forest-deep:#143B2C;
  --ochre:#C98A2B;
  --ochre-soft:#E6C079;
  --rust:#A4451F;
  --white:#FFFDF8;
  --shadow:0 18px 50px -28px rgba(20,42,32,.55);
  --radius:14px;
  --maxw:1180px;
  --serif:"Fraunces","Noto Serif SC",Georgia,serif;
  --sans:"Hanken Grotesk","Noto Sans SC",system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(circle at 12% -10%, rgba(201,138,43,.10), transparent 42%),
    radial-gradient(circle at 100% 0%, rgba(31,94,69,.08), transparent 38%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:var(--forest);text-decoration:none}
a:hover{color:var(--rust)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- Top bar ---------- */
.topbar{
  border-bottom:1px solid var(--line);
  background:rgba(246,241,231,.82);
  backdrop-filter:saturate(140%) blur(8px);
  position:sticky;top:0;z-index:50;
}
.topbar .wrap{display:flex;align-items:center;gap:18px;height:70px}
.brand{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.brand .mark{
  width:40px;height:40px;border-radius:10px;flex:0 0 auto;
  background:linear-gradient(135deg,var(--forest),var(--forest-deep));
  color:var(--ochre-soft);display:grid;place-items:center;
  font-family:var(--serif);font-weight:600;font-size:22px;
  box-shadow:inset 0 0 0 1px rgba(230,192,121,.35);
}
.brand b{font-family:var(--serif);font-size:21px;font-weight:600;letter-spacing:.2px;line-height:1}
.brand span{display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.nav{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap}
.nav a{
  font-size:13.5px;font-weight:600;letter-spacing:.02em;color:var(--ink-soft);
  padding:8px 12px;border-radius:8px;
}
.nav a:hover,.nav a.active{background:var(--paper-2);color:var(--forest-deep)}

.langsel{margin-left:8px;display:flex;gap:4px;align-items:center;border:1px solid var(--line);border-radius:999px;padding:3px}
.langsel button{
  border:0;background:transparent;cursor:pointer;font-family:var(--sans);
  font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--muted);
  padding:5px 9px;border-radius:999px;
}
.langsel button.on{background:var(--forest);color:var(--paper)}

.menu-toggle{display:none;margin-left:auto;border:1px solid var(--line);background:var(--white);
  border-radius:8px;padding:8px 11px;font-size:16px;cursor:pointer}

/* ---------- Hero ---------- */
.hero{padding:54px 0 30px;border-bottom:1px solid var(--line)}
.hero .wrap{display:grid;grid-template-columns:1.35fr .9fr;gap:46px;align-items:center}
.eyebrow{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--ochre);font-weight:800}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(34px,5vw,58px);line-height:1.04;margin:14px 0 16px;letter-spacing:-.5px}
.hero h1 em{font-style:italic;color:var(--forest)}
.hero p.lede{font-size:18px;color:var(--ink-soft);max-width:46ch}
.hero .cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;
  padding:12px 20px;border-radius:999px;border:1px solid transparent;cursor:pointer}
.btn.primary{background:var(--forest);color:var(--paper)}
.btn.primary:hover{background:var(--forest-deep);color:var(--paper)}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--forest);color:var(--forest)}
.hero-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:24px;position:relative;overflow:hidden;
}
.hero-card:before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(135deg,transparent 0 22px,rgba(31,94,69,.04) 22px 23px);pointer-events:none}
.hero-card h3{font-family:var(--serif);font-size:19px;margin-bottom:4px}
.hero-card .stat{display:flex;justify-content:space-between;align-items:baseline;
  padding:12px 0;border-bottom:1px dashed var(--line)}
.hero-card .stat:last-child{border-bottom:0}
.hero-card .stat b{font-family:var(--serif);font-size:26px;color:var(--forest)}
.hero-card .stat span{font-size:13px;color:var(--muted)}
.hero-card .learn-list{position:relative;z-index:1}
.hero-card .learn-item{display:flex;align-items:center;gap:13px;padding:14px 0;
  border-bottom:1px dashed var(--line);text-decoration:none;color:var(--ink);
  transition:transform .18s ease,color .18s ease}
.hero-card .learn-item:last-child{border-bottom:0}
.hero-card .learn-item:hover{transform:translateX(3px);color:var(--forest)}
.hero-card .learn-num{flex:none;width:28px;height:28px;border-radius:50%;
  display:grid;place-items:center;background:var(--forest);color:#fff;
  font-family:var(--serif);font-size:14px;font-weight:600}
.hero-card .learn-text{flex:1;font-size:15.5px;font-weight:600;line-height:1.3}
.hero-card .learn-arrow{flex:none;color:var(--ochre);font-size:17px;
  opacity:.5;transition:opacity .18s ease}
.hero-card .learn-item:hover .learn-arrow{opacity:1}

/* ---------- Section headers ---------- */
.sec{padding:48px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:26px;
  border-bottom:2px solid var(--ink);padding-bottom:10px}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(24px,3vw,34px);letter-spacing:-.3px}
.sec-head a{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}

/* ---------- Category chips ---------- */
.cats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.chip{border:1px solid var(--line);background:var(--white);border-radius:999px;padding:8px 16px;
  font-size:13.5px;font-weight:700;color:var(--ink-soft);cursor:pointer;transition:.15s}
.chip:hover{border-color:var(--forest);color:var(--forest)}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- Article grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--forest-deep),var(--forest));
  position:relative;display:grid;place-items:center}
.card .thumb .glyph{font-family:var(--serif);font-size:46px;color:rgba(230,192,121,.85)}
.card .thumb .tag{position:absolute;top:12px;left:12px;background:var(--paper);color:var(--forest-deep);
  font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.card .thumb .planned{position:absolute;top:12px;right:12px;background:var(--ochre);color:#3a2606;
  font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:999px}
.card .body{padding:18px 20px 22px;display:flex;flex-direction:column;flex:1}
.card .kw{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ochre);font-weight:800;margin-bottom:8px}
.card h3{font-family:var(--serif);font-size:20px;line-height:1.22;margin-bottom:10px}
.card h3 a{color:var(--ink)}
.card h3 a:hover{color:var(--forest)}
.card p{font-size:14.5px;color:var(--muted);flex:1}
.card .meta{margin-top:14px;font-size:12.5px;color:var(--muted);display:flex;gap:10px;align-items:center}
.card .meta .dot{width:4px;height:4px;border-radius:50%;background:var(--line)}

/* ---------- Article page ---------- */
.layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;padding:38px 0 60px}
.breadcrumb{font-size:13px;color:var(--muted);margin-bottom:18px}
.breadcrumb a{font-weight:600}
.article h1{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4vw,44px);line-height:1.1;letter-spacing:-.5px;margin-bottom:14px}
.article .a-meta{display:flex;gap:14px;align-items:center;color:var(--muted);font-size:13.5px;
  border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:6px;flex-wrap:wrap}
.article .a-meta .pill{background:var(--paper-2);color:var(--forest-deep);font-weight:700;
  padding:4px 11px;border-radius:999px;font-size:12px}
.article .hero-strip{height:8px;border-radius:999px;margin:24px 0 30px;
  background:linear-gradient(90deg,var(--forest),var(--ochre),var(--rust))}
.article .content{font-size:17.5px;color:var(--ink-soft)}
.article .content p{margin:0 0 20px}
.article .content h2{font-family:var(--serif);color:var(--ink);font-size:26px;margin:34px 0 12px;letter-spacing:-.2px}
.article .content h3{font-family:var(--serif);color:var(--ink);font-size:20px;margin:24px 0 8px}
.article .content ul,.article .content ol{margin:0 0 20px 22px}
.article .content li{margin:0 0 8px}
.article .content strong{color:var(--ink)}
.article .content blockquote{border-left:3px solid var(--ochre);background:var(--paper-2);
  padding:14px 20px;margin:0 0 22px;border-radius:0 10px 10px 0;font-size:16.5px}
.article .keytakeaways{background:var(--white);border:1px solid var(--line);border-left:4px solid var(--forest);
  border-radius:0 12px 12px 0;padding:18px 22px;margin:8px 0 30px}
.article .keytakeaways h4{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--forest);margin-bottom:10px}
.article .keytakeaways ul{margin:0 0 0 18px}
.article .keytakeaways li{font-size:15px;margin-bottom:6px}

/* ---------- Internal link box ---------- */
.related-inline{background:var(--paper-2);border-radius:12px;padding:16px 20px;margin:6px 0 26px;font-size:15px}
.related-inline b{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ochre);margin-bottom:6px}
.related-inline a{font-weight:700}

/* ---------- Disclaimer ---------- */
.disclaimer{font-size:13.5px;color:var(--muted);background:var(--paper-2);border:1px dashed var(--line);
  border-radius:12px;padding:16px 18px;margin:30px 0}
.disclaimer b{color:var(--ink-soft)}

/* ---------- AdSense placeholder slots ---------- */
.ad-slot{
  border:2px dashed var(--ochre);border-radius:12px;background:
    repeating-linear-gradient(45deg,rgba(201,138,43,.05) 0 12px,transparent 12px 24px);
  min-height:96px;display:grid;place-items:center;text-align:center;margin:28px 0;color:var(--ochre);
}
.ad-slot small{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:800}
.ad-slot span{font-size:12.5px;color:var(--muted)}
.ad-slot.sidebar{min-height:300px;margin:0 0 24px}

/* ---------- Sidebar ---------- */
.sidebar .widget{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-bottom:24px}
.sidebar .widget h4{font-family:var(--serif);font-size:18px;margin-bottom:12px;border-bottom:1px solid var(--line);padding-bottom:8px}
.sidebar .widget ul{list-style:none}
.sidebar .widget li{padding:9px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
.sidebar .widget li:last-child{border-bottom:0}
.sidebar .widget li a{font-weight:600;color:var(--ink)}
.sidebar .widget li a:hover{color:var(--forest)}
.sidebar .widget li small{display:block;color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.sticky{position:sticky;top:90px}

/* ---------- Static/legal pages ---------- */
.page{max-width:760px;margin:0 auto;padding:40px 0 60px}
.page h1{font-family:var(--serif);font-size:clamp(28px,4vw,42px);margin-bottom:8px}
.page .updated{color:var(--muted);font-size:13px;margin-bottom:26px}
.page h2{font-family:var(--serif);font-size:24px;margin:30px 0 10px}
.page p,.page li{color:var(--ink-soft);margin-bottom:14px}
.page ul{margin-left:22px}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:var(--paper);margin-top:50px}
footer .wrap{padding:46px 22px 30px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
footer h5{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ochre-soft);margin-bottom:14px}
footer a{color:var(--paper);opacity:.82;font-size:14px;display:block;margin-bottom:9px}
footer a:hover{opacity:1;color:var(--ochre-soft)}
footer .brand b{color:var(--paper)}
footer .brand span{color:rgba(246,241,231,.55)}
footer p.fine{font-size:13px;opacity:.6;max-width:34ch;margin-top:12px}
.subfoot{border-top:1px solid rgba(246,241,231,.15)}
.subfoot .wrap{display:flex;justify-content:space-between;gap:14px;padding:18px 22px;font-size:12.5px;opacity:.6;flex-wrap:wrap}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:30px}
  .layout{grid-template-columns:1fr;gap:30px}
  .sticky{position:static}
  .grid{grid-template-columns:repeat(2,1fr)}
  footer .wrap{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  body{font-size:16px}
  .nav,.langsel{display:none}
  .nav.open{display:flex;position:absolute;top:70px;left:0;right:0;background:var(--white);
    flex-direction:column;padding:12px;border-bottom:1px solid var(--line);gap:2px}
  .langsel.open{display:flex;position:absolute;top:70px;right:14px}
  .menu-toggle{display:block}
  .grid{grid-template-columns:1fr}
  footer .wrap{grid-template-columns:1fr}
}

/* ---------- Legal / static pages ---------- */
.legal{max-width:760px;margin:40px auto 64px;padding:0 22px}
.legal-body{background:var(--paper);border:1px solid var(--line);border-radius:18px;
  padding:clamp(24px,4vw,46px)}
.legal-body .eyebrow{margin-bottom:10px}
.legal-body h1{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4vw,42px);
  line-height:1.12;letter-spacing:-.5px;color:var(--ink);margin:0 0 18px}
.legal-body h2{font-family:var(--serif);color:var(--ink);font-size:23px;margin:30px 0 10px;letter-spacing:-.2px}
.legal-body p{font-size:17px;line-height:1.72;color:var(--ink-soft);margin:0 0 16px}
.legal-body ul{margin:0 0 18px 20px;color:var(--ink-soft);font-size:17px;line-height:1.7}
.legal-body li{margin:0 0 8px}
.legal-body b{color:var(--ink)}
.legal-body em{color:var(--muted);font-style:italic}
