/*
Theme Name: OduNews
Theme URI: https://odunews.com
Author: OduNews Media Publishing
Description: A fast, mobile-first Nigerian news theme built for Google News compliance and Core Web Vitals. Built on the OduNews brand identity.
Version: 1.0.0
License: GNU General Public License v2
Text Domain: odunews
*/

/* ============================================================
   CSS CUSTOM PROPERTIES
   Brand colours from logo:
   Navy   #1B2A4A  — primary dark, text, nav backgrounds
   Lime   #AACC00  — primary accent, badges, highlights
   White  #FFFFFF
   ============================================================ */
:root {
  --navy:        #1B2A4A;
  --navy-2:      #253660;
  --navy-3:      #162038;
  --navy-4:      #0E1826;
  --lime:        #AACC00;
  --lime-dark:   #8CAA00;
  --lime-light:  #C4E600;
  --lime-pale:   #F2FACC;
  --white:       #FFFFFF;
  --off-white:   #F6F8FA;
  --border:      #E2E8F0;
  --border-2:    #CBD5E1;
  --text:        #111827;
  --text-2:      #374151;
  --text-3:      #6B7280;
  --text-4:      #9CA3AF;
  --radius:      4px;
  --shadow:      0 1px 4px rgba(27,42,74,.08);
  --shadow-md:   0 4px 16px rgba(27,42,74,.12);
  --font-head:   'Playfair Display', Georgia, serif;
  --font-body:   'Source Sans 3', 'Helvetica Neue', Arial, sans-serif;
  --font-ui:     'Barlow Condensed', 'Arial Narrow', Arial, sans-serif;
  --max-w:       1200px;
  --gap:         24px;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0 }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100% }
body { font-family: var(--font-body); font-size: 1rem; line-height: 1.7; color: var(--text); background: var(--off-white); -webkit-font-smoothing: antialiased }
img { max-width: 100%; height: auto; display: block }
a { color: inherit; text-decoration: none }
a:hover { color: var(--navy) }
ul, ol { list-style: none }
button { cursor: pointer; border: none; background: none; font-family: inherit }
input, textarea, select { font-family: inherit }
h1,h2,h3,h4,h5,h6 { font-family: var(--font-head); line-height: 1.25; color: var(--navy); font-weight: 700 }
p { margin-bottom: 1rem }
p:last-child { margin-bottom: 0 }

/* ============================================================
   LAYOUT
   ============================================================ */
.container { width: 100%; max-width: var(--max-w); margin: 0 auto; padding: 0 16px }
@media(min-width:768px) { .container { padding: 0 24px } }
.grid { display: grid; gap: var(--gap) }
.grid-2 { grid-template-columns: 1fr }
.grid-3 { grid-template-columns: 1fr }
.grid-4 { grid-template-columns: 1fr 1fr }
@media(min-width:600px) { .grid-2 { grid-template-columns: 1fr 1fr } }
@media(min-width:768px) { .grid-3 { grid-template-columns: repeat(3,1fr) }  .grid-4 { grid-template-columns: repeat(4,1fr) } }

/* ============================================================
   CATEGORY BADGE
   ============================================================ */
.cat-badge {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: var(--lime);
  color: var(--navy);
  padding: 2px 8px;
  border-radius: 2px;
  line-height: 1.8;
  transition: background .2s;
}
.cat-badge:hover { background: var(--lime-dark); color: var(--navy) }
.cat-badge.navy { background: var(--navy); color: var(--white) }
.cat-badge.outline { background: transparent; color: var(--lime); border: 1px solid var(--lime) }

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar { background: var(--navy-4); color: #aab4c8; font-family: var(--font-ui); font-size: .73rem; font-weight: 500; letter-spacing: .04em; padding: 6px 0; display: none }
@media(min-width:768px) { .topbar { display: block } }
.topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px }
.topbar-date { color: #7a8ba8; text-transform: uppercase; letter-spacing: .06em }
.topbar-links { display: flex; gap: 20px }
.topbar-links a { color: #8899bb; transition: color .2s }
.topbar-links a:hover { color: var(--lime) }

/* ============================================================
   HEADER
   ============================================================ */
.site-header { background: var(--white); border-bottom: 3px solid var(--lime); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 12px rgba(27,42,74,.1) }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; gap: 16px }
.site-logo img { height: 40px; width: auto }
@media(min-width:768px) { .site-logo img { height: 48px } }
.header-actions { display: flex; align-items: center; gap: 10px }

.btn-search { width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--off-white); border: 1.5px solid var(--border); color: var(--text-3); transition: all .2s }
.btn-search:hover { background: var(--navy); border-color: var(--navy); color: var(--white) }

.btn-gnews { display: flex; align-items: center; gap: 6px; background: var(--lime); color: var(--navy); font-family: var(--font-ui); font-size: .72rem; font-weight: 800; letter-spacing: .05em; padding: 8px 14px; border-radius: 3px; text-transform: uppercase; transition: background .2s; white-space: nowrap }
.btn-gnews:hover { background: var(--lime-dark); color: var(--navy) }

.hamburger { display: flex; flex-direction: column; gap: 5px; width: 38px; height: 38px; align-items: center; justify-content: center; background: var(--off-white); border: 1.5px solid var(--border); border-radius: 3px }
@media(min-width:1024px) { .hamburger { display: none } }
.hamburger span { display: block; width: 20px; height: 2px; background: var(--navy); border-radius: 1px; transition: all .3s }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg) }
.hamburger.open span:nth-child(2) { opacity: 0 }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg) }

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav-wrap { background: var(--navy) }
.primary-nav { display: none }
@media(min-width:1024px) { .primary-nav { display: flex; align-items: center } }
.primary-nav a, .primary-nav button { font-family: var(--font-ui); font-size: .84rem; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: #aab4c8; padding: 13px 16px; display: block; transition: color .2s; position: relative; background: none; border: none }
.primary-nav a:hover, .primary-nav a.current, .primary-nav button:hover { color: var(--white) }
.primary-nav a.current::after { content: ''; position: absolute; bottom: 0; left: 16px; right: 16px; height: 3px; background: var(--lime); border-radius: 1px }
.nav-item { position: relative }
.nav-item:hover .dropdown { display: block }
.dropdown { display: none; position: absolute; top: 100%; left: 0; background: var(--navy-3); border-top: 3px solid var(--lime); min-width: 200px; z-index: 200; box-shadow: var(--shadow-md) }
.dropdown a { font-size: .79rem; padding: 10px 16px; color: #aab4c8; border-bottom: 1px solid rgba(255,255,255,.06); display: block }
.dropdown a:hover { color: var(--lime); background: rgba(255,255,255,.04) }
.mobile-nav { display: none; background: var(--navy-3); border-top: 1px solid rgba(255,255,255,.06) }
.mobile-nav.open { display: block }
.mobile-nav a { display: block; font-family: var(--font-ui); font-size: .88rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: #aab4c8; padding: 12px 20px; border-bottom: 1px solid rgba(255,255,255,.06); transition: color .2s }
.mobile-nav a:hover { color: var(--lime) }

/* ============================================================
   BREAKING TICKER
   ============================================================ */
.breaking-bar { background: var(--navy-3); color: var(--white); padding: 0; overflow: hidden; display: flex; align-items: center; height: 36px }
.breaking-label { background: var(--lime); color: var(--navy); font-family: var(--font-ui); font-size: .7rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; padding: 0 16px; height: 100%; display: flex; align-items: center; white-space: nowrap; flex-shrink: 0 }
.ticker-wrap { overflow: hidden; flex: 1; height: 100%; display: flex; align-items: center }
.ticker-inner { display: flex; gap: 60px; animation: ticker 32s linear infinite; white-space: nowrap }
.ticker-inner:hover { animation-play-state: paused }
.ticker-inner a { font-family: var(--font-ui); font-size: .78rem; font-weight: 600; color: #c8d0e0; letter-spacing: .02em; white-space: nowrap }
.ticker-inner a:hover { color: var(--lime) }
@keyframes ticker { 0% { transform: translateX(0) } 100% { transform: translateX(-50%) } }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; padding-bottom: 10px; border-bottom: 2px solid var(--border) }
.section-title { font-family: var(--font-ui); font-size: 1rem; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--navy); display: flex; align-items: center; gap: 8px }
.section-title::before { content: ''; display: block; width: 4px; height: 18px; background: var(--lime); border-radius: 1px; flex-shrink: 0 }
.section-more { font-family: var(--font-ui); font-size: .7rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--navy-2); border: 1.5px solid var(--navy-2); padding: 3px 11px; border-radius: 2px; transition: all .2s }
.section-more:hover { background: var(--navy); border-color: var(--navy); color: var(--white) }

/* ============================================================
   ARTICLE CARDS
   ============================================================ */
.card { background: var(--white); border-radius: var(--radius); overflow: hidden; transition: box-shadow .2s, transform .2s; display: flex; flex-direction: column }
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px) }
.card-thumb { aspect-ratio: 16/9; overflow: hidden; background: #e8edf5; flex-shrink: 0; position: relative }
.card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s }
.card:hover .card-thumb img { transform: scale(1.04) }
.card-body { padding: 14px 16px 18px; flex: 1; display: flex; flex-direction: column }
.card-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; flex-wrap: wrap }
.card-date { font-family: var(--font-ui); font-size: .68rem; color: var(--text-4); font-weight: 500 }
.card-title { font-family: var(--font-head); font-size: 1rem; font-weight: 700; line-height: 1.3; color: var(--navy); margin-bottom: 8px; flex: 1 }
.card-title a:hover { color: var(--lime-dark) }
.card-excerpt { font-size: .84rem; color: var(--text-3); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden }
.card-lg .card-title { font-size: 1.3rem }
@media(min-width:768px) { .card-lg .card-title { font-size: 1.55rem } }
.card-list { background: none; box-shadow: none; border-bottom: 1px solid var(--border); border-radius: 0; padding: 11px 0; flex-direction: row; gap: 12px; align-items: flex-start; transform: none }
.card-list:last-child { border-bottom: none }
.card-list:hover { box-shadow: none; transform: none }
.card-list .card-thumb { width: 82px; min-width: 82px; aspect-ratio: unset; height: 58px; border-radius: var(--radius) }
.card-list .card-body { padding: 0 }
.card-list .card-title { font-size: .87rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden }
.card-num { font-family: var(--font-ui); font-size: 1.5rem; font-weight: 900; color: var(--lime); line-height: 1; flex-shrink: 0; min-width: 28px; opacity: .7 }

/* ============================================================
   HOMEPAGE HERO
   ============================================================ */
.hero { padding: 24px 0 28px; background: var(--white); border-bottom: 1px solid var(--border) }
.hero-grid { display: grid; gap: var(--gap); grid-template-columns: 1fr }
@media(min-width:768px) { .hero-grid { grid-template-columns: 1fr 1fr } }
@media(min-width:1024px) { .hero-grid { grid-template-columns: 3fr 1fr 1fr } }
.hero-main .card-title { font-size: 1.4rem; line-height: 1.2 }
@media(min-width:768px) { .hero-main .card-title { font-size: 1.7rem } }
.hero-stack { display: flex; flex-direction: column; gap: 14px }
.hero-stack .card { border: none; box-shadow: none; border-radius: 0; border-bottom: 1px solid var(--border); padding-bottom: 14px }
.hero-stack .card:last-child { border-bottom: none; padding-bottom: 0 }
.hero-stack .card:hover { transform: none }
.hero-stack .card-title { font-size: .92rem }

/* ============================================================
   MAIN LAYOUT
   ============================================================ */
.content-wrap { padding: 28px 0 48px }
.content-grid { display: grid; gap: 28px; grid-template-columns: 1fr }
@media(min-width:1024px) { .content-grid { grid-template-columns: 1fr 320px } }
.main-col { min-width: 0 }
.sidebar { min-width: 0 }

/* ============================================================
   CATEGORY SECTIONS
   ============================================================ */
.cat-section { margin-bottom: 36px }

/* ============================================================
   SIDEBAR WIDGETS
   ============================================================ */
.widget { background: var(--white); border-radius: var(--radius); padding: 18px 20px; margin-bottom: 20px; box-shadow: var(--shadow) }
.widget-title { font-family: var(--font-ui); font-size: .85rem; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--navy); padding-bottom: 10px; border-bottom: 2px solid var(--lime); margin-bottom: 14px; display: flex; align-items: center; gap: 7px }
.widget-title::before { content: ''; display: block; width: 4px; height: 15px; background: var(--navy); border-radius: 1px; flex-shrink: 0 }

/* Google News widget */
.gnews-widget { background: var(--navy); color: var(--white); text-align: center; padding: 22px 18px; border-radius: var(--radius) }
.gnews-widget p { font-size: .83rem; color: #8899bb; margin-bottom: 14px; line-height: 1.6 }
.btn-gnews-lg { display: inline-flex; align-items: center; gap: 8px; background: var(--lime); color: var(--navy); font-family: var(--font-ui); font-size: .78rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; padding: 10px 18px; border-radius: 3px; transition: background .2s }
.btn-gnews-lg:hover { background: var(--lime-dark); color: var(--navy) }

/* Social follow widget */
.social-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 7px }
.social-btn { display: flex; align-items: center; gap: 7px; padding: 8px 10px; border-radius: 3px; font-family: var(--font-ui); font-size: .7rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--white); transition: opacity .2s }
.social-btn:hover { opacity: .85; color: var(--white) }
.social-btn.facebook  { background: #1877F2 }
.social-btn.twitter   { background: #000 }
.social-btn.instagram { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888) }
.social-btn.youtube   { background: #FF0000 }
.social-btn.tiktok    { background: #010101 }
.social-btn.whatsapp  { background: #25D366 }
.widget-ad { background: var(--off-white); border: 2px dashed var(--border-2); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; min-height: 250px; color: var(--text-4); font-family: var(--font-ui); font-size: .75rem; letter-spacing: .04em; text-transform: uppercase }

/* ============================================================
   SINGLE POST
   ============================================================ */
.post-header { margin-bottom: 22px }
.post-cats { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px }
.post-title { font-family: var(--font-head); font-size: 1.6rem; line-height: 1.2; color: var(--navy); margin-bottom: 16px; font-weight: 700 }
@media(min-width:768px) { .post-title { font-size: 2rem } }
@media(min-width:1024px) { .post-title { font-size: 2.3rem } }
.post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; padding: 12px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin-bottom: 22px }
.post-meta span { font-family: var(--font-ui); font-size: .73rem; color: var(--text-3); font-weight: 500; display: flex; align-items: center; gap: 5px }
.post-meta strong { color: var(--text-2) }
.post-featured { border-radius: var(--radius); overflow: hidden; margin-bottom: 26px; background: #e8edf5 }
.post-featured img { width: 100%; height: auto; max-height: 520px; object-fit: cover }
.post-featured figcaption { font-size: .73rem; color: var(--text-3); padding: 7px 12px; background: #f0f4f8; font-style: italic }
.post-content { font-size: 1.05rem; line-height: 1.85; color: var(--text) }
.post-content p { margin-bottom: 1.4rem }
.post-content h2 { font-size: 1.35rem; margin: 2rem 0 .9rem; padding-bottom: .4rem; border-bottom: 2px solid var(--lime) }
.post-content h3 { font-size: 1.15rem; margin: 1.5rem 0 .7rem }
.post-content a { color: var(--navy-2); text-decoration: underline; text-underline-offset: 3px }
.post-content a:hover { color: var(--lime-dark) }
.post-content blockquote { border-left: 4px solid var(--lime); padding: 16px 20px; background: var(--lime-pale); margin: 1.5rem 0; font-style: italic; font-size: 1.05rem; color: var(--navy) }
.post-content img { border-radius: var(--radius); margin: 1.5rem auto }
.post-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 26px; padding-top: 18px; border-top: 1px solid var(--border) }
.post-tags a { font-family: var(--font-ui); font-size: .7rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--text-3); border: 1px solid var(--border); padding: 3px 9px; border-radius: 2px; transition: all .2s }
.post-tags a:hover { background: var(--lime); border-color: var(--lime); color: var(--navy) }

/* ============================================================
   SHARE BUTTONS
   ============================================================ */
.share-bar { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; margin: 20px 0; padding: 14px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border) }
.share-label { font-family: var(--font-ui); font-size: .7rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--text-3); margin-right: 4px }
.share-btn { display: inline-flex; align-items: center; gap: 5px; padding: 7px 13px; border-radius: 3px; font-family: var(--font-ui); font-size: .7rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--white); transition: opacity .2s; border: none; cursor: pointer }
.share-btn:hover { opacity: .85 }
.share-btn.facebook  { background: #1877F2 }
.share-btn.twitter   { background: #000 }
.share-btn.whatsapp  { background: #25D366 }
.share-btn.copy      { background: var(--navy) }
.share-btn.copy.copied { background: var(--lime); color: var(--navy) }

/* ============================================================
   RELATED POSTS
   ============================================================ */
.related-posts { margin-top: 36px; padding-top: 26px; border-top: 3px solid var(--lime) }
.related-grid { display: grid; gap: 18px; grid-template-columns: 1fr }
@media(min-width:600px) { .related-grid { grid-template-columns: 1fr 1fr } }
@media(min-width:900px) { .related-grid { grid-template-columns: repeat(3,1fr) } }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination { display: flex; align-items: center; justify-content: center; gap: 6px; margin: 28px 0 }
.pagination a, .pagination span { font-family: var(--font-ui); font-size: .8rem; font-weight: 700; padding: 8px 13px; border: 1.5px solid var(--border); border-radius: 3px; color: var(--text-2); transition: all .2s; display: inline-block }
.pagination a:hover, .pagination .current { background: var(--navy); border-color: var(--navy); color: var(--white) }

/* ============================================================
   ARCHIVE
   ============================================================ */
.archive-header { background: var(--navy); color: var(--white); padding: 32px 0 28px; margin-bottom: 28px }
.archive-label { font-family: var(--font-ui); font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--lime); margin-bottom: 8px }
.archive-title { font-family: var(--font-head); font-size: 1.8rem; color: var(--white) }
.archive-desc { font-size: .88rem; color: #8899bb; margin-top: 8px }
.archive-grid { display: grid; gap: 18px; grid-template-columns: 1fr }
@media(min-width:600px) { .archive-grid { grid-template-columns: 1fr 1fr } }
@media(min-width:900px) { .archive-grid { grid-template-columns: repeat(3,1fr) } }

/* ============================================================
   STATIC PAGES
   ============================================================ */
.page-hero { background: var(--navy); padding: 44px 0 38px; color: var(--white) }
.page-hero .page-title { font-family: var(--font-head); font-size: 2rem; color: var(--white); margin-bottom: 8px }
.page-hero p { color: #8899bb; font-size: .92rem }
.page-content-wrap { padding: 36px 0 60px }
.page-content-grid { display: grid; gap: 28px; grid-template-columns: 1fr }
@media(min-width:1024px) { .page-content-grid { grid-template-columns: 1fr 300px } }
.page-body { background: var(--white); border-radius: var(--radius); padding: 28px 30px; box-shadow: var(--shadow) }
.page-body h2 { font-size: 1.25rem; margin: 2rem 0 .7rem; color: var(--navy-2); padding-bottom: .4rem; border-bottom: 2px solid var(--lime) }
.page-body h2:first-child { margin-top: 0 }
.page-body p { margin-bottom: 1.1rem; color: var(--text-2); line-height: 1.8 }
.page-body ul { list-style: disc; padding-left: 20px; margin-bottom: 1.1rem }
.page-body ul li { margin-bottom: .5rem; color: var(--text-2) }
.page-body a { color: var(--navy-2); text-decoration: underline }
.page-body a:hover { color: var(--lime-dark) }

/* Contact form */
.contact-form { display: grid; gap: 14px }
.form-row { display: grid; gap: 14px; grid-template-columns: 1fr }
@media(min-width:600px) { .form-row { grid-template-columns: 1fr 1fr } }
.form-group { display: flex; flex-direction: column; gap: 5px }
.form-group label { font-family: var(--font-ui); font-size: .75rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--text-2) }
.form-group input, .form-group textarea { padding: 10px 13px; border: 1.5px solid var(--border); border-radius: var(--radius); font-size: .93rem; color: var(--text); background: var(--off-white); transition: border-color .2s }
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: var(--lime); background: var(--white) }
.form-group textarea { min-height: 130px; resize: vertical }
.btn-submit { background: var(--navy); color: var(--white); font-family: var(--font-ui); font-size: .83rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 12px 30px; border-radius: 3px; border: none; cursor: pointer; transition: background .2s }
.btn-submit:hover { background: var(--navy-2) }
.form-success { background: #f0fff4; border: 1px solid #b7ebc8; color: #1a6b38; padding: 13px 16px; border-radius: var(--radius); font-size: .88rem; display: none }
.form-success.show { display: block }

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie-banner { position: fixed; bottom: 0; left: 0; right: 0; background: var(--navy-4); color: #c8d0e0; padding: 14px 20px; z-index: 9999; border-top: 3px solid var(--lime); transform: translateY(100%); transition: transform .4s; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap }
.cookie-banner.show { transform: translateY(0) }
.cookie-banner p { font-size: .83rem; line-height: 1.6; flex: 1; min-width: 200px }
.cookie-banner a { color: var(--lime) }
.cookie-btns { display: flex; gap: 10px; flex-shrink: 0 }
.btn-cookie-accept { background: var(--lime); color: var(--navy); font-family: var(--font-ui); font-size: .73rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; padding: 8px 16px; border-radius: 3px; border: none; cursor: pointer; transition: background .2s }
.btn-cookie-accept:hover { background: var(--lime-dark) }
.btn-cookie-decline { background: transparent; color: #8899bb; font-family: var(--font-ui); font-size: .73rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; padding: 8px 12px; border: 1px solid rgba(255,255,255,.15); border-radius: 3px; cursor: pointer; transition: all .2s }
.btn-cookie-decline:hover { border-color: rgba(255,255,255,.4); color: var(--white) }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background: var(--navy-4); color: #8899bb; padding: 48px 0 0 }
.footer-grid { display: grid; gap: 32px; grid-template-columns: 1fr; margin-bottom: 40px }
@media(min-width:600px) { .footer-grid { grid-template-columns: 1fr 1fr } }
@media(min-width:1024px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr } }
.footer-brand .site-logo img { height: 38px; margin-bottom: 14px }
.footer-brand p { font-size: .83rem; line-height: 1.7; color: #5a6a88; margin-bottom: 16px }
.footer-social { display: flex; gap: 8px; flex-wrap: wrap }
.footer-social a { width: 32px; height: 32px; background: rgba(255,255,255,.06); border-radius: 3px; display: flex; align-items: center; justify-content: center; color: #8899bb; transition: all .2s }
.footer-social a:hover { background: var(--lime); color: var(--navy) }
.footer-col h4 { font-family: var(--font-ui); font-size: .78rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--white); margin-bottom: 14px; padding-bottom: 7px; border-bottom: 2px solid var(--lime) }
.footer-col ul { display: flex; flex-direction: column; gap: 8px }
.footer-col ul a { font-size: .83rem; color: #5a6a88; transition: color .2s }
.footer-col ul a:hover { color: var(--lime) }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.06); padding: 16px 0; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px }
.footer-copy { font-size: .75rem; color: #3d4f6a }
.footer-links { display: flex; gap: 16px; flex-wrap: wrap }
.footer-links a { font-size: .73rem; color: #3d4f6a; transition: color .2s; font-family: var(--font-ui); letter-spacing: .03em }
.footer-links a:hover { color: #8899bb }

/* ============================================================
   SEARCH & 404
   ============================================================ */
.search-header { background: var(--off-white); border-bottom: 1px solid var(--border); padding: 26px 0 }
.search-form { display: flex; border: 2px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--white) }
.search-form input { flex: 1; padding: 11px 15px; border: none; font-size: .95rem; outline: none; color: var(--text) }
.search-form button { background: var(--navy); color: var(--white); padding: 11px 18px; border: none; cursor: pointer; transition: background .2s }
.search-form button:hover { background: var(--lime); color: var(--navy) }
.search-results-count { font-family: var(--font-ui); font-size: .77rem; font-weight: 600; letter-spacing: .04em; color: var(--text-3); margin-top: 8px }
.error-404 { text-align: center; padding: 80px 0 }
.error-code { font-family: var(--font-ui); font-size: 7rem; font-weight: 900; color: var(--lime); line-height: 1; margin-bottom: 16px; opacity: .25 }
.btn-home { display: inline-block; background: var(--navy); color: var(--white); font-family: var(--font-ui); font-size: .83rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 12px 26px; border-radius: 3px; transition: background .2s }
.btn-home:hover { background: var(--navy-2); color: var(--white) }

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.breadcrumbs { background: var(--white); border-bottom: 1px solid var(--border); padding: 7px 0 }
.breadcrumbs ol { display: flex; align-items: center; gap: 6px; flex-wrap: wrap }
.breadcrumbs li { font-family: var(--font-ui); font-size: .7rem; font-weight: 600; letter-spacing: .03em; color: var(--text-4) }
.breadcrumbs li:not(:last-child)::after { content: '/'; margin-left: 6px; color: var(--border) }
.breadcrumbs a { color: var(--text-4); transition: color .2s }
.breadcrumbs a:hover { color: var(--navy) }
.breadcrumbs li:last-child { color: var(--text-2) }

/* ============================================================
   POST NAV, TAGS, TABLES
   ============================================================ */
.post-nav { display: grid; gap: 14px; grid-template-columns: 1fr 1fr; margin: 28px 0; padding-top: 20px; border-top: 1px solid var(--border) }
.post-nav-item { background: var(--white); border-radius: var(--radius); padding: 14px 16px; box-shadow: var(--shadow) }
.post-nav-item .nav-label { font-family: var(--font-ui); font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--lime-dark); margin-bottom: 5px; display: block }
.post-nav-item a { font-family: var(--font-head); font-size: .92rem; font-weight: 700; color: var(--navy); line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden }
.post-nav-item.next { text-align: right }
.post-content table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: .88rem }
.post-content th { background: var(--navy); color: var(--white); padding: 9px 13px; text-align: left; font-family: var(--font-ui); font-size: .77rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase }
.post-content td { padding: 8px 13px; border-bottom: 1px solid var(--border) }
.post-content tr:nth-child(even) td { background: var(--off-white) }
.post-content .wp-block-embed__wrapper { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden }
.post-content .wp-block-embed__wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0 }

/* ============================================================
   SKIP LINK & FOCUS
   ============================================================ */
.skip-link { position: absolute; top: -100px; left: 0; background: var(--lime); color: var(--navy); padding: 8px 16px; z-index: 9999; font-family: var(--font-ui); font-size: .83rem; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; border-radius: 0 0 3px 0 }
.skip-link:focus { top: 0 }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible { outline: 3px solid var(--lime); outline-offset: 2px }

/* ============================================================
   SEARCH DRAWER
   ============================================================ */
.search-drawer { background: var(--off-white); border-bottom: 2px solid var(--lime); padding: 10px 0 }

/* ============================================================
   READING PROGRESS / BACK TO TOP — injected via JS
   ============================================================ */

/* ============================================================
   MOBILE
   ============================================================ */
@media(max-width:480px) {
  .share-bar { gap: 5px }
  .share-btn { padding: 6px 9px; font-size: .67rem }
  .post-title { font-size: 1.4rem }
  .hero-main .card-title { font-size: 1.2rem }
  .btn-gnews { font-size: .67rem; padding: 7px 10px }
  .card-list .card-thumb { width: 76px; min-width: 76px }
}

/* ============================================================
   PRINT
   ============================================================ */
@media print {
  .site-header, .nav-wrap, .breaking-bar, .sidebar, .share-bar, .related-posts, .site-footer, .cookie-banner { display: none }
  .content-grid { grid-template-columns: 1fr }
  .post-content { font-size: 11pt; line-height: 1.6 }
}

/* ============================================================
   IMAGE CONTAINMENT — post content images must never overflow
   their column or bleed into the sidebar
   ============================================================ */

/* The main column itself must clip its children */
.main-col {
    overflow: hidden;
    min-width: 0;
    max-width: 100%;
}

/* Every image inside post content is constrained to its column */
.post-content img,
.post-content figure img,
.post-content .wp-block-image img,
.post-content .size-full,
.post-content .size-large,
.post-content .size-medium,
.post-content .alignfull img,
.post-content .alignwide img {
    display: block;
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain;
    border-radius: var(--radius);
    margin-left: auto;
    margin-right: auto;
}

/* Block-level image wrappers — never wider than the column */
.post-content figure,
.post-content .wp-block-image,
.post-content .wp-block-embed,
.post-content .wp-caption,
.post-content .wp-block-gallery {
    max-width: 100% !important;
    width: 100% !important;
    overflow: hidden;
    box-sizing: border-box;
}

/* alignfull and alignwide blocks — clip to column, never spill */
.post-content .alignfull,
.post-content .alignwide {
    max-width: 100% !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Inline-styled images that set explicit width/height via HTML attributes */
.post-content img[width],
.post-content img[style*="width"] {
    max-width: 100% !important;
    height: auto !important;
}

/* Featured image on single posts — fully responsive, correct ratio */
.post-featured {
    width: 100%;
    overflow: hidden;
    border-radius: var(--radius);
    margin-bottom: 26px;
    background: #e8edf5;
}
.post-featured img {
    width: 100% !important;
    height: auto !important;
    max-height: 520px;
    object-fit: cover;
    display: block;
}

/* Card thumbnails — always fill their container proportionally */
.card-thumb {
    display: block;
    width: 100%;
    overflow: hidden;
    background: #e8edf5;
    flex-shrink: 0;
}
.card-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    display: block;
    transition: transform .4s;
}
.card:hover .card-thumb img {
    transform: scale(1.04);
}

/* List card thumbnail — fixed size, never stretch */
.card-list .card-thumb {
    width: 82px !important;
    min-width: 82px !important;
    height: 58px !important;
    border-radius: var(--radius);
    aspect-ratio: unset;
}
.card-list .card-thumb img {
    width: 82px !important;
    height: 58px !important;
    object-fit: cover;
}

/* Hero main card image — 16:9 aspect ratio, no stretch */
.hero-main .card-thumb {
    aspect-ratio: 16 / 9;
    width: 100%;
    height: auto;
}
.hero-main .card-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
}

/* Standard card thumbnail — 16:9, no stretch */
.card:not(.card-list):not(.hero-main .card) .card-thumb {
    aspect-ratio: 16 / 9;
}

/* Embedded videos stay in column */
.post-content iframe,
.post-content embed,
.post-content object,
.post-content video {
    max-width: 100% !important;
}

/* Responsive embed wrapper */
.post-content .wp-block-embed__wrapper {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}
.post-content .wp-block-embed__wrapper iframe {
    position: absolute;
    top: 0; left: 0;
    width: 100% !important;
    height: 100% !important;
    border: 0;
}

/* Global image safety net — nothing can overflow its parent */
img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ============================================================
   WEATHER WIDGET
   ============================================================ */
.odunews-weather-widget .widget-title::before { background: #E8A020 }
.odunews-weather-widget .widget-title { border-bottom-color: #E8A020 }

/* ============================================================
   FOREX WIDGET
   ============================================================ */
.odunews-forex-widget .widget-title::before { background: var(--lime) }
