/* CloudVai NewsPortal CMS 1.0 — styled to match React preview */
@import url('https://fonts.googleapis.com/css2?family=Hind+Siliguri:wght@400;500;600;700&family=Noto+Sans+Bengali:wght@400;500;600;700;800&display=swap');

:root{
  --primary:#b91c1c;          /* risingbd red */
  --primary-dark:#7f1d1d;
  --primary-fg:#ffffff;
  --bg:#fafafa;
  --card:#ffffff;
  --fg:#1f2937;
  --muted:#6b7280;
  --border:#e5e7eb;
  --accent:#f1f5f9;
  --slate-900:#0f172a;
  --slate-800:#1e293b;
  --emerald:#10b981;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);
  font-family:'Hind Siliguri','Noto Sans Bengali',system-ui,sans-serif;font-size:15px;line-height:1.55}
a{color:inherit;text-decoration:none}
a:hover{color:var(--primary)}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 14px}

/* ============ TOPBAR (red, matches React) ============ */
.topbar{background:var(--primary-dark);color:#fff;font-size:12px;padding:6px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.topbar .tb-date{opacity:.9}
.topbar .tb-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.topbar .tb-right a{color:#fff;opacity:.9}
.topbar .tb-right a:hover{opacity:1}
.topbar .epaper{background:rgba(255,255,255,.15);padding:2px 8px;border-radius:3px;font-weight:600}
.topbar .epaper:hover{background:rgba(255,255,255,.28)}
.topbar .lang-pill{background:var(--primary);padding:2px 8px;border-radius:3px;display:inline-flex;gap:4px;font-weight:700}
.topbar .lang-pill a.on{text-decoration:underline}
.topbar .sep{opacity:.45}

/* ============ LOGO BAR ============ */
.site-header{background:var(--card);border-bottom:1px solid var(--border);padding:14px 0}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.site-header .logo{font-family:'Noto Sans Bengali',serif;color:var(--primary);font-weight:800;font-size:30px;letter-spacing:-.5px}
.site-header .logo span{color:#111827}
.site-header .tagline-box{flex:1;max-width:420px;background:var(--accent);border-radius:3px;padding:8px 12px;
  color:var(--muted);font-style:italic;font-size:12.5px;text-align:center}
.site-header .search-btn{background:transparent;border:none;font-size:16px;padding:8px;cursor:pointer;border-radius:4px}
.site-header .search-btn:hover{background:var(--accent)}

/* ============ MAIN NAV ============ */
.main-nav{background:var(--primary);position:sticky;top:0;z-index:30;box-shadow:0 1px 0 rgba(0,0,0,.08)}
.main-nav .container{display:flex;flex-wrap:wrap;gap:0;overflow-x:auto}
.main-nav a{color:#fff;padding:11px 14px;font-weight:600;font-size:14px;white-space:nowrap;border-right:1px solid rgba(255,255,255,.12)}
.main-nav a:hover,.main-nav a.active{background:var(--primary-dark);color:#fff}

/* ============ TICKER ============ */
.ticker{background:#fff;border-bottom:1px solid var(--border);padding:8px 0;display:flex;align-items:center;overflow:hidden}
.ticker .lbl{background:var(--primary);color:#fff;font-weight:700;font-size:12px;padding:5px 12px;margin-right:12px;flex-shrink:0;letter-spacing:.5px}
.ticker .track{display:flex;gap:36px;white-space:nowrap;animation:scroll 50s linear infinite;font-size:14px}
.ticker .track a{color:#374151}
.ticker .track a:hover{color:var(--primary)}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============ HOMEPAGE GRID ============ */
.hero-grid{display:grid;grid-template-columns:2fr 1fr;gap:22px;margin:20px 0}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr}}
.lead{background:#fff;border:1px solid var(--border);border-radius:4px;overflow:hidden}
.lead img{aspect-ratio:16/9;object-fit:cover;width:100%}
.lead .body{padding:16px}
.lead .cat{display:inline-block;background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:2px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.lead h2{margin:0 0 8px;font-size:24px;line-height:1.3}
.lead h2 a:hover{color:var(--primary)}
.lead .meta{color:var(--muted);font-size:13px}

.side-list{border-left:3px solid var(--border);padding-left:14px}
.side-list .item{padding:10px 0;border-bottom:1px solid var(--border);display:flex;gap:10px}
.side-list .item:last-child{border-bottom:none}
.side-list .item img{width:90px;height:60px;object-fit:cover;flex-shrink:0;border-radius:2px}
.side-list .item h4{margin:0;font-size:14px;line-height:1.4;font-weight:600}
.side-list .item h4 a:hover{color:var(--primary)}

/* ============ SECTIONS ============ */
.section{margin:30px 0}
.section-title{position:relative;font-size:18px;font-weight:800;padding:8px 14px;background:var(--primary);color:#fff;display:inline-block;margin-bottom:14px;letter-spacing:.3px}
.section-title::after{content:'';position:absolute;left:100%;top:0;border:18px solid transparent;border-left-color:var(--primary)}

.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--border);border-radius:4px;overflow:hidden;transition:box-shadow .2s}
.card:hover{box-shadow:0 4px 14px rgba(0,0,0,.08)}
.card img{aspect-ratio:16/10;object-fit:cover;width:100%}
.card .card-body{padding:12px}
.card .cat{display:inline-block;color:var(--primary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.card h3{font-size:15px;line-height:1.4;margin:0 0 6px}
.card h3 a:hover{color:var(--primary)}
.card .meta{color:var(--muted);font-size:12px}

/* main + sidebar layout */
.layout{display:grid;grid-template-columns:1fr 320px;gap:28px;margin-top:24px}
@media(max-width:1000px){.layout{grid-template-columns:1fr}}
.sidebar .widget{background:#fff;border:1px solid var(--border);border-radius:4px;margin-bottom:18px}
.sidebar .widget h3{margin:0;background:var(--primary);color:#fff;padding:9px 12px;font-size:14px;letter-spacing:.3px}
.sidebar .widget ol,.sidebar .widget ul{list-style:none;margin:0;padding:0}
.sidebar .widget li{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;gap:10px;font-size:14px;line-height:1.45}
.sidebar .widget li:last-child{border-bottom:none}
.sidebar .widget ol li .n{color:var(--primary);font-weight:800;font-size:22px;line-height:1;width:24px;flex-shrink:0}
.sidebar .widget li a:hover{color:var(--primary)}

/* ============ ARTICLE ============ */
.article{background:#fff;border:1px solid var(--border);border-radius:4px;padding:22px;margin:20px 0;max-width:820px}
.article h1{font-size:28px;line-height:1.3;margin:6px 0 10px}
.article .meta{color:var(--muted);font-size:13px;padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:14px}
.article .featured{margin:14px 0}
.article .featured img{border-radius:3px}
.article .body{font-size:17px;line-height:1.85}
.article .body p{margin:0 0 14px}
.article .body img{margin:14px 0;border-radius:3px}
.article .body a{color:var(--primary);text-decoration:underline}
.article .body blockquote{border-left:4px solid var(--primary);padding:6px 14px;color:#374151;background:#fef2f2;margin:14px 0}

/* ============ FOOTER ============ */
.site-footer{background:var(--slate-900);color:#cbd5e1;margin-top:40px;padding:30px 0 0}
.site-footer .container{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
@media(max-width:780px){.site-footer .container{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:14px;margin:0 0 10px;border-bottom:2px solid var(--primary);padding-bottom:6px;display:inline-block}
.site-footer a{color:#cbd5e1}
.site-footer a:hover{color:#fff}
.support-bar{background:#0b1220;color:#94a3b8;text-align:center;padding:14px;font-size:13px;margin-top:24px}
.support-bar a{color:var(--emerald);font-weight:600}

/* ============ ADMIN ============ */
.cv-banner{background:linear-gradient(90deg,#0f172a 0%,#1e293b 50%,#0f172a 100%);color:#fff;border-bottom:2px solid var(--emerald);
  padding:12px 18px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;position:sticky;top:0;z-index:50;box-shadow:0 2px 12px rgba(0,0,0,.2)}
.cv-banner .left{display:flex;align-items:center;gap:12px}
.cv-banner .badge-ico{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:6px 10px;border-radius:10px;font-size:22px}
.cv-banner .welcome{line-height:1.2}
.cv-banner .welcome small{display:block;text-transform:uppercase;letter-spacing:1.5px;font-size:10.5px;color:rgba(255,255,255,.75)}
.cv-banner .welcome b{font-size:14px;font-weight:600}
.cv-banner .spacer{flex:1}
.cv-banner .links{display:flex;flex-wrap:wrap;gap:6px}
.cv-banner .links a{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:#fff;padding:6px 12px;border-radius:999px;font-size:12px;display:inline-flex;align-items:center;gap:6px}
.cv-banner .links a:hover{background:rgba(255,255,255,.18)}
.cv-banner .links a.site{background:#fff;color:#047857;font-weight:700;border-color:#fff}
.cv-banner .links a.site:hover{background:#ecfdf5}

.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 130px);background:#f1f5f9}
@media(max-width:820px){.admin-shell{grid-template-columns:1fr}}
.admin-side{background:#fff;border-right:1px solid var(--border);padding:14px 0}
.admin-side .brand{padding:0 16px 12px;border-bottom:1px solid var(--border);color:var(--primary);font-weight:800;font-size:16px;margin-bottom:8px}
.admin-side a{display:flex;align-items:center;gap:8px;padding:9px 16px;color:#334155;font-weight:500;font-size:14px;border-left:3px solid transparent}
.admin-side a:hover{background:#f8fafc;color:var(--primary)}
.admin-side a.active{background:#fef2f2;color:var(--primary);border-left-color:var(--primary)}
.admin-main{padding:22px}
.admin-card{background:#fff;border:1px solid var(--border);border-radius:6px;padding:18px;margin-bottom:18px;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.admin-card h2{margin:0 0 8px;font-size:18px;color:#0f172a}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
@media(max-width:820px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:linear-gradient(135deg,#fff,#fafafa);border:1px solid var(--border);border-radius:6px;padding:16px;border-left:4px solid var(--primary)}
.stat .num{font-size:28px;font-weight:800;color:var(--primary)}
.stat .lbl{color:var(--muted);font-size:13px;margin-top:2px}

table{width:100%;border-collapse:collapse;font-size:14px}
table th{text-align:left;background:#f8fafc;padding:10px;border-bottom:1px solid var(--border);font-weight:600;color:#475569;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
table td{padding:10px;border-bottom:1px solid var(--border)}
table tr:hover td{background:#fafafa}

.btn{background:var(--primary);color:#fff;border:none;padding:9px 16px;border-radius:4px;font-weight:600;cursor:pointer;font-size:14px;display:inline-block;text-decoration:none}
.btn:hover{background:var(--primary-dark);color:#fff}
.btn-sec{background:#e2e8f0;color:#0f172a}
.btn-sec:hover{background:#cbd5e1;color:#0f172a}

input[type=text],input[type=email],input[type=password],input[type=number],input[type=url],textarea,select{
  width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:4px;font:inherit;background:#fff;color:#0f172a}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(185,28,28,.12)}
label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:5px}

.badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:600;text-transform:uppercase}
.badge-pub{background:#dcfce7;color:#166534}
.badge-draft{background:#fef3c7;color:#92400e}

.admin-footer{background:var(--slate-900);color:#94a3b8;text-align:center;padding:14px;font-size:12px}
.admin-footer a{color:var(--emerald);font-weight:600}

/* ============================================================
   ADMIN PANEL (matches React preview exactly)
   ============================================================ */
.admin-body{margin:0;background:#f8fafc;font-family:'Hind Siliguri','Noto Sans Bengali',system-ui,sans-serif;color:#0f172a}
.ad-wrap{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
@media(max-width:900px){.ad-wrap{grid-template-columns:1fr}}

/* LEFT SIDEBAR */
.ad-side{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column}
.ad-brand{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:8px;height:56px}
.ad-brand .logo{font-family:'Noto Sans Bengali',serif;color:#b91c1c;font-weight:800;font-size:20px;letter-spacing:-.3px;text-decoration:none}
.ad-brand .pill{background:#f1f5f9;color:#475569;font-size:11px;padding:3px 8px;border-radius:3px;font-weight:600}
.ad-nav{padding:10px 8px;display:flex;flex-direction:column;gap:2px}
.ad-nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:3px;color:#334155;font-weight:500;font-size:14px;text-decoration:none;transition:background .15s}
.ad-nav a svg{width:16px;height:16px;flex-shrink:0;color:#64748b}
.ad-nav a:hover{background:#f1f5f9;color:#0f172a}
.ad-nav a:hover svg{color:#0f172a}
.ad-nav a.active{background:#b91c1c;color:#fff}
.ad-nav a.active svg{color:#fff}
.ad-nav a.ghost{margin-top:18px;color:#64748b}

/* RIGHT COLUMN */
.ad-main{display:flex;flex-direction:column;min-width:0;background:#f8fafc}

/* CloudVai Banner — only spans main column */
.cv-banner{background:linear-gradient(90deg,#0f172a,#1e293b 50%,#0f172a);color:#fff;
  padding:14px 24px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  border-bottom:2px solid #10b981;box-shadow:0 2px 12px rgba(0,0,0,.15)}
.cv-banner .left{display:flex;align-items:center;gap:14px}
.cv-banner .logo-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);padding:6px 12px;border-radius:10px;backdrop-filter:blur(6px)}
.cv-banner .logo-box img{height:38px;width:auto;display:block}
.cv-banner .welcome{line-height:1.2}
.cv-banner .welcome small{display:block;text-transform:uppercase;letter-spacing:2px;font-size:10.5px;color:rgba(255,255,255,.78);margin-bottom:2px}
.cv-banner .welcome b{font-size:15px;font-weight:600}
.cv-banner .spacer{flex:1}
.cv-banner .links{display:flex;flex-wrap:wrap;gap:8px}
.cv-banner .links a{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
  color:#fff;padding:7px 14px;border-radius:999px;font-size:12.5px;display:inline-flex;align-items:center;gap:7px;text-decoration:none;transition:background .15s}
.cv-banner .links a:hover{background:rgba(255,255,255,.18)}
.cv-banner .links a.site{background:#fff;color:#047857;font-weight:700;border-color:#fff}
.cv-banner .links a.site:hover{background:#ecfdf5}

/* Sub header */
.ad-subheader{background:#fff;border-bottom:1px solid #e2e8f0;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;height:56px}
.ad-subheader h1{margin:0;font-size:16px;font-weight:700;color:#0f172a}
.ad-subheader .avatar{height:32px;width:32px;border-radius:50%;background:#b91c1c;color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}

/* Content */
.ad-content{flex:1;padding:22px 24px}
.ad-foot{background:#fff;border-top:1px solid #e2e8f0;padding:12px 24px;display:flex;justify-content:space-between;color:#64748b;font-size:12px}
.ad-foot a{color:#b91c1c;font-weight:700;text-decoration:none}
.ad-foot a:hover{text-decoration:underline}

/* Page head */
.page-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px;gap:14px;flex-wrap:wrap}
.page-head h2{margin:0 0 4px;font-size:22px;font-weight:800;color:#0f172a}
.page-head p{margin:0;color:#64748b;font-size:13.5px}
.btn-primary{background:#b91c1c;color:#fff;padding:10px 18px;border-radius:6px;font-weight:600;text-decoration:none;font-size:14px;border:none;cursor:pointer;box-shadow:0 1px 2px rgba(185,28,28,.25)}
.btn-primary:hover{background:#991b1b;color:#fff}

/* Stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
@media(max-width:1100px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.stat .ico{width:44px;height:44px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;color:#fff}
.stat .ico svg{width:22px;height:22px}
.stat .ico-blue{background:#3b82f6}
.stat .ico-emerald{background:#10b981}
.stat .ico-orange{background:#f59e0b}
.stat .ico-red{background:#b91c1c}
.stat .lbl{color:#64748b;font-size:13px;margin-bottom:2px}
.stat .num{font-size:22px;font-weight:800;color:#0f172a;letter-spacing:-.5px}

/* Dashboard 2-col */
.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:1100px){.dash-cols{grid-template-columns:1fr}}
.panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.panel h3{margin:0;padding:14px 16px;border-bottom:1px solid #e2e8f0;font-size:14px;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:8px}
.panel h3 svg{color:#b91c1c}

.recent-list{list-style:none;margin:0;padding:0}
.recent-list li{padding:12px 16px;border-bottom:1px solid #f1f5f9;display:flex;gap:12px;align-items:center}
.recent-list li:last-child{border-bottom:none}
.recent-list .thumb{width:64px;height:48px;background:#f1f5f9;border-radius:4px;overflow:hidden;flex-shrink:0}
.recent-list .thumb img{width:100%;height:100%;object-fit:cover}
.recent-list .ttl{font-size:14px;font-weight:600;color:#0f172a;text-decoration:none;display:block;line-height:1.4}
.recent-list .ttl:hover{color:#b91c1c}
.recent-list .meta{color:#64748b;font-size:12px;margin-top:3px}

.popular-list{list-style:none;margin:0;padding:0}
.popular-list li{padding:12px 16px;border-bottom:1px solid #f1f5f9;display:flex;gap:12px;align-items:center;font-size:14px}
.popular-list li:last-child{border-bottom:none}
.popular-list .n{color:#b91c1c;font-weight:800;font-size:20px;width:24px;flex-shrink:0;line-height:1}
.popular-list li a{flex:1;color:#0f172a;font-weight:600;text-decoration:none;line-height:1.4}
.popular-list li a:hover{color:#b91c1c}
.popular-list .v{color:#94a3b8;font-size:12px;flex-shrink:0}

/* Generic admin cards/tables (for sub-pages) */
.admin-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:18px;margin-bottom:16px;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.admin-card h2{margin:0 0 12px;font-size:17px;color:#0f172a}
.admin-card table{width:100%;border-collapse:collapse;font-size:14px}
.admin-card th{text-align:left;background:#f8fafc;padding:10px;border-bottom:1px solid #e2e8f0;font-weight:600;color:#475569;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.admin-card td{padding:10px;border-bottom:1px solid #f1f5f9}
.admin-card tr:hover td{background:#fafbfc}
.btn{background:#b91c1c;color:#fff;border:none;padding:9px 16px;border-radius:6px;font-weight:600;cursor:pointer;font-size:14px;display:inline-block;text-decoration:none}
.btn:hover{background:#991b1b;color:#fff}
.badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:600;text-transform:uppercase}
.badge-pub{background:#dcfce7;color:#166534}
.badge-draft{background:#fef3c7;color:#92400e}

/* Homepage match React preview */
.more-title{margin:0 0 10px;font-size:13px;font-weight:800;border-left:4px solid var(--primary);padding:2px 0 2px 10px;text-transform:uppercase;letter-spacing:.5px;color:#0f172a}
.cat-section{margin:28px 0}
.cat-section-head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:16px}
.cat-section-head .section-title-line{margin:0;font-size:18px;font-weight:800;color:#0f172a;border-left:4px solid var(--primary);padding-left:10px;line-height:1.1}
.cat-section-head .see-all{color:var(--primary);font-weight:700;font-size:12px;text-decoration:none}
.cat-section-head .see-all:hover{text-decoration:underline}
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:760px){.cat-grid{grid-template-columns:1fr}}
.cat-lead img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:3px;display:block}
.cat-lead h3{margin:10px 0 6px;font-size:18px;line-height:1.35;font-weight:800}
.cat-lead h3 a{color:#0f172a}
.cat-lead h3 a:hover{color:var(--primary)}
.cat-lead p{margin:0 0 6px;color:#4b5563;font-size:14px;line-height:1.5}
.cat-lead .meta{color:var(--muted);font-size:12px}
.cat-list .item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.cat-list .item:last-child{border-bottom:none}
.cat-list .item img{width:96px;height:64px;object-fit:cover;border-radius:2px;flex-shrink:0}
.cat-list .item h4{margin:0;font-size:14px;line-height:1.4;font-weight:700}
.cat-list .item h4 a{color:#0f172a}
.cat-list .item h4 a:hover{color:var(--primary)}
.ad-slot{margin:16px 0;text-align:center}
@media(min-width:1000px){.sidebar{position:sticky;top:170px;align-self:start}}

/* ===== React-style admin list (parity with preview) ===== */
.page-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;margin:4px 0 16px}
.page-title{margin:0;font-size:22px;font-weight:800;color:#0f172a;letter-spacing:-.2px}
.page-sub{margin:2px 0 0;color:#64748b;font-size:13px}
.btn-primary{display:inline-flex;align-items:center;gap:6px;background:#b91c1c;color:#fff;padding:9px 14px;border-radius:4px;font-weight:600;text-decoration:none;font-size:13px;border:none;cursor:pointer}
.btn-primary:hover{background:#991b1b;color:#fff}

.data-card{background:#fff;border:1px solid #e2e8f0;border-radius:4px;overflow:hidden}
.data-toolbar{display:flex;gap:8px;padding:12px;border-bottom:1px solid #e2e8f0}
.data-toolbar .search{position:relative;flex:1;max-width:320px}
.data-toolbar .search svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:#94a3b8}
.data-toolbar .search input{width:100%;padding:8px 10px 8px 30px;font-size:13px;border:1px solid #e2e8f0;border-radius:3px;background:#fff}
.data-toolbar select{padding:8px 10px;font-size:13px;border:1px solid #e2e8f0;border-radius:3px;background:#fff}

.data-scroll{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:13.5px}
.data-table thead{background:#f1f5f9}
.data-table th{text-align:left;padding:10px 14px;font-weight:600;color:#334155;font-size:12px;text-transform:none;letter-spacing:0;border-bottom:1px solid #e2e8f0}
.data-table td{padding:12px 14px;border-bottom:1px solid #e2e8f0;vertical-align:middle}
.data-table tr:last-child td{border-bottom:0}
.data-table tbody tr:hover{background:#f8fafc}
.ta-right{text-align:right}
.nowrap{white-space:nowrap}
.muted{color:#64748b}
.empty{text-align:center;color:#94a3b8;padding:36px 10px}

.cell-title{max-width:520px}
.ttl-wrap{display:flex;align-items:center;gap:10px}
.thumb{width:40px;height:40px;border-radius:3px;object-fit:cover;flex-shrink:0;background:#e2e8f0}
.thumb-ph{background:linear-gradient(135deg,#e2e8f0,#cbd5e1)}
.ttl{font-weight:600;color:#0f172a;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.chip-draft{font-size:10px;font-weight:800;text-transform:uppercase;background:rgba(234,179,8,.18);color:#a16207;padding:2px 6px;border-radius:3px;flex-shrink:0}
.chip-cat{display:inline-block;font-size:11.5px;background:#f1f5f9;color:#334155;padding:3px 8px;border-radius:3px}

.icon-btn{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:3px;color:#475569;text-decoration:none;margin-left:2px;transition:background .15s,color .15s}
.icon-btn:hover{background:#f1f5f9;color:#0f172a}
.icon-btn.danger:hover{background:#b91c1c;color:#fff}

/* === Enhanced styles for v1.0 === */
.layout-boxed .container{max-width:1200px;margin:0 auto;padding:0 16px}
.layout-full .container{max-width:1600px;margin:0 auto;padding:0 20px}
.ad-strip{background:#fef3c7;padding:8px;text-align:center;font-size:12px;color:#92400e;border-bottom:1px solid #fcd34d}
.ad-slot{text-align:center;background:#f8fafc;padding:10px;border:1px dashed #cbd5e1;border-radius:4px}
.ad-slot img{max-width:100%;height:auto}

.hero-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin:16px 0}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}}
.hero-card{display:block;position:relative;color:#fff;text-decoration:none;border-radius:6px;overflow:hidden;background:#0f172a;aspect-ratio:16/10}
.hero-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.7}
.hero-meta{position:relative;padding:20px;display:flex;flex-direction:column;justify-content:flex-end;height:100%;background:linear-gradient(transparent 40%,rgba(0,0,0,.85))}
.hero-meta h2{font-size:26px;font-weight:800;line-height:1.4;margin:8px 0}
.hero-meta p{font-size:13px;opacity:.9}
.cat-pill{display:inline-block;background:var(--primary,#e11d48);padding:4px 10px;font-size:11px;font-weight:600;width:fit-content}

.news-card{display:block;background:#fff;border:1px solid #e5e7eb;border-radius:4px;overflow:hidden;text-decoration:none;color:inherit}
.news-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.news-card h4{padding:10px;font-size:14px;font-weight:600;line-height:1.5}
.hero-side{background:#fff;border:1px solid #e5e7eb;padding:14px;border-radius:4px}
.sb-h{border-bottom:2px solid var(--primary,#e11d48);padding-bottom:6px;font-size:15px;margin-bottom:10px}
.sb-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid #f1f5f9;font-size:13px;color:#1e293b;text-decoration:none}
.sb-item .num{color:var(--primary,#e11d48);font-weight:700}

.cat-section{margin:24px 0}
.cat-h{border-left:4px solid var(--primary,#e11d48);padding-left:10px;font-size:18px;margin-bottom:12px}
.cat-h a{color:#0f172a;text-decoration:none}
.cat-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:16px}
@media(max-width:768px){.cat-grid{grid-template-columns:1fr}}
.cat-main{display:block;text-decoration:none;color:inherit;background:#fff;border:1px solid #e5e7eb;border-radius:4px;overflow:hidden}
.cat-main img{width:100%;aspect-ratio:16/10;object-fit:cover}
.cat-main h3{padding:10px 12px 4px;font-size:16px;font-weight:700;line-height:1.4}
.cat-main p{padding:0 12px 12px;font-size:13px;color:#475569}
.cat-list{list-style:none}
.cat-list li a{display:flex;gap:10px;padding:10px;border-bottom:1px solid #f1f5f9;text-decoration:none;color:#1e293b}
.cat-list li img{width:80px;height:60px;object-fit:cover;border-radius:3px;flex-shrink:0}
.cat-list li span{font-size:13px;font-weight:600;line-height:1.5}

.btn-action{transition:opacity .2s}
.btn-action:hover{opacity:.85}

/* === Responsive header / mobile nav === */
.site-header .container{display:flex;align-items:center;gap:16px;padding:14px 16px;position:relative;flex-wrap:wrap}
.site-header .logo{font-weight:900;font-size:28px;color:var(--primary,#b91c1c);text-decoration:none;display:flex;align-items:center;gap:4px}
.site-header .logo span{color:#0f172a}
.site-header .tagline-box{flex:1;color:#475569;font-size:13px;border-left:2px solid #e5e7eb;padding-left:12px;display:none}
@media(min-width:900px){.site-header .tagline-box{display:block}}
.site-header .search-form{display:flex;border:1px solid #e5e7eb;border-radius:4px;overflow:hidden;flex:1;max-width:280px;margin-left:auto}
.site-header .search-form input{border:0;padding:8px 10px;outline:none;flex:1;font-family:inherit;font-size:13px;min-width:0}
.site-header .search-btn{background:var(--primary,#b91c1c);color:#fff;border:0;padding:0 14px;cursor:pointer}
.nav-toggle{display:none;background:transparent;border:0;width:42px;height:42px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:0}
.nav-toggle span{display:block;width:24px;height:3px;background:#0f172a;border-radius:2px;transition:transform .2s,opacity .2s;margin:0 auto}
.nav-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:768px){
  .nav-toggle{display:flex}
  .site-header .search-form{order:5;max-width:none;flex-basis:100%;margin-left:0}
}

.main-nav{background:var(--primary,#b91c1c);color:#fff}
.main-nav .nav-inner{display:flex;flex-wrap:wrap;gap:0}
.main-nav a{color:#fff;text-decoration:none;padding:12px 16px;font-size:14px;font-weight:500;border-right:1px solid rgba(255,255,255,.12)}
.main-nav a:hover,.main-nav a.active{background:rgba(0,0,0,.18)}
@media(max-width:768px){
  .main-nav{display:none}
  .main-nav.open{display:block}
  .main-nav .nav-inner{flex-direction:column;padding:0}
  .main-nav a{border-right:0;border-bottom:1px solid rgba(255,255,255,.12);width:100%}
}

.topbar{background:#0f172a;color:#cbd5e1;font-size:12px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding:6px 16px;flex-wrap:wrap;gap:8px}
.topbar a{color:#cbd5e1;text-decoration:none;margin:0 4px}
.topbar a.epaper{background:var(--primary,#b91c1c);color:#fff;padding:3px 10px;border-radius:3px}
.topbar .lang-pill a{padding:0 4px}
.topbar .lang-pill a.on{color:#fff;font-weight:700}
.topbar .sep{opacity:.4;margin:0 4px}

.ticker{background:#f1f5f9;border-bottom:1px solid #e2e8f0}
.ticker-inner{display:flex;align-items:center;gap:10px;padding:6px 16px;overflow:hidden}
.ticker .lbl{background:var(--primary,#b91c1c);color:#fff;padding:5px 10px;font-size:12px;font-weight:700;flex-shrink:0;border-radius:3px}
.ticker-viewport{flex:1;overflow:hidden;white-space:nowrap}
.ticker .track{display:inline-flex;gap:36px;animation:tk 60s linear infinite}
.ticker .track a{color:#0f172a;text-decoration:none;font-size:13px}
@keyframes tk{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* === Single article === */
.single-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;margin:20px 0}
@media(max-width:900px){.single-layout{grid-template-columns:1fr}}
.article{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:22px}
.article h1{font-size:30px;font-weight:800;line-height:1.4;margin:8px 0 10px}
@media(max-width:640px){.article{padding:14px}.article h1{font-size:22px}}
.article .meta{color:#64748b;font-size:13px;padding-bottom:10px;border-bottom:1px solid #f1f5f9;margin-bottom:14px}
.action-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.btn-action{padding:6px 12px;font-size:12px;border-radius:3px;color:#fff;text-decoration:none;font-weight:600}
.ba-dark{background:#0f172a}.ba-primary{background:var(--primary,#b91c1c)}.ba-fb{background:#1877f2}.ba-wa{background:#22c55e}
.featured img{width:100%;border-radius:4px;margin-bottom:14px}
.excerpt-lead{font-size:17px;line-height:1.7;color:#334155;font-weight:600;padding:12px 14px;background:#f8fafc;border-left:3px solid var(--primary);border-radius:3px;margin-bottom:14px}
.body{font-size:16px;line-height:1.95;color:#1e293b}
.body p{margin:0 0 14px}
.body img{max-width:100%;height:auto;border-radius:4px;margin:10px 0}
.body iframe{max-width:100%;width:100%;aspect-ratio:16/9;height:auto;border:0;margin:10px 0}
.body a{color:var(--primary);text-decoration:underline}
.cat-pill-sm{display:inline-block;background:var(--primary,#b91c1c);color:#fff;padding:3px 10px;font-size:11px;font-weight:700;border-radius:3px}
.tag-row{margin-top:20px;padding-top:14px;border-top:1px solid #f1f5f9;display:flex;gap:6px;flex-wrap:wrap;align-items:center;font-size:13px}
.tag-chip{background:#f1f5f9;color:#334155;padding:3px 10px;border-radius:20px;font-size:12px;text-decoration:none}
.related-h{margin:20px 0 10px;border-left:4px solid var(--primary);padding-left:8px}
.rel-card{display:block;background:#fff;border:1px solid #e5e7eb;border-radius:4px;overflow:hidden;text-decoration:none;color:inherit}
.rel-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.rel-card h4{padding:10px;font-size:13px;font-weight:600;line-height:1.5}
.grid{display:grid;gap:12px}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:768px){.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.grid-3{grid-template-columns:1fr}}
.single-side .side-widget{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:14px}
.single-side h4{border-bottom:2px solid var(--primary);padding-bottom:6px;margin-bottom:10px;font-size:15px}
.pop-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid #f1f5f9;color:#1e293b;text-decoration:none;font-size:13px;line-height:1.5}
.pop-item .n{color:var(--primary);font-weight:800;flex-shrink:0}

/* === E-Paper === */
.epaper-wrap{background:#fff;padding:24px;margin:20px 0;border:1px solid #e5e7eb}
.epaper-head{text-align:center;border-bottom:4px double #000;padding-bottom:14px;margin-bottom:18px}
.epaper-head h1{font-size:42px;font-weight:900;letter-spacing:-1px;margin:0;font-family:Georgia,'Noto Serif Bengali',serif}
.epaper-head p{color:#475569;margin:4px 0 0}
.epaper-head small{color:#64748b;font-size:12px}
@media(max-width:640px){.epaper-wrap{padding:14px}.epaper-head h1{font-size:26px}}
.ep-lead{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;text-decoration:none;color:#0f172a;border-bottom:1px solid #e5e7eb;padding-bottom:18px;margin-bottom:18px}
@media(max-width:768px){.ep-lead{grid-template-columns:1fr}}
.ep-lead img{width:100%;aspect-ratio:16/10;object-fit:cover}
.ep-lead h2{font-size:24px;font-weight:800;line-height:1.45;margin:6px 0 8px}
.ep-lead p{color:#475569;font-size:14px;line-height:1.7}
.ep-cat{display:inline-block;background:var(--primary,#b91c1c);color:#fff;padding:2px 10px;font-size:11px;font-weight:700}
.ep-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1024px){.ep-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.ep-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.ep-grid{grid-template-columns:1fr}}
.ep-tile{display:block;text-decoration:none;color:#0f172a;border:1px solid #e5e7eb;padding:8px;background:#fafafa}
.ep-tile img{width:100%;aspect-ratio:4/3;object-fit:cover;margin-bottom:8px;display:block}
.ep-tile h3{font-size:14px;font-weight:700;line-height:1.5;margin:0 0 6px}
.ep-tile p{font-size:12px;color:#64748b;line-height:1.6;margin:0}

/* === Responsive home/cat grids === */
@media(max-width:640px){
  .hero-meta h2{font-size:20px}
  .cat-h{font-size:16px}
  .cat-main h3{font-size:15px}
}
