*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#0D0D0D;--muted:#6B7280;--cream:#ffffeb;--cream-mid:#f5f5d8;
  --surface:#FFFFFF;--border:#e4e4d0;--white:#FFFFFF;--bg:#ffffeb;
  --grad-warm:linear-gradient(135deg,#1A1A18,#333);
  --font-d:'Figtree',sans-serif;--font-b:'Figtree',sans-serif;--font-serif:'EB Garamond',serif;
}
body{font-family:var(--font-b);background:var(--cream);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;display:flex;flex-direction:column;min-height:100vh}
a{text-decoration:none;color:inherit}

/* ── Nav ── */
nav{position:fixed;top:12px;left:50%;transform:translateX(-50%);z-index:100;width:calc(100% - 48px);max-width:1120px;background:var(--cream);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 0 0 1.5px var(--border);border-radius:10px}
.nav-inner{padding:0 28px;height:58px;display:flex;align-items:center;position:relative}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo-img{width:28px;height:28px;border-radius:0;object-fit:contain}
.nav-logo-text{font-family:var(--font-d);font-weight:700;font-size:20px;color:var(--ink);letter-spacing:-.01em}
.nav-links{display:none;gap:28px;align-items:center;margin-left:36px}
.nav-links a{font-family:var(--font-d);font-size:15px;font-weight:600;color:var(--ink);text-decoration:none;transition:opacity .15s}
.nav-links a:hover{opacity:.65}
.nav-ctas{margin-left:auto;display:flex;align-items:center;gap:10px}
#nav .btn{height:38px;font-size:15px;padding:0 18px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-d);font-weight:600;font-size:14px;height:44px;padding:0 24px;border-radius:12px;cursor:pointer;transition:background .18s;text-decoration:none;border:2px solid var(--ink);box-sizing:border-box;line-height:1}
.btn-primary{background:#DDD6FE;color:var(--ink)}
.btn-primary:hover{background:#C4B5FD}
.btn-outline{background:var(--cream);color:var(--ink)}
.btn-outline:hover{background:var(--cream-mid)}
.nav-dropdown{position:relative;display:flex;align-items:center}
.nav-dropdown-toggle{font-family:var(--font-d);font-size:15px;font-weight:600;color:var(--ink);cursor:pointer;display:flex;align-items:center;gap:4px;transition:background .15s,border-color .15s;user-select:none;background:none;border:2px solid transparent;padding:5px 12px;border-radius:8px 8px 0 0;position:relative;z-index:201}
.nav-dropdown:hover .nav-dropdown-toggle{background:white;border-color:rgba(0,0,0,.82);border-bottom-color:white}
.nav-dropdown-arrow{transition:transform .2s}
.nav-dropdown:hover .nav-dropdown-arrow{transform:rotate(180deg)}
.nav-dropdown-menu{visibility:hidden;position:absolute;top:calc(100% - 3px);left:0;transform:translateY(-6px);background:white;border:2px solid rgba(0,0,0,.82);border-radius:0 14px 14px 14px;padding:0;overflow:hidden;min-width:300px;z-index:200;transition:visibility 0s linear .18s,transform .18s}
.nav-dropdown:hover .nav-dropdown-menu{visibility:visible;transform:translateY(0);transition:visibility 0s,transform .18s}
.nav-dropdown-item{display:flex;align-items:flex-start;gap:12px;padding:10px 18px;border-radius:0;text-decoration:none;transition:background .14s}
.nav-dropdown-item:first-of-type{padding-top:12px}
.nav-dropdown-item:last-child{padding-bottom:16px}
.nav-dropdown-item:hover{background:var(--cream-mid)}
.nav-dd-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.nav-dd-title{font-family:var(--font-d);font-size:14px;font-weight:600;color:var(--ink);line-height:1.2}
.nav-dd-desc{font-family:var(--font-d);font-size:12px;color:rgba(0,0,0,.4);margin-top:3px;line-height:1.4}

/* ── Footer ── */
footer{background:#111714;padding:40px 0 28px;border-top:1px solid rgba(255,255,255,.06);margin-top:auto}
.footer-inner{max-width:1160px;margin:0 auto;padding:0 40px;display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}
.footer-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.footer-logo span{font-family:var(--font-d);font-size:14px;font-weight:700;color:rgba(255,255,255,.5)}
.footer-links{display:flex;gap:24px;flex-wrap:wrap;justify-content:center}
.footer-links a{font-family:var(--font-d);font-size:14px;color:rgba(255,255,255,.3);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:rgba(255,255,255,.6)}
.footer-copy{font-size:13px;color:rgba(255,255,255,.2);font-family:var(--font-d)}

/* ── Blog Index dark-hero layout ── */
body.blog-index{background:#0e0e0e}
.hero{padding:130px 40px 72px;text-align:center;max-width:1160px;margin:0 auto}
.hero-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:100px;padding:5px 14px;margin-bottom:20px;font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.hero h1{font-family:var(--font-serif);font-size:56px;font-weight:500;letter-spacing:-.01em;line-height:1.08;margin-bottom:16px;color:rgba(255,255,255,.92)}
.hero h1 em{font-style:italic;font-family:var(--font-serif);color:rgba(255,255,255,.92);background:none;-webkit-text-fill-color:rgba(255,255,255,.92);background-clip:unset}
.hero p{font-size:17px;color:rgba(255,255,255,.5);line-height:1.7;max-width:520px;margin:0 auto}

/* Cream content panel — mirrors bp-cream-body on post pages */
.blog-body{background:var(--cream);border-radius:40px 40px 0 0;padding-top:48px;flex:1}

/* Borderless cards on blog index */
body.blog-index .post-card{background:transparent;border:none;box-shadow:none;border-radius:0;overflow:visible}
body.blog-index .post-card:hover{transform:translateY(-3px);box-shadow:none;border:none}
body.blog-index .post-cover{border-radius:20px;height:380px}
body.blog-index .post-cover-placeholder{border-radius:20px;height:380px}
body.blog-index .post-body{padding:20px 4px 0}
body.blog-index .blog-grid{row-gap:72px}

.container{max-width:1160px;margin:0 auto;padding:0 40px}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px;padding:40px 0 80px}
.post-card{position:relative;background:var(--white);border:1px solid var(--border);border-radius:20px;overflow:hidden;transition:all .2s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.08);border-color:rgba(0,0,0,.2)}
.post-card-overlay{position:absolute;inset:0;z-index:0}
.post-title-link{position:relative;z-index:1;text-decoration:none;color:inherit}
.post-cover{width:100%;height:300px;object-fit:cover;background:linear-gradient(135deg,var(--cream),var(--border))}
.post-cover-placeholder{width:100%;height:300px;background:var(--cream);display:flex;align-items:center;justify-content:center}
.post-cover-icon{width:56px;height:56px;border-radius:16px;background:var(--ink);display:flex;align-items:center;justify-content:center}
.post-body{padding:24px;flex:1;display:flex;flex-direction:column}
.post-meta{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.post-badge{font-family:var(--font-d);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);background:var(--cream);border:1.5px solid var(--ink);padding:3px 10px;border-radius:100px;text-decoration:none;position:relative;z-index:1}
a.post-badge:hover{background:rgba(0,0,0,.06)}
.post-time{font-size:12px;color:var(--muted)}
.post-title{font-family:var(--font-d);font-size:20px;font-weight:800;line-height:1.25;margin-bottom:10px;letter-spacing:-.025em}
.post-excerpt{font-size:14px;color:var(--muted);line-height:1.7}

.empty{text-align:center;padding:80px 40px;color:var(--muted)}
.empty h2{font-family:var(--font-d);font-size:22px;font-weight:700;margin-bottom:8px;color:var(--ink)}

/* ── Blog Post Page ── */
body.post-page{background:#0e0e0e}

.bp-dark-header{padding:116px 40px 80px;text-align:center}
.bp-breadcrumb{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:rgba(255,255,255,0.4);margin-bottom:28px;text-decoration:none}
.bp-breadcrumb a{color:rgba(255,255,255,0.4);text-decoration:none;transition:color .15s}
.bp-breadcrumb a:hover{color:rgba(255,255,255,0.7)}
.bp-post-title{font-family:var(--font-d);font-size:48px;font-weight:700;line-height:1.1;letter-spacing:-0.025em;color:white;max-width:720px;margin:0 auto 16px}
.bp-post-meta{font-size:13px;color:rgba(255,255,255,0.35);font-family:var(--font-b)}

.bp-cream-body{background:var(--cream);border-radius:40px 40px 0 0;padding:64px 0 80px}

.bp-col{max-width:760px;margin:0 auto;padding:0 40px}

.bp-hero-img{border-radius:24px;overflow:hidden;height:420px;background:linear-gradient(135deg,#0D1F1A 0%,#1A3C34 100%);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;margin-bottom:56px}
.bp-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.bp-img-lbl{font-size:13px;color:rgba(255,255,255,0.25)}

.bp-body p{font-size:18px;line-height:1.78;color:#2c2c2c;margin-bottom:28px}
.bp-body h2{font-family:var(--font-d);font-size:28px;font-weight:700;color:#1a1a1a;margin:52px 0 18px;letter-spacing:-0.02em}
.bp-body h3{font-family:var(--font-d);font-size:20px;font-weight:700;color:#1a1a1a;margin:36px 0 14px;letter-spacing:-0.01em}
.bp-body ul,.bp-body ol{padding-left:22px;margin-bottom:28px}
.bp-body li{font-size:18px;line-height:1.78;color:#2c2c2c;margin-bottom:12px}
.bp-body strong{font-weight:600;color:#1a1a1a}
.bp-body em{font-style:italic;color:#555}
.bp-body blockquote{border-left:3px solid var(--green-light);padding:12px 20px;margin:32px 0;font-style:italic;color:#555;font-size:18px}
.bp-body img{max-width:100%;border-radius:16px;margin:16px 0}
.bp-body a{color:var(--green-mid);text-decoration:underline;text-underline-offset:3px}

.bp-chart-wrap{background:#fff;border:1px solid rgba(0,0,0,0.08);border-radius:16px;padding:28px 28px 20px;margin:40px 0}
.bp-chart-title{font-family:var(--font-d);font-size:15px;font-weight:600;color:#1a1a1a;margin-bottom:20px}
.bp-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:52px}
.bp-tag{font-family:var(--font-d);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:5px 14px;border-radius:100px;background:var(--cream);border:1.5px solid var(--ink);color:var(--ink);text-decoration:none;transition:background .15s}
a.bp-tag:hover{background:rgba(0,0,0,.06)}

/* Tag cloud (blog index) */
.tag-cloud{display:flex;flex-wrap:wrap;gap:10px;padding:24px 0 8px}
.tag-cloud-link{font-family:var(--font-d);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);background:var(--cream);border:1.5px solid var(--ink);padding:5px 14px;border-radius:100px;text-decoration:none;transition:background .15s}
.tag-cloud-link:hover{background:rgba(0,0,0,.06)}

/* Tag landing page hero */
.tag-hero{padding:80px 0 40px;text-align:center}
.tag-hero-label{font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green-mid);margin-bottom:12px}
.tag-hero h1{font-family:var(--font-d);font-size:36px;font-weight:800;color:var(--ink);margin-bottom:10px}
.tag-hero-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#888;text-decoration:none;margin-top:16px}
.tag-hero-back:hover{color:var(--green-mid)}

/* CTA section */
.bp-cta-section{position:relative;width:100%;height:520px;border-radius:80px;overflow:clip;margin-top:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;text-align:center;background:linear-gradient(135deg,#0D1F1A,#1A3C34)}
.bp-cta-bg{position:absolute;inset:0;background:url('/public/images/blog-cta-bg.jpg') center/cover no-repeat;z-index:0}
.bp-cta-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:20px}
.bp-cta-title{font-family:var(--font-d);font-size:44px;font-weight:700;color:white;line-height:1.1;letter-spacing:-0.025em;max-width:520px}
.bp-cta-sub{font-size:16px;color:rgba(255,255,255,0.85);max-width:400px;line-height:1.65}
.bp-cta-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.bp-cta-btn-p{background:var(--cream);color:var(--ink);font-size:15px;font-weight:600;font-family:var(--font-b);padding:16px 28px;border-radius:100px;text-decoration:none;display:flex;align-items:center;gap:8px;transition:opacity .15s}
.bp-cta-btn-p:hover{opacity:.9}
.bp-cta-btn-s{background:var(--green-light);color:white;font-size:15px;font-weight:600;font-family:var(--font-b);padding:16px 28px;border-radius:100px;text-decoration:none;transition:opacity .15s}
.bp-cta-btn-s:hover{opacity:.9}
.bp-cta-fn{font-size:12px;color:rgba(255,255,255,0.65)}

/* Related cards */
.bp-related-wrap{margin-top:64px}
.bp-related-label{font-size:11px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:#999;margin-bottom:20px;font-family:var(--font-b)}
.bp-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.bp-card{background:white;border-radius:20px;overflow:hidden;text-decoration:none;display:block;transition:transform .2s,box-shadow .2s}
.bp-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.08)}
.bp-card-thumb{height:160px;background-size:cover;background-position:center}
.bp-card-body{padding:18px 20px 22px}
.bp-card-tag{font-size:11px;font-weight:600;color:var(--green-mid);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:8px;font-family:var(--font-b)}
.bp-card-title{font-family:var(--font-d);font-size:15px;font-weight:600;color:#1a1a1a;line-height:1.4;margin-bottom:10px}
.bp-card-date{font-size:12px;color:#aaa;font-family:var(--font-b)}

@media(max-width:640px){
  .bp-dark-header{padding:108px 20px 60px}
  .bp-post-title{font-size:30px}
  .bp-col{padding:0 20px}
  .bp-hero-img{height:260px;border-radius:16px;margin-bottom:40px}
  .bp-body p,.bp-body li{font-size:16px}
  .bp-body h2{font-size:22px}
  .bp-cta-section{height:auto;padding:60px 24px;border-radius:40px}
  .bp-cta-title{font-size:28px}
  .bp-cards{grid-template-columns:1fr}
}

/* Subscribe section */
.subscribe-section{background:var(--cream);border-top:1px solid var(--border);padding:60px 40px;text-align:center}
.subscribe-inner{max-width:500px;margin:0 auto}
.subscribe-inner h2{font-family:var(--font-d);font-size:26px;font-weight:800;letter-spacing:-.03em;margin-bottom:8px}
.subscribe-inner p{color:var(--muted);font-size:15px;margin-bottom:24px}
.subscribe-form{display:flex;gap:8px;max-width:420px;margin:0 auto}
.subscribe-form input{flex:1;padding:0 18px;height:44px;border:2px solid var(--border);border-radius:12px;font-size:14px;font-family:var(--font-b);outline:none;background:white;box-sizing:border-box}
.subscribe-form input:focus{border-color:var(--ink)}
.subscribe-btn{background:#DDD6FE;color:var(--ink);border:2px solid var(--ink);padding:0 24px;height:44px;border-radius:12px;font-family:var(--font-d);font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .18s}
.subscribe-btn:hover{background:#C4B5FD}
.subscribe-msg{margin-top:12px;font-size:13px;color:var(--muted);display:none}
.subscribe-msg.success{color:#10b981;display:block}
.subscribe-msg.error{color:#ef4444;display:block}

@media(max-width:640px){
  .nav-inner,.footer-inner{padding-left:20px;padding-right:20px}
  .nav-ctas .btn-outline{display:none}
  .nav-inner{height:auto;min-height:58px;padding:10px 16px}
  .nav-logo-text{font-size:14px;line-height:1.25;max-width:120px}
  .hero{padding:96px 20px 40px}
  .hero h1{font-size:32px}
  .container{padding:0 20px}
  .blog-grid{grid-template-columns:1fr;gap:20px}
  .post-hero,.post-content-wrap{padding-left:20px;padding-right:20px}
  .post-hero h1{font-size:28px}
  .post-cover-wrap,.post-cover-placeholder-wrap{padding:0 20px}
  .related-section{padding:40px 20px}
  .subscribe-form{flex-direction:column}
}
@media(min-width:768px){
  .nav-links{display:flex}
}
@media(min-width:1024px){
  .footer-inner{flex-direction:row;justify-content:space-between;text-align:left}
}
