/* O3Naija News Theme — Main CSS */
:root {
  --green:#1a7a3c; --green-dark:#0f5a2a; --green-light:#e8f5ed;
  --white:#fff; --gray-50:#f8f9fa; --gray-100:#f1f3f4; --gray-200:#e8eaed;
  --gray-300:#dadce0; --gray-400:#9aa0a6; --gray-500:#80868b; --gray-600:#5f6368;
  --gray-800:#3c4043; --gray-900:#202124;
  --red:#c62828;
  --font-head:'Playfair Display',Georgia,serif;
  --font-body:'Source Sans 3',system-ui,sans-serif;
  --font-nav:'Oswald',sans-serif;
  --radius:8px; --radius-lg:12px;
  --shadow:0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:0 8px 32px rgba(0,0,0,.14);
  --tr:.2s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;width:100%;}
body{font-family:var(--font-body);background:var(--gray-50);color:var(--gray-900);font-size:15px;line-height:1.65;width:100%;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;object-fit:cover;}
ul{list-style:none;}
button{cursor:pointer;font-family:var(--font-body);}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.25;}
#page{width:100%;}
.site-content{width:100%;}

/* TOPBAR */
.topbar{background:var(--gray-900);border-bottom:2px solid var(--green);width:100%;overflow:hidden;}
.topbar-inner{max-width:1260px;margin:0 auto;padding:7px 16px;display:flex;align-items:center;gap:16px;}
.topbar-date{color:var(--gray-400);font-size:12px;white-space:nowrap;}
.breaking-ticker{flex:1;display:flex;align-items:center;gap:10px;overflow:hidden;min-width:0;}
.breaking-label{background:var(--red);color:#fff;font-family:var(--font-nav);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:3px 9px;border-radius:3px;white-space:nowrap;flex-shrink:0;}
.ticker-wrap{overflow:hidden;flex:1;}
.ticker-text{display:inline-block;white-space:nowrap;color:#fff;font-size:12px;animation:ticker 35s linear infinite;}
@keyframes ticker{from{transform:translateX(100%);}to{transform:translateX(-100%);}}
.topbar-links{display:flex;gap:14px;flex-shrink:0;}
.topbar-links a,.topbar-nav li a{color:var(--gray-400);font-size:12px;transition:color var(--tr);}
.topbar-links a:hover,.topbar-nav li a:hover{color:#fff;}
.topbar-nav{display:flex;gap:14px;}

/* HEADER */
.site-header{background:#fff;border-bottom:1px solid var(--gray-200);padding:12px 0;width:100%;position:relative;z-index:90;}
.header-inner{max-width:1260px;margin:0 auto;padding:0 16px;display:flex;align-items:center;gap:16px;}
.site-branding{flex-shrink:0;}
.site-branding img,.custom-logo{height:52px;width:auto;display:block;}
.site-name-link{font-family:var(--font-nav);font-size:26px;font-weight:700;color:var(--green);letter-spacing:1px;}
.header-search{flex:1;max-width:440px;position:relative;}
.header-search input[type="search"]{width:100%;padding:10px 44px 10px 16px;border:1.5px solid var(--gray-200);border-radius:24px;font-family:var(--font-body);font-size:14px;background:var(--gray-50);color:var(--gray-900);outline:none;transition:border-color var(--tr),box-shadow var(--tr);}
.header-search input[type="search"]:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(26,122,60,.12);}
.header-search button{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray-500);display:flex;align-items:center;transition:color var(--tr);}
.header-search button:hover{color:var(--green);}
.header-actions{display:flex;gap:10px;align-items:center;flex-shrink:0;}
.btn-signin{padding:8px 18px;border:1.5px solid var(--gray-200);border-radius:22px;font-size:13px;font-weight:600;color:var(--gray-800);background:#fff;transition:all var(--tr);}
.btn-signin:hover{border-color:var(--green);color:var(--green);}
.btn-write{padding:9px 18px;border-radius:22px;font-size:13px;font-weight:700;color:#fff;background:var(--green);border:none;display:inline-flex;align-items:center;gap:6px;transition:background var(--tr),transform .15s;}
.btn-write:hover{background:var(--green-dark);transform:translateY(-1px);}
.mobile-toggle{display:none;background:none;border:none;padding:6px;color:var(--gray-800);}

/* MAIN NAV */
.main-nav{background:var(--green);position:sticky;top:0;z-index:100;box-shadow:0 2px 10px rgba(0,0,0,.18);width:100%;}
.nav-inner{max-width:1260px;margin:0 auto;padding:0 16px;display:flex;align-items:stretch;overflow-x:auto;scrollbar-width:none;}
.nav-inner::-webkit-scrollbar{display:none;}
.nav-item{font-family:var(--font-nav);font-size:13px;letter-spacing:.7px;text-transform:uppercase;color:rgba(255,255,255,.82);padding:13px 15px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;position:relative;transition:color var(--tr);}
.nav-item:hover,.nav-item.active{color:#fff;}
.nav-item.active::after{content:'';position:absolute;bottom:0;left:12px;right:12px;height:3px;background:#fff;border-radius:2px 2px 0 0;}
.nav-discover{background:rgba(255,255,255,.13);border-right:1px solid rgba(255,255,255,.12);margin-right:4px;color:#fff!important;font-weight:600;}

/* MOBILE NAV */
.mobile-nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:200;display:none;}
.mobile-nav-overlay.open{display:flex;}
.mobile-nav-panel{background:#fff;width:280px;height:100%;padding:16px 0;overflow-y:auto;box-shadow:var(--shadow-lg);}
.mobile-nav-close{background:none;border:none;font-size:16px;padding:12px 20px;display:flex;align-items:center;gap:8px;color:var(--gray-600);margin-bottom:8px;}
.mobile-nav-list li a{display:block;padding:13px 20px;font-family:var(--font-nav);font-size:14px;letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid var(--gray-100);transition:background var(--tr),color var(--tr);}
.mobile-nav-list li a:hover{background:var(--green-light);color:var(--green);}

/* LAYOUT */
.site-body{max-width:1260px;margin:0 auto;padding:24px 16px 40px;display:grid;grid-template-columns:1fr 310px;gap:28px;align-items:start;}
.main-content{min-width:0;}
.sidebar{min-width:0;}

/* SECTION HEADER */
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--gray-200);}
.section-title{font-family:var(--font-nav);font-size:13px;letter-spacing:1px;text-transform:uppercase;font-weight:600;color:var(--gray-900);display:flex;align-items:center;gap:10px;}
.section-title::before{content:'';display:inline-block;width:4px;height:18px;background:var(--green);border-radius:2px;flex-shrink:0;}
.section-more{font-size:13px;font-weight:600;color:var(--green);transition:opacity var(--tr);}
.section-more:hover{opacity:.75;}
.picks-arrows{display:flex;gap:8px;}

/* HERO SLIDER */
.hero-slider{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-900);margin-bottom:28px;aspect-ratio:16/7;box-shadow:var(--shadow-lg);}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s;pointer-events:none;}
.hero-slide.active{opacity:1;pointer-events:all;}
.hero-img-link{display:block;width:100%;height:100%;}
.hero-bg{width:100%;height:100%;object-fit:cover;filter:brightness(.52);transition:transform 8s ease;}
.hero-slide.active .hero-bg{transform:scale(1.04);}
.hero-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.35) 60%,transparent 100%);padding:56px 28px 24px;}
.hero-category{display:inline-block;background:var(--green);color:#fff;font-family:var(--font-nav);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:4px 11px;border-radius:3px;margin-bottom:10px;transition:background var(--tr);}
.hero-category:hover{background:var(--green-dark);}
.hero-title{font-family:var(--font-head);color:#fff;font-size:clamp(20px,3vw,30px);font-weight:700;line-height:1.22;margin-bottom:12px;}
.hero-title a{color:#fff;transition:opacity var(--tr);}
.hero-title a:hover{opacity:.85;}
.hero-meta{display:flex;gap:16px;flex-wrap:wrap;}
.hero-meta-item{color:rgba(255,255,255,.75);font-size:13px;display:inline-flex;align-items:center;gap:5px;}
.hero-controls{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 12px;pointer-events:none;}
.hero-btn{width:40px;height:40px;background:rgba(0,0,0,.42);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.18);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;pointer-events:all;transition:background var(--tr),transform .15s;}
.hero-btn:hover{background:var(--green);transform:scale(1.08);}
.hero-dots{position:absolute;bottom:18px;right:22px;display:flex;gap:7px;}
.hero-dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.35);border:none;transition:background var(--tr),transform var(--tr);}
.hero-dot.active{background:#fff;transform:scale(1.25);}

/* CATEGORY COLOURS */
.cat-news{--cc:#1a7a3c;--cb:#e8f5ed;}
.cat-sport{--cc:#1565c0;--cb:#e3f0fb;}
.cat-ent{--cc:#b71c1c;--cb:#fbe9e7;}
.cat-health{--cc:#2e7d32;--cb:#e8f5e9;}
.cat-tech{--cc:#4527a0;--cb:#ede7f6;}
.cat-edu{--cc:#e65100;--cb:#fff3e0;}
.cat-career{--cc:#00695c;--cb:#e0f2f1;}
.cat-business{--cc:#f57f17;--cb:#fff8e1;}
.cat-politics{--cc:#880e4f;--cb:#fce4ec;}
.cat-lifestyle{--cc:#6a1b9a;--cb:#f3e5f5;}

/* NEWS GRIDS */
.news-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:28px;}
.news-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:28px;}

/* NEWS CARD */
.news-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);transition:box-shadow var(--tr),transform var(--tr);display:flex;flex-direction:column;}
.news-card:hover{box-shadow:var(--shadow);transform:translateY(-3px);}
.card-image-wrap{position:relative;aspect-ratio:16/10;overflow:hidden;display:block;background:var(--gray-100);}
.card-image-wrap img{width:100%;height:100%;transition:transform .45s;}
.news-card:hover .card-image-wrap img{transform:scale(1.05);}
.card-category{position:absolute;top:10px;left:10px;background:var(--cc,var(--green));color:#fff;font-family:var(--font-nav);font-size:10px;letter-spacing:.8px;text-transform:uppercase;padding:3px 9px;border-radius:3px;z-index:1;}
.card-body{padding:14px;flex:1;display:flex;flex-direction:column;}
.card-source{display:flex;align-items:center;gap:7px;margin-bottom:8px;}
.card-source-icon{width:20px;height:20px;border-radius:50%;background:var(--green);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.card-source-name{font-size:12px;color:var(--gray-600);font-weight:600;}
.card-source-time{font-size:11px;color:var(--gray-400);margin-left:auto;}
.card-title{font-family:var(--font-head);font-size:15px;font-weight:700;line-height:1.35;color:var(--gray-900);margin-bottom:10px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card-title a{color:inherit;transition:color var(--tr);}
.card-title a:hover{color:var(--green);}
.card-excerpt{font-size:13px;color:var(--gray-600);line-height:1.55;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card-footer{display:flex;align-items:center;gap:12px;padding-top:10px;border-top:1px solid var(--gray-100);margin-top:auto;}
.card-action{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--gray-400);transition:color var(--tr);background:none;border:none;padding:0;}
.card-action:hover{color:var(--green);}
.card-share{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--gray-400);background:none;border:none;padding:4px 8px;border-radius:20px;transition:all var(--tr);}
.card-share:hover{background:var(--green-light);color:var(--green);}

/* PICKS CAROUSEL */
.picks-scroll{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none;margin-bottom:28px;scroll-snap-type:x mandatory;}
.picks-scroll::-webkit-scrollbar{display:none;}
.pick-card{flex:0 0 185px;background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);scroll-snap-align:start;transition:box-shadow var(--tr),transform var(--tr);display:flex;flex-direction:column;}
.pick-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.pick-image{aspect-ratio:4/3;overflow:hidden;display:block;background:var(--gray-100);}
.pick-image img{width:100%;height:100%;transition:transform .45s;}
.pick-card:hover .pick-image img{transform:scale(1.07);}
.pick-body{padding:10px 12px;flex:1;}
.pick-source{font-family:var(--font-nav);font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--green);margin-bottom:5px;}
.pick-title{font-family:var(--font-head);font-size:13px;font-weight:700;line-height:1.35;color:var(--gray-900);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--tr);}
.pick-title:hover{color:var(--green);}
.pick-actions{display:flex;gap:12px;padding:8px 12px;border-top:1px solid var(--gray-100);}
.pick-stat{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--gray-400);}
.scroll-arrow{width:30px;height:30px;background:#fff;border:1px solid var(--gray-200);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gray-600);box-shadow:0 1px 4px rgba(0,0,0,.08);transition:all var(--tr);}
.scroll-arrow:hover{background:var(--green);color:#fff;border-color:var(--green);}

/* LIST CARD */
.more-stories-list{background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);padding:0 16px;margin-bottom:28px;}
.list-card{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--gray-100);}
.list-card:last-child{border-bottom:none;}
.list-card-image{flex:0 0 100px;height:70px;border-radius:6px;overflow:hidden;display:block;background:var(--gray-100);}
.list-card-image img{width:100%;height:100%;transition:transform .4s;}
.list-card:hover .list-card-image img{transform:scale(1.06);}
.list-card-body{flex:1;min-width:0;}
.list-card-source{font-family:var(--font-nav);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--green);margin-bottom:4px;}
.list-card-title{font-family:var(--font-head);font-size:14px;font-weight:700;line-height:1.35;color:var(--gray-900);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--tr);}
.list-card-title:hover{color:var(--green);}
.list-card-time{font-size:11px;color:var(--gray-400);margin-top:4px;}

/* IMAGE PLACEHOLDERS */
.img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-nav);font-size:12px;letter-spacing:.5px;text-transform:uppercase;font-weight:700;}
.cat-news.img-placeholder,.img-placeholder.cat-news{background:#e8f5ed;color:#0f5a2a;}
.cat-sport.img-placeholder,.img-placeholder.cat-sport{background:#e3f0fb;color:#1565c0;}
.cat-ent.img-placeholder,.img-placeholder.cat-ent{background:#fbe9e7;color:#b71c1c;}
.cat-health.img-placeholder,.img-placeholder.cat-health{background:#e8f5e9;color:#2e7d32;}
.cat-tech.img-placeholder,.img-placeholder.cat-tech{background:#ede7f6;color:#4527a0;}

/* SIDEBAR */
.sidebar-widget{background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);margin-bottom:22px;overflow:hidden;}
.widget-header,.widget-title{padding:13px 16px;border-bottom:1px solid var(--gray-100);font-family:var(--font-nav);font-size:12px;letter-spacing:1px;text-transform:uppercase;font-weight:600;color:var(--gray-900);display:flex;align-items:center;gap:8px;}
.widget-header::before,.widget-title::before{content:'';display:inline-block;width:3px;height:14px;background:var(--green);border-radius:2px;flex-shrink:0;}
.widget-body{padding:14px 16px;}
.newsletter-widget{background:var(--green);border-color:var(--green);}
.newsletter-widget .widget-header{color:#fff;border-bottom-color:rgba(255,255,255,.15);}
.newsletter-widget .widget-header::before{background:#fff;}
.newsletter-body{padding:16px;}
.newsletter-body p{font-size:13px;color:rgba(255,255,255,.87);margin-bottom:14px;line-height:1.55;}
.newsletter-form{display:flex;flex-direction:column;gap:10px;}
.newsletter-input{width:100%;padding:11px 14px;border:none;border-radius:5px;font-family:var(--font-body);font-size:13px;background:rgba(255,255,255,.18);color:#fff;outline:none;transition:background var(--tr);}
.newsletter-input::placeholder{color:rgba(255,255,255,.58);}
.newsletter-input:focus{background:rgba(255,255,255,.26);}
.newsletter-btn{width:100%;padding:12px;background:#fff;border:none;border-radius:5px;font-family:var(--font-nav);font-size:13px;font-weight:700;letter-spacing:.5px;color:var(--green);transition:background var(--tr),color var(--tr);}
.newsletter-btn:hover{background:var(--gray-900);color:#fff;}
.newsletter-msg{font-size:13px;color:#fff;padding:4px 0;}
.trending-item{display:flex;align-items:flex-start;gap:11px;padding:11px 0;border-bottom:1px solid var(--gray-100);}
.trending-item:last-child{border-bottom:none;}
.trending-num{font-family:var(--font-nav);font-size:24px;font-weight:700;color:var(--gray-200);line-height:1;flex-shrink:0;min-width:30px;transition:color var(--tr);}
.trending-item:hover .trending-num{color:var(--green-light);}
.trending-text{font-family:var(--font-head);font-size:13px;font-weight:700;line-height:1.35;color:var(--gray-900);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--tr);}
.trending-item:hover .trending-text{color:var(--green);}
.trending-meta{font-size:11px;color:var(--gray-400);margin-top:3px;}
.tags-wrap{display:flex;flex-wrap:wrap;gap:8px;}
.tag{padding:5px 13px;border:1.5px solid var(--gray-200);border-radius:22px;font-size:12px;font-weight:600;color:var(--gray-600);transition:all var(--tr);}
.tag:hover{background:var(--green);color:#fff;border-color:var(--green);}

/* ARCHIVE */
.archive-header{background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);padding:24px;margin-bottom:24px;}
.archive-header-inner{display:flex;align-items:flex-start;gap:16px;}
.archive-icon{width:52px;height:52px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--cb,var(--green-light));color:var(--cc,var(--green));}
.archive-avatar{width:60px;height:60px;border-radius:50%;}
.archive-label{font-family:var(--font-nav);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--green);margin-bottom:4px;}
.archive-title{font-size:clamp(20px,3vw,28px);font-weight:700;margin-bottom:6px;}
.archive-desc{font-size:13px;color:var(--gray-600);line-height:1.55;}
.archive-search-form{display:flex;border:1.5px solid var(--gray-200);border-radius:24px;overflow:hidden;max-width:440px;}
.archive-search-form input{flex:1;padding:10px 16px;border:none;font-family:var(--font-body);font-size:14px;background:var(--gray-50);outline:none;}
.archive-search-form button{padding:10px 16px;background:var(--green);border:none;color:#fff;display:flex;align-items:center;transition:background var(--tr);}
.archive-search-form button:hover{background:var(--green-dark);}

/* SINGLE ARTICLE */
.breadcrumb{font-size:12px;color:var(--gray-400);margin-bottom:16px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.breadcrumb a{color:var(--green);}
.breadcrumb a:hover{opacity:.75;}
.single-article,.page-article{background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);padding:28px;margin-bottom:28px;}
.article-header{margin-bottom:20px;}
.article-meta-top{margin-bottom:10px;}
.article-category{display:inline-flex;align-items:center;background:var(--cb,var(--green-light));color:var(--cc,var(--green));font-family:var(--font-nav);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:22px;font-weight:600;}
.article-title{font-size:clamp(22px,4vw,34px);font-weight:700;line-height:1.2;margin-bottom:12px;}
.article-excerpt{font-size:17px;color:var(--gray-600);line-height:1.65;margin-bottom:16px;}
.article-byline{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);flex-wrap:wrap;}
.article-author{display:flex;align-items:center;gap:10px;}
.author-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;}
.author-name{font-size:14px;font-weight:600;color:var(--gray-800);display:block;}
.author-name a{color:var(--green);}
.article-date{font-size:12px;color:var(--gray-400);display:block;margin-top:2px;}
.article-featured-image{border-radius:var(--radius);overflow:hidden;margin-bottom:24px;aspect-ratio:16/8;}
.article-featured-image img{width:100%;height:100%;}
.article-content{font-size:16px;line-height:1.8;color:var(--gray-800);max-width:760px;}
.article-content p{margin-bottom:18px;}
.article-content h2{font-size:24px;margin:28px 0 12px;}
.article-content h3{font-size:20px;margin:24px 0 10px;}
.article-content a{color:var(--green);text-decoration:underline;}
.article-content img{border-radius:6px;margin:18px 0;}
.article-content blockquote{border-left:4px solid var(--green);background:var(--green-light);padding:16px 20px;border-radius:0 6px 6px 0;margin:20px 0;font-style:italic;color:var(--gray-600);}
.article-content ul,.article-content ol{padding-left:24px;margin-bottom:18px;}
.article-content li{margin-bottom:6px;}
.article-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:22px;padding-top:18px;border-top:1px solid var(--gray-100);}
.tags-label{font-size:12px;font-weight:700;color:var(--gray-600);font-family:var(--font-nav);text-transform:uppercase;letter-spacing:.5px;}
.author-box{display:flex;align-items:flex-start;gap:16px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);padding:20px;margin-top:28px;}
.author-box-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.author-box-name{font-family:var(--font-head);font-size:17px;font-weight:700;color:var(--gray-900);display:block;margin-bottom:6px;}
.author-box-name:hover{color:var(--green);}
.author-box-bio{font-size:13px;color:var(--gray-600);line-height:1.55;}
.related-posts{margin-top:28px;}
.comments-section{background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);padding:28px;}
.comments-area{}
.comments-title{font-size:18px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:8px;}
.comments-title svg{color:var(--green);}
.comment-list{list-style:none;padding:0;}
.comment{padding:16px 0;border-bottom:1px solid var(--gray-100);}
.comment:last-child{border-bottom:none;}
.comment-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.comment-author img{width:44px;height:44px;border-radius:50%;object-fit:cover;}
.comment-content{font-size:14px;color:var(--gray-700,#4a4a4a);line-height:1.65;margin-left:54px;}
.comment-awaiting-moderation{font-size:12px;color:var(--gray-400);font-style:italic;}
.comment-reply-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--gray-400);padding:4px 10px;border-radius:20px;border:1px solid var(--gray-200);margin-left:auto;transition:all var(--tr);}
.comment-reply-link:hover{background:var(--green-light);color:var(--green);border-color:var(--green);}
.comment-reply-title{font-size:18px;font-weight:700;margin:28px 0 16px;}
.comment-form{display:flex;flex-direction:column;gap:14px;}
.comment-form label{display:block;font-size:14px;font-weight:600;color:var(--gray-700,#444);margin-bottom:6px;}
.comment-form textarea,.comment-form input[type="text"],.comment-form input[type="email"],.comment-form input[type="url"]{width:100%;padding:12px 14px;border:1.5px solid var(--gray-200);border-radius:6px;font-family:var(--font-body);font-size:14px;background:var(--gray-50);color:var(--gray-900);outline:none;transition:border-color var(--tr),box-shadow var(--tr);resize:vertical;}
.comment-form textarea:focus,.comment-form input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(26,122,60,.1);}
.comment-form .btn-write{align-self:flex-start;padding:11px 22px;}

/* NO RESULTS */
.no-results{background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);padding:60px 24px;text-align:center;}
.no-results svg{margin:0 auto 20px;color:var(--gray-300);}
.no-results h2{font-size:22px;margin-bottom:10px;}
.no-results p{font-size:15px;color:var(--gray-500);margin-bottom:22px;}

/* PAGINATION */
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin:28px 0;flex-wrap:wrap;}
.pagination a,.pagination span.current{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border-radius:6px;font-size:13px;font-weight:600;border:1.5px solid var(--gray-200);background:#fff;color:var(--gray-700,#444);transition:all var(--tr);}
.pagination a:hover{background:var(--green-light);border-color:var(--green);color:var(--green);}
.pagination span.current{background:var(--green);color:#fff;border-color:var(--green);}

/* SHARE MODAL */
.share-modal{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;}
.share-modal-inner{background:#fff;border-radius:var(--radius-lg);padding:28px;max-width:380px;width:100%;position:relative;box-shadow:var(--shadow-lg);}
.share-modal-inner h3{font-size:18px;margin-bottom:18px;}
.share-close{position:absolute;top:14px;right:14px;background:var(--gray-100);border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gray-600);transition:background var(--tr);}
.share-close:hover{background:var(--gray-200);}
.share-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.share-btn{padding:11px 14px;border-radius:6px;font-family:var(--font-nav);font-size:12px;font-weight:600;letter-spacing:.5px;text-align:center;border:none;transition:all var(--tr);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;}
.share-fb{background:#1877f2;color:#fff;}
.share-fb:hover{background:#1465d8;}
.share-tw{background:#111;color:#fff;}
.share-tw:hover{background:#000;}
.share-wa{background:#25d366;color:#fff;}
.share-wa:hover{background:#20b85a;}
.share-copy{background:var(--gray-100);color:var(--gray-800);border:1.5px solid var(--gray-200);}
.share-copy:hover{background:var(--green-light);color:var(--green);border-color:var(--green);}

/* FOOTER */
.site-footer{background:#111418;color:var(--gray-400);margin-top:40px;width:100%;}
.footer-top{border-bottom:1px solid rgba(255,255,255,.07);}
.footer-inner{max-width:1260px;margin:0 auto;padding:44px 16px 36px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;}
.footer-logo-wrap img,.footer-logo-wrap .custom-logo{height:46px;width:auto;margin-bottom:14px;filter:brightness(0) invert(1) opacity(.85);}
.footer-site-name{font-family:var(--font-nav);font-size:24px;font-weight:700;color:#4caf50;letter-spacing:1px;display:block;margin-bottom:14px;}
.footer-desc{font-size:13px;line-height:1.75;color:rgba(255,255,255,.44);margin-bottom:18px;}
.footer-socials{display:flex;gap:10px;flex-wrap:wrap;}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:all var(--tr);}
.social-btn:hover{background:var(--green);border-color:var(--green);color:#fff;transform:translateY(-2px);}
.footer-col-title{font-family:var(--font-nav);font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.7);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.07);}
.footer-links{list-style:none;}
.footer-links li{margin-bottom:10px;}
.footer-links li a,.footer-links a{font-size:13px;color:rgba(255,255,255,.42);transition:color var(--tr);}
.footer-links li a:hover,.footer-links a:hover{color:#fff;}
.footer-bottom{background:rgba(0,0,0,.2);}
.footer-bottom-inner{max-width:1260px;margin:0 auto;padding:15px 16px;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.footer-copyright{font-size:12px;color:rgba(255,255,255,.28);}
.footer-bottom-links{display:flex;gap:16px;}
.footer-bottom-links a{font-size:12px;color:rgba(255,255,255,.28);transition:color var(--tr);}
.footer-bottom-links a:hover{color:rgba(255,255,255,.7);}

/* WP CORE */
.alignleft{float:left;margin:0 20px 16px 0;}
.alignright{float:right;margin:0 0 16px 20px;}
.aligncenter{display:block;margin:16px auto;}
.wp-caption{max-width:100%;}
.wp-caption-text{font-size:13px;color:var(--gray-500);text-align:center;padding:6px 0;}
.screen-reader-text{clip:rect(1px,1px,1px,1px);height:1px;overflow:hidden;position:absolute;width:1px;}
.admin-bar .main-nav{top:32px;}

/* RESPONSIVE */
@media(max-width:1024px){.site-body{grid-template-columns:1fr;}.sidebar{margin-top:28px;}.footer-inner{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){.news-grid{grid-template-columns:1fr;}.news-grid-3{grid-template-columns:1fr 1fr;}.header-search{display:none;}.mobile-toggle{display:flex;}.footer-inner{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.news-grid-3{grid-template-columns:1fr;}.hero-slider{aspect-ratio:4/3;}.hero-overlay{padding:32px 16px 16px;}.single-article,.page-article{padding:18px;}.footer-inner{grid-template-columns:1fr;}.footer-bottom-inner{flex-direction:column;align-items:flex-start;}.topbar-date,.topbar-links{display:none;}.share-buttons{grid-template-columns:1fr 1fr;}}
@media screen and(max-width:782px){.admin-bar .main-nav{top:46px;}}

/* ═══════════════════════════════════════════════════
   POST REACTIONS BAR
═══════════════════════════════════════════════════ */
.post-reactions-bar {
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid var(--gray-200);
    padding: 20px 24px;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}
.reactions-label {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
    font-weight: 600;
    color: var(--gray-600);
    white-space: nowrap;
    font-family: var(--font-nav);
    letter-spacing: .5px;
    text-transform: uppercase;
}
.reactions-label svg { color: var(--green); flex-shrink: 0; }
.reactions-list {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    flex: 1;
}
.reaction-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 50px;
    border: 1.5px solid var(--gray-200);
    background: #fff;
    cursor: pointer;
    transition: all .22s ease;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 600;
    color: var(--gray-600);
    position: relative;
    overflow: hidden;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
}
.reaction-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--rb, #e8f5ed);
    opacity: 0;
    transition: opacity .22s;
    border-radius: inherit;
}
.reaction-btn:hover::before { opacity: 1; }
.reaction-btn:hover {
    border-color: var(--rc, var(--green));
    color: var(--rc, var(--green));
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(0,0,0,.1);
}
.reaction-btn:hover .reaction-icon svg { fill: var(--rc, var(--green)); }
.reaction-btn.reacted {
    background: var(--rb, #e8f5ed);
    border-color: var(--rc, var(--green));
    color: var(--rc, var(--green));
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.reaction-btn.reacted .reaction-icon svg { fill: var(--rc, var(--green)); }
.reaction-btn.reacted .reaction-icon { animation: reactionPop .4s cubic-bezier(.36,.07,.19,.97); }
@keyframes reactionPop {
    0%   { transform: scale(1); }
    30%  { transform: scale(1.45) rotate(-8deg); }
    60%  { transform: scale(.88) rotate(5deg); }
    80%  { transform: scale(1.12); }
    100% { transform: scale(1); }
}
.reaction-btn.animating .reaction-icon { animation: reactionPop .4s cubic-bezier(.36,.07,.19,.97); }
.reaction-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}
.reaction-icon svg { transition: fill .22s; }
.reaction-label { position: relative; z-index: 1; }
.reaction-count {
    background: var(--rc, var(--green));
    color: #fff;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 700;
    padding: 1px 6px;
    min-width: 18px;
    text-align: center;
    position: relative;
    z-index: 1;
    transition: transform .2s;
}
.reaction-btn:not(.reacted) .reaction-count:empty { display: none; }
.reaction-count.bump { animation: countBump .3s ease; }
@keyframes countBump {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.35); }
    100% { transform: scale(1); }
}
.reactions-total {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--gray-400);
    margin-left: auto;
    white-space: nowrap;
}
.reactions-total-icons { display: flex; gap: 2px; font-size: 15px; }
.reactions-total-count { font-weight: 600; }

/* floating emoji burst */
.emoji-burst {
    position: fixed;
    pointer-events: none;
    z-index: 9999;
    font-size: 26px;
    animation: emojiFly .9s ease forwards;
}
@keyframes emojiFly {
    0%   { opacity: 1; transform: translateY(0) scale(1); }
    100% { opacity: 0; transform: translateY(-90px) scale(1.6); }
}

/* ═══════════════════════════════════════════════════
   COMMENTS SECTION
═══════════════════════════════════════════════════ */
.comments-section {
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid var(--gray-200);
    padding: 28px;
    margin-top: 0;
}
.comments-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--gray-100);
    flex-wrap: wrap;
    gap: 12px;
}
.comments-title {
    font-size: 18px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 9px;
    color: var(--gray-900);
    margin: 0;
}
.comments-title svg { color: var(--green); flex-shrink: 0; }
.btn-leave-comment {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    background: var(--green-light);
    border: 1.5px solid var(--green);
    border-radius: 22px;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 600;
    color: var(--green);
    cursor: pointer;
    transition: all var(--tr);
}
.btn-leave-comment:hover { background: var(--green); color: #fff; }

/* ── Comment List ── */
.comment-list {
    list-style: none;
    padding: 0;
    margin: 0 0 28px 0;
}
.comment-item {
    position: relative;
}
.comment-body {
    display: flex;
    gap: 14px;
    padding: 18px 0;
    border-bottom: 1px solid var(--gray-100);
}
.comment-item:last-child > .comment-body { border-bottom: none; }

/* Threaded nesting */
.comment-item .children {
    list-style: none;
    padding: 0;
    margin: 0 0 0 48px;
    border-left: 2px solid var(--gray-100);
    padding-left: 18px;
}
.comment-item.is-reply .comment-body { padding-top: 14px; padding-bottom: 14px; }
.depth-2 .comment-body { background: var(--gray-50); border-radius: var(--radius); padding: 14px; margin-bottom: 8px; }
.depth-3 .comment-body { background: #f0f4f0; border-radius: var(--radius); padding: 12px; margin-bottom: 6px; }

.comment-avatar { flex-shrink: 0; position: relative; }
.avatar-img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; display: block; border: 2px solid var(--gray-200); }
.is-reply .avatar-img { width: 38px; height: 38px; }
.thread-line {
    width: 2px;
    background: var(--gray-200);
    position: absolute;
    top: 54px;
    left: 50%;
    transform: translateX(-50%);
    bottom: -18px;
    border-radius: 2px;
}

.comment-main { flex: 1; min-width: 0; }
.comment-head {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
}
.comment-author-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--gray-900);
    transition: color var(--tr);
}
a.comment-author-name:hover { color: var(--green); }
.comment-badge {
    background: var(--green);
    color: #fff;
    font-family: var(--font-nav);
    font-size: 9px;
    letter-spacing: .7px;
    text-transform: uppercase;
    padding: 2px 7px;
    border-radius: 10px;
    font-weight: 700;
}
.comment-time {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--gray-400);
    margin-left: auto;
}
.comment-time svg { flex-shrink: 0; }

.comment-pending {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #f57c00;
    background: #fff3e0;
    border-radius: 6px;
    padding: 7px 12px;
    margin-bottom: 10px;
}
.comment-text {
    font-size: 14px;
    line-height: 1.7;
    color: var(--gray-800);
    margin-bottom: 10px;
}
.comment-text p { margin-bottom: 8px; }
.comment-text p:last-child { margin-bottom: 0; }

.comment-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.reply-wrap a,
.comment-reply-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: var(--gray-500);
    padding: 5px 12px;
    border-radius: 20px;
    border: 1px solid var(--gray-200);
    transition: all var(--tr);
    background: #fff;
    font-weight: 600;
}
.reply-wrap a:hover,
.comment-reply-link:hover {
    background: var(--green-light);
    border-color: var(--green);
    color: var(--green);
}
.comment-edit-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: var(--gray-400);
    transition: color var(--tr);
    font-weight: 600;
}
.comment-edit-link:hover { color: var(--green); }
.cancel-reply-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--gray-400);
    transition: color var(--tr);
}
.cancel-reply-link:hover { color: var(--red); }

/* ── No Comments Yet ── */
.no-comments-yet {
    text-align: center;
    padding: 32px 16px;
    color: var(--gray-400);
}
.no-comments-yet svg { margin: 0 auto 14px; opacity: .4; }
.no-comments-yet p { font-size: 14px; }

/* ── Comments Closed ── */
.comments-closed {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
    color: var(--gray-400);
    background: var(--gray-50);
    border-radius: 6px;
    padding: 12px 16px;
    margin-top: 16px;
}

/* ── Comment Navigation ── */
.comment-navigation {
    display: flex;
    justify-content: space-between;
    padding: 16px 0;
    border-top: 1px solid var(--gray-100);
    margin-top: 8px;
}
.comment-nav-prev a,
.comment-nav-next a {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 600;
    color: var(--green);
    transition: opacity var(--tr);
}
.comment-nav-prev a:hover,
.comment-nav-next a:hover { opacity: .75; }

/* ── Comment Form ── */
.comment-form-header {
    margin-bottom: 20px;
    padding-top: 24px;
    border-top: 2px solid var(--gray-100);
}
.comment-reply-title {
    font-size: 18px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 9px;
    color: var(--gray-900);
    margin: 0;
}
.comment-reply-title svg { color: var(--green); flex-shrink: 0; }
.comment-form { display: flex; flex-direction: column; gap: 16px; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cf-field { display: flex; flex-direction: column; gap: 6px; }
.cf-field label {
    font-size: 13px;
    font-weight: 600;
    color: var(--gray-700, #444);
    display: flex;
    align-items: center;
    gap: 4px;
}
.required-star { color: var(--red); font-size: 14px; line-height: 1; }
.cf-field textarea,
.cf-field input[type="text"],
.cf-field input[type="email"],
.comment-form textarea,
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"] {
    width: 100%;
    padding: 12px 14px;
    border: 1.5px solid var(--gray-200);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: 14px;
    background: var(--gray-50);
    color: var(--gray-900);
    outline: none;
    transition: border-color var(--tr), box-shadow var(--tr);
    resize: vertical;
    line-height: 1.6;
}
.cf-field textarea:focus,
.cf-field input:focus,
.comment-form textarea:focus,
.comment-form input:focus {
    border-color: var(--green);
    box-shadow: 0 0 0 3px rgba(26,122,60,.1);
    background: #fff;
}
.cf-field textarea { min-height: 130px; resize: vertical; }
.cf-submit {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}
.cf-submit .btn-write { padding: 12px 24px; font-size: 14px; }
#cancel-comment-reply-link { font-size: 13px; }
.comment-form-cookies-consent label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 12px;
    color: var(--gray-500);
    line-height: 1.5;
    cursor: pointer;
}
.comment-form-cookies-consent input { flex-shrink: 0; margin-top: 2px; }
.comment-notes { font-size: 12px; color: var(--gray-400); }

@media (max-width: 600px) {
    .cf-row { grid-template-columns: 1fr; }
    .post-reactions-bar { padding: 16px; gap: 12px; }
    .reactions-list { gap: 6px; }
    .reaction-btn { padding: 7px 11px; font-size: 12px; }
    .reaction-label { display: none; }
    .comment-item .children { margin-left: 24px; padding-left: 12px; }
    .comments-section { padding: 18px; }
}

/* replying-to highlight */
.comment-item.replying-to > .comment-body {
    background: #fffde7;
    border-radius: var(--radius);
    padding: 14px;
    outline: 2px solid #f9a825;
    transition: background .3s, outline .3s;
}
/* respond / cancel reply */
#respond { scroll-margin-top: 80px; }
#cancel-comment-reply-link { font-size:13px; color:var(--gray-400); display:inline-flex; align-items:center; gap:4px; }
#cancel-comment-reply-link:hover { color:var(--red,#c62828); }
