/* Esoygen Journal styles — matches the main site (soy palette, Fraunces + Hanken, paper texture). */
@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap");

:root{
  --paper:#faf6ee; --paper-2:#f2e9da; --card:#fffdf9;
  --ink:#2a2018; --ink-soft:#4f4334; --ink-faint:#6b5d4a;
  --soy:#6b5a3e; --soy-deep:#463a28; --soy-light:#8b7355;
  --sage:#7c8a5f; --clay:#bc6b45; --gold:#c0973f;
  --line:rgba(70,58,40,.14); --line-soft:rgba(70,58,40,.08);
  --shadow:0 30px 80px rgba(70,48,28,.14); --shadow-sm:0 14px 36px rgba(70,48,28,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  background:var(--paper) url("img/paper-texture.png") repeat; background-size:560px;
  color:var(--ink); line-height:1.65; overflow-x:hidden;
}
body::after{content:"";position:fixed;inset:0;z-index:9;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--clay);color:#fff}
.page{position:relative;z-index:1}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.05;letter-spacing:-.015em;color:var(--ink)}
em.em,.em{font-style:italic;font-weight:400;color:var(--clay)}

/* ---- nav (matches index) ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:.4s;background:linear-gradient(180deg,rgba(250,246,238,.94),rgba(250,246,238,0))}
.nav.scrolled{background:rgba(250,246,238,.9);backdrop-filter:blur(16px);border-bottom:1px solid var(--line-soft)}
.nav-inner{max-width:1240px;margin:0 auto;padding:14px clamp(20px,5vw,64px);display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center}
.logo-img{height:44px;width:auto;display:block}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:14px;font-weight:600;color:var(--ink-soft);transition:.2s}
.nav-links a:hover{color:var(--clay)}
.buttons{display:flex;gap:14px;align-items:center}
.nav-cta{display:inline-flex;align-items:center;padding:11px 20px;border-radius:999px;background:var(--soy-deep);color:#fff;font-weight:700;font-size:14px;transition:.25s}
.nav-cta:hover{background:var(--clay);transform:translateY(-1px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:1px solid var(--line);border-radius:12px;background:rgba(255,253,249,.7);cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span{width:18px;height:2px;background:var(--ink);transition:.25s}
.mobile-menu{display:none;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line)}
.mobile-menu a{padding:15px clamp(20px,5vw,64px);border-top:1px solid var(--line-soft);font-weight:600;color:var(--ink-soft)}
.nav.open .mobile-menu{display:flex}
.nav.open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav-toggle span:nth-child(2){opacity:0}
.nav.open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.section{max-width:1240px;margin:0 auto;padding:130px clamp(20px,5vw,64px) 70px}

/* ---- blog index hero ---- */
.blog-hero{max-width:760px}
.pill{display:inline-flex;align-items:center;gap:9px;padding:8px 14px;border-radius:999px;background:var(--card);border:1px solid var(--line);color:var(--soy);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.18em;margin-bottom:22px}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--sage)}
.blog-hero h1{font-size:clamp(40px,6.4vw,76px);letter-spacing:-.03em;line-height:.98;margin-bottom:18px}
.blog-hero p{font-size:18px;color:var(--ink-soft);line-height:1.7;max-width:54ch}

/* ---- grid ---- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.blog-card{background:var(--card);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.blog-card-body{padding:26px;display:flex;flex-direction:column;flex:1}
.blog-card-tag{align-self:flex-start;padding:7px 12px;border-radius:999px;background:var(--paper-2);color:var(--clay);border:1px solid var(--line);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.blog-card h2{font-size:23px;line-height:1.16;margin-bottom:12px}
.blog-card h2 a:hover{color:var(--clay)}
.blog-card p{color:var(--ink-soft);line-height:1.6;margin-bottom:18px;flex:1}
.blog-card-meta{font-size:13px;font-weight:700;color:var(--ink-faint)}
.blog-card-meta .dot{display:inline-block;width:3px;height:3px;border-radius:50%;background:var(--clay);margin:0 8px;vertical-align:middle}

/* ---- article ---- */
.article{max-width:760px;margin:0 auto;padding:130px clamp(20px,5vw,64px) 24px}
.article-back{display:inline-flex;align-items:center;gap:6px;color:var(--clay);font-weight:700;font-size:14px;margin-bottom:26px}
.article-back:hover{text-decoration:underline}
.article-tag{display:inline-block;padding:7px 12px;border-radius:999px;background:var(--paper-2);color:var(--clay);border:1px solid var(--line);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:18px}
.article h1{font-size:clamp(34px,5.2vw,58px);letter-spacing:-.025em;line-height:1.02;margin-bottom:18px}
.article-meta{color:var(--ink-faint);font-size:14px;font-weight:700;margin-bottom:14px}
.article-meta .dot{display:inline-block;width:3px;height:3px;border-radius:50%;background:var(--clay);margin:0 8px;vertical-align:middle}
.article-lead{font-size:20px;line-height:1.7;color:var(--ink-soft);margin:26px 0 8px;font-family:"Fraunces",serif;font-style:italic;font-weight:400}
.article-content{font-size:17px;line-height:1.8;color:var(--ink)}
.article-content h2{font-size:29px;letter-spacing:-.01em;margin:42px 0 14px}
.article-content h3{font-size:21px;margin:30px 0 10px}
.article-content p{margin-bottom:18px;color:#463a33}
.article-content a{color:var(--clay);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.article-content ul{margin:0 0 18px 22px}
.article-content li{margin-bottom:8px;color:#463a33}
.article-content blockquote{margin:24px 0;padding:18px 24px;border-left:4px solid var(--sage);background:rgba(124,138,95,.08);border-radius:0 16px 16px 0;font-size:18px;line-height:1.7;color:var(--ink-soft);font-family:"Fraunces",serif;font-style:italic}
.callout{margin:30px 0;padding:22px 24px;border-radius:18px;background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.callout strong{color:var(--ink)}
.references{margin-top:44px;padding-top:26px;border-top:1px solid var(--line)}
.references h3{font-size:18px;margin-bottom:16px}
.references ol{margin-left:20px}
.references li{font-size:14px;line-height:1.6;color:var(--ink-soft);margin-bottom:12px}
.references a{color:var(--clay);word-break:break-word}

.blog-cta{margin:48px auto 0;max-width:760px;border-radius:26px;padding:48px 30px;text-align:center;
  background:radial-gradient(circle at top right,rgba(189,107,69,.25),transparent 42%),linear-gradient(135deg,var(--soy-deep),#33291b);
  color:#f3ead9;box-shadow:var(--shadow)}
.blog-cta h2{font-size:clamp(26px,4vw,38px);letter-spacing:-.01em;margin-bottom:12px;color:#fbf6ec}
.blog-cta p{max-width:520px;margin:0 auto 24px;color:#e0d2bf;line-height:1.7}
.btn{display:inline-flex;align-items:center;justify-content:center;height:52px;padding:0 26px;border-radius:999px;font-weight:700;font-size:15px;border:none;cursor:pointer;transition:.25s;font-family:inherit}
.btn-secondary{background:var(--paper);color:var(--soy-deep)}
.btn-secondary:hover{transform:translateY(-2px)}

/* ---- faq ---- */
.faq{max-width:820px}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;background:none;border:none;text-align:left;padding:24px 0;font-family:"Fraunces",serif;font-size:20px;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;gap:20px;align-items:center}
.qa button .pm{flex:none;color:var(--clay);font-size:24px;transition:.2s}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.qa .ans p{padding:0 0 24px;font-size:15px;color:var(--ink-soft);line-height:1.75}
.qa.open .pm{transform:rotate(45deg)}

/* ---- footer (matches index) ---- */
footer{background:var(--soy-deep);color:#d8cab2;padding:60px clamp(20px,5vw,64px) 40px;text-align:center;position:relative;z-index:1}
.footer-disclaimer{max-width:820px;margin:0 auto 16px;font-size:13px;line-height:1.6;color:#bdae95}
.footer-links{margin-bottom:14px;font-size:14px;font-weight:700}
.footer-links a:hover{color:#fff}

@media(max-width:920px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .blog-grid{grid-template-columns:1fr}
  .section{padding:110px 20px 50px}
  .article{padding:110px 20px 24px}
}
