/* ─── Adventure Gamers Blog — Shared Stylesheet ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#fff;color:#1a1a1a;font-size:15px;line-height:1.65}

/* Reading progress bar */
.reading-progress{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,#16a34a,#4ade80);z-index:9997;transition:width .1s ease}

/* Util bar */
.util-bar{background:#1a1a1a;border-bottom:1px solid #2a2a2a}
.ub-inner{max-width:1200px;margin:0 auto;padding:0 20px;height:34px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.ub-left{display:flex;align-items:center;gap:12px}
.ub-left a{color:#9ca3af;font-size:.7rem;text-decoration:none}
.ub-left a:hover{color:#d1d5db}
.ub-right{display:flex;align-items:center;gap:10px}
.ub-right span{font-size:.68rem;color:#6b7280}
.ub-badge{font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:4px;background:#16a34a;color:#fff;text-transform:uppercase;letter-spacing:.06em}

/* Nav */
nav{background:#fff;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:998;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 20px;height:58px;display:flex;align-items:center;gap:4px}
.nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;margin-right:20px;flex-shrink:0}
.nav-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,#15803d,#22c55e);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:900;color:#fff;letter-spacing:-.02em}
.nav-logo-text{font-size:.95rem;font-weight:800;color:#111;line-height:1.1}
.nav-logo-text span{display:block;font-size:.6rem;font-weight:500;color:#6b7280;letter-spacing:.04em;text-transform:uppercase}
.nav-menu{display:flex;gap:0;list-style:none;flex:1}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:4px;padding:0 14px;height:58px;font-size:.82rem;font-weight:600;color:#374151;text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;cursor:pointer;transition:.18s}
.nav-link:hover,.nav-link.on{color:#15803d;border-bottom-color:#16a34a}
.nav-link .arr{font-size:.6rem;color:#9ca3af}
.nav-cta{margin-left:auto;background:#16a34a;color:#fff;padding:8px 18px;border-radius:7px;font-size:.8rem;font-weight:700;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:.2s}
.nav-cta:hover{background:#15803d}

/* Breadcrumb */
.bc-bar{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:9px 0}
.bc-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:5px;font-size:.75rem;color:#9ca3af}
.bc-inner a{color:#16a34a;text-decoration:none}
.bc-inner a:hover{text-decoration:underline}

/* ─── Blog index hero ─── */
.blog-hero{background:linear-gradient(135deg,#052e16 0%,#14532d 50%,#166534 100%);color:#fff;padding:64px 20px 80px;position:relative;overflow:hidden}
.blog-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(74,222,128,.18),transparent 65%);pointer-events:none}
.blog-hero::after{content:'';position:absolute;bottom:-150px;left:-100px;width:380px;height:380px;background:radial-gradient(circle,rgba(34,197,94,.12),transparent 65%);pointer-events:none}
.bh-inner{max-width:1200px;margin:0 auto;position:relative;z-index:2}
.bh-eye{display:inline-block;background:rgba(74,222,128,.15);border:1px solid rgba(74,222,128,.35);color:#86efac;font-size:.65rem;font-weight:800;letter-spacing:.12em;padding:5px 12px;border-radius:20px;text-transform:uppercase;margin-bottom:16px}
.bh-title{font-size:2.6rem;font-weight:900;letter-spacing:-.03em;line-height:1.05;max-width:760px;margin-bottom:14px}
.bh-title span{color:#4ade80}
.bh-sub{font-size:1.05rem;color:rgba(255,255,255,.75);max-width:620px;line-height:1.6}
.bh-stats{display:flex;gap:32px;margin-top:30px;flex-wrap:wrap}
.bh-stat{display:flex;flex-direction:column}
.bh-stat .v{font-size:1.6rem;font-weight:900;color:#4ade80;line-height:1}
.bh-stat .l{font-size:.7rem;color:rgba(255,255,255,.6);margin-top:3px;text-transform:uppercase;letter-spacing:.08em}

/* Blog wrap & filters */
.blog-wrap{max-width:1200px;margin:0 auto;padding:32px 20px 60px}
.blog-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid #e5e7eb}
.blog-filters span{font-size:.7rem;color:#9ca3af;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-right:6px}
.bf-pill{font-size:.74rem;font-weight:600;padding:6px 12px;border-radius:20px;background:#f3f4f6;border:1px solid #e5e7eb;color:#6b7280;cursor:pointer;transition:.15s;text-decoration:none}
.bf-pill:hover,.bf-pill.on{background:#16a34a;border-color:#16a34a;color:#fff}

/* Featured + grid */
.blog-feat{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;margin-bottom:36px}
.bf-card{position:relative;border-radius:14px;overflow:hidden;text-decoration:none;color:#fff;display:flex;align-items:flex-end;min-height:420px;transition:.3s}
.bf-card:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(0,0,0,.18)}
.bf-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85));pointer-events:none}
.bf-card .bf-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:.6s}
.bf-card:hover .bf-img{transform:scale(1.05)}
.bf-card .bf-body{position:relative;padding:24px;z-index:2}
.bf-card .bf-cat{display:inline-block;background:#16a34a;color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.1em;padding:4px 10px;border-radius:4px;text-transform:uppercase;margin-bottom:10px}
.bf-card h2{font-size:1.55rem;font-weight:900;line-height:1.18;margin-bottom:8px;letter-spacing:-.015em}
.bf-card p{font-size:.85rem;color:rgba(255,255,255,.78);line-height:1.55;max-width:480px;margin-bottom:10px}
.bf-card .bf-meta{display:flex;gap:12px;font-size:.7rem;color:rgba(255,255,255,.6);font-weight:500}

.bf-side{display:flex;flex-direction:column;gap:14px}
.bf-side .bf-card{min-height:198px}
.bf-side .bf-card h2{font-size:1.05rem}
.bf-side .bf-card p{font-size:.75rem}

@media(max-width:880px){.blog-feat{grid-template-columns:1fr}.bf-card{min-height:280px}.bf-card h2{font-size:1.3rem}}

/* Post grid */
.blog-grid-h{font-size:1.15rem;font-weight:800;color:#111;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.blog-grid-h::before{content:'';display:inline-block;width:4px;height:18px;background:#16a34a;border-radius:2px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.bg-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:.22s;display:flex;flex-direction:column}
.bg-card:hover{border-color:#86efac;box-shadow:0 12px 32px rgba(22,163,74,.1);transform:translateY(-2px)}
.bg-img{aspect-ratio:16/10;background-size:cover;background-position:center;background-color:#f3f4f6;position:relative}
.bg-img .bg-cat{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.95);color:#15803d;font-size:.55rem;font-weight:800;letter-spacing:.1em;padding:4px 9px;border-radius:4px;text-transform:uppercase;backdrop-filter:blur(4px)}
.bg-body{padding:18px;display:flex;flex-direction:column;flex:1}
.bg-body h3{font-size:1rem;font-weight:800;color:#111;line-height:1.3;margin-bottom:8px;letter-spacing:-.01em}
.bg-card:hover .bg-body h3{color:#15803d}
.bg-body p{font-size:.78rem;color:#6b7280;line-height:1.55;margin-bottom:12px;flex:1}
.bg-meta{display:flex;align-items:center;gap:10px;padding-top:10px;border-top:1px solid #f3f4f6;font-size:.68rem;color:#9ca3af;font-weight:500}
.bg-meta .dot{width:3px;height:3px;border-radius:50%;background:#d1d5db}
@media(max-width:880px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.blog-grid{grid-template-columns:1fr}}

/* Newsletter */
.nl-card{margin:48px 0;background:linear-gradient(110deg,#0a0a1a,#1f2937);color:#fff;border-radius:14px;padding:36px;display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:center;position:relative;overflow:hidden}
.nl-card::before{content:'';position:absolute;top:-80px;right:-80px;width:280px;height:280px;background:radial-gradient(circle,rgba(74,222,128,.18),transparent 65%);pointer-events:none}
.nl-left h3{font-size:1.45rem;font-weight:900;letter-spacing:-.02em;margin-bottom:8px;line-height:1.2}
.nl-left p{font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.6;max-width:440px}
.nl-form{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1}
.nl-form input{flex:1;min-width:0;padding:13px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#fff;font-size:.85rem;font-family:inherit}
.nl-form input::placeholder{color:rgba(255,255,255,.45)}
.nl-form input:focus{outline:none;border-color:#4ade80;background:rgba(74,222,128,.06)}
.nl-form button{padding:13px 22px;background:linear-gradient(90deg,#22c55e,#4ade80);color:#052e16;border:none;border-radius:8px;font-size:.82rem;font-weight:800;cursor:pointer;letter-spacing:.01em;transition:.2s;font-family:inherit}
.nl-form button:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(34,197,94,.4)}
.nl-disc{font-size:.6rem;color:rgba(255,255,255,.35);margin-top:9px}
@media(max-width:760px){.nl-card{grid-template-columns:1fr;padding:24px}}

/* ─── Article page ─── */
.art-wrap{max-width:1200px;margin:0 auto;padding:24px 20px 48px;display:grid;grid-template-columns:1fr 288px;gap:36px;align-items:start}
.art-main{min-width:0;max-width:760px}
.art-hero{margin-bottom:30px}
.art-cat{display:inline-block;background:#dcfce7;color:#15803d;font-size:.62rem;font-weight:800;letter-spacing:.1em;padding:5px 11px;border-radius:4px;text-transform:uppercase;margin-bottom:14px}
.art-h1{font-size:2.2rem;font-weight:900;letter-spacing:-.025em;line-height:1.13;color:#111;margin-bottom:14px}
.art-deck{font-size:1.05rem;color:#6b7280;line-height:1.6;margin-bottom:18px;max-width:680px}
.art-byline{display:flex;align-items:center;gap:14px;font-size:.78rem;color:#6b7280;flex-wrap:wrap;padding:14px 0;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;margin-bottom:26px}
.art-byline .ab-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#4ade80);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.78rem}
.art-byline strong{color:#111;font-weight:700}
.art-byline .sep{color:#d1d5db}
.art-byline .ab-time{display:inline-flex;align-items:center;gap:4px}
.art-byline .ab-time::before{content:'\23F1';margin-right:2px}

.art-feat-img{width:100%;aspect-ratio:16/9;border-radius:14px;background-size:cover;background-position:center;margin-bottom:30px;background-color:#f3f4f6}

.art-body{font-size:1rem;color:#374151;line-height:1.78}
.art-body h2{font-size:1.55rem;font-weight:800;color:#111;letter-spacing:-.02em;margin:36px 0 14px;line-height:1.25;padding-bottom:8px;border-bottom:2px solid #f0fdf4}
.art-body h3{font-size:1.18rem;font-weight:700;color:#111;margin:28px 0 10px;letter-spacing:-.015em}
.art-body p{margin-bottom:16px}
.art-body ul,.art-body ol{margin:14px 0 22px 22px}
.art-body li{margin-bottom:8px;line-height:1.7}
.art-body strong{color:#111;font-weight:700}
.art-body a{color:#16a34a;font-weight:600;text-decoration:none;border-bottom:1.5px solid #bbf7d0;transition:.15s}
.art-body a:hover{background:#f0fdf4;border-bottom-color:#16a34a}
.art-body blockquote{border-left:4px solid #16a34a;padding:12px 18px;background:#f0fdf4;margin:22px 0;font-size:1.02rem;color:#15803d;font-weight:500;border-radius:0 8px 8px 0;font-style:italic}
.art-body blockquote::before{content:'\201C';font-size:2rem;color:#16a34a;line-height:0;vertical-align:-12px;margin-right:5px}
.art-body code{background:#f3f4f6;padding:1px 6px;border-radius:4px;font-size:.92em;color:#dc2626;font-family:'Monaco','Menlo',monospace}

/* Article CTA box */
.art-cta-box{margin:30px 0;padding:24px;background:linear-gradient(110deg,#052e16,#14532d);color:#fff;border-radius:12px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;border:1px solid rgba(74,222,128,.25)}
.acb-logo{width:54px;height:36px;background:rgba(255,255,255,.1);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.acb-logo img{width:48px;height:32px;object-fit:contain}
.acb-text{flex:1;min-width:200px}
.acb-text h4{font-size:1rem;font-weight:800;line-height:1.3;margin-bottom:5px}
.acb-text p{color:rgba(255,255,255,.65);font-size:.78rem;line-height:1.55;margin:0}
.acb-cta{background:linear-gradient(90deg,#22c55e,#4ade80);color:#052e16;padding:11px 20px;border-radius:8px;font-weight:800;font-size:.82rem;text-decoration:none;border-bottom:none;white-space:nowrap;transition:.2s}
.acb-cta:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(34,197,94,.4);background:linear-gradient(90deg,#22c55e,#4ade80)}

/* Stat callout */
.art-stat{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0;padding:18px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px}
.as-item{text-align:center;padding:6px}
.as-v{font-size:1.55rem;font-weight:900;color:#15803d;line-height:1;letter-spacing:-.02em}
.as-l{font-size:.65rem;color:#6b7280;margin-top:4px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* Comparison mini-table */
.art-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.84rem;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}
.art-table th{background:#f9fafb;padding:10px 12px;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;border-bottom:1px solid #e5e7eb}
.art-table td{padding:10px 12px;border-bottom:1px solid #f3f4f6;color:#374151}
.art-table tbody tr:last-child td{border-bottom:none}
.art-table tbody tr:hover td{background:#f9fafb}
.art-table .yes{color:#16a34a;font-weight:700}
.art-table .no{color:#9ca3af}

/* Sidebar */
.art-side{position:sticky;top:74px;display:flex;flex-direction:column;gap:14px}
.as-card{border:1px solid #e5e7eb;border-radius:9px;overflow:hidden;background:#fff}
.as-h{padding:11px 14px;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-size:.78rem;font-weight:700;color:#111}
.as-toc{padding:8px 0}
.as-toc a{display:block;padding:6px 14px;font-size:.76rem;color:#374151;text-decoration:none;border-left:2px solid transparent;transition:.15s}
.as-toc a:hover{color:#16a34a;background:#f0fdf4;border-left-color:#16a34a}

/* Verdict mini sidebar */
.as-verdict{padding:14px;text-align:center}
.av-logo{width:54px;height:34px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:8px}
.av-logo img{width:48px;height:30px;object-fit:contain}
.av-name{font-size:1rem;font-weight:800;color:#111;margin-bottom:3px}
.av-stars{color:#f59e0b;font-size:.85rem;letter-spacing:.5px;margin-bottom:8px}
.av-offer{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:6px;padding:8px;margin-bottom:9px}
.av-offer .v{font-size:1rem;font-weight:800;color:#15803d;line-height:1.1}
.av-offer .l{font-size:.6rem;color:#6b7280;margin-top:2px}
.av-btn{display:block;padding:10px;background:#16a34a;color:#fff;border-radius:7px;font-size:.78rem;font-weight:800;text-decoration:none;transition:.2s}
.av-btn:hover{background:#15803d}
.av-tc{font-size:.55rem;color:#9ca3af;margin-top:6px}

/* Related posts */
.related-wrap{max-width:1200px;margin:0 auto;padding:0 20px 60px}
.related-h{font-size:1.25rem;font-weight:800;color:#111;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.related-h::before{content:'';display:inline-block;width:4px;height:20px;background:#16a34a;border-radius:2px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:880px){.related-grid{grid-template-columns:1fr}}

/* Author bio bottom */
.author-box{margin:36px 0 0;padding:22px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.ab-big{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#4ade80);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.3rem;flex-shrink:0}
.ab-info h5{font-size:.95rem;font-weight:800;color:#111;margin-bottom:3px}
.ab-info p{font-size:.78rem;color:#6b7280;margin:0;line-height:1.5;max-width:480px}

/* Mega menu — same as main page */
.nav-item:hover .megamenu,.nav-item:focus-within .megamenu{opacity:1;visibility:visible;transform:translateY(0)}
.megamenu{position:absolute;top:100%;left:0;min-width:680px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 14px 40px rgba(0,0,0,.12);padding:18px;display:grid;grid-template-columns:1fr 1fr 220px;gap:18px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:1000;margin-top:-2px}
.nav-item:nth-last-child(2) .megamenu,.nav-item:nth-last-child(3) .megamenu{left:auto;right:0}
.mm-col h5{font-size:.6rem;font-weight:800;color:#9ca3af;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #f3f4f6}
.mm-col a{display:flex;align-items:flex-start;gap:8px;padding:7px 8px;font-size:.78rem;color:#374151;text-decoration:none;border-radius:6px;line-height:1.4;border-bottom:none;transition:.15s}
.mm-col a:hover{background:#f0fdf4;color:#15803d}
.mm-col a .mm-icon{font-size:.95rem;line-height:1;margin-top:1px}
.mm-col a .mm-txt strong{display:block;font-weight:600;font-size:.78rem;color:#111}
.mm-col a:hover .mm-txt strong{color:#15803d}
.mm-col a .mm-txt small{display:block;font-size:.65rem;color:#9ca3af;margin-top:1px}
.mm-rank{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;font-weight:900;font-size:.75rem;flex-shrink:0;margin-top:1px;box-shadow:0 2px 5px rgba(22,163,74,.3);transition:.18s}
.mm-col a:hover .mm-rank{transform:scale(1.1);box-shadow:0 3px 9px rgba(22,163,74,.45)}
.mm-feature{background:linear-gradient(155deg,#052e16,#14532d,#166534);border-radius:8px;padding:14px;display:flex;flex-direction:column;justify-content:space-between;color:#fff;text-decoration:none;border-bottom:none;position:relative;overflow:hidden}
.mm-feature::after{content:'';position:absolute;top:-30%;right:-30%;width:140px;height:140px;background:radial-gradient(circle,rgba(74,222,128,.25),transparent 70%);pointer-events:none}
.mm-feature .mm-eye{font-size:.55rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#4ade80;margin-bottom:6px;position:relative;z-index:1}
.mm-feature h6{font-size:.95rem;font-weight:800;margin-bottom:5px;line-height:1.3;position:relative;z-index:1}
.mm-feature p{font-size:.65rem;color:rgba(255,255,255,.6);line-height:1.5;margin-bottom:10px;position:relative;z-index:1}
.mm-feature .mm-btn{background:#fff;color:#14532d;font-size:.7rem;font-weight:700;padding:6px 10px;border-radius:5px;text-align:center;align-self:flex-start;position:relative;z-index:1}
@media(max-width:1020px){.megamenu{display:none!important}}

/* Article body card hover */
.bg-card{transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s,border-color .25s}
.bg-card:hover{transform:translateY(-4px);border-color:#86efac;box-shadow:0 18px 40px rgba(22,163,74,.15)}
.bg-img{transition:transform .6s}
.bg-card:hover .bg-img{transform:scale(1.04)}

/* Hero feat card */
.bf-card{transition:transform .35s,box-shadow .35s}
.bf-card:hover{transform:translateY(-3px);box-shadow:0 22px 60px rgba(0,0,0,.22)}

/* CTA / button shimmer */
.nav-cta,.av-btn,.mc-btn,.acb-cta,.bf-pill.on{position:relative;overflow:hidden}
.nav-cta::before,.acb-cta::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transition:.5s;pointer-events:none}
.nav-cta:hover::before,.acb-cta:hover::before{left:100%}

/* Selection / focus */
::selection{background:#86efac;color:#052e16}
a:focus-visible,button:focus-visible{outline:2px solid #16a34a;outline-offset:3px;border-radius:4px}

/* Side banner refinement */
.side-banner{transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s}
.side-banner:hover{transform:translateY(-50%) scale(1.04) rotate(-1deg)}

/* Smoother reveal */
.rev{opacity:0;transform:translateY(14px);transition:opacity .55s cubic-bezier(.4,0,.2,1),transform .55s cubic-bezier(.4,0,.2,1)}
.rev.vis{opacity:1;transform:translateY(0)}

/* Article body link polish */
.art-body a{transition:.15s}
.art-body a:hover{color:#15803d;background:#f0fdf4}

/* Featured-in band (used in blog landing) */
.featured-in{margin:0 0 28px;padding:14px 18px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;position:relative;overflow:hidden}
.featured-in::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#16a34a,#22c55e)}
.fi-label{font-size:.65rem;font-weight:800;color:#6b7280;letter-spacing:.12em;text-transform:uppercase;flex-shrink:0;padding-left:6px}
.fi-logos{display:flex;gap:24px;align-items:center;flex-wrap:wrap;flex:1;justify-content:center}
.fi-logo{font-family:Georgia,'Times New Roman',serif;font-size:1.05rem;font-weight:700;color:#9ca3af;letter-spacing:-.01em;font-style:italic;transition:.22s;cursor:default}
.fi-logo:hover{color:#15803d;transform:translateY(-1px)}
.fi-logo.bold{font-family:'Inter',sans-serif;font-weight:900;font-style:normal;letter-spacing:-.02em;text-transform:uppercase;font-size:.95rem}
.fi-logo.serif-light{font-weight:400;font-style:normal}
.fi-logo.italic-bold{font-style:italic;font-weight:900}

/* Floating side banner */
.side-banner{position:fixed;right:10px;top:50%;transform:translateY(-50%);z-index:50;width:154px;max-height:82vh;border-radius:13px;overflow:hidden;box-shadow:0 10px 35px rgba(0,0,0,.22);transition:.35s;cursor:pointer;line-height:0;background:#fff;display:block;animation:sbIn .6s cubic-bezier(.34,1.4,.64,1) .8s both}
@keyframes sbIn{from{opacity:0;transform:translate(20px,-50%)}to{opacity:1;transform:translateY(-50%)}}
.side-banner:hover{transform:translateY(-50%) scale(1.04) rotate(-1.5deg);box-shadow:0 22px 50px rgba(22,163,74,.36)}
.side-banner img{width:100%;height:auto;max-height:82vh;object-fit:contain;display:block}
.ad-sponsored-tag{position:absolute;top:6px;right:6px;font-size:.48rem;font-weight:700;color:rgba(255,255,255,.95);background:rgba(0,0,0,.6);padding:2px 6px;border-radius:4px;letter-spacing:.05em;line-height:1.4;backdrop-filter:blur(4px);z-index:2;text-transform:uppercase}
.side-banner-close{position:absolute;top:6px;left:6px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;backdrop-filter:blur(4px);transition:.2s;padding:0;z-index:2}
.side-banner-close:hover{background:rgba(0,0,0,.95);transform:scale(1.12)}
.side-banner-pulse{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);background:#fbbf24;color:#78350f;font-size:.5rem;font-weight:800;padding:4px 9px;border-radius:20px;letter-spacing:.04em;text-transform:uppercase;z-index:2;animation:sbPulse 1.8s ease-in-out infinite;white-space:nowrap}
@keyframes sbPulse{0%,100%{box-shadow:0 0 0 0 rgba(251,191,36,.7)}50%{box-shadow:0 0 0 8px rgba(251,191,36,0)}}
@media(max-width:1280px){.side-banner{display:none}}

/* Mobile sticky CTA */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:2px solid #16a34a;padding:9px 12px;z-index:9990;box-shadow:0 -4px 20px rgba(0,0,0,.12);align-items:center;gap:10px;transform:translateY(100%);transition:transform .3s ease}
.mobile-cta.show{transform:translateY(0)}
.mc-logo{width:36px;height:36px;border-radius:7px;background:#f0fdf4;border:1px solid #bbf7d0;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.mc-logo img{width:30px;height:30px;object-fit:contain}
.mc-text{flex:1;min-width:0}
.mc-text strong{display:block;font-size:.78rem;font-weight:800;color:#111;line-height:1.1}
.mc-text small{display:block;font-size:.62rem;color:#15803d;margin-top:1px;font-weight:600}
.mc-btn{background:#16a34a;color:#fff;padding:9px 14px;font-size:.75rem;font-weight:800;border-radius:6px;text-decoration:none;flex-shrink:0;white-space:nowrap;box-shadow:0 4px 12px rgba(22,163,74,.35)}
.mc-btn:hover{background:#15803d}
@media(max-width:1020px){.mobile-cta{display:flex}body.has-mc{padding-bottom:64px}}

/* Back to top */
.back-top{position:fixed;bottom:84px;right:18px;width:42px;height:42px;border-radius:50%;background:#111;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;box-shadow:0 6px 18px rgba(0,0,0,.25);z-index:60;opacity:0;pointer-events:none;transition:.25s;transform:translateY(8px)}
.back-top.show{opacity:1;pointer-events:all;transform:translateY(0)}
.back-top:hover{background:#16a34a;transform:translateY(-2px) scale(1.08)}
@media(min-width:1021px){.back-top{bottom:24px}}

/* Footer */
footer{background:#111;padding:36px 20px 24px;border-top:1px solid #1f2937}
.footer-wrap{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:24px}
.fg-logo{display:flex;align-items:center;gap:7px;margin-bottom:8px}
.fg-logo-icon{width:28px;height:28px;background:linear-gradient(135deg,#15803d,#22c55e);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:900;color:#fff}
.fg-logo-text{font-size:.88rem;font-weight:800;color:#fff}
.fg-desc{font-size:.73rem;color:rgba(255,255,255,.36);line-height:1.7;max-width:230px}
.fg-col h4{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:10px}
.fg-col a{display:block;font-size:.73rem;color:rgba(255,255,255,.44);text-decoration:none;margin-bottom:7px;transition:.18s}
.fg-col a:hover{color:rgba(255,255,255,.85)}
.footer-bot{border-top:1px solid rgba(255,255,255,.05);padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:.68rem;color:rgba(255,255,255,.2)}
.disclaimer{font-size:.63rem;color:rgba(255,255,255,.16);line-height:1.7;max-width:600px}

@media(max-width:1020px){
  .art-wrap{grid-template-columns:1fr}
  .art-side{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-menu{display:none}
  .bh-title{font-size:1.7rem}
  .bh-sub{font-size:.92rem}
  .art-h1{font-size:1.55rem}
  .art-deck{font-size:.95rem}
  .footer-grid{grid-template-columns:1fr}
  .blog-hero{padding:42px 20px 56px}
}
