/* ===== BASE ===== */
:root {
  --red: #c0392b;
  --red-dark: #96281b;
  --red-light: #f8d7da;
  --dark: #1a1a2e;
  --dark2: #2d2d44;
  --gray: #555;
  --gray-light: #f5f5f5;
  --border: #e8e8e8;
  --text: #222;
  --white: #fff;
  --font-body: 'Sarabun', sans-serif;
  --font-display: 'Prompt', sans-serif;
  --shadow: 0 2px 12px rgba(0,0,0,0.1);
  --shadow-hover: 0 8px 30px rgba(0,0,0,0.15);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-body); color:var(--text); background:#f8f8f8; font-size:16px; line-height:1.6; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }

.container { max-width:1280px; margin:0 auto; padding:0 16px; }

/* ===== BREAKING BAR ===== */
.breaking-bar { background:var(--red); color:#fff; display:flex; align-items:center; overflow:hidden; height:36px; }
.breaking-label { background:var(--dark); padding:0 16px; font-weight:700; font-size:13px; white-space:nowrap; height:100%; display:flex; align-items:center; gap:6px; font-family:var(--font-display); }
.breaking-ticker { flex:1; overflow:hidden; }
.ticker-inner { display:inline-flex; animation:ticker 30s linear infinite; white-space:nowrap; padding-left:100%; }
.ticker-inner a { color:#fff; font-size:13px; font-weight:500; padding:0 8px; }
.ticker-inner a:hover { text-decoration:underline; }
@keyframes ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-100%)} }

/* ===== HEADER ===== */
.site-header { background:#fff; box-shadow:0 2px 8px rgba(0,0,0,0.08); position:sticky; top:0; z-index:100; }
.header-top { padding:12px 0; border-bottom:1px solid var(--border); }
.header-top-inner { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.site-logo a { display:flex; flex-direction:column; line-height:1; }
.logo-text { font-family:var(--font-display); font-size:2rem; font-weight:800; color:var(--red); letter-spacing:-1px; }
.logo-sub { font-size:11px; color:var(--gray); letter-spacing:2px; }
.header-right { display:flex; align-items:center; gap:16px; }
.header-search form { display:flex; }
.header-search input { border:2px solid var(--border); padding:8px 14px; border-radius:24px 0 0 24px; outline:none; font-family:var(--font-body); font-size:14px; width:220px; }
.header-search input:focus { border-color:var(--red); }
.header-search button { background:var(--red); color:#fff; border:none; padding:8px 16px; border-radius:0 24px 24px 0; cursor:pointer; }
.btn-login { background:var(--red); color:#fff; padding:8px 16px; border-radius:6px; font-size:13px; font-weight:600; display:flex; align-items:center; gap:6px; transition:.2s; }
.btn-login:hover { background:var(--red-dark); }

/* Nav */
.main-nav { background:var(--dark); }
.main-nav .container { display:flex; align-items:center; }
.nav-list { display:flex; list-style:none; overflow-x:auto; }
.nav-list a { display:block; padding:12px 16px; color:rgba(255,255,255,0.85); font-size:14px; font-weight:600; font-family:var(--font-display); white-space:nowrap; transition:.2s; }
.nav-list a:hover, .nav-list a.active { color:#fff; background:var(--red); }
.nav-toggle { display:none; background:none; border:none; color:#fff; font-size:1.3rem; padding:12px; cursor:pointer; }

/* ===== HERO ===== */
.hero-section { display:grid; grid-template-columns:2fr 1fr; gap:4px; margin:16px 0; height:420px; }
.hero-post-main { position:relative; display:block; overflow:hidden; border-radius:8px 0 0 8px; }
.hero-post-main img, .hero-placeholder { width:100%; height:100%; object-fit:cover; }
.hero-placeholder { background:var(--dark2); display:flex; align-items:center; justify-content:center; }
.hero-placeholder i { font-size:4rem; color:rgba(255,255,255,0.2); }
.hero-overlay { position:absolute; bottom:0; left:0; right:0; padding:24px 20px 20px; background:linear-gradient(transparent, rgba(0,0,0,0.85)); }
.hero-overlay h2 { color:#fff; font-family:var(--font-display); font-size:1.4rem; line-height:1.4; }
.hero-meta { display:flex; gap:16px; margin-top:8px; }
.hero-meta span { color:rgba(255,255,255,0.8); font-size:12px; display:flex; align-items:center; gap:4px; }
.badge-cat { background:var(--red); color:#fff; padding:3px 10px; border-radius:4px; font-size:11px; font-weight:700; display:inline-block; margin-bottom:8px; }
.badge-cat-sm { background:var(--red); color:#fff; padding:2px 8px; border-radius:3px; font-size:10px; font-weight:700; display:inline-block; margin-bottom:4px; }

.hero-side { display:flex; flex-direction:column; gap:4px; }
.hero-post-side { position:relative; flex:1; overflow:hidden; }
.hero-post-side:first-child { border-radius:0 8px 0 0; }
.hero-post-side:last-child { border-radius:0 0 8px 0; }
.hero-post-side img { width:100%; height:100%; object-fit:cover; }
.hero-side-placeholder { width:100%; height:100%; background:var(--dark2); display:flex; align-items:center; justify-content:center; }
.hero-side-placeholder i { font-size:1.5rem; color:rgba(255,255,255,0.2); }
.hero-side-overlay { position:absolute; bottom:0; left:0; right:0; padding:12px; background:linear-gradient(transparent, rgba(0,0,0,0.8)); }
.hero-side-overlay h4 { color:#fff; font-size:12px; line-height:1.4; }

/* ===== LAYOUT ===== */
.site-main { padding:16px 0 40px; }
.content-layout { display:grid; grid-template-columns:1fr 300px; gap:24px; margin-top:24px; }
.content-main { min-width:0; }

/* ===== SECTIONS ===== */
.section-block { margin-bottom:40px; }
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; border-bottom:3px solid var(--red); padding-bottom:8px; }
.section-title { font-family:var(--font-display); font-size:1.2rem; font-weight:800; color:var(--dark); }
.section-title span { border-left:4px solid var(--red); padding-left:10px; }
.see-all { font-size:13px; color:var(--red); display:flex; align-items:center; gap:4px; font-weight:600; }
.see-all:hover { text-decoration:underline; }

/* ===== POST CARDS ===== */
.posts-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }
.posts-grid-4 { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:16px; }

.post-card { background:#fff; border-radius:8px; overflow:hidden; box-shadow:var(--shadow); transition:.25s; }
.post-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-hover); }
.post-card-img { display:block; position:relative; height:180px; overflow:hidden; background:var(--gray-light); }
.post-card-img img { width:100%; height:100%; object-fit:cover; transition:.4s; }
.post-card:hover .post-card-img img { transform:scale(1.05); }
.post-card-img-placeholder { display:flex; align-items:center; justify-content:center; background:var(--dark2); }
.post-card-img-placeholder i { font-size:2.5rem; color:rgba(255,255,255,0.15); }
.badge { position:absolute; top:10px; left:10px; padding:3px 10px; border-radius:4px; font-size:11px; font-weight:700; }
.badge-breaking { background:var(--red); color:#fff; }
.post-card-body { padding:14px; }
.post-category { font-size:11px; font-weight:700; color:var(--red); text-transform:uppercase; letter-spacing:.5px; display:inline-block; margin-bottom:6px; }
.post-title { font-family:var(--font-display); font-size:15px; font-weight:700; line-height:1.5; margin-bottom:8px; }
.post-title a:hover { color:var(--red); }
.post-excerpt { font-size:13px; color:var(--gray); line-height:1.5; margin-bottom:8px; }
.post-meta { display:flex; gap:12px; font-size:12px; color:#999; }
.post-meta span { display:flex; align-items:center; gap:4px; }

/* ===== SIDEBAR ===== */
.sidebar { min-width:0; }
.widget { background:#fff; border-radius:8px; padding:16px; box-shadow:var(--shadow); margin-bottom:20px; }
.widget-title { font-family:var(--font-display); font-size:1rem; font-weight:800; color:var(--dark); border-left:4px solid var(--red); padding-left:10px; margin-bottom:14px; }

.popular-list { list-style:none; }
.popular-list li { display:flex; gap:10px; padding:10px 0; border-bottom:1px solid var(--border); }
.popular-list li:last-child { border-bottom:none; }
.popular-num { background:var(--red); color:#fff; border-radius:4px; min-width:24px; height:24px; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; flex-shrink:0; }
.popular-content { min-width:0; }
.popular-content a { font-size:13px; font-weight:600; line-height:1.4; display:block; }
.popular-content a:hover { color:var(--red); }
.popular-content small { color:#999; font-size:11px; display:flex; align-items:center; gap:4px; margin-top:2px; }

.cat-widget { list-style:none; }
.cat-widget li a { display:flex; align-items:center; gap:8px; padding:8px 0; border-bottom:1px solid var(--border); font-size:14px; color:var(--text); transition:.15s; }
.cat-widget li:last-child a { border-bottom:none; }
.cat-widget li a:hover, .cat-widget li a.active { color:var(--red); }
.cat-widget li a i { font-size:10px; color:var(--red); }

/* ===== SINGLE POST ===== */
.post-single { background:#fff; border-radius:8px; padding:28px; box-shadow:var(--shadow); min-width:0; }
.breadcrumb { font-size:12px; color:#999; margin-bottom:12px; display:flex; gap:6px; align-items:center; flex-wrap:wrap; }
.breadcrumb a:hover { color:var(--red); }
.post-cat-label { background:var(--red); color:#fff; padding:4px 12px; border-radius:4px; font-size:12px; font-weight:700; display:inline-block; margin-bottom:12px; }
.post-single-title { font-family:var(--font-display); font-size:1.8rem; font-weight:800; line-height:1.4; margin:12px 0; }
.post-single-excerpt { font-size:1rem; color:var(--gray); background:var(--gray-light); padding:12px 16px; border-left:4px solid var(--red); border-radius:0 6px 6px 0; margin:12px 0; }
.post-single-meta { display:flex; flex-wrap:wrap; gap:16px; font-size:13px; color:#999; margin:12px 0; padding-bottom:12px; border-bottom:1px solid var(--border); }
.post-single-meta span { display:flex; align-items:center; gap:4px; }
.post-single-image { margin:16px 0; border-radius:8px; overflow:hidden; }
.post-single-image img { width:100%; max-height:500px; object-fit:cover; }
.post-single-content { font-size:16px; line-height:1.9; color:var(--text); }
.post-single-content h2 { font-family:var(--font-display); font-size:1.4rem; margin:24px 0 12px; color:var(--dark); }
.post-single-content h3 { font-family:var(--font-display); font-size:1.2rem; margin:20px 0 10px; }
.post-single-content p { margin-bottom:16px; }
.post-single-content img { border-radius:6px; margin:16px auto; }
.post-single-content ul, .post-single-content ol { margin:12px 0 12px 24px; }
.post-single-content li { margin-bottom:6px; }

.post-share { display:flex; align-items:center; gap:10px; margin-top:24px; padding-top:20px; border-top:1px solid var(--border); flex-wrap:wrap; }
.post-share span { font-weight:700; font-size:14px; }
.share-fb { background:#1877f2; color:#fff; padding:8px 16px; border-radius:6px; font-size:13px; font-weight:600; display:flex; align-items:center; gap:6px; }
.share-tw { background:#1da1f2; color:#fff; padding:8px 16px; border-radius:6px; font-size:13px; font-weight:600; display:flex; align-items:center; gap:6px; }
.share-line { background:#06c755; color:#fff; padding:8px 16px; border-radius:6px; font-size:13px; font-weight:600; display:flex; align-items:center; gap:6px; }

/* ===== PAGE HEADER ===== */
.page-header { background:var(--dark); color:#fff; padding:24px 0; margin-bottom:0; }
.page-header h1 { font-family:var(--font-display); font-size:1.8rem; font-weight:800; }
.page-header p { color:rgba(255,255,255,0.7); font-size:14px; margin-top:4px; }

.search-box-large { margin-bottom:24px; }
.search-box-large form { display:flex; }
.search-box-large input { flex:1; border:2px solid var(--border); padding:12px 18px; font-size:16px; border-radius:8px 0 0 8px; font-family:var(--font-body); outline:none; }
.search-box-large input:focus { border-color:var(--red); }
.search-box-large button { background:var(--red); color:#fff; border:none; padding:12px 24px; border-radius:0 8px 8px 0; cursor:pointer; font-size:15px; font-family:var(--font-body); font-weight:600; display:flex; align-items:center; gap:8px; }

/* ===== PAGINATION ===== */
.pagination { display:flex; gap:6px; justify-content:center; margin-top:24px; flex-wrap:wrap; }
.page-btn { padding:8px 14px; border:2px solid var(--border); border-radius:6px; font-size:14px; font-weight:600; color:var(--text); transition:.15s; background:#fff; }
.page-btn:hover { border-color:var(--red); color:var(--red); }
.page-btn.active { background:var(--red); border-color:var(--red); color:#fff; }

/* ===== ALERTS ===== */
.alert { padding:12px 16px; border-radius:6px; margin-bottom:16px; font-size:14px; display:flex; align-items:center; gap:8px; }
.alert-success { background:#d4edda; color:#155724; border:1px solid #c3e6cb; }
.alert-error { background:#f8d7da; color:#721c24; border:1px solid #f5c6cb; }

/* ===== EMPTY STATE ===== */
.empty-state { text-align:center; padding:60px 20px; color:#ccc; }
.empty-state i { font-size:4rem; display:block; margin-bottom:16px; }
.empty-state p { font-size:1rem; }
.empty-state a { color:var(--red); }

/* ===== FOOTER ===== */
.site-footer { background:var(--dark); color:rgba(255,255,255,0.8); padding:40px 0 0; margin-top:40px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:32px; padding-bottom:32px; }
.footer-logo { font-family:var(--font-display); font-size:2rem; font-weight:800; color:#fff; margin-bottom:12px; }
.footer-about p { font-size:14px; line-height:1.7; color:rgba(255,255,255,0.6); }
.social-links { display:flex; gap:10px; margin-top:16px; }
.social-links a { background:rgba(255,255,255,0.1); color:#fff; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:14px; transition:.2s; }
.social-links a:hover { background:var(--red); }
.footer-cats h4, .footer-links h4 { font-family:var(--font-display); font-size:1rem; font-weight:700; color:#fff; margin-bottom:16px; border-bottom:2px solid var(--red); padding-bottom:8px; }
.footer-cats ul, .footer-links ul { list-style:none; }
.footer-cats li, .footer-links li { margin-bottom:8px; }
.footer-cats a, .footer-links a { font-size:14px; color:rgba(255,255,255,0.6); transition:.15s; }
.footer-cats a:hover, .footer-links a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.1); padding:16px 0; text-align:center; font-size:13px; color:rgba(255,255,255,0.4); }

/* ===== AUTH ===== */
.auth-body { background:linear-gradient(135deg, var(--dark) 0%, var(--dark2) 100%); min-height:100vh; display:flex; align-items:center; justify-content:center; }
.auth-container { width:100%; max-width:420px; padding:16px; }
.auth-box { background:#fff; border-radius:12px; padding:36px; box-shadow:0 20px 60px rgba(0,0,0,0.3); }
.auth-logo { text-align:center; margin-bottom:28px; }
.auth-logo a { font-family:var(--font-display); font-size:2.2rem; font-weight:800; color:var(--red); display:block; }
.auth-logo span { font-size:13px; color:#999; }
.auth-form .form-group { margin-bottom:16px; }
.auth-form label { display:block; font-weight:600; margin-bottom:6px; font-size:14px; }
.input-icon { position:relative; }
.input-icon i { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:#999; }
.input-icon input { width:100%; padding:11px 12px 11px 38px; border:2px solid var(--border); border-radius:8px; font-family:var(--font-body); font-size:15px; outline:none; transition:.2s; }
.input-icon input:focus { border-color:var(--red); }
.btn-primary { background:var(--red); color:#fff; border:none; padding:12px 24px; border-radius:8px; font-size:15px; font-weight:700; cursor:pointer; font-family:var(--font-body); display:inline-flex; align-items:center; gap:8px; transition:.2s; }
.btn-primary:hover { background:var(--red-dark); }
.btn-block { width:100%; justify-content:center; margin-top:8px; }
.auth-hint { margin-top:20px; padding:14px; background:var(--gray-light); border-radius:8px; font-size:13px; color:#666; }
.auth-hint p { margin-bottom:4px; }
.auth-hint code { background:#fff; padding:2px 6px; border-radius:4px; border:1px solid var(--border); }

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
  .content-layout { grid-template-columns:1fr; }
  .sidebar { display:none; }
  .hero-section { height:300px; }
}
@media (max-width:768px) {
  .hero-section { grid-template-columns:1fr; height:auto; }
  .hero-side { display:none; }
  .hero-post-main { height:250px; border-radius:8px; }
  .header-search { display:none; }
  .nav-toggle { display:block; }
  .nav-list { display:none; flex-direction:column; width:100%; position:absolute; top:100%; left:0; background:var(--dark); z-index:200; }
  .nav-list.open { display:flex; }
  .main-nav { position:relative; }
  .footer-grid { grid-template-columns:1fr; }
  .logo-text { font-size:1.5rem; }
  .posts-grid { grid-template-columns:1fr 1fr; }
  .post-single-title { font-size:1.4rem; }
}
@media (max-width:480px) {
  .posts-grid { grid-template-columns:1fr; }
  .posts-grid-4 { grid-template-columns:1fr 1fr; }
}

/* ===== BANNERS ===== */
.banner-zone {
  width: 100%;
  text-align: center;
  background: #f8f8f8;
  overflow: hidden;
}
.banner-zone-header {
  border-bottom: 1px solid var(--border);
  padding: 6px 0;
}
.banner-zone-header_below {
  border-bottom: 3px solid var(--red);
  padding: 8px 0;
  background: #fff;
}
.banner-zone-footer {
  border-top: 1px solid var(--border);
  padding: 8px 0;
  background: #fff;
}
.banner-zone-content_mid {
  margin: 20px 0;
  padding: 8px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.banner-zone-sidebar_top,
.banner-zone-sidebar_mid {
  margin-bottom: 20px;
  border-radius: 8px;
  overflow: hidden;
}
.banner-item {
  display: inline-block;
  max-width: 100%;
}
.banner-img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  transition: opacity .2s;
}
.banner-img:hover { opacity: .92; }

/* Sidebar banner inside widget */
.sidebar .banner-zone {
  background: transparent;
  border-radius: 8px;
  overflow: hidden;
}
.sidebar .banner-img {
  border-radius: 8px;
  width: 100%;
}
