/* News platform — shared stylesheet. Per-site colours come from CSS variables
   (--primary, --accent) injected inline in <head>. One file, themed per domain. */

*,*::before,*::after{box-sizing:border-box}
:root{--primary:#2563eb;--accent:#0f172a;--bg:#ffffff;--soft:#f5f6f8;--line:#e6e8ec;--text:#1a1d23;--muted:#6b7280;--radius:12px;--wrap:1180px}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Merriweather',Georgia,serif;line-height:1.25;margin:0 0 .5em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}

/* Header / nav */
.site-header{border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:0;z-index:50}
.topbar{display:flex;align-items:center;gap:20px;height:64px;position:relative}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.35rem;font-family:'Merriweather',serif}
.brand .badge{background:var(--primary);color:#fff;font-weight:800;border-radius:8px;padding:4px 10px;font-family:'Inter',sans-serif;letter-spacing:-.02em}
.nav-drawer{display:flex;align-items:center;gap:20px;flex:1}
.nav-cats{display:flex;gap:4px;flex:1;overflow-x:auto;scrollbar-width:none}
.nav-cats::-webkit-scrollbar{display:none}
.nav-cats a{padding:8px 12px;border-radius:8px;font-size:.9rem;font-weight:600;color:var(--muted);white-space:nowrap}
.nav-cats a:hover,.nav-cats a.active{color:var(--primary);background:var(--soft)}
.search-box{display:flex;align-items:center}
.search-box input{border:1px solid var(--line);border-radius:20px;padding:7px 14px;font-size:.85rem;width:150px;outline:none}
.search-box input:focus{border-color:var(--primary);width:190px}
.menu-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;margin-left:auto;cursor:pointer;border-radius:8px;flex:0 0 auto}
.menu-toggle span{display:block;height:2px;width:22px;margin:0 auto;background:var(--text);border-radius:2px;transition:.25s}
.nav-cb:checked~.menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-cb:checked~.menu-toggle span:nth-child(2){opacity:0}
.nav-cb:checked~.menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero grid */
.section-title{display:flex;align-items:center;gap:14px;margin:30px 0 18px}
.section-title h2{font-size:1.4rem;margin:0}
.section-title .rule{flex:1;height:1px;background:var(--line)}
.section-title .more{font-size:.85rem;color:var(--primary);font-weight:600;font-family:'Inter',sans-serif}
.grid{display:grid;gap:22px}
.grid-hero{grid-template-columns:2fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.layout{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start;margin:28px 0}

/* Cards */
.card{display:flex;flex-direction:column;background:var(--bg);border-radius:var(--radius);overflow:hidden;transition:transform .15s}
.card:hover{transform:translateY(-3px)}
.card .thumb{aspect-ratio:16/9;overflow:hidden;background:var(--soft)}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.card:hover .thumb img{transform:scale(1.04)}
.cat-badge{display:inline-block;background:var(--primary);color:#fff;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;border-radius:5px}
.card .body{padding:12px 4px}
.card h3{font-size:1.05rem;margin:8px 0 6px}
.card:hover h3{color:var(--primary)}
.card .excerpt{color:var(--muted);font-size:.9rem;font-family:'Inter',sans-serif}
.card .meta{color:var(--muted);font-size:.78rem;margin-top:8px;font-family:'Inter',sans-serif}
.card.hero .thumb{aspect-ratio:16/10}
.card.hero h3{font-size:1.9rem;line-height:1.15}
.card.small{flex-direction:row;gap:12px}
.card.small .thumb{width:112px;flex:0 0 112px;aspect-ratio:1;border-radius:8px}
.card.small .body{padding:0}
.card.small h3{font-size:.92rem;margin:4px 0}

/* Sidebar */
.sidebar .box{background:var(--soft);border-radius:var(--radius);padding:18px;margin-bottom:22px}
.sidebar h4{font-size:1rem;margin:0 0 14px;font-family:'Inter',sans-serif;font-weight:800}
.rank{display:flex;gap:12px;padding:10px 0;border-top:1px solid var(--line)}
.rank:first-of-type{border-top:0}
.rank .n{font-size:1.5rem;font-weight:800;color:var(--primary);font-family:'Merriweather',serif;line-height:1}
.rank a{font-size:.9rem;font-weight:600;font-family:'Inter',sans-serif}
.rank a:hover{color:var(--primary)}
.cat-list a{display:flex;justify-content:space-between;padding:9px 0;border-top:1px solid var(--line);font-weight:600;font-size:.9rem;font-family:'Inter',sans-serif}
.cat-list a:first-child{border-top:0}

/* Article */
.article{max-width:760px}
.breadcrumb{font-size:.82rem;color:var(--muted);margin:22px 0;font-family:'Inter',sans-serif}
.breadcrumb a:hover{color:var(--primary)}
.article h1{font-size:2.3rem;margin:14px 0}
.article .byline{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.85rem;font-family:'Inter',sans-serif;margin-bottom:22px}
.article .avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem}
.article .lead-img{border-radius:var(--radius);overflow:hidden;margin-bottom:26px}
.article-content{font-size:1.12rem;line-height:1.8}
.article-content p{margin:0 0 1.3rem}
.article-content h2{font-size:1.6rem;margin:2rem 0 1rem}
.article-content h3{font-size:1.3rem;margin:1.6rem 0 .8rem}
.article-content ul,.article-content ol{margin:1rem 0;padding-left:1.6rem}
.article-content li{margin-bottom:.5rem}
.article-content a{color:var(--primary);text-decoration:underline}
.article-content img{border-radius:var(--radius);margin:1.6rem 0}
.article-content blockquote{border-left:4px solid var(--primary);padding-left:1rem;margin:1.6rem 0;color:var(--muted);font-style:italic}
.source-note{margin-top:34px;padding-top:18px;border-top:1px solid var(--line);font-size:.78rem;color:var(--muted);font-family:'Inter',sans-serif}

/* Footer */
.site-footer{background:var(--accent);color:#cbd5e1;margin-top:60px;padding:44px 0 26px;font-family:'Inter',sans-serif}
.site-footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px}
.site-footer .brand{color:#fff;margin-bottom:10px}
.site-footer h5{color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;font-family:'Inter',sans-serif}
.site-footer a{display:block;padding:4px 0;font-size:.88rem;color:#cbd5e1}
.site-footer a:hover{color:#fff}
.site-footer .legal{margin-top:30px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);font-size:.8rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Pagination + buttons */
.pager{display:flex;justify-content:center;align-items:center;gap:10px;margin:34px 0;font-family:'Inter',sans-serif}
.pager a,.pager span{padding:9px 16px;border:1px solid var(--line);border-radius:8px;font-size:.88rem;font-weight:600}
.pager a:hover{border-color:var(--primary);color:var(--primary)}
.btn{display:inline-block;background:var(--primary);color:#fff;padding:11px 20px;border-radius:8px;font-weight:600;font-family:'Inter',sans-serif;border:0;cursor:pointer;font-size:.9rem}
.btn:hover{filter:brightness(1.08)}
.prose-page{max-width:760px;font-family:'Inter',sans-serif}
.prose-page h1{font-size:2rem;margin:24px 0 16px}
.prose-page h2{font-size:1.3rem;margin:1.8rem 0 .7rem}
.prose-page p,.prose-page li{color:#374151;margin-bottom:1rem}

@media(max-width:860px){
  .layout{grid-template-columns:1fr}
  .grid-hero,.grid-3,.grid-2,.site-footer .cols{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .article h1{font-size:1.7rem}
  .card.hero h3{font-size:1.4rem}
  .menu-toggle{display:flex}
  .nav-drawer{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--bg);border-bottom:1px solid var(--line);box-shadow:0 12px 24px rgba(0,0,0,.08);padding:8px}
  .nav-cb:checked~.nav-drawer{display:flex}
  .nav-cats{flex-direction:column;overflow:visible;gap:2px;flex:none}
  .nav-cats a{padding:12px 14px;font-size:1rem;border-radius:8px}
  .nav-cats a:not(:last-child){border-bottom:1px solid var(--soft)}
  .search-box{display:flex;padding:8px 6px 4px}
  .search-box input{width:100%}
  .search-box input:focus{width:100%}
}
@media(max-width:560px){.grid-3{grid-template-columns:1fr}}
