/* =========================================================================
   NATION PRESS — Editorial / Broadsheet stylesheet
   Loaded last to override style.css with a newspaper aesthetic
   ========================================================================= */

:root {
    --np-ink:       #111111;
    --np-ink-soft:  #2a2a2a;
    --np-mute:      #6b6b6b;
    --np-rule:      #c8c4ba;
    --np-rule-soft: #e3dfd5;
    --np-paper:     #f6f1e7;
    --np-paper-2:   #fbf8f1;
    --np-card:      #ffffff;
    --np-accent:    #b22222;        /* firebrick — matches "NATION" in logo */
    --np-accent-deep:#7a1f1f;       /* burgundy — matches "PRESS" in logo  */
    --np-accent-ink:#2a1010;        /* near-black plum                     */
    --np-accent-tint:#fbeaea;       /* faintest red-cream tint for hover bg */
    --np-serif:     "Playfair Display", "Cheltenham", "Times New Roman", Georgia, serif;
    --np-serif-text:"Spectral", "Charter", Georgia, "Times New Roman", serif;
    --np-sans:      "Inter", "Helvetica Neue", "Helvetica", Arial, sans-serif;
}

/* ---------- Page ---------- */
html, body {
    background: var(--np-paper) !important;
    color: var(--np-ink) !important;
}
body, p {
    font-family: var(--np-serif-text) !important;
    font-size: 16px !important;
    line-height: 1.65 !important;
    color: var(--np-ink) !important;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, h5, h6,
.post-title, .nf-hero-title, .nf-card-title, .nf-cards-row-title {
    font-family: var(--np-serif) !important;
    color: var(--np-ink) !important;
    letter-spacing: -0.005em;
    font-weight: 800 !important;
    -webkit-font-smoothing: antialiased;
}
h1 { font-size: 44px; line-height: 1.08; letter-spacing: -0.015em; }
h2 { font-size: 32px; line-height: 1.15; letter-spacing: -0.01em; }
h3 { font-size: 24px; line-height: 1.2;  }
h4 { font-size: 20px; line-height: 1.3;  }
a { color: var(--np-ink); }
a:hover { color: var(--np-accent); }
hr { background-color: var(--np-rule); }

/* ---------- Top bar (paper edition strip) ---------- */
.top-bar {
    background: var(--np-paper-2) !important;
    color: var(--np-ink) !important;
    border-top: 1px solid var(--np-ink) !important;
    border-bottom: 1px solid var(--np-rule) !important;
    font-family: var(--np-sans) !important;
    font-size: 12px !important;
    padding: 8px 0 !important;
    letter-spacing: 0.02em;
}
.top-bar .ts-date { color: var(--np-ink); border-right: 1px solid var(--np-rule); padding-right: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; }
.top-bar .top-nav li a { color: var(--np-ink-soft); font-weight: 600; text-transform: uppercase; font-size: 11px; letter-spacing: 0.08em; }
.top-bar .top-nav li a:hover { color: var(--np-accent); }
.live-text { color: var(--np-accent) !important; }

/* Top-bar: vertically center every child on a single baseline */
.top-bar .row {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap;
}
.top-bar .col-md-8 {
    display: flex !important;
    align-items: center !important;
    gap: 14px;
    flex-wrap: nowrap;
}
.top-bar .col-md-4 { display: flex !important; align-items: center !important; }
.top-bar .ts-date {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 2px 12px 2px 0 !important;
    height: 24px;
}
.top-bar .ts-date i { font-size: 12px; line-height: 1; }
.top-bar .top-nav {
    display: inline-flex !important;
    align-items: center !important;
    gap: 14px;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none;
    height: 24px;
}
.top-bar .top-nav li {
    display: inline-flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    height: 24px;
}
.top-bar .top-nav li a {
    display: inline-flex !important;
    align-items: center !important;
    line-height: 1 !important;
    padding: 0 !important;
    height: 24px;
}
.top-bar .top-right-content {
    align-items: center !important;
    height: 40px;
}
.top-bar .live-time-container,
.top-bar .live-indicator { align-items: center !important; height: 100%; }
.top-bar .android-app-link,
.top-bar .ios-app-link {
    display: inline-flex !important;
    align-items: center !important;
    height: 40px;
}
.top-bar .android-app-link img,
.top-bar .ios-app-link img {
    height: 32px !important;
    width: auto;
    display: block;
    margin: 0 6px 0 0 !important;
}
.top-bar .social-icons {
    display: inline-flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none;
    height: 100%;
}
.top-bar .social-icons li {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1;
}
.top-bar .social-icons a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center;
    width: 22px;
    height: 22px;
    line-height: 1;
}
.top-bar .social-icons .social-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center;
    width: 100%;
    height: 100%;
}
.top-bar .social-icons i { font-size: 13px; line-height: 1; vertical-align: middle; }
.top-bar .social-icons svg { display: block; }
.live-dot { background: var(--np-accent) !important; }
.current-time { background: transparent !important; border: 1px solid var(--np-rule) !important; color: var(--np-ink) !important; font-family: var(--np-serif-text) !important; }

/* ---------- Masthead / header ---------- */
.header { padding: 28px 0 18px !important; background: var(--np-paper) !important; border-bottom: 3px double var(--np-ink) !important; position: relative; }

.header .language-switcher {
    font-family: var(--np-sans);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--np-mute);
    margin-bottom: 6px !important;
}
.header .language-switcher .lang-link { color: var(--np-ink-soft) !important; font-weight: 600; }
.header .language-switcher .lang-link:hover { color: var(--np-accent) !important; }

.header .logo-with-hero { flex-direction: column !important; gap: 6px !important; margin-bottom: 8px !important; }
.header .logo { padding: 4px 0 !important; }
.header .logo a { display: inline-flex !important; align-items: center; justify-content: center; }
.header .logo img { height: 64px !important; width: auto !important; }

/* Replace tagline area with classic dateline */
.header .hero-content { max-width: 100% !important; text-align: center; padding: 0 16px; position: relative; }
.header .hero-content::before, .header .hero-content::after {
    content: ""; position: absolute; top: 50%; width: 22%; height: 1px; background: var(--np-rule);
}
.header .hero-content::before { left: 14%; }
.header .hero-content::after  { right: 14%; }
.header .main-heading {
    font-family: var(--np-serif) !important;
    font-style: italic;
    font-weight: 500 !important;
    font-size: 14px !important;
    color: var(--np-ink-soft) !important;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin: 0 0 4px !important;
}
.header .hero-description {
    font-family: var(--np-serif-text) !important;
    font-size: 13px !important;
    color: var(--np-mute) !important;
    margin: 0 auto !important;
    max-width: 720px;
    font-style: italic;
}

/* ---------- Navigation (broadsheet bar) ---------- */
.main-nav {
    border-top: 1px solid var(--np-ink) !important;
    border-bottom: 1px solid var(--np-ink) !important;
    background: var(--np-paper) !important;
}
.main-nav > .container > .row {
    border-top: 0 !important;
    border-bottom: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    background: transparent !important;
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    min-height: 48px;
}
.navbar { padding: 0 !important; flex: 1 1 auto !important; min-width: 0 !important; width: auto !important; }
@media (min-width: 992px) {
    .main-nav .navbar-collapse { display: flex !important; flex-basis: auto !important; width: 100%; }
    ul.navbar-nav {
        display: flex !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        list-style: none;
        margin: 0 !important;
        padding: 0 !important;
        width: 100%;
    }
    ul.navbar-nav > li { flex: 0 0 auto; }
}
ul.navbar-nav > li > a {
    font-family: var(--np-sans) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--np-ink) !important;
    line-height: 46px !important;
    padding: 0 11px !important;
    letter-spacing: 0.10em !important;
    text-transform: uppercase;
    white-space: nowrap !important;
}
@media (min-width: 992px) and (max-width: 1300px) {
    ul.navbar-nav > li > a { padding: 0 8px !important; letter-spacing: 0.06em !important; }
}
@media (min-width: 992px) and (max-width: 1100px) {
    ul.navbar-nav > li > a { font-size: 10px !important; padding: 0 6px !important; }
}
ul.navbar-nav > li > a,
ul.navbar-nav > li:hover > a,
ul.navbar-nav > li.active > a {
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
    border-radius: 0 !important;
    margin: 0 !important;
}
ul.navbar-nav > li:hover > a,
ul.navbar-nav > li.active > a { color: var(--np-accent) !important; }
ul.navbar-nav > li > a:before { border-bottom: 2px solid var(--np-accent) !important; }
.navbar-toggler {
    align-items: center !important;
    justify-content: center !important;
    width: 30px !important;
    height: 30px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: var(--np-ink) !important;
    color: var(--np-paper) !important;
    line-height: 1 !important;
    box-shadow: none !important;
    transition: background .18s ease, color .18s ease !important;
}
@media (max-width: 991px) {
    .navbar-toggler { display: inline-flex !important; }
}
.navbar-toggler:focus,
.navbar-toggler:active,
.navbar-toggler[aria-expanded="true"] {
    background: var(--np-ink) !important;
    color: var(--np-paper) !important;
    outline: none !important;
    box-shadow: none !important;
}
.navbar-toggler:hover,
.navbar-toggler:focus-visible {
    background: var(--np-accent) !important;
    color: var(--np-paper) !important;
    outline: none !important;
    box-shadow: none !important;
}
.navbar-toggler .navbar-toggler-icon {
    width: 16px !important;
    height: 16px !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='%23f4eedd' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
    background-size: 16px 16px !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}
.navbar-toggler:hover .navbar-toggler-icon,
.navbar-toggler:focus-visible .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='%23ffffff' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}
.dropdown-menu {
    background: var(--np-card) !important;
    border: 1px solid var(--np-rule) !important;
    border-top: 3px solid var(--np-accent) !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin-top: 0 !important;
    box-shadow: 0 14px 28px rgba(0,0,0,.12) !important;
    font-family: var(--np-sans) !important;
    min-width: 220px !important;
}
.dropdown-menu li a,
.dropdown-menu .dropdown-item {
    border-bottom: 1px solid var(--np-rule-soft) !important;
    border-left: 3px solid transparent !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: 0.1em !important;
    padding: 11px 16px !important;
    color: var(--np-ink) !important;
    background: transparent !important;
    border-radius: 0 !important;
    transform: none !important;
    transition: background .15s ease, color .15s ease, border-color .15s ease !important;
}
.dropdown-menu li:first-child > a,
.dropdown-menu li:first-child > .dropdown-item,
.dropdown-menu li:last-child > a,
.dropdown-menu li:last-child > .dropdown-item {
    border-radius: 0 !important;
}
.dropdown-menu li:last-child > a,
.dropdown-menu li:last-child > .dropdown-item { border-bottom: 0 !important; }
.dropdown-menu > li > a:hover,
.dropdown-menu > li > .dropdown-item:hover,
.dropdown-menu > li > a:focus,
.dropdown-menu > li > .dropdown-item:focus,
.navbar-nav .dropdown-item:hover,
.navbar-nav .dropdown-item:focus {
    background: var(--np-paper) !important;
    background-image: none !important;
    color: var(--np-accent) !important;
    border-left-color: var(--np-accent) !important;
    border-radius: 0 !important;
    transform: none !important;
    padding-left: 16px !important;
}
/* Search pill — absolutely anchored to the right edge of the nav row,
   so it can't be misaligned by the navbar's flex content height. */
.main-nav > .container { position: relative; }
.main-nav .navbar { padding-right: 70px !important; }
@media (min-width: 992px) and (max-width: 1300px) {
    .main-nav .navbar { padding-right: 60px !important; }
}
@media (min-width: 992px) and (max-width: 1100px) {
    .main-nav .navbar { padding-right: 54px !important; }
}
.main-nav .nav-search {
    position: absolute !important;
    top: 50% !important;
    right: 15px !important;
    transform: translateY(-50%) !important;
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 0 0 16px !important;
    border: 0 !important;
    z-index: 5;
}
.main-nav .nav-search::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    height: 20px;
    width: 1px;
    background: var(--np-rule);
    transform: translateY(-50%);
}
.main-nav .nav-search #search {
    display: inline-flex !important;
    align-items: center !important;
}
.main-nav .nav-search-pill {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 30px !important;
    height: 30px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: var(--np-ink) !important;
    color: var(--np-paper) !important;
    line-height: 1 !important;
    transform: none !important;
    transition: background .18s ease, color .18s ease !important;
}
.main-nav .nav-search-pill:hover,
.main-nav .nav-search-pill:focus,
.main-nav .nav-search-pill:focus-visible {
    background: var(--np-accent) !important;
    color: var(--np-paper) !important;
    transform: none !important;
}
.main-nav .nav-search-pill i {
    color: inherit !important;
    font-size: 13px !important;
    line-height: 1 !important;
}
.main-nav .nav-search-pill:hover i,
.main-nav .nav-search-pill:focus i { color: var(--np-paper) !important; }
@media (max-width: 991px) {
    .main-nav .navbar { padding: 9px 0 !important; }
    .main-nav .row { align-items: flex-start !important; }
    .main-nav .navbar .site-nav-inner { display: flex; align-items: center; }
    .main-nav .nav-search {
        position: static !important;
        transform: none !important;
        border-left: 0 !important;
        padding: 9px 0 !important;
        margin-left: 0 !important;
        align-self: flex-start !important;
        display: flex !important;
        align-items: center !important;
    }
    .main-nav .nav-search::before { display: none; }
}

/* ---------- Trending bar (now editorial ticker) ---------- */
.trending-bar {
    background: var(--np-ink) !important;
    color: #f4eedd !important;
    padding: 10px 0 !important;
    border-top: 1px solid var(--np-ink);
    border-bottom: 4px double var(--np-accent);
}
.trending-title {
    background: var(--np-accent) !important;
    color: #fff !important;
    font-family: var(--np-sans) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
    padding: 6px 14px !important;
    text-transform: uppercase;
    border-radius: 0 !important;
}
.trending-slide .post-title.title-small {
    font-family: var(--np-serif-text) !important;
    font-size: 14px !important;
    color: #f4eedd !important;
    font-weight: 500 !important;
    font-style: italic;
}
.trending-slide .post-title a { color: #f4eedd !important; }
.trending-slide .post-title a:hover { color: #fff !important; }
.owl-carousel.owl-theme.trending-slide .owl-nav > div { background: transparent !important; border: 1px solid #f4eedd !important; color: #f4eedd !important; }
.owl-carousel.owl-theme.trending-slide .owl-nav > div:hover { background: var(--np-accent) !important; border-color: var(--np-accent) !important; color: #fff !important; }

/* =========================================================================
   HERO — replace dark Netflix style with broadsheet front page
   ========================================================================= */
.nf-hero-section {
    background: var(--np-paper) !important;
    padding: 36px 0 16px !important;
    width: 100vw !important;
    left: 50% !important;
    margin-left: -50vw !important;
    position: relative !important;
    border-bottom: 1px solid var(--np-rule);
}
.nf-hero-section::before {
    content: "TODAY'S FRONT PAGE";
    display: block;
    text-align: center;
    font-family: var(--np-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.32em;
    color: var(--np-mute);
    padding-bottom: 14px;
    border-bottom: 1px solid var(--np-rule);
    margin-bottom: 24px;
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
}
.nf-hero-banner {
    padding-bottom: 52% !important;
    border-radius: 0 !important;
    overflow: hidden;
    box-shadow: 0 0 0 1px var(--np-ink) inset;
}
.nf-hero-banner-bg { transition: transform 0.6s ease !important; }
.nf-hero-gradient {
    background: linear-gradient(to top, rgba(10,10,10,0.92) 0%, rgba(10,10,10,0.55) 35%, rgba(10,10,10,0) 75%) !important;
    height: 80% !important;
}
.nf-hero-content { padding: 36px 32px 28px !important; }
.nf-hero-badges { top: 16px; right: 16px; }
.nf-badge-breaking {
    background: var(--np-accent) !important;
    border-radius: 0 !important;
    font-family: var(--np-sans) !important;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
    padding: 5px 12px !important;
    text-transform: uppercase;
    font-size: 10px !important;
}
.nf-badge-cat {
    background: rgba(255,255,255,0.92) !important;
    color: var(--np-ink) !important;
    border-radius: 0 !important;
    font-family: var(--np-sans) !important;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
    padding: 5px 12px !important;
    text-transform: uppercase;
    font-size: 10px !important;
}
.nf-hero-title {
    font-family: var(--np-serif) !important;
    font-size: clamp(28px, 4.6vw, 56px) !important;
    line-height: 1.04 !important;
    font-weight: 800 !important;
    letter-spacing: -0.018em !important;
    max-width: 820px !important;
    margin: 0 0 12px !important;
}
.nf-hero-title a { color: #fff !important; }
.nf-hero-title a:hover { color: #f4d4a3 !important; }
.nf-hero-date {
    font-family: var(--np-serif-text) !important;
    font-style: italic;
    color: rgba(255,255,255,0.85) !important;
    font-size: 14px !important;
}

/* "More breaking news" rail — convert from dark to ivory */
.nf-cards-outer {
    background: var(--np-paper-2) !important;
    border-top: 1px solid var(--np-rule);
    border-bottom: 1px solid var(--np-rule);
    padding: 26px 0 32px !important;
    margin-bottom: 36px !important;
}
.nf-cards-row-title,
.nf-cards-outer .nf-cards-row-title {
    font-family: var(--np-serif) !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--np-ink) !important;
    text-transform: none;
    position: relative;
    padding-left: 14px;
}
.nf-cards-row-title::before {
    content: ""; position: absolute; left: 0; top: 6px; bottom: 6px; width: 4px; background: var(--np-accent);
}
.nf-cards-nav-btn {
    background: var(--np-card) !important;
    border: 1px solid var(--np-ink) !important;
    color: var(--np-ink) !important;
    width: 36px !important; height: 36px !important;
    border-radius: 0 !important;
}
.nf-cards-nav-btn:hover { background: var(--np-ink) !important; color: #fff !important; }
.nf-card {
    width: 320px !important;
    border-radius: 0 !important;
    background: var(--np-card);
    border: 1px solid var(--np-rule);
    overflow: hidden;
}
.nf-card:hover { transform: none !important; box-shadow: 0 6px 18px rgba(0,0,0,0.08) !important; }
.nf-card-img-wrap { padding-bottom: 66% !important; background: var(--np-paper) !important; }
.nf-card-img { object-position: center !important; }
.nf-card-overlay {
    background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.55) 55%, transparent 100%) !important;
    padding: 24px 16px 16px !important;
}
.nf-card-title {
    font-family: var(--np-serif) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 1.22 !important;
    color: #fff !important;
}
.nf-card-date {
    font-family: var(--np-serif-text) !important;
    font-style: italic;
    color: rgba(255,255,255,0.82) !important;
}

/* =========================================================================
   Section blocks — unify all the .color-* variants into a single editorial style
   ========================================================================= */
.main-content { background: var(--np-paper); padding-top: 8px; }
.main-content > .container > .row > [class*="col-"] { padding-left: 24px; padding-right: 24px; }

.block { margin: 36px 0 !important; padding: 0 !important; }

.block-title,
.color-default .block-title,
.color-red .block-title,
.color-blue .block-title,
.color-dark-blue .block-title,
.color-orange .block-title,
.color-aqua .block-title,
.color-violet .block-title {
    border-bottom: 1px solid var(--np-ink) !important;
    border-top: 4px double var(--np-ink) !important;
    margin: 0 0 28px !important;
    padding: 14px 0 10px !important;
    text-align: center;
    font-family: var(--np-sans) !important;
    font-size: 11px !important;
    letter-spacing: 0.32em !important;
    color: var(--np-ink) !important;
    text-transform: uppercase;
    font-weight: 700 !important;
}
.block-title > span,
.color-default .block-title > span,
.color-red .block-title > span,
.color-blue .block-title > span,
.color-dark-blue .block-title > span,
.color-orange .block-title > span,
.color-aqua .block-title > span,
.color-violet .block-title > span {
    background: transparent !important;
    color: var(--np-ink) !important;
    padding: 0 18px !important;
    line-height: 1 !important;
    height: auto !important;
    position: relative;
    display: inline-block;
}
.block-title > span:after,
.color-default .block-title > span:after,
.color-red .block-title > span:after,
.color-blue .block-title > span:after,
.color-dark-blue .block-title > span:after,
.color-orange .block-title > span:after,
.color-aqua .block-title > span:after,
.color-violet .block-title > span:after { display: none !important; }

/* Cards / posts — newspaper-style blocks */
.post-overaly-style {
    background: var(--np-card);
    border: 1px solid var(--np-rule);
    border-radius: 0;
    overflow: hidden;
}
.post-overaly-style:before {
    background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.5) 45%, rgba(0,0,0,0) 80%) !important;
}
.post-overaly-style .post-content { padding: 22px 22px 18px !important; }
.post-overaly-style .post-title {
    font-family: var(--np-serif) !important;
    font-weight: 800 !important;
    font-size: 22px !important;
    line-height: 1.18 !important;
    margin: 0 !important;
    letter-spacing: -0.005em;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.post-overaly-style .post-title a { color: #fff !important; }
.post-overaly-style .post-title a:hover { color: #f4d4a3 !important; }
.post-overaly-style .post-meta { line-height: 1.4 !important; padding-bottom: 2px; }
.post-overaly-style .post-date,
.post-overaly-style .post-meta span {
    font-family: var(--np-serif-text) !important;
    font-style: italic;
    color: rgba(255,255,255,0.85) !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    border: 0 !important;
    margin-right: 0 !important;
    padding-right: 0 !important;
    padding-bottom: 2px !important;
}

/* Category pill on cards */
a.post-cat,
.color-default a.post-cat,
.color-red a.post-cat,
.color-blue a.post-cat,
.color-dark-blue a.post-cat,
.color-orange a.post-cat,
.color-aqua a.post-cat,
.color-violet a.post-cat {
    background: var(--np-ink) !important;
    color: #fff !important;
    font-family: var(--np-sans) !important;
    font-weight: 700 !important;
    font-size: 10px !important;
    letter-spacing: 0.16em !important;
    padding: 4px 10px !important;
    border-radius: 0 !important;
    height: auto !important;
    line-height: 1.2 !important;
    text-transform: uppercase;
}
.post-cat:before { display: none !important; }

/* Float / list posts */
.post-block-style {
    background: var(--np-card);
    border-bottom: 1px solid var(--np-rule);
    padding-bottom: 18px;
    margin-bottom: 18px;
}
.post-block-style:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.post-block-style .post-title {
    font-family: var(--np-serif) !important;
    font-size: 18px !important;
    line-height: 1.22 !important;
    margin: 8px 0 4px !important;
    font-weight: 700 !important;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.post-block-style .post-title.title-small {
    font-size: 16px !important;
    line-height: 1.25 !important;
    -webkit-line-clamp: 3;
}
.list-post-block .list-post > li {
    max-height: none !important;
    margin-bottom: 18px !important;
}
.post-block-style .post-title a { color: var(--np-ink) !important; }
.post-block-style .post-title a:hover { color: var(--np-accent) !important; }
.post-block-style.post-float .post-thumb img {
    width: 110px !important;
    height: 78px !important;
    object-fit: cover;
    border: 1px solid var(--np-rule);
    display: block !important;
}
.list-post-block .post-block-style.post-float {
    display: flex !important;
    align-items: stretch !important;
    gap: 14px !important;
    overflow: visible !important;
}
.list-post-block .post-block-style.post-float .post-thumb {
    float: none !important;
    margin-right: 0 !important;
    flex: 0 0 110px !important;
    align-self: stretch !important;
}
.list-post-block .post-block-style.post-float .post-thumb > a:not(.post-cat) {
    display: block !important;
    height: 100% !important;
}
.list-post-block .post-block-style.post-float .post-thumb img {
    height: 100% !important;
    min-height: 78px !important;
}
.list-post-block .post-block-style.post-float .post-content {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}
.post-block-style .post-content p {
    font-family: var(--np-serif-text) !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
    color: var(--np-ink-soft) !important;
}
.post-meta { line-height: 1.5 !important; }
.post-meta span {
    font-family: var(--np-serif-text) !important;
    font-style: italic;
    color: var(--np-mute) !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    border: 0 !important;
    margin-right: 0 !important;
    padding-right: 0 !important;
    padding-bottom: 2px !important;
}
.post-meta span + span::before {
    content: "·";
    display: inline-block;
    color: var(--np-rule);
    margin: 0 8px;
    font-style: normal;
}
.post-meta .post-author a {
    font-family: var(--np-sans) !important;
    font-style: normal;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 11px !important;
    color: var(--np-ink) !important;
}

/* Read more buttons */
.btn-primary, .btn-dark, .btn.btn-primary, .btn.btn-dark {
    background: var(--np-ink) !important;
    color: #fff !important;
    font-family: var(--np-sans) !important;
    font-size: 11px !important;
    letter-spacing: 0.18em !important;
    border: 1px solid var(--np-ink) !important;
    border-radius: 0 !important;
    padding: 12px 22px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
}
.btn-primary:hover, .btn-dark:hover, .btn.btn-primary:hover, .btn.btn-dark:hover {
    background: var(--np-accent) !important; border-color: var(--np-accent) !important; color: #fff !important;
}
a.read-more { color: var(--np-accent) !important; font-family: var(--np-sans) !important; font-size: 11px !important; letter-spacing: 0.16em !important; }

/* Read more wrapper */
.read-more-wrapper { padding: 16px 0 0 !important; border-top: 1px solid var(--np-rule-soft); margin-top: 28px !important; text-align: center !important; }

/* =========================================================================
   Sidebar
   ========================================================================= */
.sidebar .widget { background: var(--np-card); border: 1px solid var(--np-rule); padding: 22px 22px 18px; margin-bottom: 28px !important; }
.sidebar .widget .block-title { margin: -6px 0 18px !important; padding-bottom: 12px !important; }
.sidebar .social-icon li a i {
    background: var(--np-card) !important;
    color: var(--np-ink) !important;
    border: 1px solid var(--np-ink);
    width: 38px !important; height: 38px !important; line-height: 38px !important;
    font-size: 14px !important;
}
.sidebar .social-icon li a i:hover { background: var(--np-ink) !important; color: #fff !important; }
.sidebar .popular-posts .media-heading,
.sidebar .popular-posts h3 {
    font-family: var(--np-serif) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    margin: 0 0 6px !important;
}
.sidebar .popular-posts .media-heading a { color: var(--np-ink) !important; }
.sidebar .popular-posts .media-heading a:hover { color: var(--np-accent) !important; }
.sidebar .popular-posts .media-meta .date {
    font-family: var(--np-serif-text);
    font-style: italic;
    color: var(--np-mute);
    font-size: 12px;
}
.sidebar .popular-posts li.media.post-item { padding-bottom: 14px; margin-bottom: 14px; border-bottom: 1px solid var(--np-rule-soft); display: flex; gap: 14px; }
.sidebar .popular-posts li.media.post-item:last-child { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }

/* =========================================================================
   Footer — newspaper colophon
   ========================================================================= */
.footer {
    background: #15110c !important;
    color: #d6cfbf !important;
    font-family: var(--np-serif-text) !important;
    padding: 56px 0 0 !important;
    border-top: 4px double var(--np-accent);
}
.footer p, .footer ul li, .footer ul li a, .footer .footer-about-widget p { color: #d6cfbf !important; font-size: 14px !important; }
.footer ul li a:hover { color: #fff !important; }
.footer .widget-title {
    font-family: var(--np-serif) !important;
    font-weight: 800 !important;
    font-size: 14px !important;
    color: #fff !important;
    text-transform: uppercase !important;
    letter-spacing: 0.18em !important;
    padding-bottom: 10px;
    margin-bottom: 22px !important;
    border-bottom: 1px solid #3a342a;
    position: relative;
}
.footer .widget-title::after {
    content: ""; position: absolute; left: 0; bottom: -1px; width: 32px; height: 2px; background: var(--np-accent);
}
.footer ul.list-arrow li:before { color: var(--np-accent); }
.footer-social li a i {
    background: transparent !important;
    border: 1px solid #4a4234;
    color: #d6cfbf !important;
}
.footer-social li a i:hover { background: var(--np-accent) !important; border-color: var(--np-accent) !important; color: #fff !important; }
.copyright, .footer-bottom {
    background: #0e0a06 !important;
    color: #a89e8a !important;
    border-top: 1px solid #2a241b !important;
    margin-top: 40px;
    padding: 18px 0 !important;
    font-family: var(--np-sans) !important;
    font-size: 12px !important;
    letter-spacing: 0.08em;
}
.copyright-info { color: #a89e8a !important; font-style: italic; }

/* =========================================================================
   Single post / article — drop cap + reading typography
   ========================================================================= */
.single-post .post-title {
    font-family: var(--np-serif) !important;
    font-size: 44px !important;
    line-height: 1.08 !important;
    font-weight: 800 !important;
    letter-spacing: -0.015em;
    padding: 18px 0 12px !important;
}
.single-post p {
    font-family: var(--np-serif-text) !important;
    font-size: 18px !important;
    line-height: 1.72 !important;
    color: var(--np-ink-soft) !important;
    margin-bottom: 22px !important;
}
/* "THE STORY" divider before the article body so it's visually distinct
   from the KEY TAKEAWAYS / lede summary that comes before. */
.entry-content { position: relative; margin-top: 0; }
.entry-content::before {
    content: "THE STORY";
    display: block;
    text-align: center;
    font-family: var(--np-sans);
    font-size: 11px;
    letter-spacing: 0.32em;
    color: var(--np-ink);
    text-transform: uppercase;
    font-weight: 700;
    border-top: 4px double var(--np-ink);
    border-bottom: 1px solid var(--np-ink);
    padding: 14px 0 10px;
    margin: 36px 0 28px;
}

/* Uniform vertical rhythm for all editorial section headings on the article page.
   Synopsis, Key Takeaways, Point of View, and "The Story" all get the same gap
   above and below regardless of what (ad, image, prev section) sits before them. */
.synopsis-section,
.key-takeaways,
.point-of-view-section,
.entry-content {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.synopsis-section > .block-title,
.key-takeaways > .block-title,
.point-of-view-section > .block-title {
    margin: 36px 0 28px !important;
    padding: 14px 0 10px !important;
}

/* Collapse ad slots that haven't rendered an ad iframe — keeps dev preview tight,
   doesn't affect production where GPT injects an iframe inside the slot. */
.ad-container { margin: 0 !important; padding: 0 !important; }
.ad-container > div:not(:has(iframe)):not(:has(ins[data-ad-status="filled"])) {
    min-height: 0 !important;
    height: 0 !important;
    overflow: hidden;
}

/* Drop cap on the lede of the actual article body */
.entry-content #articleContent > p:first-of-type::first-letter,
#articleContent > p:first-of-type::first-letter,
.single-post .post-content-area > p:first-of-type::first-letter {
    font-family: var(--np-serif);
    font-weight: 800;
    float: left;
    font-size: 64px;
    line-height: 0.85;
    padding: 6px 12px 0 0;
    margin-top: 6px;
    color: var(--np-accent);
}

/* First paragraph of the story gets a slightly larger lede treatment */
.entry-content #articleContent > p:first-of-type,
#articleContent > p:first-of-type {
    font-size: 19px !important;
    line-height: 1.7 !important;
}
blockquote {
    background: transparent !important;
    border-left: 4px solid var(--np-accent) !important;
    padding: 8px 0 8px 28px !important;
    margin: 32px 0 !important;
    font-family: var(--np-serif) !important;
    font-style: italic;
    font-size: 24px !important;
    line-height: 1.4 !important;
    text-align: left !important;
    color: var(--np-ink) !important;
}
blockquote:before { display: none !important; }

/* =========================================================================
   Misc — cleanup
   ========================================================================= */
.body-inner { background: var(--np-paper); }
.featured-tab .nav-tabs > li > a {
    font-family: var(--np-sans) !important;
    font-size: 11px !important;
    letter-spacing: 0.16em !important;
}
.featured-tab .nav-tabs > li > a.active { color: var(--np-accent) !important; }
.featured-tab .nav-tabs > li > a.active:after { border-color: transparent transparent var(--np-accent) transparent !important; }

/* Preserve Web Stories label area readability */
.section-padding { padding: 36px 0 !important; }

/* =========================================================================
   Entertainment section — repaint dark navy/pink into broadsheet ivory
   ========================================================================= */
.nf-ent-section {
    background: var(--np-paper) !important;
    border-top: 1px solid var(--np-rule) !important;
    border-bottom: 1px solid var(--np-rule) !important;
    padding: 30px 0 32px !important;
}
.nf-ent-section::before {
    content: "ENTERTAINMENT";
    display: block;
    text-align: center;
    font-family: var(--np-sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.32em;
    color: var(--np-mute);
    padding-bottom: 14px;
    border-bottom: 1px solid var(--np-rule);
    margin-bottom: 24px;
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
}
.nf-ent-section .nf-hero-banner {
    border-radius: 0 !important;
    box-shadow: 0 0 0 1px var(--np-ink) inset;
    padding-bottom: 52% !important;
}
.nf-ent-section .nf-hero-gradient {
    background: linear-gradient(to top, rgba(10,10,10,0.92) 0%, rgba(10,10,10,0.55) 35%, rgba(10,10,10,0) 75%) !important;
    height: 80% !important;
}
.nf-ent-section .nf-badge-entertainment {
    background: var(--np-accent) !important;
    color: #fff !important;
    border-radius: 0 !important;
    font-family: var(--np-sans) !important;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
    padding: 5px 12px !important;
    text-transform: uppercase;
    font-size: 10px !important;
}
.nf-ent-section .nf-badge-cat {
    background: rgba(255,255,255,0.92) !important;
    color: var(--np-ink) !important;
    border-radius: 0 !important;
    font-family: var(--np-sans) !important;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
    padding: 5px 12px !important;
    font-size: 10px !important;
}
.nf-ent-section .nf-hero-title a { color: #fff !important; }
.nf-ent-section .nf-hero-title a:hover { color: #f4d4a3 !important; }

.nf-ent-cards-outer {
    background: var(--np-paper-2) !important;
    border-top: 1px solid var(--np-rule) !important;
    border-bottom: 1px solid var(--np-rule) !important;
    padding: 26px 0 32px !important;
    margin-bottom: 36px !important;
}
.nf-ent-cards-outer .nf-cards-row-title { color: var(--np-ink) !important; }
.nf-ent-cards-outer .nf-cards-nav-btn {
    background: var(--np-card) !important;
    border: 1px solid var(--np-ink) !important;
    color: var(--np-ink) !important;
    border-radius: 0 !important;
    width: 36px !important; height: 36px !important;
}
.nf-ent-cards-outer .nf-cards-nav-btn:hover {
    background: var(--np-ink) !important;
    border-color: var(--np-ink) !important;
    color: #fff !important;
}
.nf-ent-cards-outer .nf-card .nf-badge-entertainment {
    background: var(--np-accent) !important;
    border-radius: 0 !important;
    font-family: var(--np-sans) !important;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
}
.nf-ent-cards-outer .nf-card .nf-card-overlay {
    background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.55) 55%, transparent 100%) !important;
}

/* =========================================================================
   Web stories sections — repaint dark navy/purple panels into broadsheet ivory
   ========================================================================= */
.nf-webstories-outer,
.nf-ent-webstories-outer {
    background: var(--np-paper-2) !important;
    border-top: 1px solid var(--np-rule) !important;
    border-bottom: 1px solid var(--np-rule) !important;
    padding: 28px 0 32px !important;
    margin-top: 24px !important;
    margin-bottom: 24px !important;
    /* preserve the partial's full-bleed margin-left: -50vw — do NOT use shorthand */
}
.nf-webstories-outer .nf-webstory-cards-title,
.nf-ent-webstories-outer .nf-webstory-cards-title {
    color: var(--np-ink) !important;
    font-family: var(--np-serif) !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    position: relative;
    padding-left: 14px;
}
.nf-webstories-outer .nf-webstory-cards-title::before,
.nf-ent-webstories-outer .nf-webstory-cards-title::before {
    content: ""; position: absolute; left: 0; top: 6px; bottom: 6px;
    width: 4px; background: var(--np-accent);
}
.nf-webstories-outer .nf-webstory-nav-btn,
.nf-ent-webstories-outer .nf-webstory-nav-btn {
    background: var(--np-card) !important;
    border: 1px solid var(--np-ink) !important;
    color: var(--np-ink) !important;
    border-radius: 0 !important;
    width: 36px !important; height: 36px !important;
}
.nf-webstories-outer .nf-webstory-nav-btn:hover,
.nf-ent-webstories-outer .nf-webstory-nav-btn:hover {
    background: var(--np-ink) !important;
    border-color: var(--np-ink) !important;
    color: #fff !important;
}
.nf-webstories-outer .nf-webstory-thumb,
.nf-ent-webstories-outer .nf-webstory-thumb,
.nf-ent-webstory-card .nf-webstory-thumb {
    border-radius: 0 !important;
    background: var(--np-paper) !important;
    border: 1px solid var(--np-rule);
}
.nf-webstories-outer .nf-webstory-title,
.nf-ent-webstories-outer .nf-webstory-title,
.nf-ent-webstory-card .nf-webstory-title {
    color: var(--np-ink) !important;
    font-family: var(--np-serif) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    margin-top: 10px !important;
}
.nf-webstories-outer .nf-webstory-card:hover .nf-webstory-title,
.nf-ent-webstories-outer .nf-ent-webstory-card:hover .nf-webstory-title,
.nf-ent-webstory-card:hover .nf-webstory-title {
    color: var(--np-accent) !important;
}
.nf-webstories-outer .nf-webstory-scroll::-webkit-scrollbar-thumb,
.nf-ent-webstories-outer .nf-webstory-scroll::-webkit-scrollbar-thumb {
    background: var(--np-accent) !important;
}
.nf-webstories-outer .nf-webstory-scroll::-webkit-scrollbar-track,
.nf-ent-webstories-outer .nf-webstory-scroll::-webkit-scrollbar-track {
    background: var(--np-rule-soft) !important;
}

/* Focus styles — keyboard only (avoid stray rings on click/hover) */
a:focus { outline: 0; }
a:focus-visible, button:focus-visible { outline: 2px solid var(--np-accent); outline-offset: 1px; }
.dropdown-menu a:focus, .dropdown-menu a:focus-visible,
.navbar-nav a:focus, .navbar-nav a:focus-visible { outline: 0 !important; }

/* =========================================================================
   Responsive refinements
   ========================================================================= */
@media (max-width: 991px) {
    h1 { font-size: 32px; }
    h2 { font-size: 26px; }
    .nf-hero-title { font-size: clamp(22px, 5vw, 36px) !important; }
    .header .logo img { height: 48px !important; }
    .header .hero-content::before, .header .hero-content::after { display: none; }
    ul.navbar-nav > li > a { line-height: 40px !important; padding: 0 10px !important; }
}

/* ---------- Pagination — newspaper theme ---------- */
.paging { margin-top: 28px; }
.paging .pagination,
ul.pagination {
    display: flex !important;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    list-style: none;
    margin: 0 !important;
    padding: 0 !important;
}
.paging .pagination > li,
ul.pagination > li {
    display: inline-flex;
    list-style: none;
    margin: 0;
    padding: 0;
}
.paging .pagination > li > a,
.paging .pagination > li > span,
ul.pagination > li > a,
ul.pagination > li > span {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 12px !important;
    background: var(--np-card) !important;
    border: 1px solid var(--np-rule) !important;
    border-radius: 0 !important;
    color: var(--np-ink) !important;
    font-family: var(--np-sans) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    text-decoration: none !important;
    transition: background .15s ease, color .15s ease, border-color .15s ease !important;
    box-shadow: none !important;
}
.paging .pagination > li > a:hover,
.paging .pagination > li > span:hover,
ul.pagination > li > a:hover,
ul.pagination > li > span:hover {
    background: var(--np-paper) !important;
    border-color: var(--np-ink) !important;
    color: var(--np-accent) !important;
}
.paging .pagination > li.active > a,
.paging .pagination > li.active > span,
ul.pagination > li.active > a,
ul.pagination > li.active > span {
    background: var(--np-accent) !important;
    border-color: var(--np-accent) !important;
    color: var(--np-paper) !important;
    font-weight: 700 !important;
}
.paging .pagination > li.disabled > a,
.paging .pagination > li.disabled > span,
ul.pagination > li.disabled > a,
ul.pagination > li.disabled > span {
    background: transparent !important;
    border-color: var(--np-rule-soft) !important;
    color: var(--np-mute) !important;
    cursor: default;
    pointer-events: none;
}
.paging .pagination > li > a i,
ul.pagination > li > a i { font-size: 12px; line-height: 1; }
@media (max-width: 768px) {
    body, p { font-size: 15px !important; }
    .single-post .post-title { font-size: 30px !important; }
    .nf-hero-banner { padding-bottom: 70% !important; }
    .nf-hero-content { padding: 22px 18px 18px !important; }
    .post-overaly-style .post-title { font-size: 18px !important; }
    .nf-cards-row-title { font-size: 18px !important; }
    .nf-card { width: 260px !important; }
    .block-title { letter-spacing: 0.22em !important; font-size: 10px !important; }
    .header { padding: 18px 0 6px !important; }
    .main-content > .container > .row > [class*="col-"] { padding-left: 15px; padding-right: 15px; }
}
