
/* shared layout, theme controls variables */
:root{ --accent:#d4af37 }
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}
.hero{position:relative;height:46vh;background:var(--hero-bg);display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center}
.hero .overlay{position:absolute;inset:0;background:var(--hero-overlay)}
.hero h1,.hero p,.hero .quick-actions{z-index:2}
.quick-actions{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap;justify-content:center}
.btn{padding:10px 16px;border-radius:999px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text);cursor:pointer;text-decoration:none}
.btn.ghost{background:transparent}
.btn.small{padding:6px 10px;border-radius:10px}
.search{padding:10px 14px;border-radius:10px;border:1px solid var(--btn-border);background:var(--input-bg);color:var(--text);min-width:240px}
.muted{color:var(--muted)}
.topbar{position:sticky;top:0;background:var(--topbar-bg);backdrop-filter:blur(10px);padding:12px 20px;display:flex;justify-content:space-between;align-items:center}
.logo{color:var(--text);text-decoration:none;font-weight:700}

.featured{max-width:1200px;margin:-40px auto 10px;padding:0 20px}
.featured-card{display:block;position:relative;height:360px;border-radius:22px;background-size:cover;background-position:center;color:#fff;text-decoration:none;box-shadow:var(--shadow-lg);padding:18px;overflow:hidden}
.featured-card .badge{position:absolute;top:16px;left:16px;background:var(--badge-bg);padding:6px 10px;border-radius:999px;border:1px solid var(--badge-border)}
.featured-card h2{position:absolute;left:0;right:0;bottom:54px;margin:0;padding:0 18px;text-shadow:0 8px 30px rgba(0,0,0,.6)}
.featured-card p{position:absolute;left:0;right:0;bottom:16px;margin:0;padding:0 18px;opacity:.95}

.filters{max-width:1200px;margin:10px auto 0;padding:0 20px}
.tags{display:flex;gap:10px;flex-wrap:wrap}
.tag{background:transparent;border:1px solid var(--btn-border);color:var(--text);padding:8px 12px;border-radius:999px;cursor:pointer}
.tag.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft) inset}

.posts{max-width:1200px;margin:16px auto;padding:0 20px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.card{display:block;background:var(--card);border-radius:16px;overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow);transform:translateZ(0);transition:transform .25s, box-shadow .25s}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover)}
.thumb{height:200px;background-size:cover;background-position:center;filter:saturate(1.05)}
.info{padding:18px}
.meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.chip{background:var(--chip-bg);color:var(--chip-text);padding:4px 10px;border-radius:999px;font-weight:700}
.date{color:var(--muted);font-size:.9rem}
.info h3{margin:6px 0 6px 0;font-size:1.15rem}
.info p{margin:0;color:var(--muted)}

.article-hero{position:relative;height:50vh;background-size:cover;background-position:center;display:flex;align-items:flex-end}
.article-hero .overlay{position:absolute;inset:0;background:var(--article-overlay)}
.article-hero h1{position:relative;z-index:2;margin:24px;font-size:2.2rem}
.article-meta{position:relative;z-index:2;margin:0 24px 24px;color:#ddd;display:flex;gap:12px;align-items:center}
.article-content{max-width:900px;margin:28px auto;padding:0 20px;color:var(--text);font-size:1.1rem;line-height:1.7}

footer{max-width:1200px;margin:20px auto;padding:20px;color:var(--muted);text-align:center}

.reveal{opacity:0;transform:translateY(20px);transition:.4s}
.reveal.show{opacity:1;transform:none}

.loadMore{height:80px}

/* Age Gate overlay */
.age-blur{position:fixed;inset:0;backdrop-filter:blur(12px);background:rgba(0,0,0,.45);z-index:9998;display:none}
.age-overlay{position:fixed;inset:0;z-index:9999;display:none;justify-content:center;align-items:center}
.age-box{background:#1a1a1a;color:#fff;padding:28px;border-radius:16px;text-align:center;width:min(94%,460px);box-shadow:0 30px 80px rgba(0,0,0,.6);animation:popIn .22s ease-out}
.age-box h2{margin:0 0 8px 0}
.age-box p{opacity:.9}
.age-actions{display:flex;gap:10px;justify-content:center;margin-top:14px;flex-wrap:wrap}
.age-btn{padding:12px 16px;border:none;border-radius:10px;cursor:pointer}
.age-yes{background:#0bc20b;color:#fff}
.age-no{background:#c20b0b;color:#fff}
@keyframes popIn{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}

/* LQIP blur */
.lqip{filter:blur(12px); transition:filter .35s ease}
.lqip:not(.lqip){filter:none}
