/*
Theme Name: Newsline
Theme URI: https://example.com/newsline
Author: Newsline
Author URI: https://example.com
Description: A modern, responsive news magazine theme with a sticky navigation, trending ticker, big-grid hero, category sections, sidebar widget area, and customizable social media links. Built from scratch with clean code — no page-builder dependency.
Version: 1.0.0
Requires at least: 5.5
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: newsline
Tags: news, magazine, blog, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, two-columns, right-sidebar, sticky-post, full-width-template
*/

:root{
  --accent:#d62828;
  --accent-dark:#a31d1d;
  --ink:#1a1a1a;
  --ink-soft:#444;
  --muted:#888;
  --line:#e5e5e5;
  --bg:#ffffff;
  --bg-soft:#f7f7f5;
  --footer-bg:#111111;
  --footer-ink:#bdbdbd;
  --serif:'Playfair Display', Georgia, serif;
  --sans:'Source Sans 3', system-ui, -apple-system, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none;transition:color .15s ease}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto;display:block}
p{margin-bottom:1em}

/* ===== Top bar ===== */
.topbar{background:#fafafa;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink-soft)}
.topbar .inner{max-width:1180px;margin:0 auto;padding:8px 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.socials{display:flex;gap:14px}
.socials a{color:var(--muted);font-size:14px;display:inline-flex;align-items:center;gap:5px}
.socials a:hover{color:var(--accent)}
.socials svg{width:16px;height:16px;fill:currentColor}

/* ===== Masthead ===== */
.masthead{border-bottom:1px solid var(--line)}
.masthead .inner{max-width:1180px;margin:0 auto;padding:28px 20px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.site-logo{font-family:var(--serif);font-weight:900;font-size:42px;letter-spacing:-1px;color:var(--ink);line-height:1}
.site-logo span{color:var(--accent)}
.site-logo small{display:block;font-family:var(--sans);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:6px}
.site-logo img{max-height:80px;width:auto}
.banner-ad{min-width:300px;min-height:90px;background:repeating-linear-gradient(45deg,#f5f5f5,#f5f5f5 10px,#eee 10px,#eee 20px);border:1px dashed #ddd;display:flex;align-items:center;justify-content:center;color:#aaa;font-size:12px;letter-spacing:2px;text-transform:uppercase;padding:10px 20px;text-align:center}

/* ===== Nav ===== */
nav.primary{background:var(--ink);position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.06)}
nav.primary .inner{max-width:1180px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between}
nav.primary ul{display:flex;list-style:none;flex-wrap:wrap;margin:0;padding:0}
nav.primary li a{display:block;padding:14px 16px;color:#fff;font-weight:600;font-size:14px;letter-spacing:.5px;text-transform:uppercase;border-bottom:3px solid transparent;transition:all .2s ease}
nav.primary li.current-menu-item a,
nav.primary li a:hover{border-bottom-color:var(--accent);color:#fff;background:rgba(255,255,255,.04)}
.search-toggle{background:none;border:none;color:#fff;padding:14px 16px;cursor:pointer;font-size:14px;border-left:1px solid #2a2a2a;font-family:inherit;letter-spacing:.5px}
.search-toggle:hover{color:var(--accent)}
.mobile-toggle{display:none;background:none;border:none;color:#fff;padding:14px 16px;cursor:pointer;font-size:20px}
.search-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:100;align-items:center;justify-content:center}
.search-overlay.active{display:flex}
.search-overlay form{width:90%;max-width:600px}
.search-overlay input{width:100%;background:transparent;border:none;border-bottom:2px solid #555;color:#fff;font-size:32px;font-family:var(--serif);padding:20px 0;outline:none}
.search-overlay input::placeholder{color:#666}
.search-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:30px;cursor:pointer}

/* ===== Trending ticker ===== */
.trending{background:#fff;border-bottom:1px solid var(--line)}
.trending .inner{max-width:1180px;margin:0 auto;padding:0 20px;display:flex;align-items:center;overflow:hidden}
.trending-label{background:var(--ink);color:#fff;padding:12px 18px;font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;flex-shrink:0;position:relative}
.trending-label::after{content:"";position:absolute;right:-10px;top:0;bottom:0;width:0;border-left:10px solid var(--ink);border-top:21px solid transparent;border-bottom:21px solid transparent}
.ticker{flex:1;overflow:hidden;padding:12px 24px 12px 28px;white-space:nowrap;position:relative}
.ticker-track{display:inline-block;animation:scroll 40s linear infinite;font-size:14px;color:var(--ink-soft)}
.ticker-track a{margin-right:36px;font-weight:600}
.ticker-track a::before{content:"●";color:var(--accent);margin-right:10px;font-size:10px;vertical-align:middle}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== Layout ===== */
.site-content{max-width:1180px;margin:0 auto;padding:30px 20px 50px}

/* ===== Hero grid ===== */
.hero{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:40px}
.hero-main{position:relative;overflow:hidden;border-radius:2px;min-height:460px;background:#222;cursor:pointer}
.hero-main .img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s ease}
.hero-main:hover .img{transform:scale(1.04)}
.hero-main::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.3) 50%,transparent 100%)}
.hero-main .content{position:absolute;left:0;right:0;bottom:0;padding:30px;color:#fff;z-index:2}
.hero-main .cat{display:inline-block;background:var(--accent);color:#fff;padding:5px 12px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.hero-main h2{font-family:var(--serif);font-size:34px;font-weight:900;line-height:1.15;margin-bottom:10px;color:#fff}
.hero-main h2 a{color:#fff}
.hero-main .meta{font-size:13px;opacity:.85}
.hero-side{display:grid;grid-template-rows:repeat(3,1fr);gap:20px}
.hero-card{position:relative;overflow:hidden;border-radius:2px;min-height:140px;background:#222;cursor:pointer}
.hero-card .img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s ease}
.hero-card:hover .img{transform:scale(1.06)}
.hero-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85),rgba(0,0,0,.1))}
.hero-card .content{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;z-index:2}
.hero-card .cat{display:inline-block;background:var(--accent);color:#fff;padding:3px 8px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.hero-card h3{font-family:var(--serif);font-size:17px;font-weight:700;line-height:1.25;color:#fff}
.hero-card h3 a{color:#fff}

/* ===== Section headings ===== */
.section-head{display:flex;align-items:center;border-top:2px solid var(--ink);margin:40px 0 22px;position:relative}
.section-head h3{background:var(--ink);color:#fff;padding:8px 18px;font-size:13px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;font-family:var(--sans)}
.section-head .view-all{margin-left:auto;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);padding-top:6px}

/* ===== Article grid ===== */
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.article{transition:transform .2s ease}
.article .thumb{position:relative;overflow:hidden;aspect-ratio:16/10;background:#222;margin-bottom:12px}
.article .thumb .img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s ease}
.article:hover .thumb .img{transform:scale(1.05)}
.article .cat{position:absolute;top:10px;left:10px;background:var(--accent);color:#fff;padding:3px 9px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;z-index:2}
.article h4{font-family:var(--serif);font-size:18px;font-weight:700;line-height:1.3;margin-bottom:8px;color:var(--ink)}
.article h4 a:hover{color:var(--accent)}
.article .meta{font-size:12px;color:var(--muted);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.article .meta .author{color:var(--ink-soft);font-weight:600}
.article .excerpt{font-size:14px;color:var(--ink-soft);margin-top:8px;line-height:1.5}

/* Two column section with sidebar */
.two-col{display:grid;grid-template-columns:2fr 1fr;gap:40px;margin-top:50px}
.two-col .article-grid{grid-template-columns:repeat(2,1fr)}
.widget{margin-bottom:34px}
.widget-title{font-size:13px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;padding-bottom:10px;border-bottom:2px solid var(--ink);margin-bottom:16px}
.small-article{display:flex;gap:12px;margin-bottom:16px}
.small-article .thumb{width:90px;height:65px;flex-shrink:0;background-size:cover;background-position:center;background-color:#222}
.small-article h6{font-family:var(--serif);font-size:14px;font-weight:700;line-height:1.3;margin-bottom:4px}
.small-article h6 a:hover{color:var(--accent)}
.small-article .meta{font-size:11px;color:var(--muted)}
.number{display:inline-block;font-family:var(--serif);font-weight:900;color:var(--accent);font-size:22px;width:32px;flex-shrink:0;line-height:1}

/* Sidebar widget styling */
aside .widget ul{list-style:none;padding:0}
aside .widget ul li{padding:8px 0;border-bottom:1px solid var(--line);font-size:14px}
aside .widget ul li a:hover{color:var(--accent)}

/* Newsletter widget */
.newsletter-widget input[type="email"]{width:100%;padding:11px 12px;border:1px solid var(--line);font-family:inherit;font-size:14px;margin-bottom:8px}
.newsletter-widget button{width:100%;padding:11px;background:var(--accent);color:#fff;border:none;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:13px;cursor:pointer;font-family:inherit}
.newsletter-widget button:hover{background:var(--accent-dark)}

/* ===== Single post / page ===== */
.single-post,.page-content{max-width:820px;margin:0 auto}
.entry-header{margin-bottom:30px}
.entry-header .cat{display:inline-block;background:var(--accent);color:#fff;padding:5px 12px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px}
.entry-title{font-family:var(--serif);font-size:42px;font-weight:900;line-height:1.15;margin-bottom:16px}
.entry-meta{font-size:13px;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:24px}
.entry-meta .author{color:var(--ink-soft);font-weight:600}
.featured-img{margin-bottom:28px}
.featured-img img{width:100%}
.entry-content{font-size:17px;line-height:1.75;color:var(--ink-soft)}
.entry-content h2,.entry-content h3{font-family:var(--serif);color:var(--ink);margin:1.6em 0 .6em}
.entry-content h2{font-size:28px}
.entry-content h3{font-size:22px}
.entry-content a{color:var(--accent);border-bottom:1px solid currentColor}
.entry-content img{margin:1.5em 0}
.entry-content blockquote{border-left:4px solid var(--accent);padding:8px 0 8px 24px;font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink);margin:1.5em 0}

/* Pagination */
.pagination{margin:40px 0;display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.pagination .page-numbers{padding:10px 16px;border:1px solid var(--line);font-weight:600;font-size:14px}
.pagination .current,.pagination .page-numbers:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* Comments */
.comments-area{margin-top:50px;max-width:820px;margin-left:auto;margin-right:auto}
.comments-title{font-family:var(--serif);font-size:24px;margin-bottom:20px}
.comment-list{list-style:none;padding:0}
.comment-list .comment{padding:18px 0;border-bottom:1px solid var(--line)}
.comment-author{font-weight:700;font-size:14px;margin-bottom:6px}
.comment-meta{font-size:12px;color:var(--muted);margin-bottom:8px}

/* ===== Footer ===== */
.site-footer{background:var(--footer-bg);color:var(--footer-ink);margin-top:50px}
.site-footer .inner{max-width:1180px;margin:0 auto;padding:50px 20px 30px;display:grid;grid-template-columns:1.5fr 2fr 1fr;gap:40px}
.site-footer h6{color:#fff;font-size:13px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--accent);display:inline-block}
.site-footer .site-logo{color:#fff;font-size:32px;margin-bottom:14px}
.site-footer .site-logo small{color:#666}
.site-footer p{font-size:14px;line-height:1.7}
.site-footer .contact{margin-top:14px;font-size:14px}
.site-footer .contact a{color:var(--accent)}
.site-footer .socials a{color:#fff;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid #333;margin-right:8px;transition:all .2s ease}
.site-footer .socials a:hover{background:var(--accent);border-color:var(--accent)}
.subfooter{border-top:1px solid #222;padding:18px 20px;font-size:13px;display:flex;justify-content:space-between;max-width:1180px;margin:0 auto;flex-wrap:wrap;gap:10px;align-items:center}
.subfooter ul{display:flex;list-style:none;gap:18px;flex-wrap:wrap;padding:0;margin:0}
.subfooter a:hover{color:var(--accent)}

/* Search form */
.search-form{display:flex;gap:0;margin-bottom:20px}
.search-form input[type="search"]{flex:1;padding:10px 12px;border:1px solid var(--line);font-family:inherit;font-size:14px}
.search-form button{padding:10px 18px;background:var(--ink);color:#fff;border:none;font-weight:600;font-size:13px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-family:inherit}

/* 404 */
.error-404{text-align:center;padding:60px 20px;max-width:600px;margin:0 auto}
.error-404 h1{font-family:var(--serif);font-size:120px;color:var(--accent);font-weight:900;line-height:1}
.error-404 h2{font-family:var(--serif);font-size:32px;margin:10px 0 16px}
.error-404 p{color:var(--ink-soft);margin-bottom:24px}

/* Responsive */
@media(max-width:900px){
  .hero{grid-template-columns:1fr}
  .article-grid{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
  .two-col .article-grid{grid-template-columns:repeat(2,1fr)}
  .site-footer .inner{grid-template-columns:1fr;gap:30px}
  .hero-main h2{font-size:26px}
  .site-logo{font-size:34px}
  .entry-title{font-size:32px}
  nav.primary ul{display:none;width:100%;flex-direction:column}
  nav.primary ul.open{display:flex}
  nav.primary li a{border-bottom:1px solid #2a2a2a}
  .mobile-toggle{display:block}
}
@media(max-width:600px){
  .article-grid{grid-template-columns:1fr}
  .two-col .article-grid{grid-template-columns:1fr}
  .hero-side{grid-template-rows:repeat(3,180px)}
  .masthead .inner{flex-direction:column;text-align:center}
  .banner-ad{width:100%}
}

/* WP-required classes */
.alignleft{float:left;margin-right:1.5em;margin-bottom:1em}
.alignright{float:right;margin-left:1.5em;margin-bottom:1em}
.aligncenter{display:block;margin-left:auto;margin-right:auto;margin-bottom:1em}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:13px;color:var(--muted);text-align:center;margin-top:6px;font-style:italic}
.sticky{}
.bypostauthor{}
.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin:20px 0}
