/* -------------------------------------------------------------------------
   News portal typography & layout (Indian Express / HT–inspired)
   Loaded after custom.css. Scoped under .kok-news-portal on <body>.
   ------------------------------------------------------------------------- */

body.kok-news-portal {
  --kok-ink: #0f172a;
  --kok-ink-muted: #475569;
  --kok-border: #e2e8f0;
  --kok-bg-subtle: #f8fafc;
  --kok-accent: #b91c1c;
  --kok-accent-hover: #991b1b;
  --kok-rule: #cbd5e1;
  --kok-font-sans: "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --kok-font-serif: "IBM Plex Serif", Georgia, "Times New Roman", serif;
  font-family: var(--kok-font-sans);
  color: var(--kok-ink);
  -webkit-font-smoothing: antialiased;
}

/* --- Masthead top bar --- */
.kok-news-topbar {
  background: var(--kok-ink);
  color: #e2e8f0;
  font-size: 0.75rem;
  letter-spacing: 0.02em;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.kok-news-topbar-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  min-height: 2rem;
  padding-top: 0.35rem;
  padding-bottom: 0.35rem;
}

.kok-topbar-edition {
  opacity: 0.92;
}

.kok-topbar-date {
  color: #cbd5e1;
  font-variant-numeric: tabular-nums;
}

body[data-theme="dark"] .kok-news-topbar {
  background: #020617;
  border-bottom-color: rgba(255, 255, 255, 0.06);
}

/* --- Masthead: logo link must stay clickable (stacking + navbar layout) --- */
body.kok-news-portal .header .container .logo {
  position: relative;
  z-index: 4;
  flex-shrink: 0;
}

body.kok-news-portal .header .container .logo a {
  display: inline-flex;
  align-items: center;
  position: relative;
  z-index: 1;
}

/* Clicks go to the <a>, not a hidden stacked duplicate image */
body.kok-news-portal .header .container .logo a img,
body.kok-news-portal .navbar .logo a img,
body.kok-news-portal .sticky-navbar .logo a img {
  pointer-events: none;
}

body.kok-news-portal .sticky-navbar .logo {
  position: relative;
  z-index: 3;
  flex-shrink: 0;
}

body.kok-news-portal .sticky-navbar .logo a {
  display: inline-flex;
  align-items: center;
}

/* Below 768px the main logo moves into .navbar; legacy theme never made .navbar .container a flex row */
@media (max-width: 767px) {
  body.kok-news-portal .navbar > .container {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    position: relative;
    min-height: 2.5rem;
  }

  body.kok-news-portal .navbar .hamburger-menu {
    margin-right: 0;
    flex: 0 0 auto;
    z-index: 2;
  }

  body.kok-news-portal .navbar .search-button {
    margin-left: 0;
    flex: 0 0 auto;
    z-index: 2;
  }

  body.kok-news-portal .navbar .logo {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    margin-left: 0;
    margin-right: 0;
  }

  body.kok-news-portal .navbar .logo a {
    display: inline-flex;
    align-items: center;
  }
}

body.kok-news-portal .side-widget .logo .side-widget-logo-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: inherit;
}

body.kok-news-portal .side-widget .logo .side-widget-logo-link img {
  pointer-events: none;
}

/* --- Homepage: Top Stories + Insight --- */
.kok-home-lead-block {
  padding-top: 1.5rem;
  padding-bottom: 2rem;
}

.kok-trending-container {
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 576px) {
  .kok-trending-container {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}

.kok-home-lead-block .kok-lead-main {
  border-right: 1px solid var(--kok-border);
  padding: 1.25rem 1.25rem 1.35rem 1.25rem;
}

.kok-home-lead-block .kok-insight-rail {
  padding: 1.25rem 1.15rem 1.35rem 1.15rem;
}

@media (max-width: 991px) {
  .kok-home-lead-block .kok-lead-main {
    border-right: none;
    padding: 1.1rem 1rem 1.2rem;
    margin-bottom: 0;
  }

  .kok-home-lead-block .kok-insight-rail {
    padding: 1.1rem 1rem 1.2rem;
  }
}

.kok-news-section-label {
  margin: 0 0 1rem;
  font-family: var(--kok-font-sans);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kok-accent);
  border-bottom: 2px solid var(--kok-ink);
  padding-bottom: 0.5rem;
  display: inline-block;
  min-width: 8rem;
}

.kok-lead-hero .kok-lead-hero-img {
  position: relative;
  margin: 0 0 1rem;
  overflow: hidden;
  border-radius: 2px;
  background: var(--kok-bg-subtle);
}

.kok-lead-hero .kok-lead-hero-img img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.kok-lead-hero .kok-lead-hero-img a {
  display: block;
}

.kok-home-lead-block .kok-lead-list {
  padding-top: 0.25rem;
}

@media (min-width: 992px) {
  .kok-home-lead-block .kok-lead-list {
    padding-top: 2.75rem;
  }
}

.kok-lead-kicker {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--kok-accent);
  margin-bottom: 0.35rem;
}

.kok-lead-headline {
  font-family: var(--kok-font-serif);
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 0.75rem;
  letter-spacing: -0.02em;
}

.kok-lead-headline a {
  color: var(--kok-ink);
  text-decoration: none;
}

.kok-lead-headline a:hover {
  color: var(--kok-accent);
}

.kok-lead-deck {
  font-size: 1rem;
  line-height: 1.55;
  color: var(--kok-ink-muted);
  margin: 0 0 1rem;
  text-align: justify;
}

.kok-lead-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 1rem;
  font-size: 0.8125rem;
  color: var(--kok-ink-muted);
  border-top: 1px solid var(--kok-border);
  padding-top: 0.75rem;
}

.kok-lead-meta a {
  color: var(--kok-ink);
  font-weight: 600;
  text-decoration: none;
}

.kok-lead-meta a:hover {
  color: var(--kok-accent);
}

.kok-lead-list {
  padding-left: 0.5rem;
}

.kok-lead-list-item {
  display: flex;
  gap: 0.75rem;
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--kok-border);
}

.kok-lead-list-item:last-child {
  border-bottom: none;
}

.kok-lead-list-item figure {
  flex: 0 0 88px;
  margin: 0;
  overflow: hidden;
  border-radius: 2px;
  background: var(--kok-bg-subtle);
}

.kok-lead-list-item figure img {
  width: 88px;
  height: 66px;
  object-fit: cover;
  display: block;
}

.kok-lead-list-item .kok-mini-title {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.35;
}

.kok-lead-list-item .kok-mini-title a {
  color: var(--kok-ink);
  text-decoration: none;
}

.kok-lead-list-item .kok-mini-title a:hover {
  color: var(--kok-accent);
}

.kok-lead-list-item .kok-mini-meta {
  margin-top: 0.35rem;
  font-size: 0.75rem;
  color: var(--kok-ink-muted);
}

.kok-insight-rail {
  padding-left: 0.25rem;
}

@media (max-width: 991px) {
  .kok-insight-rail {
    padding-left: 0;
    margin-top: 1rem;
  }
}

.kok-insight-card {
  margin-bottom: 1.25rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--kok-border);
}

.kok-insight-card:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.kok-insight-card figure {
  margin: 0 0 0.65rem;
  overflow: hidden;
  border-radius: 2px;
  background: var(--kok-bg-subtle);
}

.kok-insight-card figure img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
}

.kok-insight-card .kok-insight-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.35;
}

.kok-insight-card .kok-insight-title a {
  color: var(--kok-ink);
  text-decoration: none;
}

.kok-insight-card .kok-insight-title a:hover {
  color: var(--kok-accent);
}

.kok-insight-card .kok-insight-meta {
  margin-top: 0.4rem;
  font-size: 0.75rem;
  color: var(--kok-ink-muted);
}

/* --- Article page --- */
.kok-article-page {
  padding-top: 1rem;
  padding-bottom: 2.5rem;
}

.kok-breadcrumb {
  font-size: 0.75rem;
  text-transform: capitalize;
  margin-bottom: 1rem;
  color: var(--kok-ink-muted);
}

.kok-breadcrumb a {
  color: var(--kok-ink-muted);
  text-decoration: none;
}

.kok-breadcrumb a:hover {
  color: var(--kok-accent);
}

.kok-breadcrumb .sep {
  margin: 0 0.35rem;
  opacity: 0.5;
}

.kok-article {
  max-width: 100%;
  /* Flex row children default to min-width:auto; wide/floated media can clip siblings — allow column to lay out correctly */
  min-width: 0;
}

.kok-article-page .row > .kok-article-sidebar {
  min-width: 0;
}

.kok-article-header {
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--kok-border);
}

.kok-article-headline {
  font-family: var(--kok-font-serif);
  font-size: clamp(1.75rem, 4vw, 2.35rem);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.02em;
  color: var(--kok-ink);
  margin: 0 0 0.75rem;
}

.kok-article-deck {
  font-size: 1.125rem;
  line-height: 1.5;
  color: var(--kok-ink-muted);
  margin: 0 0 1rem;
  font-weight: 400;
}

.kok-article-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 1.25rem;
  font-size: 0.875rem;
  color: var(--kok-ink-muted);
}

.kok-byline a {
  color: var(--kok-ink);
  font-weight: 600;
  text-decoration: none;
}

.kok-byline a:hover {
  color: var(--kok-accent);
}

.kok-dateline {
  font-variant-numeric: tabular-nums;
}

.kok-article-feature {
  margin: 0 0 1.25rem;
}

.kok-article-feature img {
  width: 100%;
  height: auto !important;
  max-height: min(85vh, 960px);
  display: block;
  border-radius: 2px;
}

.kok-article-feature figcaption {
  font-size: 0.8125rem;
  color: var(--kok-ink-muted);
  font-style: italic;
  margin-top: 0.5rem;
  line-height: 1.4;
  border-left: 3px solid var(--kok-rule);
  padding-left: 0.75rem;
}

.kok-article-share {
  margin: 0 0 1.5rem;
  padding: 0.75rem 0;
  border-top: 1px solid var(--kok-border);
  border-bottom: 1px solid var(--kok-border);
}

.kok-article-body {
  font-family: var(--kok-font-serif);
  font-size: 1.0625rem;
  line-height: 1.75;
  color: #1e293b;
  /* Contain floats from editor (thumbnails) so following text isn’t trapped in a zero-width strip */
  display: flow-root;
  overflow-wrap: anywhere;
  word-wrap: break-word;
}

.kok-article-body > *:first-child {
  margin-top: 0;
}

.kok-article-body p {
  margin: 0 0 1.15em;
  /* Keep paragraph text readable next to floats (avoid 0-width “column” beside floated images) */
  min-width: 0;
}

.kok-article-body h2,
.kok-article-body h3 {
  font-family: var(--kok-font-sans);
  font-weight: 700;
  line-height: 1.25;
  margin: 1.5em 0 0.65em;
  color: var(--kok-ink);
}

.kok-article-body h2 {
  font-size: 1.35rem;
}

.kok-article-body h3 {
  font-size: 1.15rem;
}

.kok-article-body a {
  color: var(--kok-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.kok-article-body a:hover {
  color: var(--kok-accent-hover);
}

.kok-article-body blockquote {
  margin: 1.25em 0;
  padding: 0.75em 0 0.75em 1.25em;
  border-left: 4px solid var(--kok-rule);
  font-style: italic;
  color: var(--kok-ink-muted);
  background: var(--kok-bg-subtle);
}

.kok-article-body img {
  max-width: 100%;
  height: auto;
}

.kok-article-body video,
.kok-article-body iframe,
.kok-article-body embed {
  max-width: 100%;
}

.kok-article-body figure {
  margin: 1.25em 0;
  max-width: 100%;
}

.kok-article-body figure img {
  margin: 0;
}

/* TinyMCE / WordPress-style aligned images */
.kok-article-body .alignleft,
.kok-article-body img[style*="float: left"],
.kok-article-body img[style*="float:left"] {
  float: left;
  margin: 0.35em 1.15em 0.85em 0;
  max-width: min(100%, 320px);
}

.kok-article-body .alignright,
.kok-article-body img[style*="float: right"],
.kok-article-body img[style*="float:right"] {
  float: right;
  margin: 0.35em 0 0.85em 1.15em;
  max-width: min(100%, 320px);
}

.kok-article-body .aligncenter,
.kok-article-body .alignnone {
  display: block;
  float: none;
  margin-left: auto;
  margin-right: auto;
  clear: both;
}

@media (max-width: 575px) {
  .kok-article-body .alignleft,
  .kok-article-body .alignright,
  .kok-article-body img[style*="float: left"],
  .kok-article-body img[style*="float:left"],
  .kok-article-body img[style*="float: right"],
  .kok-article-body img[style*="float:right"] {
    float: none;
    display: block;
    margin: 1em auto;
    max-width: 100%;
  }
}

.kok-article-body ul,
.kok-article-body ol {
  margin: 0 0 1.15em;
  padding-left: 1.35em;
}

/*
 * Legacy listing/card classes from style.css (blog-post, arizona, chicago, etc.)
 * use position:absolute + height:100% on .post-image. If that HTML is pasted into
 * post_content, the image covers the whole column and body text disappears.
 */
.kok-article-body .blog-post,
.kok-article-body [class*="post-style-"] {
  display: block !important;
  flex-wrap: unset !important;
  width: 100% !important;
  max-width: 100% !important;
  position: static !important;
  min-height: 0 !important;
  background: transparent !important;
}

.kok-article-body .post-image,
.kok-article-body .blog-image {
  position: static !important;
  inset: auto !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 0 1rem !important;
  opacity: 1 !important;
  background-image: none !important;
  background-size: unset !important;
  overflow: visible !important;
}

.kok-article-body .post-image img,
.kok-article-body .blog-image img {
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  position: static !important;
  transform: none !important;
  object-fit: unset !important;
}

.kok-article-body .post-content,
.kok-article-body .blog-post-details {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  z-index: auto !important;
  display: block !important;
  color: inherit !important;
  background: transparent !important;
}

.kok-article-body .arizona,
.kok-article-body .nevada,
.kok-article-body .florida,
.kok-article-body .chicago,
.kok-article-body .miami,
.kok-article-body .texas {
  position: static !important;
  display: block !important;
  width: 100% !important;
  min-height: 0 !important;
  background: transparent !important;
}

.kok-article-body .arizona .post-image {
  position: static !important;
  width: 100% !important;
  height: auto !important;
  opacity: 1 !important;
  background: none !important;
}

.kok-article-body .arizona .post-content,
.kok-article-body .nevada .post-content {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  position: static !important;
  z-index: auto !important;
}

/* Inline editor junk: full-viewport height on images */
.kok-article-body img[style*="height: 100%"],
.kok-article-body img[style*="height:100%"],
.kok-article-body img[style*="height: 100vh"],
.kok-article-body img[style*="height:100vh"] {
  height: auto !important;
  max-height: 85vh !important;
}

/* Sidebar rail */
.kok-article-sidebar {
  position: sticky;
  top: 1rem;
  align-self: flex-start;
}

.kok-rail-title {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--kok-ink);
  margin: 0 0 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--kok-ink);
}

.kok-rail-item {
  display: flex;
  gap: 0.75rem;
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--kok-border);
}

.kok-rail-item:last-child {
  border-bottom: none;
}

.kok-rail-item figure {
  flex: 0 0 80px;
  margin: 0;
  overflow: hidden;
  border-radius: 2px;
  background: var(--kok-bg-subtle);
}

.kok-rail-item figure img {
  width: 80px;
  height: 60px;
  object-fit: cover;
  display: block;
}

.kok-rail-item .kok-rail-item-title {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.35;
}

.kok-rail-item .kok-rail-item-title a {
  color: var(--kok-ink);
  text-decoration: none;
}

.kok-rail-item .kok-rail-item-title a:hover {
  color: var(--kok-accent);
}

.kok-rail-item .kok-rail-item-meta {
  margin-top: 0.3rem;
  font-size: 0.7rem;
  color: var(--kok-ink-muted);
}

/* Related stories */
.kok-related-section {
  padding-top: 1.5rem;
  padding-bottom: 2.5rem;
  background: var(--kok-bg-subtle);
  border-top: 1px solid var(--kok-border);
}

.kok-related-section .kok-related-title {
  font-family: var(--kok-font-sans);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--kok-ink);
  margin: 0 0 1.25rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--kok-border);
}

.kok-related-card {
  background: #fff;
  border: 1px solid var(--kok-border);
  border-radius: 4px;
  overflow: hidden;
  height: 100%;
  transition: box-shadow 0.2s ease;
}

.kok-related-card:hover {
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

.kok-related-card figure {
  margin: 0;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--kok-bg-subtle);
}

.kok-related-card figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.kok-related-card .kok-related-body {
  padding: 0.85rem 1rem 1rem;
}

.kok-related-card .kok-related-headline {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.35;
}

.kok-related-card .kok-related-headline a {
  color: var(--kok-ink);
  text-decoration: none;
}

.kok-related-card .kok-related-headline a:hover {
  color: var(--kok-accent);
}

.kok-related-card .kok-related-meta {
  margin-top: 0.45rem;
  font-size: 0.72rem;
  color: var(--kok-ink-muted);
}

/* Dark mode */
body.kok-news-portal[data-theme="dark"] {
  --kok-ink: #f1f5f9;
  --kok-ink-muted: #94a3b8;
  --kok-border: #334155;
  --kok-bg-subtle: #0f172a;
  --kok-rule: #475569;
}

body[data-theme="dark"] .kok-related-card {
  background: #1e293b;
  border-color: #334155;
}

body[data-theme="dark"] .kok-related-card:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}

body[data-theme="dark"] .kok-article-body {
  color: #cbd5e1;
}

body[data-theme="dark"] .kok-lead-headline a,
body[data-theme="dark"] .kok-article-headline {
  color: #f8fafc;
}

body[data-theme="dark"] .kok-lead-headline a:hover,
body[data-theme="dark"] .kok-mini-title a:hover,
body[data-theme="dark"] .kok-insight-title a:hover {
  color: #fca5a5;
}

body[data-theme="dark"] .kok-news-section-label {
  border-bottom-color: #f1f5f9;
}

body[data-theme="dark"] .kok-rail-title {
  color: #f1f5f9;
  border-bottom-color: #f1f5f9;
}

body[data-theme="dark"] .kok-rail-item .kok-rail-item-title a,
body[data-theme="dark"] .kok-mini-title a,
body[data-theme="dark"] .kok-insight-title a,
body[data-theme="dark"] .kok-related-headline a {
  color: #f1f5f9;
}

body[data-theme="dark"] .kok-byline a {
  color: #e2e8f0;
}
