.reading-progress {
  position: fixed;
  inset: 0 0 auto;
  z-index: 140;
  height: 3px;
  background: rgba(17, 24, 39, 0.08);
  pointer-events: none;
}

.reading-progress__bar {
  display: block;
  width: 0;
  height: 100%;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  transition: width 0.12s ease-out;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.main-grid,
.dual-section-grid,
.video-grid,
.gallery-grid,
.news-grid,
.author-cards,
.contact-grid,
.results-grid {
  display: grid;
  gap: 1.5rem;
}

.page-body {
  padding: 0 0.65rem;
  min-width: 0;
}

.main-grid {
  gap: 2rem;
}

.section-heading,
.section-heading--compact,
.page-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.section-heading {
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid color-mix(in srgb, var(--color-primary) 30%, var(--color-border));
}

.section-heading--compact {
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
}

.page-heading {
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid color-mix(in srgb, var(--color-primary) 30%, var(--color-border));
}

.section-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  color: var(--color-primary);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
}

.section-link--green {
  color: var(--color-green);
}

.section-link--blue {
  color: var(--color-blue);
}

.section-title--widget-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}

.section-title--widget-dark {
  color: #fff;
}

.section-title--widget-bar {
  margin: 0 0 1rem;
  padding-left: 0.75rem;
  border-left: 4px solid var(--color-primary);
  font-size: 1.125rem;
}

.section-link--dark {
  color: color-mix(in srgb, var(--color-primary) 68%, #ffffff);
}

.widget-icon-accent {
  color: var(--color-primary);
}

.widget-mask--bottom-left {
  justify-content: flex-start;
  align-items: flex-end;
  padding: 0.75rem;
}

.dark-panel .section-link,
.widget--dark .widget-link,
.dark-panel .widget-icon-accent,
.widget--dark .widget-icon-accent {
  color: color-mix(in srgb, var(--color-primary) 72%, #ffffff);
}

.featured-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.home-utility-strip {
  margin-bottom: 1.75rem;
}

.home-utility-grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(15.5rem, 82%);
  gap: 0.85rem;
  overflow-x: auto;
  padding: 0.125rem 0.125rem 0.65rem;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
}

.home-utility-grid::-webkit-scrollbar {
  display: none;
}

.home-utility-card {
  scroll-snap-align: start;
  display: grid;
  gap: 0.85rem;
  min-height: 8.75rem;
  padding: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--color-accent) 14%, var(--color-surface)), transparent 42%),
    linear-gradient(180deg, var(--color-surface), color-mix(in srgb, var(--color-accent) 4%, var(--color-surface)));
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.home-utility-card__top {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.home-utility-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.85rem;
  background: var(--color-secondary);
  color: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.18);
}

.home-utility-card__icon .icon {
  width: 1.05rem;
  height: 1.05rem;
}

.home-utility-card__label {
  color: var(--color-text);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-utility-card__chip {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0 0.6rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-primary) 12%, var(--color-surface));
  color: var(--color-primary);
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.home-utility-card__value {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -0.02em;
}

.home-utility-card__meta {
  color: var(--color-text-muted);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.55;
}

.bilgikarti {
  --bk-accent: var(--widget-theme-accent, var(--color-primary));
  --bk-accent-strong: var(--color-primary-dark);
  --bk-bg: var(--widget-theme-bg, var(--color-surface));
  --bk-text: var(--widget-theme-text, var(--color-text));
  --bk-muted: var(--color-text-muted);
  --bk-border: var(--color-border);
  --bk-surface: color-mix(in srgb, var(--bk-bg) 96%, var(--bk-text) 4%);
  --bk-surface-strong: color-mix(in srgb, var(--bk-bg) 90%, var(--bk-text) 10%);
  --bk-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
}

.bilgikarti__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: 0.9rem;
}

.bilgikarti__card {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 0.9rem;
  min-width: 0;
  min-height: 9.25rem;
  padding: 1rem 1rem 0.95rem;
  border: 1px solid var(--bk-border);
  border-radius: 1.1rem;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--bk-accent) 12%, transparent), transparent 42%),
    linear-gradient(180deg, var(--bk-bg) 0%, var(--bk-surface) 100%);
  color: var(--bk-text);
  box-shadow: var(--bk-shadow);
  overflow: hidden;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.bilgikarti__card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--bk-accent) 28%, var(--bk-border));
  box-shadow: 0 20px 44px rgba(15, 23, 42, 0.12);
}

.bilgikarti__head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.7rem;
  min-width: 0;
}

.bilgikarti__control {
  position: relative;
  z-index: 1;
  min-width: 0;
  justify-self: start;
  width: 100%;
  margin-top: -0.08rem;
}

.bilgikarti__control::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0.12rem;
  width: 0.42rem;
  height: 0.42rem;
  border-right: 1.4px solid color-mix(in srgb, var(--bk-text) 76%, var(--bk-accent) 24%);
  border-bottom: 1.4px solid color-mix(in srgb, var(--bk-text) 76%, var(--bk-accent) 24%);
  transform: translateY(-62%) rotate(45deg);
  pointer-events: none;
  opacity: 0.55;
}

.bilgikarti__select {
  width: 100%;
  min-width: 0;
  min-height: 0;
  padding: 0 1rem 0 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--bk-text);
  font-family: var(--font-main);
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.32;
  box-shadow: none;
  appearance: none;
  outline: none;
  cursor: pointer;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.bilgikarti__select:hover {
  color: color-mix(in srgb, var(--bk-text) 86%, var(--bk-accent) 14%);
}

.bilgikarti__select:focus {
  color: color-mix(in srgb, var(--bk-text) 82%, var(--bk-accent) 18%);
}

.bilgikarti__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.55rem;
  height: 2.55rem;
  border-radius: 0.9rem;
  background: linear-gradient(135deg, var(--bk-accent) 0%, var(--bk-accent-strong) 100%);
  color: #fff;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--bk-accent) 22%, transparent);
}

.bilgikarti__icon .icon {
  width: 1.05rem;
  height: 1.05rem;
}

.bilgikarti__label {
  min-width: 0;
  color: color-mix(in srgb, var(--bk-text) 92%, var(--bk-accent) 8%);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.bilgikarti__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.8rem;
  max-width: 100%;
  padding: 0.22rem 0.62rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bk-accent) 12%, var(--bk-bg));
  color: var(--bk-accent);
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.bilgikarti__chip--up {
  background: color-mix(in srgb, var(--color-green) 14%, var(--bk-bg));
  color: var(--color-green);
}

.bilgikarti__chip--down {
  background: color-mix(in srgb, var(--bk-accent-strong) 14%, var(--bk-bg));
  color: var(--bk-accent-strong);
}

.bilgikarti__body {
  display: grid;
  align-content: start;
  gap: 0.5rem;
  min-width: 0;
}

.bilgikarti__card-link {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 0.75rem;
  min-width: 0;
  margin-top: auto;
  color: inherit;
  text-decoration: none;
}

.bilgikarti__value {
  color: var(--bk-text);
  font-family: var(--font-display);
  font-size: clamp(1rem, 1.3vw, 1.22rem);
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.bilgikarti__meta {
  color: var(--bk-muted);
  font-size: 0.76rem;
  font-weight: 600;
  line-height: 1.5;
}

.bilgikarti__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin-top: auto;
  margin-left: auto;
  border-radius: 999px;
  background: var(--bk-surface-strong);
  color: color-mix(in srgb, var(--bk-text) 72%, var(--bk-accent) 28%);
  transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.bilgikarti__card:hover .bilgikarti__arrow {
  transform: translateX(2px);
  background: color-mix(in srgb, var(--bk-accent) 12%, var(--bk-bg));
  color: var(--bk-accent);
}

[data-theme-mode="dark"] .bilgikarti {
  --bk-shadow: 0 16px 34px rgba(0, 0, 0, 0.2);
}

@media (max-width: 860px) {
  .bilgikarti__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .bilgikarti__grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.75rem;
  }

  .bilgikarti__card {
    min-height: 8.6rem;
    padding: 0.9rem 0.9rem 0.85rem;
  }

  .bilgikarti__value {
    font-size: 1rem;
  }

  .bilgikarti__meta {
    font-size: 0.72rem;
  }
}

.ad-banner,
.ad-box {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed #d1d5db;
  background: #f9fafb;
  color: var(--color-text-muted, #9ca3af);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-align: center;
}

.ad-banner {
  min-height: 5rem;
  font-size: 0.625rem;
  font-weight: 800;
}

.ad-box {
  min-height: 16rem;
  font-size: 0.75rem;
  font-weight: 700;
}

.manset4 {
  --m4-accent: var(--widget-theme-accent, var(--color-primary));
  --m4-accent-strong: var(--color-primary-dark);
  --m4-bg: var(--widget-theme-bg, var(--color-bg, #fff));
  --m4-surface: var(--color-surface, #fff);
  --m4-surface-soft: var(--color-surface-soft, #f7f7f8);
  --m4-text: var(--widget-theme-text, var(--color-text, #171717));
  --m4-muted: var(--color-text-muted, #6f7279);
  --m4-border: var(--color-border, rgba(0, 0, 0, 0.08));
  --m4-shadow: 0 24px 60px rgba(15, 23, 42, 0.12);
  position: relative;
  margin-bottom: clamp(1rem, 2vw, 1.75rem);
  color: var(--m4-text);
}

.manset4__inner {
  display: grid;
  gap: 1.15rem;
}

.manset4__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.92fr) minmax(260px, 0.74fr);
  gap: 0.65rem;
  align-items: start;
}

.manset4__grid--single {
  grid-template-columns: minmax(0, 1fr);
}

.manset4__main {
  position: relative;
  min-width: 0;
  display: grid;
  gap: 0.72rem;
  padding-bottom: 0;
  align-self: start;
  isolation: isolate;
}

.manset4__stage {
  position: relative;
  aspect-ratio: 1560 / 800;
  min-height: 0;
  border: 1px solid var(--m4-border);
  border-radius: 28px;
  overflow: hidden;
  background: var(--m4-surface-soft);
  box-shadow: var(--m4-shadow);
}

.manset4__slides {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background: var(--m4-surface-soft);
}

.manset4__slide {
  position: absolute;
  inset: 0;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.45s ease, visibility 0.45s ease, transform 0.45s ease;
}

.manset4__slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 2;
}

.manset4__link {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 100%;
  color: inherit;
  text-decoration: none;
}

.manset4__media {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background: var(--m4-surface-soft);
}

.manset4__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.01);
}

.manset4__overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 78% 16%, color-mix(in srgb, var(--m4-accent) 20%, transparent) 0%, transparent 34%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.04) 0%, rgba(0, 0, 0, 0.12) 24%, rgba(0, 0, 0, 0.76) 100%);
}

.manset4__body {
  position: relative;
  z-index: 2;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.9rem;
  padding: clamp(1.25rem, 2.6vw, 2.15rem);
  padding-right: clamp(1.25rem, 5vw, 7rem);
  padding-bottom: clamp(6.2rem, 10vw, 7.2rem);
  color: #fff;
}

.manset4__content {
  width: min(72%, 46rem);
  padding: clamp(1rem, 1.8vw, 1.2rem);
  border-radius: 26px;
  background: linear-gradient(135deg, rgba(8, 10, 18, 0.52) 0%, rgba(8, 10, 18, 0.22) 100%);
  border: 1px solid rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.18);
}

.manset4__meta {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.manset4__tag,
.manset4__time {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.manset4__tag {
  padding: 0.38rem 0.8rem;
  background: color-mix(in srgb, var(--m4-accent) 22%, transparent);
  border: 1px solid color-mix(in srgb, var(--m4-accent) 45%, transparent);
  color: #fff;
}

.manset4__time {
  padding: 0.32rem 0.72rem;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.94);
}

.manset4__title {
  margin: 0;
  max-width: 12.5ch;
  font-size: clamp(2rem, 4.05vw, 3.45rem);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.04em;
  text-wrap: balance;
}

.manset4__summary {
  margin: 0;
  max-width: 34rem;
  font-size: clamp(0.94rem, 1.45vw, 1.06rem);
  line-height: 1.58;
  color: rgba(255, 255, 255, 0.84);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.manset4__arrow {
  position: static;
  width: 3rem;
  height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  backdrop-filter: blur(14px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.2);
  pointer-events: auto;
}

.manset4__nav {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.1rem;
  pointer-events: none;
}

.manset4__arrow:hover {
  background: rgba(255, 255, 255, 0.24);
}

.manset4__pager {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: nowrap;
  gap: 0.38rem;
  width: 100%;
  min-width: 0;
  padding: 0.18rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--m4-surface) 97%, var(--m4-accent) 3%);
  border: 1px solid var(--m4-border);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.1);
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x;
}

.manset4__pager::-webkit-scrollbar {
  display: none;
}

.manset4__pager button,
.manset4__all {
  flex: 0 0 auto;
  min-width: 2.05rem;
  min-height: 2.05rem;
  padding: 0 0.62rem;
  border-radius: 999px;
  border: 1px solid var(--m4-border);
  background: var(--m4-surface-soft);
  color: var(--m4-text);
  font-size: 0.74rem;
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
  scroll-snap-align: start;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.manset4__pager button.is-active {
  background: linear-gradient(135deg, var(--m4-accent) 0%, var(--m4-accent-strong) 100%);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 12px 30px color-mix(in srgb, var(--m4-accent) 32%, transparent);
}

.manset4__pager button:not(.is-active) {
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--m4-surface) 86%, #fff 14%);
}

.manset4__pager button:hover,
.manset4__all:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--m4-accent) 26%, var(--m4-border));
  background: color-mix(in srgb, var(--m4-surface-soft) 88%, var(--m4-accent) 12%);
}

.manset4__all {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  font-size: 0.7rem;
}

.manset4__rail {
  display: grid;
  grid-template-rows: minmax(0, 1.2fr) auto;
  gap: 0.72rem;
  min-width: 0;
  width: min(100%, 316px);
  height: auto;
  padding-bottom: 2.15rem;
  justify-self: end;
  align-self: start;
}

.manset4__spotlight,
.manset4__card,
.manset4__strip-item {
  border: 1px solid var(--m4-border);
  background: var(--m4-surface);
  color: var(--m4-text);
  box-shadow: var(--m4-shadow);
}

.manset4__spotlight {
  position: relative;
  min-height: 182px;
  border-radius: 20px;
  overflow: hidden;
}

.manset4__spotlight-link {
  display: flex;
  min-height: 100%;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.manset4__spotlight-media,
.manset4__spotlight-media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.manset4__spotlight::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.06) 10%, rgba(0, 0, 0, 0.76) 100%);
}

.manset4__spotlight-body {
  position: relative;
  z-index: 1;
  margin-top: auto;
  padding: 0.82rem;
  color: #fff;
}

.manset4__spotlight-body h3 {
  margin: 0.45rem 0 0;
  font-size: clamp(0.88rem, 1.35vw, 1.1rem);
  line-height: 1.18;
  font-weight: 850;
}

.manset4__spotlight-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.9);
}

.manset4__spotlight-kicker::before {
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  background: var(--m4-accent);
  box-shadow: 0 0 0 0.22rem color-mix(in srgb, var(--m4-accent) 18%, transparent);
}

.manset4__card-list {
  display: grid;
  gap: 0.68rem;
  grid-template-rows: repeat(2, minmax(0, 1fr));
}

.manset4__card {
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(180deg, var(--m4-surface) 0%, var(--m4-surface-soft) 100%);
}

.manset4__card-link {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  align-items: stretch;
  min-height: 82px;
  color: inherit;
  text-decoration: none;
}

.manset4__card-media,
.manset4__card-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.manset4__card-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.22rem;
  min-width: 0;
  padding: 0.58rem 0.68rem;
}

.manset4__card-label {
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--m4-accent);
}

.manset4__card-title {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.22;
  font-weight: 800;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.manset4__strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
}

.manset4__strip-item {
  min-width: 0;
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(180deg, var(--m4-surface) 0%, var(--m4-surface-soft) 100%);
}

.manset4__strip-link {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  height: 100%;
  padding: 1rem 1.05rem 1.1rem;
  color: inherit;
  text-decoration: none;
}

.manset4__strip-label {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--m4-muted);
}

.manset4__strip-label::before {
  content: "";
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--m4-accent);
}

.manset4__strip-title {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.42;
  font-weight: 780;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.manset4__card-link:hover .manset4__card-title,
.manset4__spotlight-link:hover h3,
.manset4__strip-link:hover .manset4__strip-title {
  color: var(--m4-accent);
}

[data-theme-mode="dark"] .manset4 {
  --m4-shadow: 0 22px 44px rgba(0, 0, 0, 0.24);
}

@media (max-width: 1180px) {
  .manset4__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .manset4__rail {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: none;
    align-items: start;
    width: 100%;
    height: auto;
    justify-self: stretch;
  }

  .manset4__strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .manset4__stage {
    min-height: 0;
  }

  .manset4__title {
    max-width: 11.5ch;
    font-size: clamp(1.45rem, 5.9vw, 2.05rem);
    line-height: 1.02;
  }

  .manset4__summary {
    max-width: 100%;
    font-size: 0.88rem;
    line-height: 1.48;
    -webkit-line-clamp: 2;
  }

  .manset4__arrow {
    display: inline-flex;
    width: 2.35rem;
    height: 2.35rem;
  }

  .manset4__nav {
    padding: 0 0.8rem;
  }

  .manset4__rail {
    grid-template-columns: minmax(0, 1fr);
    height: auto;
  }

  .manset4__body {
    padding: 1rem 1rem 5.2rem;
  }

  .manset4__content {
    width: min(100%, 30rem);
    padding: 0.9rem 0.95rem;
    border-radius: 22px;
  }

  .manset4__meta {
    gap: 0.45rem;
  }

  .manset4__time {
    min-height: 1.75rem;
    padding: 0.26rem 0.62rem;
    font-size: 0.67rem;
  }

  .manset4__card-list {
    grid-template-rows: none;
  }

  .manset4__pager {
    gap: 0.3rem;
    padding: 0.14rem;
  }

  .manset4__pager button,
  .manset4__all {
    min-width: 1.88rem;
    min-height: 1.88rem;
    padding: 0 0.5rem;
    font-size: 0.68rem;
  }
}

@media (max-width: 640px) {
  .manset4__stage {
    min-height: 0;
    border-radius: 22px;
  }

  .manset4__body {
    padding: 0.9rem 0.9rem 4.15rem;
  }

  .manset4__content {
    width: 100%;
    max-width: 22rem;
    padding: 0.78rem 0.82rem;
    border-radius: 18px;
  }

  .manset4__title {
    max-width: 10.5ch;
    font-size: clamp(1.12rem, 5vw, 1.46rem);
    line-height: 1.04;
  }

  .manset4__summary {
    display: none;
  }

  .manset4__pager {
    gap: 0.24rem;
    padding: 0.12rem;
  }

  .manset4__pager button,
  .manset4__all {
    min-width: 1.66rem;
    min-height: 1.66rem;
    padding: 0 0.42rem;
    font-size: 0.62rem;
  }

  .manset4__arrow {
    width: 2rem;
    height: 2rem;
  }

  .manset4__nav {
    padding: 0 0.65rem;
  }

  .manset4__card-link {
    grid-template-columns: 68px minmax(0, 1fr);
    min-height: 68px;
  }

  .manset4__strip {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 480px) {
  .manset4__stage {
    min-height: 0;
  }

  .manset4__body {
    padding: 0.75rem 0.75rem 3.7rem;
  }

  .manset4__content {
    max-width: 18rem;
    padding: 0.72rem 0.76rem;
    border-radius: 16px;
  }

  .manset4__title {
    font-size: clamp(1rem, 4.7vw, 1.22rem);
    max-width: 10ch;
  }

  .manset4__time {
    min-height: 1.5rem;
    padding: 0.2rem 0.52rem;
    font-size: 0.62rem;
  }

  .manset4__pager button,
  .manset4__all {
    min-width: 1.48rem;
    min-height: 1.48rem;
    padding: 0 0.34rem;
    font-size: 0.58rem;
  }

  .manset4__pager {
    gap: 0.22rem;
    padding: 0.1rem;
  }

  .manset4__arrow {
    width: 1.72rem;
    height: 1.72rem;
  }

  .manset4__nav {
    padding: 0 0.5rem;
  }
}

.news-card {
  display: block;
  position: relative;
  overflow: hidden;
  background: var(--color-surface, #fff);
  border-radius: var(--radius-md, 12px);
}

.news-card--overlay {
  border-radius: var(--radius-sm);
}

.news-card__media {
  position: relative;
  overflow: hidden;
  background: var(--color-surface-muted, #e5e7eb);
}

.news-card__media--ratio {
  aspect-ratio: 16 / 9;
}

.news-card__media--square {
  aspect-ratio: 1 / 1;
}

.news-card__media--small {
  height: 8.75rem;
}

.news-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.news-card:hover .news-card__media img {
  transform: scale(1.06);
}

.news-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0.88));
}

.news-card__badge {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  width: fit-content;
  padding: 0.25rem 0.5rem;
  background: var(--color-primary);
  color: #fff;
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.news-card__title {
  margin: 0;
  color: var(--color-text, inherit);
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.news-card__title--overlay {
  color: #fff;
}

.news-card__title--small {
  font-size: 0.9rem;
}

.news-card__title--medium {
  font-size: 1.125rem;
}

.news-card__title--large {
  font-size: 1.6rem;
}

.news-card__summary {
  margin: 0.75rem 0 0;
  color: #d1d5db;
  font-size: 0.875rem;
  line-height: 1.5;
}

.news-card--category-feature {
  min-height: clamp(20rem, 34vw, 25rem);
}

.news-card__media--category-feature {
  min-height: clamp(20rem, 34vw, 25rem);
}

.news-card__overlay--category-feature {
  padding: 1.25rem 1.25rem 1.35rem;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0) 0%, rgba(15, 23, 42, 0.08) 42%, rgba(15, 23, 42, 0.74) 76%, rgba(15, 23, 42, 0.94) 100%);
}

.news-card--category-feature .news-card__title--medium {
  font-size: clamp(1.2rem, 2vw, 1.55rem);
}

.news-card--category-feature .news-card__summary {
  max-width: 32rem;
}

.news-card__icon {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 999px;
  color: #fff;
}

.news-card__icon--video {
  background: var(--color-primary);
}

.news-card__icon--gallery {
  background: var(--color-blue);
}

.news-list-card {
  display: flex;
  align-items: flex-start;
  gap: 0.875rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-border, #f3f4f6);
}

.news-list-card:last-child {
  border-bottom: 0;
}

.news-list-card__thumb {
  flex: 0 0 auto;
  width: 5rem;
  height: 3.5rem;
  overflow: hidden;
  border-radius: var(--radius-sm);
}

.news-list-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.news-list-card:hover .news-list-card__thumb img {
  transform: scale(1.08);
}

.news-list-card__title {
  margin: 0;
  color: var(--color-text, inherit);
  font-family: var(--font-display);
  font-size: 0.8125rem;
  font-weight: 800;
  line-height: 1.28;
}

.news-list-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.35rem;
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.625rem;
  font-weight: 800;
  text-transform: uppercase;
}

.news-list-card__meta .is-category {
  color: var(--color-primary);
}

.feature-block {
  display: grid;
  gap: 1rem;
}

.home-section-shell {
  padding: 1.25rem;
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  background: linear-gradient(180deg, var(--color-surface, #ffffff), var(--color-surface-soft, #fbfcfe));
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.home-section-shell .section-heading,
.home-section-shell .section-heading--compact {
  align-items: flex-start;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}

.home-section-shell--dark {
  border-color: var(--color-border);
  border-radius: 1rem;
  box-shadow: 0 20px 44px rgba(15, 23, 42, 0.18);
}

.home-section-shell--soft {
  border-color: var(--color-border);
  background: linear-gradient(180deg, var(--color-surface-soft, #f8fafc), var(--color-surface-muted, #f3f4f6));
}

.home-topic-split>div {
  padding: 1.25rem;
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  background: var(--color-surface, #fff);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.home-sidebar {
  display: grid;
  gap: 1.25rem;
  align-content: start;
}

.home-sidebar .widget,
.home-sidebar .poll-card,
.home-sidebar .newsletter-box,
.home-sidebar .ad-box {
  border-radius: var(--radius-md, 12px);
}

.home-sidebar .widget,
.home-sidebar .poll-card {
  padding: 1.15rem;
}

.home-sidebar .widget-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.home-sidebar .popular-list li:first-child {
  padding-top: 0;
}

.home-sidebar .newsletter-box {
  box-shadow: 0 18px 36px color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.home-sidebar .ad-box {
  min-height: 13rem;
}

.dark-panel,
.light-panel {
  padding: 2rem;
  border-radius: var(--radius-sm);
}

.dark-panel {
  background: var(--widget-theme-bg, linear-gradient(135deg, color-mix(in srgb, var(--color-secondary) 94%, #000000), var(--color-secondary)));
  color: var(--widget-theme-text, #fff);
}

.light-panel {
  background: var(--color-surface-muted);
}

.media-grid {
  display: grid;
  gap: 1.5rem;
}

.media-item {
  display: block;
}

.media-item__thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-sm);
  margin-bottom: 0.75rem;
}

.media-item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.media-item:hover .media-item__thumb img {
  transform: scale(1.08);
}

.media-item__mask {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.25);
  transition: background 0.3s ease;
}

.media-item:hover .media-item__mask {
  background: rgba(0, 0, 0, 0.4);
}

.media-item__play {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 999px;
  background: var(--color-primary);
  color: #fff;
}

.media-item__badge {
  position: absolute;
  left: 0.75rem;
  bottom: 0.75rem;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: #fff;
  font-size: 0.625rem;
  font-weight: 800;
}

.media-item__title {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 800;
  line-height: 1.35;
}

.light-panel .media-item__title {
  color: var(--color-text);
}

.dark-panel .media-item__title {
  color: var(--widget-theme-text, #fff);
}

.section-border--green {
  border-bottom: 2px solid var(--color-green);
}

.section-border--blue {
  border-bottom: 2px solid var(--color-blue);
}

.sidebar {
  display: grid;
  gap: 1.25rem;
}

.widget {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 12px);
  padding: 1.5rem;
  box-shadow: var(--shadow-sm);
}

.widget--dark {
  background: var(--widget-theme-bg, linear-gradient(135deg, color-mix(in srgb, var(--color-secondary) 94%, #000000), var(--color-secondary)));
  border-color: color-mix(in srgb, var(--widget-theme-bg, var(--color-secondary)) 18%, #000000);
  color: var(--widget-theme-text, #fff);
}

.widget--weather {
  background: var(--widget-theme-bg, linear-gradient(135deg, var(--color-accent), var(--color-secondary)));
  color: var(--widget-theme-text, #fff);
  box-shadow: var(--shadow-md);
  align-self: start;
  padding: 1rem;
}

.widget--weather .widget-title__main,
.widget--weather .widget-link {
  color: var(--widget-theme-text, #fff);
}

.widget--weather .widget-select select {
  border-color: color-mix(in srgb, var(--widget-theme-text, #fff) 22%, transparent);
  background: color-mix(in srgb, var(--widget-theme-text, #fff) 14%, transparent);
  color: var(--widget-theme-text, #fff);
}

.widget--weather .widget-select::after {
  color: var(--widget-theme-text, #fff);
}

.widget--weather.is-loading {
  opacity: 1;
}

.widget--weather.is-loading .weather-main,
.widget--weather.is-loading .weather-stats {
  opacity: 0;
}

.weather-widget__body {
  position: relative;
  min-height: 10.75rem;
}

.weather-widget__skeleton {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: none;
  pointer-events: none;
  padding-top: 0.35rem;
}

.widget--weather.is-loading .weather-widget__skeleton {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
}

.weather-widget__skeleton-line {
  display: block;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.34) 50%, rgba(255, 255, 255, 0.18) 100%);
  background-size: 200% 100%;
  animation: weather-widget-shimmer 1.35s linear infinite;
}

.weather-widget__skeleton-line--city {
  width: 5.5rem;
  min-height: 0.85rem;
}

.weather-widget__skeleton-line--temp {
  width: 7rem;
  min-height: 3rem;
}

.weather-widget__skeleton-line--summary {
  width: 8.5rem;
  min-height: 0.8rem;
}

.weather-widget__skeleton-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  width: 100%;
  margin-top: auto;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.weather-widget__skeleton-line--stat {
  min-height: 2.2rem;
}

@keyframes weather-widget-shimmer {
  0% {
    background-position: 200% 0;
  }

  100% {
    background-position: -200% 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .weather-widget__skeleton-line {
    animation: none;
  }
}

.widget-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin: 0 0 1rem;
  font-size: 0.875rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.widget-title__main {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.widget-title__actions {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  margin-left: auto;
}

.widget-link {
  color: var(--color-primary);
  font-size: 0.5625rem;
  font-weight: 900;
  text-transform: uppercase;
}

.widget-select {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.widget-select::after {
  content: "";
  position: absolute;
  right: 0.7rem;
  top: 50%;
  width: 0.38rem;
  height: 0.38rem;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: translateY(-65%) rotate(45deg);
  opacity: 0.7;
  pointer-events: none;
}

.widget-select select {
  appearance: none;
  min-height: 2rem;
  padding: 0 1.8rem 0 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-soft);
  color: var(--color-text);
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  cursor: pointer;
}

.widget-select select:focus {
  outline: none;
}

.widget-select select option {
  color: var(--color-text, #111827);
}

.weather-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  transition: opacity 0.18s ease;
}

.weather-temp {
  margin: 0;
  font-size: 2.5rem;
  font-weight: 900;
  line-height: 1;
}

.weather-city {
  margin: 0 0 0.25rem;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.85;
}

.weather-summary {
  margin: 0.4rem 0 0;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.45;
  color: color-mix(in srgb, var(--widget-theme-text, #fff) 92%, transparent);
}

.weather-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  padding-top: 1rem;
  border-top: 1px solid color-mix(in srgb, var(--widget-theme-text, #fff) 20%, transparent);
  transition: opacity 0.18s ease;
}

.weather-stats div {
  text-align: center;
  font-size: 0.625rem;
  font-weight: 800;
  text-transform: uppercase;
}

.weather-stats strong {
  display: block;
  margin-top: 0.25rem;
  color: var(--widget-theme-text, #fff);
  font-size: 0.75rem;
}

.market-list,
.prayer-grid,
.popular-list,
.author-list,
.horoscope-grid {
  margin: 0;
  padding: 0;
  list-style: none;
}

.market-list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.6rem;
  margin-bottom: 0.6rem;
  border-bottom: 1px solid color-mix(in srgb, var(--widget-theme-text, #fff) 12%, transparent);
}

.market-list li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}

.market-list span {
  color: var(--color-text-muted, color-mix(in srgb, var(--widget-theme-text, #fff) 58%, transparent));
  font-size: 0.75rem;
  font-weight: 800;
}

.market-list strong {
  display: block;
  color: var(--widget-theme-text, #fff);
  font-size: 0.875rem;
  text-align: right;
}

.market-list em {
  display: block;
  font-style: normal;
  font-size: 0.625rem;
  font-weight: 900;
  text-align: right;
}

.prayer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
}

.prayer-grid li {
  padding: 0.55rem;
  border: 1px solid var(--color-border, color-mix(in srgb, var(--color-primary) 18%, var(--color-surface)));
  background: var(--color-surface,
      linear-gradient(180deg,
        color-mix(in srgb, var(--color-primary) 7%, var(--color-surface)),
        color-mix(in srgb, var(--color-accent) 7%, var(--color-surface))));
  text-align: center;
  border-radius: var(--radius-sm, 4px);
}

.prayer-grid span {
  display: block;
  color: var(--color-text-muted, color-mix(in srgb, var(--color-text) 60%, var(--color-primary)));
  font-size: 0.5625rem;
  font-weight: 900;
  text-transform: uppercase;
}

.prayer-grid strong {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.75rem;
  font-weight: 900;
  color: var(--color-primary, var(--color-secondary));
}

.poll-card {
  padding: 1.5rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface, #fff);
  box-shadow: var(--shadow-sm);
}

.poll-question {
  margin: 0 0 1rem;
  font-size: 0.9375rem;
  font-weight: 800;
  line-height: 1.4;
}

.poll-options {
  display: grid;
  gap: 0.5rem;
}

.poll-options.is-disabled {
  opacity: 0.72;
}

.poll-options label {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface-soft);
  color: var(--color-text);
  font-size: 0.8125rem;
  font-weight: 700;
}

.poll-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
}

.poll-card.is-loading {
  opacity: 0.82;
}

.button,
.button-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0 1rem;
  border: 0;
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.button {
  background: var(--color-primary);
  color: #fff;
}

.button-secondary {
  background: var(--btn-action-bg, var(--color-secondary));
  color: var(--btn-action-text, #fff);
}

.button:disabled,
.button-secondary:disabled {
  cursor: not-allowed;
  opacity: 0.7;
}

.poll-feedback {
  margin: 0.9rem 0 0;
  font-size: 0.75rem;
  font-weight: 700;
}

.poll-feedback.is-error {
  color: #b91c1c;
}

.poll-feedback.is-success {
  color: #047857;
}

.poll-feedback.is-info {
  color: #1d4ed8;
}

.poll-results {
  display: grid;
  gap: 0.75rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}

.poll-results__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.poll-results__label,
.poll-results__total {
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
}

.poll-results__label {
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
}

.poll-results__total {
  color: var(--color-text);
}

.poll-results__list {
  display: grid;
  gap: 0.75rem;
}

.poll-result-item {
  display: grid;
  gap: 0.35rem;
}

.poll-result-item__head,
.poll-result-item__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.poll-result-item__head {
  font-size: 0.75rem;
  font-weight: 800;
}

.poll-result-item__meta {
  color: var(--color-text-muted);
  font-size: 0.6875rem;
  font-weight: 700;
}

.poll-result-item__track {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 0.5rem;
  border-radius: 999px;
  background: var(--color-surface-muted);
}

.poll-result-item__fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
}

.ranking-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.6875rem;
}

.ranking-table th,
.ranking-table td {
  padding: 0.55rem 0;
  border-bottom: 1px solid var(--color-border);
  text-align: center;
}

.ranking-table th:first-child,
.ranking-table td:first-child {
  text-align: left;
}

.ranking-table th {
  color: var(--color-text-muted, #9ca3af);
  font-weight: 900;
  text-transform: uppercase;
}

.ranking-table td strong {
  color: var(--color-primary);
}

.standings-widget__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.standings-widget__filter {
  display: block;
  flex: 1 1 auto;
}

.standings-widget__select {
  width: 100%;
  min-height: 2.5rem;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 0.85rem;
  background: var(--color-surface, #fff);
  color: var(--color-text);
  font-size: 0.75rem;
  font-weight: 700;
}

.standings-widget__select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.popular-list li {
  display: flex;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--color-border);
}

.popular-list li:last-child {
  border-bottom: 0;
}

.popular-index {
  color: color-mix(in srgb, var(--color-primary) 18%, var(--color-surface));
  font-size: 1.875rem;
  font-weight: 900;
  line-height: 1;
}

.popular-list a {
  font-size: 0.875rem;
  font-weight: 800;
  line-height: 1.35;
}

.author-list {
  display: grid;
  gap: 1rem;
}

.author-list li {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.author-list img,
.author-profile__image {
  width: 3rem;
  height: 3rem;
  border-radius: 999px;
  object-fit: cover;
}

.author-list h4 {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 800;
}

.author-list p {
  margin: 0.2rem 0 0;
  color: var(--color-text-muted);
  font-size: 0.6875rem;
  font-weight: 600;
}

.author-showcase {
  position: relative;
  overflow: hidden;
  padding: 1.1rem;
  border-color: var(--color-border);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--color-primary) 12%, var(--color-surface)), transparent 34%),
    linear-gradient(180deg, var(--color-surface), color-mix(in srgb, var(--color-accent) 3%, var(--color-surface)));
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.07);
}

.author-showcase__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.author-showcase__eyebrow {
  margin: 0 0 0.4rem;
  color: var(--color-primary);
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.author-showcase__title {
  font-size: 1.02rem;
  letter-spacing: -0.03em;
}

.author-showcase__actions {
  display: inline-flex;
  gap: 0.5rem;
}

.author-showcase__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.15rem;
  height: 2.15rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: var(--btn-action-bg, var(--color-secondary));
  color: var(--btn-action-text, #fff);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
  transition:
    transform 0.2s ease,
    color 0.2s ease,
    background-color 0.2s ease,
    box-shadow 0.2s ease;
}

.author-showcase__arrow .icon {
  width: 0.9rem;
  height: 0.9rem;
}

.author-showcase__arrow:hover,
.author-showcase__arrow:focus-visible {
  transform: translateY(-1px);
  background: var(--color-primary);
  color: #fff;
  box-shadow: 0 14px 28px color-mix(in srgb, var(--color-primary) 24%, transparent);
}

.author-showcase:focus-visible,
.author-showcase__arrow:focus-visible,
.author-showcase__link:focus-visible,
.author-showcase__dots button:focus-visible,
.author-showcase__avatar:focus-visible,
.author-showcase__name:focus-visible,
.author-showcase__latest:focus-visible,
.author-showcase__profile:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-primary) 28%, transparent);
  outline-offset: 2px;
}

.author-showcase__viewport {
  position: relative;
  min-height: 18.25rem;
}

.author-showcase__slide {
  display: none;
  width: 100%;
}

.author-showcase__slide.is-active {
  display: block;
  animation: author-showcase-enter 0.35s ease;
}

@keyframes author-showcase-enter {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.author-showcase__card {
  position: relative;
  display: grid;
  gap: 0.85rem;
  min-height: 18.25rem;
  padding: 1rem 1rem 0.95rem;
  border: 1px solid var(--color-border);
  border-radius: 1.1rem;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--color-surface) 98%, #ffffff), color-mix(in srgb, var(--color-surface-soft, var(--color-surface)) 96%, #ffffff)),
    linear-gradient(180deg, var(--color-surface), var(--color-surface-soft, var(--color-surface)));
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.08);
  transition:
    transform 0.25s ease,
    border-color 0.25s ease,
    box-shadow 0.25s ease;
}

.author-showcase__card::before {
  content: "";
  position: absolute;
  top: 0.95rem;
  left: 1rem;
  width: 2.8rem;
  height: 0.24rem;
  border-radius: 999px;
  background: var(--author-accent, var(--color-primary));
}

.author-showcase__card:hover,
.author-showcase__card:focus-within {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--author-accent, var(--color-primary)) 20%, var(--color-border));
  box-shadow: 0 22px 40px rgba(15, 23, 42, 0.1);
}

.author-showcase__slide[data-tone="ekonomi"] {
  --author-accent: #dc2626;
}

.author-showcase__slide[data-tone="teknoloji"] {
  --author-accent: #2563eb;
}

.author-showcase__slide[data-tone="spor"] {
  --author-accent: #ea580c;
}

.author-showcase__slide[data-tone="yasam"] {
  --author-accent: #0f766e;
}

.author-showcase__slide[data-tone="saglik"] {
  --author-accent: #16a34a;
}

.author-showcase__slide[data-tone="gundem"] {
  --author-accent: #7c3aed;
}

.author-showcase__top {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding-top: 0.65rem;
}

.author-showcase__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  padding: 0.16rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--author-accent, var(--color-primary)), var(--color-secondary));
  box-shadow: 0 12px 26px rgba(15, 23, 42, 0.16);
  flex: 0 0 auto;
}

.author-showcase__avatar img {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid var(--color-surface, #fff);
}

.author-showcase__identity {
  min-width: 0;
  display: grid;
  gap: 0.2rem;
}

.author-showcase__chip {
  display: inline-flex;
  align-items: center;
  justify-self: flex-start;
  min-height: 1.45rem;
  width: fit-content;
  padding: 0 0.5rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--author-accent, var(--color-primary)) 12%, var(--color-surface));
  color: var(--author-accent, var(--color-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--author-accent, var(--color-primary)) 16%, var(--color-surface));
  font-size: 0.58rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.author-showcase__identity h4 {
  margin: 0.05rem 0 0;
  line-height: 1.1;
}

.author-showcase__name {
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 900;
}

.author-showcase__role {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.73rem;
  font-weight: 700;
  line-height: 1.45;
}

.author-showcase__bio {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.77rem;
  line-height: 1.62;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.author-showcase__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.author-showcase__meta span {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0 0.62rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-secondary) 4%, var(--color-surface));
  color: color-mix(in srgb, var(--color-text) 82%, var(--color-surface));
  box-shadow: inset 0 0 0 1px var(--color-border);
  font-size: 0.6rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.author-showcase__latest {
  display: grid;
  gap: 0.28rem;
  padding: 0.85rem 0.9rem;
  border-radius: 0.95rem;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--color-secondary) 96%, #000000), var(--color-secondary)),
    linear-gradient(135deg, color-mix(in srgb, var(--author-accent, var(--color-primary)) 38%, transparent), transparent);
  color: #fff;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.14);
}

.author-showcase__latest span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.55rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.author-showcase__latest strong {
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.author-showcase__profile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--author-accent, var(--color-primary)), var(--color-secondary));
  color: #fff;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.14);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.author-showcase__profile:hover,
.author-showcase__profile:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(15, 23, 42, 0.18);
}

.author-showcase__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 0.85rem;
}

.author-showcase__dots {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.author-showcase__dots button {
  width: 0.45rem;
  height: 0.45rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: var(--color-border);
  transition:
    width 0.2s ease,
    background-color 0.2s ease,
    transform 0.2s ease;
}

.author-showcase__dots button:hover {
  transform: scale(1.05);
}

.author-showcase__dots button.is-active {
  width: 1.55rem;
  background: var(--author-accent, var(--color-primary));
}

.author-showcase__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.45rem;
  padding: 0 0.9rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-secondary) 4%, var(--color-surface));
  color: var(--color-text);
  box-shadow: inset 0 0 0 1px var(--color-border);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.author-showcase__link:hover,
.author-showcase__link:focus-visible {
  background: var(--color-secondary);
  color: var(--color-surface, #fff);
  transform: translateY(-1px);
}

.newsletter-box {
  background: var(--widget-theme-bg, var(--newsletter-bg, linear-gradient(135deg, var(--color-primary), var(--color-primary-dark))));
  color: var(--widget-theme-text, var(--newsletter-text, #fff));
  border-radius: var(--radius-sm);
  padding: 1.5rem;
  transition: all 0.3s ease;
}

.newsletter-box h3 {
  margin: 0 0 0.35rem;
  font-size: 1.125rem;
  font-weight: 900;
  text-transform: uppercase;
}

.newsletter-box p {
  margin: 0 0 1rem;
  color: var(--color-text-muted, color-mix(in srgb, #ffffff 74%, var(--color-primary)));
  font-size: 0.75rem;
}

.newsletter-box input,
.footer-newsletter input,
.contact-form input,
.contact-form select,
.contact-form textarea,
.search-form input,
.archive-filter input {
  width: 100%;
  min-height: 3rem;
  padding: 0.8rem 1rem;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-surface, #ffffff) 82%, transparent);
  color: var(--widget-theme-text, #fff);
}

.newsletter-box input::placeholder,
.footer-newsletter input::placeholder {
  color: var(--color-text-muted, color-mix(in srgb, #ffffff 74%, var(--color-primary)));
}

.newsletter-box input:focus-visible,
.footer-newsletter input:focus-visible {
  outline-color: rgba(255, 255, 255, 0.3);
}

.newsletter-box__button {
  width: 100%;
  background: color-mix(in srgb, var(--color-surface, #ffffff) 88%, #ffffff);
  color: var(--color-primary);
}

.newsletter-box__button:hover,
.newsletter-box__button:focus-visible {
  background: color-mix(in srgb, var(--color-surface, #ffffff) 82%, #ffffff);
  color: var(--color-primary-dark);
}

.horoscope-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.horoscope-grid button {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding: 0;
  border: 0;
  background: transparent;
}

.horoscope-grid span:first-child {
  font-size: 1.5rem;
}

.horoscope-grid span:last-child {
  color: var(--color-text-muted);
  font-size: 0.5625rem;
  font-weight: 800;
}

.newspapers-strip {
  margin-top: 4rem;
  padding: 3rem 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--color-primary) 12%, transparent), transparent 26%),
    linear-gradient(180deg, var(--color-surface-soft, #f8fafc), var(--color-surface-muted, #f3f4f6));
}

.newspapers-strip__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.newspapers-strip__title-wrap {
  display: grid;
  gap: 0.45rem;
}

.newspapers-strip__eyebrow {
  color: var(--color-primary);
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.newspapers-strip__title {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  margin: 0;
}

.newspapers-strip__actions {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.newspapers-strip__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-text) 94%, var(--color-surface));
  color: var(--color-surface, #fff);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.16);
  transition: transform 0.2s ease, background-color 0.2s ease, opacity 0.2s ease;
}

.newspapers-strip__arrow:hover,
.newspapers-strip__arrow:focus-visible {
  transform: translateY(-1px);
  background: var(--color-primary);
}

.newspapers-strip:focus-visible,
.newspapers-strip__arrow:focus-visible,
.newspapers-strip__link:focus-visible,
.newspaper-card:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-primary) 24%, transparent);
  outline-offset: 2px;
}

.newspapers-strip__arrow[disabled] {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.newspapers-strip__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  padding: 0 1rem;
  border-radius: 999px;
  background: var(--color-surface, #fff);
  color: var(--color-text, #111827);
  box-shadow: inset 0 0 0 1px var(--color-border);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.newspapers-strip__link:hover,
.newspapers-strip__link:focus-visible {
  background: color-mix(in srgb, var(--color-text) 94%, var(--color-surface));
  color: var(--color-surface, #fff);
}

.newspapers-strip__viewport {
  position: relative;
}

.newspaper-row {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  padding: 0.2rem 0.1rem 0.8rem;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
}

.newspaper-row::-webkit-scrollbar {
  display: none;
}

.newspaper-card {
  scroll-snap-align: start;
  flex: 0 0 clamp(9.75rem, 22vw, 11.25rem);
  display: grid;
  gap: 0.8rem;
  padding: 0.8rem;
  border: 1px solid var(--color-border);
  border-radius: 1.15rem;
  background: color-mix(in srgb, var(--color-surface, #ffffff) 94%, transparent);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.08);
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.newspaper-card:hover,
.newspaper-card:focus-visible {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--color-primary) 22%, var(--color-border));
  box-shadow: 0 20px 38px rgba(15, 23, 42, 0.12);
}

.newspaper-card__thumb {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: 0.95rem;
  background: var(--color-surface, #fff);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.newspaper-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}

.newspaper-card:hover .newspaper-card__thumb img,
.newspaper-card:focus-visible .newspaper-card__thumb img {
  transform: scale(1.03);
}

.newspaper-card__body {
  display: grid;
  gap: 0.35rem;
}

.newspaper-card__kicker {
  color: var(--color-primary);
  font-size: 0.5625rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.newspaper-card p {
  margin: 0;
  color: var(--color-text, #111827);
  font-size: 0.8rem;
  font-weight: 900;
  line-height: 1.3;
  text-transform: uppercase;
}

.footer {
  margin-top: 3rem;
  padding: 4rem 0 2rem;
  background: var(--footer-bg);
  color: var(--footer-text);
}

.footer-grid {
  display: grid;
  gap: 3rem;
  margin-bottom: 4rem;
}

.footer-title {
  margin: 0 0 1.5rem;
  color: var(--footer-text);
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.footer-brand p {
  margin: 0;
}

.footer-brand .logo {
  align-items: flex-start;
}

.footer-brand .logo img {
  display: block;
  width: auto;
  max-width: min(100%, 13.75rem);
  height: auto;
}

.footer-brand .logo__tag {
  color: var(--footer-muted);
}

.footer-brand .brand-text {
  margin-top: 1rem;
  color: var(--footer-muted);
  font-family: var(--font-ui);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.75;
}

.footer-links-grid,
.footer-links-list {
  display: grid;
  gap: 0.75rem;
}

.footer-links-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.footer-links-list a,
.footer-links-grid a {
  color: var(--footer-text);
  font-size: 0.875rem;
}

.footer-social {
  display: flex;
  gap: 1rem;
}

.footer-store-links {
  margin-top: 1.25rem;
  flex-wrap: wrap;
}

.footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--footer-bg) 88%, var(--footer-text));
  color: var(--footer-text);
}

.footer-newsletter {
  position: relative;
}

.footer-newsletter input {
  background: color-mix(in srgb, var(--footer-bg) 88%, var(--footer-text));
  color: var(--footer-text);
}

.footer-newsletter button {
  position: absolute;
  top: 0.75rem;
  right: 0.65rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-primary);
}

.footer-meta {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 2rem;
  border-top: 1px solid var(--footer-border);
}

.footer-meta p {
  margin: 0;
  color: var(--footer-muted);
  font-size: 0.75rem;
  line-height: 1.8;
  text-align: center;
}

.footer-meta a {
  color: var(--footer-text);
  font-weight: 700;
}

.footer-meta a:hover {
  color: var(--color-primary);
}

.store-badges {
  display: flex;
  gap: 1rem;
}

.store-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 7.5rem;
  height: 2.5rem;
  border: 1px solid var(--footer-border);
  color: var(--footer-text);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  text-decoration: none;
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.store-badge:hover {
  border-color: var(--color-primary);
  color: #ffffff;
  background: rgba(255, 255, 255, 0.04);
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 1.5rem;
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.6875rem;
  font-weight: 500;
  text-transform: uppercase;
}

.breadcrumb a:hover {
  color: var(--color-primary);
}

.page-copy {
  margin: 0;
  color: var(--color-text-muted, #4b5563);
  font-family: var(--font-ui);
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1.75;
}

.filter-bar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.filter-tools {
  display: flex;
  align-items: center;
  gap: 1rem;
  color: var(--color-text-muted);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
}

.filter-tools select {
  border: 0;
  background: transparent;
  color: inherit;
  font-weight: 800;
}

.category-grid {
  display: grid;
  gap: 2rem;
}

.category-grid__lead {
  grid-column: 1 / -1;
}

.category-showcase {
  display: grid;
  gap: 1rem;
}

.category-showcase__tabs {
  display: flex;
  gap: 0.45rem;
  overflow-x: auto;
  padding-bottom: 0.25rem;
  scrollbar-width: thin;
}

.category-showcase__tab {
  flex: 0 0 auto;
  min-height: 3rem;
  padding: 0.75rem 1rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface-soft, #eef2f7);
  color: var(--color-text-muted, #334155);
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.category-showcase__tab:hover,
.category-showcase__tab:focus-visible {
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface, #ffffff));
  border-color: var(--color-primary);
  color: var(--color-text, var(--color-primary));
}

.category-showcase__tab.is-active {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: #fff;
}

.category-showcase__grid {
  display: grid;
  gap: 1rem;
}

.category-showcase__lead .news-card__media--ratio {
  min-height: 22rem;
}

.category-showcase__side {
  display: grid;
  gap: 1rem;
}

.category-showcase__card {
  display: grid;
  gap: 0.7rem;
  color: inherit;
}

.category-showcase__thumb {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: var(--color-surface-muted, #e5e7eb);
  aspect-ratio: 16 / 10;
}

.category-showcase__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.category-showcase__card-title {
  margin: 0;
  color: var(--color-text, #0f172a);
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.18;
}

.pagination {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 3rem;
}

.pagination button,
.pagination a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 0;
  border-radius: var(--radius-sm);
  background: #f3f4f6;
  color: #4b5563;
  font-size: 0.875rem;
  font-weight: 800;
}

.pagination .is-active {
  background: var(--color-primary);
  color: #fff;
}

.pagination__edge {
  width: auto !important;
  min-width: 2.5rem;
  padding: 0 1rem;
}

.pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  color: var(--color-text-muted);
  font-size: 0.875rem;
  font-weight: 900;
}

.breaking-pagination {
  flex-wrap: wrap;
  row-gap: 0.75rem;
}

.article-layout {
  display: grid;
  gap: 3rem;
}

.article {
  min-width: 0;
}

.article-header {
  margin-bottom: 2rem;
}

.article-kicker {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.75rem;
  background: var(--color-primary);
  color: #fff;
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.article-title {
  margin: 1rem 0 1.25rem;
  color: var(--color-text, #111827);
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.03em;
}

.article-meta-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 0;
  margin-bottom: 2rem;
  border-top: 1px solid var(--color-border, #f3f4f6);
  border-bottom: 1px solid var(--color-border, #f3f4f6);
}

.author-mini {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.author-mini__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 999px;
  background: var(--color-surface-soft, #f3f4f6);
  color: var(--color-text-muted, #9ca3af);
}

.author-mini__name {
  display: block;
  color: var(--color-text, #111827);
  font-size: 0.875rem;
  font-weight: 800;
}

.author-mini__role {
  display: block;
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.625rem;
  font-weight: 800;
  text-transform: uppercase;
}

.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.6875rem;
  font-weight: 500;
  text-transform: uppercase;
}

.share-buttons {
  display: flex;
  gap: 0.5rem;
}

.share-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  color: #fff;
}

.share-button .icon,
.author-mini__avatar .icon {
  width: 1rem;
  height: 1rem;
  color: currentColor;
  fill: currentColor;
  stroke: currentColor;
  flex: 0 0 1rem;
}

.author-mini__avatar .icon {
  width: 1.1rem;
  height: 1.1rem;
  flex-basis: 1.1rem;
}

.share-button--facebook {
  background: #2563eb;
}

.share-button--twitter {
  background: #0ea5e9;
}

.share-button--linkedin {
  background: #1d4ed8;
}

.share-button--whatsapp {
  background: #25D366;
}

.share-button--gnews {
  background: #4285F4;
}

.share-button--copy {
  background: #f3f4f6;
  color: #4b5563;
}

.article-cover {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-sm);
  margin-bottom: 2rem;
}

.article-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.article-body {
  color: var(--color-text, #1f2937);
  font-family: var(--font-ui);
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.8;
}

.article-lead {
  margin: 0 0 2rem;
  padding-left: 1.5rem;
  border-left: 4px solid var(--color-primary);
  color: var(--color-text-muted, #4b5563);
  font-family: var(--font-ui);
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.72;
}

.article-body p,
.article-body ul {
  margin: 0 0 1.5rem;
}

.article-quote {
  margin: 2.5rem 0;
  padding: 2rem;
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-sm);
  background: var(--color-surface-soft, #f9fafb);
  color: var(--color-text-muted, #6b7280);
  font-family: var(--font-ui);
  font-size: 1.25rem;
  font-weight: 600;
  font-style: italic;
  line-height: 1.72;
}

.article-insights__grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  align-items: center;
}

.article-insights__item {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  min-width: min(100%, 17rem);
}

.article-insights__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 999px;
  background: rgba(220, 38, 38, 0.1);
  color: var(--color-primary);
  flex: 0 0 2.6rem;
}

.article-insights__icon .icon {
  width: 1rem;
  height: 1rem;
}

.article-insights__content {
  display: grid;
  gap: 0.2rem;
}

.article-insights__label {
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.6875rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.article-insights__value,
.article-insights__source {
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.4;
}

a.article-insights__source:hover,
a.article-insights__source:focus-visible {
  color: var(--color-primary);
}

.comment-box {
  padding: 1.5rem;
  border: 1px solid #eceff3;
  border-radius: 1rem;
  background: linear-gradient(180deg, #ffffff, #fafbfc);
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.06);
}

.comment-box__header {
  margin-bottom: 1.25rem;
}

.comment-box__title {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 1.35rem;
  text-transform: none;
}

.comment-box__title span {
  color: #374151;
}

.comment-form {
  display: grid;
  gap: 1rem;
}

.comment-form__row {
  display: grid;
  gap: 0.9rem;
  grid-template-columns: minmax(0, 1fr);
}

.comment-form__field {
  position: relative;
}

.comment-form__field input,
.comment-form__field textarea {
  width: 100%;
  border: 1px solid #dbe3ec;
  border-radius: 0.8rem;
  background: #fff;
  color: #111827;
  padding: 0.95rem 1rem 0.95rem 3rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.comment-form__field textarea {
  min-height: 8rem;
  resize: vertical;
}

.comment-form__field input::placeholder,
.comment-form__field textarea::placeholder {
  color: #6b7280;
}

.comment-form__field input:focus,
.comment-form__field textarea:focus {
  border-color: rgba(220, 38, 38, 0.45);
  box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.08);
  outline: none;
}

.comment-form__icon {
  position: absolute;
  top: 1rem;
  left: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted, #9ca3af);
  pointer-events: none;
}

.comment-form__icon .icon {
  width: 1rem;
  height: 1rem;
}

.comment-form__submit {
  min-width: 10rem;
  border-radius: 0.8rem;
}

.comment-form__hint,
.comment-empty {
  margin: 0.35rem 0 0;
  color: #4b5563;
  font-size: 0.95rem;
}

.comment-form__hint {
  color: #15803d;
  font-weight: 700;
}

.comment-form__hint[data-state="error"] {
  color: #dc2626;
}

.comment-list {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}

.comment-card {
  padding: 1.2rem 1.25rem;
  border: 1px solid #e8edf3;
  border-radius: 0.9rem;
  background: #fff;
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.05);
}

.comment-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.85rem;
}

.comment-head strong {
  font-size: 0.95rem;
}

.comment-head span {
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.6875rem;
  font-weight: 800;
  text-transform: uppercase;
}

.comment-card p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.95rem;
  line-height: 1.7;
}

.detail-stream__head {
  margin-bottom: 1.1rem;
}

.detail-stream__copy {
  margin: 0.35rem 0 0;
  color: #6b7280;
  font-size: 0.95rem;
  line-height: 1.7;
}

.detail-stream__list {
  display: grid;
  gap: 2.5rem;
}

.detail-stream-article {
  padding-top: 2rem;
  border-top: 1px solid #e7edf4;
}

.detail-stream-article:first-child {
  padding-top: 0;
  border-top: 0;
}

.detail-stream-article__header {
  display: grid;
  gap: 0.8rem;
  margin-bottom: 1.35rem;
}

.detail-stream-article__eyebrow {
  color: var(--color-primary);
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.detail-stream-article__title {
  margin: 0;
  color: #111827;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.detail-stream-article__spot {
  margin: 0;
  color: #4b5563;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.75;
}

.detail-stream-article__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.8rem;
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
}

.detail-stream-article__media {
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 0.85rem;
  background: #e5e7eb;
  margin-bottom: 1.5rem;
}

.detail-stream-article__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.detail-stream-article:hover .detail-stream-article__media img {
  transform: scale(1.04);
}

.detail-stream-article__body {
  margin-top: 0;
}

.detail-stream-article__footer {
  margin-top: 1.5rem;
}

.detail-stream-article__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 2.5rem;
  padding: 0 0.9rem;
  border-radius: 999px;
  background: #111827;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 1.1rem;
}

.detail-stream-article__link:hover,
.detail-stream-article__link:focus-visible {
  background: var(--color-primary);
}

.detail-stream__status {
  margin-top: 1rem;
  color: #6b7280;
  font-size: 0.85rem;
  font-weight: 700;
  text-align: center;
}

.detail-stream__sentinel {
  height: 1px;
}

.back-to-top {
  position: fixed;
  right: 1rem;
  bottom: 5.6rem;
  z-index: 1006;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border: 1px solid color-mix(in srgb, var(--color-border, #d8e1ec) 84%, transparent);
  border-radius: 999px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-surface-soft, #f8fafc) 94%, transparent),
    color-mix(in srgb, var(--color-bg-alt, var(--color-surface, #ffffff)) 90%, transparent)
  );
  color: var(--color-text, #111827);
  box-shadow: 0 16px 30px color-mix(in srgb, var(--color-text, #111827) 12%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  opacity: 0;
  visibility: hidden;
  transform: translateY(0.5rem);
  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    visibility 0.2s ease,
    background-color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    color 0.2s ease;
}

.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top .icon {
  width: 1.1rem;
  height: 1.1rem;
}

.back-to-top:hover,
.back-to-top:focus-visible {
  background: var(--color-primary);
  color: var(--btn-action-contrast, #ffffff);
  border-color: color-mix(in srgb, var(--color-primary) 72%, transparent);
  box-shadow: 0 18px 34px color-mix(in srgb, var(--color-primary) 24%, transparent);
}

#nextArticlePopup {
  position: fixed;
  right: 4.9rem;
  bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
  z-index: 1005;
  width: min(23rem, calc(100vw - 6.4rem));
  padding: 0.9rem 1rem 1rem;
  border: 1px solid color-mix(in srgb, var(--color-border, #d8e1ec) 84%, transparent);
  border-radius: 1.1rem;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-surface-soft, #f8fafc) 96%, transparent),
    color-mix(in srgb, var(--color-bg-alt, var(--color-surface, #ffffff)) 90%, transparent)
  );
  color: var(--color-text, #111827);
  box-shadow: 0 22px 48px color-mix(in srgb, var(--color-text, #111827) 14%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(0.75rem);
  transition:
    opacity 0.22s ease,
    transform 0.22s ease,
    visibility 0.22s ease,
    border-color 0.22s ease,
    box-shadow 0.22s ease;
}

#nextArticlePopup.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

#nextArticlePopup:hover,
#nextArticlePopup:focus-visible {
  border-color: color-mix(in srgb, var(--color-primary) 28%, var(--color-border, #d8e1ec));
  box-shadow: 0 26px 56px color-mix(in srgb, var(--color-primary) 16%, transparent);
}

#nextArticlePopup .popup-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 1.9rem;
  padding: 0 0.75rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-primary) 12%, var(--color-surface-soft, #f8fafc));
  color: var(--color-primary);
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

#nextArticlePopup .popup-label i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 0.95rem;
  height: 0.95rem;
  font-size: 0.9rem;
}

#nextArticlePopup .popup-title {
  margin-top: 0.75rem;
  color: var(--color-text, #111827);
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1.35;
}

@media (max-width: 767px) {
  .back-to-top {
    right: 0.85rem;
    bottom: calc(5.25rem + env(safe-area-inset-bottom, 0px));
    z-index: 1006;
  }

  #nextArticlePopup {
    left: 1rem;
    right: 1rem;
    width: auto;
    bottom: calc(9.05rem + env(safe-area-inset-bottom, 0px));
    padding: 0.85rem 0.95rem 0.95rem;
  }

  #nextArticlePopup .popup-title {
    font-size: 0.9rem;
  }
}

.detail-stream-article--skeleton .detail-stream-article__media,
.detail-stream-skeleton__line {
  background: linear-gradient(90deg, #edf2f7 0%, #f8fafc 50%, #edf2f7 100%);
  background-size: 200% 100%;
  animation: detail-stream-shimmer 1.4s linear infinite;
}

.detail-stream-skeleton__line {
  display: block;
  border-radius: 999px;
  min-height: 0.9rem;
}

.detail-stream-skeleton__line--short {
  width: 7rem;
}

.detail-stream-skeleton__line--badge {
  width: 5rem;
  min-height: 1.4rem;
  border-radius: 999px;
}

.detail-stream-skeleton__line--title {
  width: 78%;
  min-height: 1.15rem;
}

.detail-stream-skeleton__line--copy {
  width: 100%;
}

.detail-stream-skeleton__line--meta {
  width: 9rem;
  min-height: 0.8rem;
}

.detail-stream-skeleton__line--wide {
  width: 92%;
}

@keyframes detail-stream-shimmer {
  0% {
    background-position: 200% 0;
  }

  100% {
    background-position: -200% 0;
  }
}

.author-profile {
  display: grid;
  gap: 1.5rem;
  padding: 1.5rem;
  border: 1px solid #f3f4f6;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.author-profile__top {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.author-profile__image {
  width: 5rem;
  height: 5rem;
}

.author-profile__name {
  margin: 0;
  font-size: 1.75rem;
  font-weight: 900;
  letter-spacing: -0.03em;
}

.author-profile__title {
  margin: 0.25rem 0 0;
  color: var(--color-primary);
  font-size: 0.875rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.author-profile__bio {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.9375rem;
  line-height: 1.8;
}

.author-meta-grid {
  display: grid;
  gap: 0.75rem;
  color: #4b5563;
  font-size: 0.875rem;
  font-weight: 700;
}

.editor-page__heading {
  align-items: flex-end;
}

.editor-page__eyebrow {
  margin: 0 0 0.55rem;
  color: var(--color-primary);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.editor-page__summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.65rem;
}

.editor-page__summary-chip {
  display: inline-flex;
  align-items: center;
  min-height: 2.3rem;
  padding: 0 0.95rem;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: #fff;
  color: #475569;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: var(--shadow-sm);
}

.author-profile--feature {
  padding: 1.75rem;
  border-radius: 1.5rem;
  background:
    radial-gradient(circle at top right, rgba(239, 68, 68, 0.08), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.author-profile__hero {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 1.25rem;
  align-items: center;
}

.author-profile--feature .author-profile__image {
  width: 7rem;
  height: 7rem;
  border: 4px solid #fff;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
}

.author-profile__intro {
  min-width: 0;
}

.author-profile__badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.9rem;
  padding: 0 0.75rem;
  margin-bottom: 0.85rem;
  border-radius: 999px;
  background: rgba(220, 38, 38, 0.08);
  color: var(--color-primary);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.author-meta-grid--pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1rem;
}

.author-meta-pill {
  display: inline-flex;
  align-items: center;
  min-height: 2.2rem;
  padding: 0 0.9rem;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.8);
  color: #334155;
  font-size: 0.78rem;
  font-weight: 800;
}

.editor-page__stream {
  margin-top: 1.5rem;
}

.author-bio-card {
  padding: 1.5rem 1.6rem;
  border: 1px solid #f1f5f9;
  border-radius: 1.25rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: var(--shadow-sm);
}

.author-richtext {
  color: var(--color-text);
  font-size: 0.98rem;
  line-height: 1.85;
}

.author-richtext> :first-child {
  margin-top: 0;
}

.author-richtext> :last-child {
  margin-bottom: 0;
}

.author-richtext p,
.author-richtext ul,
.author-richtext ol,
.author-richtext blockquote {
  margin: 0 0 1rem;
}

.author-richtext ul,
.author-richtext ol {
  padding-left: 1.25rem;
}

.author-richtext li+li {
  margin-top: 0.45rem;
}

.author-richtext a {
  color: var(--color-primary);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

.author-richtext blockquote {
  padding-left: 1rem;
  border-left: 3px solid rgba(220, 38, 38, 0.22);
  color: #475569;
}

.headline-archive__heading {
  align-items: flex-end;
}

.headline-archive__eyebrow {
  margin: 0 0 0.55rem;
  color: var(--color-primary);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.headline-archive__filter {
  display: grid;
  gap: 0.55rem;
  min-width: min(100%, 18rem);
}

.headline-archive__filter label {
  color: #475569;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.headline-archive__filter-row {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

.headline-archive__filter input[type="date"] {
  flex: 1 1 auto;
  min-height: 3rem;
  padding: 0 0.95rem;
  border: 1px solid #e5e7eb;
  border-radius: 0.95rem;
  background: #fff;
  color: var(--color-text);
  font-weight: 700;
}

.headline-archive__panel {
  padding: 1.5rem;
  border: 1px solid #f1f5f9;
  border-radius: 1.5rem;
  background:
    radial-gradient(circle at top right, rgba(239, 68, 68, 0.06), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: var(--shadow-sm);
}

.headline-archive__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.headline-archive__chip {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0 0.85rem;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: #475569;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.headline-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.headline-archive-card {
  overflow: hidden;
  border: 1px solid #eef2f7;
  border-radius: 1.15rem;
  background: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.06);
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.headline-archive-card:hover {
  transform: translateY(-4px);
  border-color: #e2e8f0;
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.1);
}

.headline-archive-card__media {
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #e5e7eb;
}

.headline-archive-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.headline-archive-card:hover .headline-archive-card__media img {
  transform: scale(1.04);
}

.headline-archive-card__body {
  display: grid;
  gap: 0.6rem;
  padding: 1rem 1rem 1.1rem;
}

.headline-archive-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.85rem;
  color: #64748b;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.headline-archive-card__meta span {
  color: var(--color-primary);
}

.headline-archive-card__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 900;
  line-height: 1.4;
}

.headline-archive-card__title a {
  color: var(--color-text);
}

.headline-archive__pagination {
  margin-top: 2rem;
}

.search-form,
.archive-filter,
.contact-form {
  display: grid;
  gap: 1rem;
}

.search-form input,
.archive-filter input,
.contact-form input,
.contact-form select,
.contact-form textarea {
  border: 1px solid var(--color-border);
  background: #fff;
  color: var(--color-text);
}

.contact-form textarea {
  min-height: 10rem;
  resize: vertical;
}

.search-summary,
.empty-state {
  color: var(--color-text-muted);
  font-size: 0.875rem;
}

.breaking-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1rem;
}

.breaking-chip {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0 0.8rem;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: #fff;
  color: #4b5563;
  font-size: 0.6875rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.breaking-lead {
  margin-bottom: 1.5rem;
}

.breaking-feed {
  display: grid;
}

.breaking-page__head {
  align-items: flex-end;
}

.breaking-page__eyebrow {
  margin: 0 0 0.55rem;
  color: var(--color-primary);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.breaking-page__summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.65rem;
}

.breaking-page__summary-chip {
  display: inline-flex;
  align-items: center;
  min-height: 2.3rem;
  padding: 0 0.95rem;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: #fff;
  color: #475569;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: var(--shadow-sm);
}

.breaking-item {
  display: grid;
  grid-template-columns: 4.8rem minmax(0, 1fr);
  gap: 1rem;
  padding: 1.15rem 0;
  border-bottom: 1px solid #f3f4f6;
}

.breaking-item:last-child {
  border-bottom: 0;
}

.breaking-item__time {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  width: 5rem;
  min-height: 3rem;
  height: 3rem;
  padding: 0;
  border-radius: 999px;
  background: var(--color-primary);
  color: #fff;
  font-size: 0.875rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.03em;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}

.breaking-item__body {
  min-width: 0;
}

.breaking-item__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.85rem;
  margin-bottom: 0.45rem;
  color: var(--color-text-muted);
  font-size: 0.6875rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.breaking-item__category {
  color: var(--color-primary);
}

.breaking-item__title {
  margin: 0 0 0.5rem;
  font-size: 1.2rem;
  font-weight: 900;
  line-height: 1.28;
}

.breaking-item__title a {
  color: var(--color-text);
}

.breaking-item__summary {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.72;
}

.breaking-rail-list {
  display: grid;
  gap: 0.9rem;
}

.breaking-rail-list li {
  padding-bottom: 0.9rem;
  border-bottom: 1px solid #f3f4f6;
}

.breaking-rail-list li:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.breaking-rail-list time {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--color-primary);
  font-size: 0.6875rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.breaking-rail-list a {
  color: var(--color-text);
  font-weight: 700;
  line-height: 1.55;
}

.search-result-card,
.archive-list-card {
  display: block;
  padding: 1rem 0;
  border-bottom: 1px solid #f3f4f6;
}

.search-result-card:last-child,
.archive-list-card:last-child {
  border-bottom: 0;
}

.search-result-card h3,
.archive-list-card h3,
.contact-card h3,
.contact-card h2 {
  margin: 0 0 0.5rem;
}

.search-result-card p,
.archive-list-card p,
.contact-card p {
  margin: 0;
  color: var(--color-text-muted);
}

.archive-day {
  padding: 1.5rem;
  border: 1px solid #f3f4f6;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.archive-day__title {
  margin: 0 0 1rem;
  font-size: 1.125rem;
  font-weight: 900;
}

.contact-card,
.map-card {
  padding: 1.5rem;
  border: 1px solid #f3f4f6;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.contact-list {
  display: grid;
  gap: 0.75rem;
}

.contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  color: #4b5563;
  font-size: 0.9375rem;
  line-height: 1.7;
}

.map-frame {
  width: 100%;
  min-height: 20rem;
  border: 0;
}

.traffic-map-head {
  align-items: flex-start;
}

.traffic-city-picker {
  min-width: 11rem;
}

.traffic-map-shell {
  display: grid;
  gap: 1rem;
}

.traffic-map-frame {
  position: relative;
  overflow: hidden;
  min-height: 31rem;
  border: 1px solid #e5e7eb;
  border-radius: var(--radius-sm);
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.08), transparent 26%),
    linear-gradient(180deg, #f8fafc, #eef2f7);
}

.traffic-map {
  width: 100%;
  min-height: 31rem;
  border: 0;
}

.traffic-map--preview {
  position: relative;
  overflow: hidden;
  display: grid;
  align-items: stretch;
  background:
    radial-gradient(circle at top right, rgba(37, 99, 235, 0.12), transparent 28%),
    linear-gradient(180deg, #f8fbff, #eef4fb);
}

.traffic-preview-svg {
  width: 100%;
  height: 100%;
}

.traffic-preview-sea {
  fill: #eef4fb;
}

.traffic-preview-land {
  fill: #f8fafc;
  stroke: #cbd5e1;
  stroke-width: 2.4;
}

.traffic-preview-grid {
  stroke: rgba(148, 163, 184, 0.2);
  stroke-width: 1;
  stroke-dasharray: 6 8;
}

.traffic-preview-route {
  fill: none;
  stroke: rgba(37, 99, 235, 0.22);
  stroke-width: 3;
  stroke-linecap: round;
}

.traffic-preview-marker {
  transition: transform 0.2s ease;
}

.traffic-preview-marker circle {
  fill: #fff;
  stroke: #cbd5e1;
  stroke-width: 2;
}

.traffic-preview-marker.is-active circle {
  fill: #fff7ed;
  stroke: #ea580c;
  stroke-width: 3;
}

.traffic-preview-marker.is-heavy circle {
  fill: #fef2f2;
  stroke: #dc2626;
}

.traffic-preview-marker.is-medium circle {
  fill: #fffbeb;
  stroke: #d97706;
}

.traffic-preview-marker.is-open circle {
  fill: #f0fdf4;
  stroke: #16a34a;
}

.traffic-preview-marker text {
  fill: #0f172a;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.traffic-preview-badge {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 1rem;
  background: rgba(15, 23, 42, 0.78);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.18);
  backdrop-filter: blur(10px);
}

.traffic-preview-badge strong {
  color: #fff;
  font-size: 0.95rem;
  font-weight: 900;
}

.traffic-preview-badge span {
  color: rgba(226, 232, 240, 0.82);
  font-size: 0.75rem;
  font-weight: 700;
}

.traffic-map-actions {
  display: none;
}

.traffic-map-status {
  flex: 1 1 24rem;
  margin: 0;
  padding: 0.85rem 1rem;
  border: 1px solid #e5e7eb;
  border-radius: var(--radius-sm);
  background: #f9fafb;
  color: #4b5563;
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1.6;
}

.traffic-map-status[data-state="loading"] {
  color: #1d4ed8;
  background: #eff6ff;
  border-color: #bfdbfe;
}

.traffic-map-status[data-state="ready"] {
  color: #166534;
  background: #f0fdf4;
  border-color: #bbf7d0;
}

.traffic-map-status[data-state="warning"] {
  color: #92400e;
  background: #fffbeb;
  border-color: #fde68a;
}

.traffic-map-status[data-state="error"] {
  color: #b91c1c;
  background: #fef2f2;
  border-color: #fecaca;
}

.traffic-map-link {
  min-width: 11rem;
}

.service-hero {
  display: grid;
  gap: 1.25rem;
  padding: 1.5rem;
  border-radius: var(--radius-md);
  color: #fff;
  box-shadow: var(--shadow-md);
}

.service-hero__main {
  display: grid;
  align-content: start;
  gap: 0.95rem;
}

.service-hero--market {
  position: relative;
  overflow: hidden;
  padding: 1.3rem;
  background:
    linear-gradient(135deg, rgba(17, 24, 39, 0.96), rgba(31, 41, 55, 0.92)),
    radial-gradient(circle at top right, rgba(220, 38, 38, 0.25), transparent 38%);
}

.service-hero--market::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: inherit;
  pointer-events: none;
}

.service-hero--market .service-title-row {
  align-items: center;
  margin-bottom: 0.15rem;
}

.service-hero--market .service-title-icon {
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.08);
}

.service-hero--market .service-title {
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.service-hero--market .page-copy {
  max-width: 38rem;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.34;
}

.service-hero--market .service-summary {
  max-width: 40rem;
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.96rem;
  line-height: 1.62;
}

.service-hero--market .service-meta-row {
  gap: 0.7rem;
}

.service-hero--market .service-meta-chip {
  padding: 0.42rem 0.82rem;
  background: rgba(255, 255, 255, 0.06);
}

.service-hero--market .service-stats {
  grid-template-columns: 1fr;
  align-self: start;
  align-content: start;
  gap: 0.55rem;
  width: min(100%, 19.5rem);
  margin-left: auto;
}

.service-hero--market .service-stat {
  align-content: start;
  gap: 0.42rem;
  min-height: 0;
  padding: 0.75rem 0.72rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.07);
}

.service-hero--market .service-card-head {
  align-items: flex-start;
  gap: 0.45rem;
}

.service-hero--market .service-stat__icon {
  width: 1.85rem;
  height: 1.85rem;
}

.service-hero--market .service-stat__label {
  color: rgba(226, 232, 240, 0.72);
  font-size: 0.58rem;
  line-height: 1.28;
  letter-spacing: 0.07em;
}

.service-hero--market .service-stat strong {
  font-size: 0.92rem;
  line-height: 1.18;
  letter-spacing: -0.02em;
  text-wrap: balance;
}

.service-hero--market .service-stat em {
  font-size: 0.8rem;
  line-height: 1.2;
}

.service-hero--market .market-change--up {
  color: #86efac;
}

.service-hero--market .market-change--down {
  color: #fca5a5;
}

.service-hero--weather {
  background:
    linear-gradient(135deg, rgba(14, 116, 144, 0.96), rgba(37, 99, 235, 0.92)),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.22), transparent 35%);
}

.service-hero--breaking {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(127, 29, 29, 0.98), rgba(185, 28, 28, 0.92)),
    radial-gradient(circle at top right, rgba(254, 202, 202, 0.18), transparent 34%);
}

.service-hero--breaking::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: inherit;
  pointer-events: none;
}

.service-hero--breaking .service-title-icon,
.service-hero--breaking .service-stat__icon {
  background: rgba(255, 255, 255, 0.12);
  color: #fff1f2;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.service-hero--breaking .service-meta-chip,
.service-hero--breaking .service-accent-card {
  border-color: rgba(254, 226, 226, 0.18);
  background: rgba(255, 255, 255, 0.08);
}

.service-hero--breaking .page-copy {
  max-width: 36rem;
  color: rgba(255, 255, 255, 0.88);
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.42;
}

.service-hero--breaking .service-summary {
  max-width: 42rem;
}

.service-hero--breaking .service-stats {
  width: min(100%, 19.5rem);
  margin-left: auto;
}

.service-hero--breaking .service-stat strong,
.service-hero--breaking .service-accent-card strong {
  color: #fff;
}

.service-hero--breaking .service-stat em,
.service-hero--breaking .service-accent-card em,
.service-hero--breaking .service-meta-chip {
  color: rgba(255, 241, 242, 0.86);
}

.breaking-page .page-grid {
  align-items: start;
}

.breaking-showcase {
  display: grid;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.breaking-showcase__meta {
  display: grid;
  gap: 1rem;
  padding: 1.25rem;
  border: 1px solid #f1f5f9;
  border-radius: 1.25rem;
  background: linear-gradient(180deg, #ffffff 0%, #fff5f5 100%);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.07);
}

.breaking-showcase__stamp {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

.breaking-showcase__time {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.5rem;
  min-height: 4.5rem;
  padding: 0.5rem;
  border-radius: 1.25rem;
  background: linear-gradient(135deg, #111827, #1f2937);
  color: #fff;
  font-size: 1.4rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  box-shadow: 0 16px 30px rgba(17, 24, 39, 0.16);
}

.breaking-showcase__stamp strong {
  display: block;
  margin-bottom: 0.3rem;
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 900;
}

.breaking-showcase__stamp p,
.breaking-showcase__summary {
  margin: 0;
  color: #64748b;
  line-height: 1.7;
}

.breaking-stream-card {
  padding: 1.6rem;
}

.breaking-item--elevated {
  position: relative;
  padding-right: 0.35rem;
}

.breaking-item__flag {
  display: inline-flex;
  align-items: center;
  min-height: 1.6rem;
  padding: 0 0.55rem;
  border-radius: 999px;
  background: #fee2e2;
  color: #b91c1c;
  font-size: 0.6875rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.breaking.home-sidebar {
  display: grid;
  gap: 1.25rem;
}

.breaking-sidebar-card {
  padding: 1.25rem;
}

.breaking-sidebar-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.breaking-sidebar-stat {
  display: grid;
  gap: 0.35rem;
  padding: 0.95rem;
  border: 1px solid #eef2f7;
  border-radius: 1rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.breaking-sidebar-stat--wide {
  grid-column: 1 / -1;
}

.breaking-sidebar-stat span {
  color: #64748b;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.breaking-sidebar-stat strong {
  color: #111827;
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: -0.02em;
}

.breaking-rail-list--dense {
  gap: 1rem;
}

.breaking-rail-list--dense li {
  padding-bottom: 1rem;
}

.breaking-rail-list--dense time {
  font-size: 0.75rem;
}

.service-hero--standings {
  background:
    linear-gradient(135deg, rgba(20, 83, 45, 0.96), rgba(22, 101, 52, 0.92)),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.18), transparent 35%);
}

.service-hero--standings .page-copy {
  max-width: 34rem;
  font-size: 1rem;
  line-height: 1.58;
}

.service-league-filter {
  margin-left: auto;
}

.service-league-filter select {
  min-width: 12rem;
}

.service-hero--standings .service-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-self: start;
  align-content: start;
  gap: 0.7rem;
  width: min(100%, 19rem);
  margin-left: auto;
}

.service-hero--standings .service-stat {
  gap: 0.4rem;
  min-height: 0;
  padding: 0.85rem 0.8rem;
  background: rgba(255, 255, 255, 0.07);
}

.service-hero--standings .service-card-head {
  align-items: flex-start;
  gap: 0.45rem;
}

.service-hero--standings .service-stat__icon {
  width: 1.85rem;
  height: 1.85rem;
}

.service-hero--standings .service-stat__label {
  color: rgba(226, 232, 240, 0.74);
  font-size: 0.58rem;
  line-height: 1.28;
  letter-spacing: 0.07em;
}

.service-hero--standings .service-stat strong {
  font-size: 0.98rem;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.service-hero--standings .service-stat em {
  font-size: 0.78rem;
  line-height: 1.22;
}

.service-hero--traffic {
  background:
    linear-gradient(135deg, rgba(146, 64, 14, 0.96), rgba(194, 65, 12, 0.9)),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.15), transparent 35%);
}

.service-hero--prayer {
  background:
    linear-gradient(135deg, rgba(6, 78, 59, 0.96), rgba(22, 101, 52, 0.92)),
    radial-gradient(circle at top right, rgba(187, 247, 208, 0.16), transparent 35%);
}

.service-hero .page-copy {
  color: rgba(255, 255, 255, 0.82);
}

.service-hero--prayer .service-title-icon,
.service-hero--prayer .service-meta-chip,
.service-hero--prayer .service-accent-card {
  border-color: rgba(187, 247, 208, 0.22);
  background: rgba(240, 253, 244, 0.08);
}

.service-hero--prayer .service-title-icon,
.service-hero--prayer .service-stat__icon {
  color: #dcfce7;
  background: rgba(22, 163, 74, 0.16);
  box-shadow: inset 0 0 0 1px rgba(187, 247, 208, 0.14);
}

.service-hero--prayer .service-meta-chip,
.service-hero--prayer .service-accent-card span,
.service-hero--prayer .service-accent-card em {
  color: rgba(220, 252, 231, 0.86);
}

.service-hero--prayer .service-accent-card strong {
  color: #ffffff;
}

.service-kicker {
  margin: 0 0 0.75rem;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-title-row {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 0.85rem;
}

.service-title-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  flex: 0 0 auto;
}

.service-title-icon .icon {
  font-size: 1.2rem;
}

.service-title-row .page-title {
  margin: 0;
}

.service-title {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.55rem 0.75rem;
  color: #fff;
}

.service-city-filter {
  position: relative;
  display: inline-flex;
  align-items: center;
  max-width: 100%;
}

.service-city-filter::after {
  content: "";
  position: absolute;
  right: 0.95rem;
  top: 50%;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 2px solid rgba(255, 255, 255, 0.88);
  border-bottom: 2px solid rgba(255, 255, 255, 0.88);
  transform: translateY(-65%) rotate(45deg);
  pointer-events: none;
}

.service-city-filter select {
  appearance: none;
  min-height: 2.75rem;
  max-width: 100%;
  padding: 0.55rem 2.45rem 0.55rem 0.95rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  cursor: pointer;
}

.service-city-filter select:focus {
  outline: none;
}

.service-city-filter select option {
  color: #111827;
}

.service-summary {
  margin: 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 1rem;
  line-height: 1.75;
}

.service-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  margin-top: 1rem;
}

.service-meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 2rem;
  padding: 0.35rem 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.8125rem;
  font-weight: 700;
}

.service-meta-chip .icon {
  font-size: 0.95rem;
  flex: 0 0 auto;
}

.service-inline-note {
  color: var(--color-text-muted);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.service-stats {
  display: grid;
  gap: 0.85rem;
}

.service-card-head {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.service-stat__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  flex: 0 0 auto;
}

.service-stat__label,
.service-accent-card__label {
  margin: 0;
}

.service-stat,
.service-accent-card {
  display: grid;
  gap: 0.35rem;
  padding: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.08);
}

.service-stat span,
.service-accent-card span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.service-stat strong,
.service-accent-card strong {
  font-size: 1.4rem;
  font-weight: 900;
  letter-spacing: -0.03em;
}

.service-stat em,
.service-accent-card em {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.8125rem;
  font-style: normal;
  font-weight: 700;
}

.service-table-card .service-stat,
.service-table-card .service-accent-card {
  border-color: #e5e7eb;
  background: #f9fafb;
}

.service-table-card .service-stat__icon {
  background: #fff;
  color: var(--color-primary);
  box-shadow: inset 0 0 0 1px #fee2e2;
}

.service-table-card .service-stat span,
.service-table-card .service-accent-card span {
  color: #6b7280;
}

.service-table-card .service-stat strong,
.service-table-card .service-accent-card strong {
  color: #111827;
}

.service-table-card .service-stat em,
.service-table-card .service-accent-card em {
  color: #4b5563;
}

.service-current {
  display: grid;
  gap: 1rem;
  padding: 1.25rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.12);
}

.service-current__temp {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.06em;
}

.service-current__summary {
  margin: 0 0 0.65rem;
  color: #fff;
  font-size: 1rem;
  font-weight: 800;
}

.service-current__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.8125rem;
  font-weight: 700;
}

.service-current__meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 2rem;
  padding: 0.35rem 0.65rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
}

.service-current__meta .icon {
  font-size: 0.95rem;
  flex: 0 0 auto;
}

.weather-selection {
  position: relative;
  z-index: 5;
  margin-top: -1.5rem;
}

.weather-selection__panel {
  display: grid;
  gap: 1rem;
  padding: 1.1rem;
  border: 1px solid #dbeafe;
  border-radius: 1.25rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  box-shadow: 0 20px 45px rgba(15, 23, 42, 0.08);
}

.weather-selection__copy {
  display: grid;
  gap: 0.45rem;
}

.weather-selection__eyebrow {
  color: #2563eb;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.weather-selection__title {
  margin: 0;
  color: #0f172a;
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.weather-selection__text {
  margin: 0;
  color: #64748b;
  font-size: 0.95rem;
  line-height: 1.7;
}

.weather-selection__field {
  display: grid;
  gap: 0.55rem;
  align-content: start;
}

.weather-selection__label {
  color: #0f172a;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.weather-selection__select {
  position: relative;
}

.weather-selection__select::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1rem;
  width: 0.55rem;
  height: 0.55rem;
  border-right: 2px solid #64748b;
  border-bottom: 2px solid #64748b;
  transform: translateY(-70%) rotate(45deg);
  pointer-events: none;
}

.weather-selection__input {
  appearance: none;
  width: 100%;
  min-height: 3.25rem;
  padding: 0.8rem 2.7rem 0.8rem 1rem;
  border: 1px solid #d9e5f4;
  border-radius: 1rem;
  background: #ffffff;
  color: #0f172a;
  font-size: 0.95rem;
  font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
  cursor: pointer;
}

.weather-selection__input:focus {
  outline: none;
  border-color: #93c5fd;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.14);
}

.weather-selection__input option {
  color: #111827;
}

.weather-premium {
  margin-top: 3rem;
}

.weather-forecast-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 1rem;
}

.weather-forecast-grid .forecast-card {
  gap: 0.85rem;
  padding: 1.05rem;
  border-color: #dbeafe;
  background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
  box-shadow: var(--shadow-sm);
}

.weather-forecast-grid .forecast-card__head {
  display: grid;
  gap: 0.18rem;
}

.weather-forecast-grid .forecast-card__day {
  color: #0f172a;
  font-size: 0.95rem;
  font-weight: 900;
}

.weather-forecast-grid .forecast-card__date {
  color: #64748b;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.weather-forecast-grid .forecast-card__icon {
  width: 4.25rem;
  height: 4.25rem;
  padding: 0.4rem;
  border: 0;
  border-radius: 1rem;
  background: #eff6ff;
}

.weather-forecast-grid .forecast-card__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.weather-forecast-grid .forecast-card__temps {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
}

.weather-forecast-grid .forecast-card__max {
  color: #0f172a;
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: -0.04em;
}

.weather-forecast-grid .forecast-card__min {
  color: #64748b;
  font-size: 0.95rem;
  font-weight: 800;
}

.weather-forecast-grid .forecast-card__desc {
  margin: 0;
  color: #475569;
  font-size: 0.95rem;
  line-height: 1.6;
}

.weather-empty-state {
  padding: 1.1rem 1.2rem;
  border: 1px dashed #cbd5e1;
  border-radius: 1rem;
  background: #f8fafc;
  color: #64748b;
  font-size: 0.95rem;
}

.weather-cities {
  margin-top: 3rem;
  padding-top: 1.75rem;
  border-top: 1px dashed #d9e2ec;
}

.weather-cities__header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.8rem 1rem;
  margin-bottom: 1rem;
}

.weather-cities__title {
  margin: 0;
}

.weather-cities__note {
  margin: 0;
  color: #64748b;
  font-size: 0.9rem;
  line-height: 1.6;
}

.popular-cities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10.5rem, 1fr));
  gap: 0.8rem;
}

.popular-city-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-height: 3.2rem;
  padding: 0.9rem 1rem;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  color: #0f172a;
  box-shadow: var(--shadow-sm);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.popular-city-card:hover,
.popular-city-card:focus-visible {
  transform: translateY(-2px);
  border-color: #93c5fd;
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.08);
}

.popular-city-card__name {
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.35;
}

.popular-city-card__action {
  color: #2563eb;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@media (min-width: 900px) {
  .weather-selection__panel {
    grid-template-columns: minmax(0, 1.2fr) minmax(18rem, 22rem);
    align-items: end;
  }
}

@media (max-width: 767px) {
  .weather-selection {
    margin-top: 1rem;
  }

  .weather-selection__panel {
    padding: 1rem;
  }

  .weather-selection__title {
    font-size: 1.1rem;
  }

  .weather-cities__header {
    flex-direction: column;
    align-items: flex-start;
  }

  .weather-forecast-grid .forecast-card__temps {
    flex-wrap: wrap;
  }
}

@media (max-width: 539px) {

  .weather-forecast-grid,
  .popular-cities-grid {
    grid-template-columns: 1fr;
  }

  .weather-forecast-grid .forecast-card__icon {
    width: 3.75rem;
    height: 3.75rem;
  }
}

.service-table-card {
  padding: 1.5rem;
  border: 1px solid var(--color-border, #f3f4f6);
  background: var(--color-surface, #fff);
  box-shadow: var(--shadow-sm);
  border-radius: var(--radius-base);
}

.service-utility-bar {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}

.service-share-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border: 1px solid #f3f4f6;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.service-share-copy {
  margin: 0.3rem 0 0;
  color: var(--color-text-muted);
  font-size: 0.875rem;
  line-height: 1.65;
}

.service-share-buttons {
  margin-left: auto;
}

.service-jump-grid {
  display: grid;
  gap: 0.85rem;
}

.service-jump-card {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 1rem 1.1rem;
  border: 1px solid #f3f4f6;
  border-radius: var(--radius-sm);
  background: #fff;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}

.service-jump-card:hover,
.service-jump-card:focus-visible {
  border-color: rgba(220, 38, 38, 0.24);
  background: #fff7f7;
  transform: translateY(-1px);
}

.service-jump-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 999px;
  background: #111827;
  color: #fff;
  flex: 0 0 auto;
}

.service-jump-card__content {
  display: grid;
  gap: 0.2rem;
  flex: 1 1 auto;
}

.service-jump-card__label {
  color: var(--color-text-muted, #9ca3af);
  font-size: 0.625rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.service-jump-card__title {
  color: #111827;
  font-size: 0.9375rem;
  font-weight: 800;
  line-height: 1.45;
}

.service-jump-card__arrow {
  color: var(--color-primary);
  flex: 0 0 auto;
}

.service-jump-card--prev .service-jump-card__arrow,
.service-jump-card--next .service-jump-card__arrow {
  color: #111827;
}

.service-section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}

.service-section-title .icon {
  color: var(--color-primary);
}

.service-table-wrap {
  width: 100%;
  overflow-x: auto;
}

.service-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 40rem;
}

.service-table th,
.service-table td {
  padding: 0.9rem 0.85rem;
  border-bottom: 1px solid #f3f4f6;
  font-size: 0.875rem;
  text-align: left;
}

.service-table th {
  color: #6b7280;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.service-table tbody tr:last-child td {
  border-bottom: 0;
}

.market-change--up {
  color: #16a34a;
  font-weight: 800;
}

.market-change--down {
  color: #dc2626;
  font-weight: 800;
}

.market-change--neutral {
  color: #94a3b8;
  font-weight: 800;
}

.service-note-list,
.service-alert-list,
.route-list {
  display: grid;
  gap: 0.9rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.service-note-list li,
.service-alert-list li {
  position: relative;
  padding-left: 1.1rem;
  color: #4b5563;
  font-size: 0.9375rem;
  line-height: 1.75;
}

.service-note-list li::before,
.service-alert-list li::before {
  content: "";
  position: absolute;
  top: 0.7rem;
  left: 0;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--color-primary);
}

.forecast-grid {
  display: grid;
  gap: 0.85rem;
}

.forecast-card {
  display: grid;
  gap: 0.35rem;
  padding: 1rem;
  border: 1px solid #e0f2fe;
  border-radius: var(--radius-sm);
  background: #f8fbff;
}

.forecast-card__top {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.forecast-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: #dbeafe;
  color: #2563eb;
  flex: 0 0 auto;
}

.forecast-card__day {
  color: #0f172a;
  font-size: 0.875rem;
  font-weight: 800;
}

.forecast-card strong {
  color: #111827;
  font-size: 1.5rem;
  font-weight: 900;
}

.forecast-card span {
  color: #2563eb;
  font-size: 0.875rem;
  font-weight: 800;
}

.forecast-card p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.875rem;
  line-height: 1.6;
}

.route-item {
  display: grid;
  gap: 0.6rem;
  padding: 1rem;
  border: 1px solid #fde68a;
  border-radius: var(--radius-sm);
  background: #fffaf0;
}

.route-item__top,
.route-item__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
}

.route-item__top strong {
  font-size: 1rem;
  font-weight: 800;
}

.route-item__headline {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
}

.route-item__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: #fff;
  color: #c2410c;
  box-shadow: inset 0 0 0 1px #fed7aa;
  flex: 0 0 auto;
}

.route-item__meta {
  color: #92400e;
  font-size: 0.8125rem;
  font-weight: 800;
}

.route-item__meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.route-item p {
  margin: 0;
  color: #4b5563;
  font-size: 0.875rem;
  line-height: 1.7;
}

.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.8rem;
  padding: 0 0.75rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.status-badge--open {
  background: #dcfce7;
  color: #166534;
}

.status-badge--medium {
  background: #fef3c7;
  color: #92400e;
}

.status-badge--heavy {
  background: #fee2e2;
  color: #b91c1c;
}

.service-form {
  color: #2563eb;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.service-links {
  display: grid;
  gap: 0.75rem;
}

.service-link-card {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 0.95rem 1rem;
  border: 1px solid #f3f4f6;
  border-radius: var(--radius-sm);
  background: #fff;
  transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}

.service-link-card:hover,
.service-link-card:focus-visible,
.service-link-card.is-current {
  border-color: rgba(220, 38, 38, 0.24);
  background: #fef2f2;
  transform: translateY(-1px);
}

.service-link-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 999px;
  background: #111827;
  color: #fff;
  flex: 0 0 auto;
}

.service-link-card__body {
  display: grid;
  gap: 0.2rem;
  flex: 1 1 auto;
}

.service-link-card__arrow {
  margin-left: auto;
  color: var(--color-text-muted, #9ca3af);
  flex: 0 0 auto;
}

.service-link-card__body strong {
  color: #111827;
  font-size: 0.95rem;
  font-weight: 800;
}

.service-link-card__body span {
  color: var(--color-text-muted);
  font-size: 0.8125rem;
  line-height: 1.55;
}

.prayer-time__label {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
}

.prayer-time__label .icon {
  color: var(--color-primary);
  font-size: 0.85rem;
  flex: 0 0 auto;
}

[data-theme-mode="dark"] .home-utility-card,
[data-theme-mode="dark"] .home-section-shell,
[data-theme-mode="dark"] .home-topic-split>div,
[data-theme-mode="dark"] .widget,
[data-theme-mode="dark"] .poll-card,
[data-theme-mode="dark"] .comment-card,
[data-theme-mode="dark"] .comment-box,
[data-theme-mode="dark"] .author-profile,
[data-theme-mode="dark"] .author-bio-card,
[data-theme-mode="dark"] .light-panel,
[data-theme-mode="dark"] .newspapers-strip,
[data-theme-mode="dark"] .tag-list a,
[data-theme-mode="dark"] .pagination a,
[data-theme-mode="dark"] .pagination button,
[data-theme-mode="dark"] .service-link-card,
[data-theme-mode="dark"] .service-jump-card,
[data-theme-mode="dark"] .service-table-card,
[data-theme-mode="dark"] .service-stat,
[data-theme-mode="dark"] .forecast-card,
[data-theme-mode="dark"] .route-item,
[data-theme-mode="dark"] .archive-card,
[data-theme-mode="dark"] .search-result-card {
  background: var(--color-surface, #111827);
  border-color: var(--color-border, #243041);
  color: var(--color-text, #e2e8f0);
  box-shadow: none;
}

[data-theme-mode="dark"] .service-table th {
  background: color-mix(in srgb, var(--color-surface) 94%, #fff);
  border-color: var(--color-border);
  color: var(--color-text);
}

[data-theme-mode="dark"] .service-table td {
  border-color: var(--color-border);
  color: var(--color-text-muted);
}

[data-theme-mode="dark"] .service-table tr:hover td {
  background: color-mix(in srgb, var(--color-surface) 96%, #fff);
}

[data-theme-mode="dark"] .home-section-shell--soft,
[data-theme-mode="dark"] .light-panel,
[data-theme-mode="dark"] .newspapers-strip,
[data-theme-mode="dark"] .comment-box,
[data-theme-mode="dark"] .route-item,
[data-theme-mode="dark"] .forecast-card,
[data-theme-mode="dark"] .breaking-chip,
[data-theme-mode="dark"] .traffic-map-frame,
[data-theme-mode="dark"] .traffic-map-status {
  background: #0f172a;
}

[data-theme-mode="dark"] .traffic-map--preview {
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.16), transparent 28%),
    linear-gradient(180deg, #0f172a, #111827);
}

[data-theme-mode="dark"] .traffic-preview-sea {
  fill: #111827;
}

[data-theme-mode="dark"] .traffic-preview-land {
  fill: #172033;
  stroke: #334155;
}

[data-theme-mode="dark"] .traffic-preview-grid {
  stroke: rgba(71, 85, 105, 0.28);
}

[data-theme-mode="dark"] .traffic-preview-marker text {
  fill: #e2e8f0;
}

[data-theme-mode="dark"] .section-title,
[data-theme-mode="dark"] .page-title,
[data-theme-mode="dark"] .widget-title,
[data-theme-mode="dark"] .news-list-card__title,
[data-theme-mode="dark"] .media-item__title,
[data-theme-mode="dark"] .home-utility-card__value,
[data-theme-mode="dark"] .popular-list a,
[data-theme-mode="dark"] .author-list h4,
[data-theme-mode="dark"] .ranking-table td,
[data-theme-mode="dark"] .ranking-table th,
[data-theme-mode="dark"] .comment-head strong,
[data-theme-mode="dark"] .article-title,
[data-theme-mode="dark"] .article-body,
[data-theme-mode="dark"] .article-lead,
[data-theme-mode="dark"] .service-link-card__body strong,
[data-theme-mode="dark"] .forecast-card__day,
[data-theme-mode="dark"] .forecast-card strong,
[data-theme-mode="dark"] .route-item__top strong {
  color: var(--color-text, #f8fafc);
}

[data-theme-mode="dark"] .category-showcase__tab {
  border-color: var(--color-border, #243041);
  background: var(--color-surface-soft, #111827);
  color: var(--color-text-muted, #cbd5e1);
}

[data-theme-mode="dark"] .category-showcase__tab:hover,
[data-theme-mode="dark"] .category-showcase__tab:focus-visible {
  color: var(--color-text, #fff);
}

[data-theme-mode="dark"] .category-showcase__tab.is-active {
  background: var(--color-primary);
  border-color: var(--color-primary);
}

[data-theme-mode="dark"] .category-showcase__card-title {
  color: var(--color-text, #f8fafc);
}

[data-theme-mode="dark"] .page-copy,
[data-theme-mode="dark"] .news-card__summary,
[data-theme-mode="dark"] .home-utility-card__meta,
[data-theme-mode="dark"] .author-showcase__role,
[data-theme-mode="dark"] .author-list p,
[data-theme-mode="dark"] .author-showcase__bio,
[data-theme-mode="dark"] .popular-index,
[data-theme-mode="dark"] .comment-box p,
[data-theme-mode="dark"] .comment-card p,
[data-theme-mode="dark"] .article-quote,
[data-theme-mode="dark"] .article-meta,
[data-theme-mode="dark"] .author-mini__role,
[data-theme-mode="dark"] .brand-text,
[data-theme-mode="dark"] .newspaper-card p,
[data-theme-mode="dark"] .breaking-chip,
[data-theme-mode="dark"] .breaking-item__summary,
[data-theme-mode="dark"] .breaking-item__meta,
[data-theme-mode="dark"] .service-link-card__body span,
[data-theme-mode="dark"] .forecast-card p,
[data-theme-mode="dark"] .route-item__meta,
[data-theme-mode="dark"] .filter-tools,
[data-theme-mode="dark"] .breadcrumb,
[data-theme-mode="dark"] .article-insights__label,
[data-theme-mode="dark"] .author-mini__avatar,
[data-theme-mode="dark"] .traffic-map-status {
  color: var(--color-text-muted, #94a3b8);
}

[data-theme-mode="dark"] .weather-selection__panel,
[data-theme-mode="dark"] .weather-empty-state,
[data-theme-mode="dark"] .popular-city-card {
  background: #111827;
  border-color: #243041;
  box-shadow: none;
}

[data-theme-mode="dark"] .weather-selection__title,
[data-theme-mode="dark"] .weather-selection__label,
[data-theme-mode="dark"] .weather-cities__title,
[data-theme-mode="dark"] .weather-forecast-grid .forecast-card__max,
[data-theme-mode="dark"] .headline-archive__filter input[type="date"],
[data-theme-mode="dark"] .headline-archive__chip,
[data-theme-mode="dark"] .popular-city-card__name,
[data-theme-mode="dark"] .editor-page__summary-chip,
[data-theme-mode="dark"] .breaking-page__summary-chip {
  color: #f8fafc;
}

[data-theme-mode="dark"] .weather-selection__eyebrow,
[data-theme-mode="dark"] .weather-selection__text,
[data-theme-mode="dark"] .weather-cities__note,
[data-theme-mode="dark"] .weather-forecast-grid .forecast-card__date,
[data-theme-mode="dark"] .weather-forecast-grid .forecast-card__min,
[data-theme-mode="dark"] .weather-forecast-grid .forecast-card__desc,
[data-theme-mode="dark"] .popular-city-card__action {
  color: #94a3b8;
}

[data-theme-mode="dark"] .weather-selection__input {
  background: #0f172a;
  border-color: #334155;
  color: #f8fafc;
  box-shadow: none;
}

[data-theme-mode="dark"] .weather-selection__input option {
  color: #f8fafc;
  background: #0f172a;
}

[data-theme-mode="dark"] .weather-selection__select::after {
  border-right-color: #cbd5e1;
  border-bottom-color: #cbd5e1;
}

[data-theme-mode="dark"] .weather-forecast-grid .forecast-card__icon {
  background: rgba(59, 130, 246, 0.14);
}

[data-theme-mode="dark"] .popular-city-card:hover,
[data-theme-mode="dark"] .popular-city-card:focus-visible {
  border-color: #3b82f6;
}

[data-theme-mode="dark"] .news-list-card,
[data-theme-mode="dark"] .headline-archive-card,
[data-theme-mode="dark"] .headline-archive__chip,
[data-theme-mode="dark"] .headline-archive__filter input[type="date"],
[data-theme-mode="dark"] .popular-list li,
[data-theme-mode="dark"] .author-meta-pill,
[data-theme-mode="dark"] .breaking-item,
[data-theme-mode="dark"] .breaking-page__summary-chip,
[data-theme-mode="dark"] .breaking-rail-list li,
[data-theme-mode="dark"] .market-list li,
[data-theme-mode="dark"] .ranking-table th,
[data-theme-mode="dark"] .ranking-table td,
[data-theme-mode="dark"] .article-meta-bar,
[data-theme-mode="dark"] .section-heading,
[data-theme-mode="dark"] .page-heading,
[data-theme-mode="dark"] .footer-meta,
[data-theme-mode="dark"] .drawer-head,
[data-theme-mode="dark"] .service-link-card,
[data-theme-mode="dark"] .traffic-map-frame,
[data-theme-mode="dark"] .traffic-map-status {
  border-color: var(--color-border, #243041);
}

[data-theme-mode="dark"] .breaking-rail-list a,
[data-theme-mode="dark"] .headline-archive-card__title a,
[data-theme-mode="dark"] .breaking-item__title a,
[data-theme-mode="dark"] .author-richtext a {
  color: #f8fafc;
}

[data-theme-mode="dark"] .headline-archive__panel,
[data-theme-mode="dark"] .editor-page__summary-chip,
[data-theme-mode="dark"] .breaking-page__summary-chip {
  background: var(--color-secondary);
  border-color: #243041;
}

[data-theme-mode="dark"] .headline-archive__panel,
[data-theme-mode="dark"] .headline-archive-card,
[data-theme-mode="dark"] .headline-archive__chip,
[data-theme-mode="dark"] .headline-archive__filter input[type="date"] {
  background: var(--color-secondary);
  border-color: #243041;
}

[data-theme-mode="dark"] .headline-archive__filter label,
[data-theme-mode="dark"] .headline-archive-card__meta,
[data-theme-mode="dark"] .headline-archive__chip {
  color: #94a3b8;
}

[data-theme-mode="dark"] .headline-archive-card__meta span {
  color: #f87171;
}

[data-theme-mode="dark"] .author-meta-pill {
  background: #0f172a;
  border-color: #243041;
  color: #cbd5e1;
}

[data-theme-mode="dark"] .author-richtext,
[data-theme-mode="dark"] .author-richtext blockquote {
  color: #cbd5e1;
}

[data-theme-mode="dark"] .breaking-showcase__meta,
[data-theme-mode="dark"] .breaking-sidebar-stat {
  background: var(--color-secondary);
  border-color: #243041;
}

[data-theme-mode="dark"] .breaking-showcase__stamp strong,
[data-theme-mode="dark"] .breaking-sidebar-stat strong {
  color: #f8fafc;
}

[data-theme-mode="dark"] .breaking-showcase__stamp p,
[data-theme-mode="dark"] .breaking-showcase__summary,
[data-theme-mode="dark"] .breaking-sidebar-stat span {
  color: #94a3b8;
}

[data-theme-mode="dark"] .breaking-item__flag {
  background: rgba(220, 38, 38, 0.18);
  color: #fecaca;
}

[data-theme-mode="dark"] .prayer-grid li,
[data-theme-mode="dark"] .poll-options label,
[data-theme-mode="dark"] .tag-list a,
[data-theme-mode="dark"] .article-quote,
[data-theme-mode="dark"] .weather-stats,
[data-theme-mode="dark"] .service-link-card:hover,
[data-theme-mode="dark"] .service-link-card:focus-visible,
[data-theme-mode="dark"] .service-link-card.is-current {
  background: var(--color-surface-soft, var(--color-surface, #0f172a));
  border-color: var(--color-border, #243041);
}

[data-theme-mode="dark"] .prayer-grid strong {
  color: var(--color-primary);
}

[data-theme-mode="dark"] .article-insights__value,
[data-theme-mode="dark"] .article-insights__source {
  color: #f8fafc;
}

[data-theme-mode="dark"] .article-insights__icon {
  background: rgba(248, 113, 113, 0.12);
  color: #f87171;
}

[data-theme-mode="dark"] .comment-form__field input,
[data-theme-mode="dark"] .comment-form__field textarea {
  background: #111827;
  border-color: #243041;
  color: #f8fafc;
}

[data-theme-mode="dark"] .comment-form__field input::placeholder,
[data-theme-mode="dark"] .comment-form__field textarea::placeholder,
[data-theme-mode="dark"] .comment-form__icon,
[data-theme-mode="dark"] .comment-box__title span,
[data-theme-mode="dark"] .detail-stream__copy,
[data-theme-mode="dark"] .detail-stream__status,
[data-theme-mode="dark"] .detail-stream-article__spot,
[data-theme-mode="dark"] .detail-stream-article__meta {
  color: #94a3b8;
}

[data-theme-mode="dark"] .detail-stream-article {
  border-color: #243041;
}

[data-theme-mode="dark"] .detail-stream-article__title,
[data-theme-mode="dark"] .detail-stream-article__link {
  color: #f8fafc;
}

[data-theme-mode="dark"] .detail-stream-article__link {
  background: #111827;
}

[data-theme-mode="dark"] .detail-stream-article__link:hover,
[data-theme-mode="dark"] .detail-stream-article__link:focus-visible {
  background: #f87171;
}

[data-theme-mode="dark"] .detail-stream-article__media {
  background: #111827;
}

[data-theme-mode="dark"] .detail-stream-article--skeleton .detail-stream-article__media,
[data-theme-mode="dark"] .detail-stream-skeleton__line {
  background: linear-gradient(90deg, #172132 0%, #243041 50%, #172132 100%);
  background-size: 200% 100%;
}

[data-theme-mode="dark"] .reading-progress {
  background: rgba(148, 163, 184, 0.16);
}

[data-theme-mode="dark"] .back-to-top {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-surface-soft, #1f2937) 92%, transparent),
    color-mix(in srgb, var(--color-surface, #111827) 96%, transparent)
  );
  color: var(--color-text, #f8fafc);
  border-color: color-mix(in srgb, var(--color-border, #243041) 88%, transparent);
}

[data-theme-mode="dark"] .author-showcase {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--color-primary) 22%, transparent), transparent 34%),
    linear-gradient(180deg, var(--color-surface, #111827), color-mix(in srgb, var(--color-surface, #111827) 88%, #000000));
  border-color: var(--color-border, #243041);
  box-shadow: none;
}

[data-theme-mode="dark"] .author-showcase__arrow,
[data-theme-mode="dark"] .author-showcase__card,
[data-theme-mode="dark"] .author-showcase__meta span {
  background: var(--color-surface-soft, #0f172a);
  border-color: var(--color-border, #243041);
  box-shadow: none;
  color: var(--color-text, #e2e8f0);
}

[data-theme-mode="dark"] .author-showcase__arrow:hover,
[data-theme-mode="dark"] .author-showcase__arrow:focus-visible {
  background: var(--author-accent, var(--color-primary));
  color: #f8fafc;
}

[data-theme-mode="dark"] .author-showcase__card:hover,
[data-theme-mode="dark"] .author-showcase__card:focus-within {
  border-color: color-mix(in srgb, var(--author-accent, var(--color-primary)) 28%, var(--color-border, #334155));
}

[data-theme-mode="dark"] .author-showcase__avatar img {
  border-color: var(--color-surface-soft, #0f172a);
}

[data-theme-mode="dark"] .author-showcase__chip {
  background: color-mix(in srgb, var(--author-accent, var(--color-primary)) 18%, transparent);
  box-shadow: inset 0 0 0 1px var(--color-border, #243041);
}

[data-theme-mode="dark"] .author-showcase__name {
  color: var(--color-text, #f8fafc);
}

[data-theme-mode="dark"] .newspapers-strip {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--color-primary) 24%, transparent), transparent 28%),
    linear-gradient(180deg, var(--color-surface, #111827), color-mix(in srgb, var(--color-surface, #111827) 88%, #000000));
}

[data-theme-mode="dark"] .newspapers-strip__link,
[data-theme-mode="dark"] .newspaper-card {
  background: var(--color-surface, #111827);
  border-color: var(--color-border, #243041);
  box-shadow: none;
}

[data-theme-mode="dark"] .newspapers-strip__arrow {
  background: color-mix(in srgb, var(--color-text, #e2e8f0) 92%, var(--color-surface, #0f172a));
  color: var(--color-surface, #0f172a);
  box-shadow: none;
}

[data-theme-mode="dark"] .newspapers-strip__arrow:hover,
[data-theme-mode="dark"] .newspapers-strip__arrow:focus-visible {
  background: var(--color-primary);
  color: #fff;
}

[data-theme-mode="dark"] .newspaper-card__thumb {
  border-color: var(--color-border, #243041);
  box-shadow: none;
}

[data-theme-mode="dark"] .newspaper-card p,
[data-theme-mode="dark"] .newspapers-strip__link {
  color: var(--color-text, #f8fafc);
}

[data-theme-mode="dark"] .newspaper-card__kicker {
  color: color-mix(in srgb, var(--color-primary) 56%, #ffffff);
}

[data-theme-mode="dark"] .author-showcase__meta span {
  background: var(--color-surface-muted, #172033);
  color: var(--color-text, #cbd5e1);
}

[data-theme-mode="dark"] .author-showcase__dots button {
  background: var(--color-border, #334155);
}

[data-theme-mode="dark"] .author-showcase__dots button.is-active {
  background: var(--author-accent, var(--color-primary));
}

[data-theme-mode="dark"] .author-showcase__latest {
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-surface, #020617) 78%, #000000), color-mix(in srgb, var(--color-surface-soft, #0f172a) 88%, #000000));
}

[data-theme-mode="dark"] .author-showcase__profile {
  background: linear-gradient(135deg, var(--author-accent, var(--color-primary)), color-mix(in srgb, var(--color-surface-soft, #1e293b) 92%, #000000));
  color: #fff;
  box-shadow: none;
}

[data-theme-mode="dark"] .author-showcase__link {
  background: var(--color-surface-muted, #172033);
  color: var(--color-text, #e2e8f0);
  box-shadow: none;
}

[data-theme-mode="dark"] .widget-select select,
[data-theme-mode="dark"] .service-select,
[data-theme-mode="dark"] .standings-widget__select {
  border-color: var(--color-border, #243041);
  background: var(--color-surface, #0f172a);
  color: var(--color-text, #e2e8f0);
}

[data-theme-mode="dark"] .widget--weather .widget-select select {
  border-color: color-mix(in srgb, var(--widget-theme-text, #fff) 18%, transparent);
  background: color-mix(in srgb, var(--widget-theme-text, #fff) 12%, transparent);
}

[data-theme-mode="dark"] .widget-select select option,
[data-theme-mode="dark"] .service-select option,
[data-theme-mode="dark"] .standings-widget__select option {
  color: var(--color-text, #e2e8f0);
  background: var(--color-surface, #0f172a);
}

[data-theme-mode="dark"] .widget--weather,
[data-theme-mode="dark"] .newsletter-box {
  background: var(--widget-theme-bg, var(--color-surface));
  --newsletter-text: var(--color-text);
  border: 1px solid var(--color-border);
  box-shadow: none;
}

[data-theme-mode="dark"] .weather-widget__skeleton-line {
  background: linear-gradient(90deg, rgba(148, 163, 184, 0.14) 0%, rgba(226, 232, 240, 0.28) 50%, rgba(148, 163, 184, 0.14) 100%);
  background-size: 200% 100%;
}

[data-theme-mode="dark"] .weather-widget__skeleton-stats {
  border-top-color: rgba(148, 163, 184, 0.18);
}

[data-theme-mode="dark"] .newsletter-box p {
  color: var(--color-text-muted);
}

[data-theme-mode="dark"] .newsletter-box input {
  background: var(--color-bg);
  border-color: var(--color-border);
  color: var(--color-text);
}

[data-theme-mode="dark"] .newsletter-box__button {
  background: var(--color-primary);
  color: #fff;
}

[data-theme-mode="dark"] .share-button--copy,
[data-theme-mode="dark"] .button-secondary,
[data-theme-mode="dark"] .service-link-card__icon {
  background: #0f172a;
  color: #e2e8f0;
}

[data-theme-mode="dark"] .footer {
  background: var(--footer-bg);
  color: var(--footer-text);
}

[data-theme-mode="dark"] .footer-meta {
  border-color: var(--footer-border);
}

.hidden-cards {
  display: none;
}

.show-more.is-expanded .hidden-cards {
  display: contents;
}

@media (min-width: 640px) {
  .home-utility-grid {
    grid-auto-flow: row;
    grid-auto-columns: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: visible;
    padding-bottom: 0;
  }

  .featured-grid,
  .dual-section-grid,
  .video-grid,
  .gallery-grid,
  .author-cards,
  .contact-grid,
  .related-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-stats,
  .forecast-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-jump-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-meta {
    flex-direction: row;
  }

  .news-list-card__thumb {
    width: 6rem;
    height: 4rem;
  }
}

@media (min-width: 768px) {
  .comment-form__row {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
    align-items: center;
  }

  .comment-form__submit {
    min-height: 3.25rem;
  }

  .home-utility-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .video-grid,
  .gallery-grid,
  .related-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dual-section-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .featured-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .home-section-shell,
  .home-topic-split>div {
    padding: 1.5rem;
  }

  .category-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-grid__lead {
    grid-column: 1 / -1;
  }

  .category-showcase__grid {
    grid-template-columns: minmax(0, 1.8fr) minmax(0, 1fr);
    align-items: start;
  }

  .category-showcase__side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-hero {
    grid-template-columns: minmax(0, 1.35fr) minmax(16rem, 0.95fr);
    align-items: start;
  }

  .service-hero--market {
    grid-template-columns: minmax(0, 1.72fr) minmax(17.5rem, 0.84fr);
  }

  .service-hero--breaking {
    grid-template-columns: minmax(0, 1.65fr) minmax(17.5rem, 0.9fr);
  }

  .service-hero--market .service-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .breaking-showcase {
    grid-template-columns: minmax(0, 1.6fr) minmax(17rem, 0.9fr);
    align-items: stretch;
  }

  .service-stats,
  .forecast-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .service-utility-bar {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    align-items: start;
  }

  .service-jump-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .news-card__media--small {
    height: 11.25rem;
  }

  .news-card__title--large {
    font-size: 1.85rem;
  }

  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2rem;
  }
}

@media (min-width: 1200px) {
  .footer-grid {
    grid-template-columns: 1.2fr 1fr 1fr 1fr;
    gap: 3rem;
  }
}

@media (max-width: 767px) {
  .back-to-top {
    width: 2.85rem;
    height: 2.85rem;
  }
}

@media (max-width: 767px) {
  .page-main {
    padding-top: 1rem;
  }

  .page-grid>*,
  .article-layout>* {
    min-width: 0;
  }

  .page-section {
    margin-top: 1.5rem;
  }

  .page-heading,
  .section-heading,
  .section-heading--compact {
    align-items: flex-start;
    flex-direction: column;
  }

  .page-heading {
    margin-bottom: 1.5rem;
    padding-bottom: 0.9rem;
  }

  .breaking-page__summary {
    justify-content: flex-start;
  }

  .section-heading {
    margin-bottom: 1.15rem;
  }

  .page-title {
    font-size: clamp(1.65rem, 8vw, 2.2rem);
    line-height: 1.06;
  }

  .section-title {
    font-size: 1.2rem;
  }

  .page-copy {
    font-size: 0.9rem;
    line-height: 1.68;
  }

  .filter-bar {
    gap: 0.75rem;
  }

  .filter-tools {
    width: 100%;
    align-items: stretch;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.65rem;
    padding: 0.8rem 0.9rem;
    border: 1px solid #f3f4f6;
    border-radius: var(--radius-sm);
    background: #f9fafb;
  }

  .filter-tools label {
    width: 100%;
  }

  .filter-tools select {
    width: 100%;
    min-height: 2.75rem;
    padding: 0 0.9rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: #fff;
    color: var(--color-text);
  }

  .pagination {
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 0.4rem;
    margin-top: 2rem;
    scrollbar-width: none;
  }

  .pagination::-webkit-scrollbar {
    display: none;
  }

  .pagination button,
  .pagination a {
    flex: 0 0 2.35rem;
    width: 2.35rem;
    height: 2.35rem;
  }

  .article-layout {
    gap: 1.75rem;
  }

  .article-header {
    margin-bottom: 1.5rem;
  }

  .article-title {
    margin: 0.85rem 0 1rem;
    font-size: clamp(1.95rem, 8.6vw, 2.65rem);
    line-height: 1.06;
  }

  .article-meta-bar {
    align-items: flex-start;
    gap: 0.95rem;
    padding: 0.85rem 0;
    margin-bottom: 1.5rem;
  }

  .article-meta {
    gap: 0.45rem 0.8rem;
    font-size: 0.625rem;
  }

  .share-buttons {
    width: 100%;
    justify-content: flex-start;
  }

  .article-cover {
    margin-bottom: 1.5rem;
  }

  .article-body {
    font-size: 1rem;
    line-height: 1.78;
  }

  .article-lead {
    margin-bottom: 1.5rem;
    padding-left: 1rem;
    font-size: 1.05rem;
    line-height: 1.66;
  }

  .article-body p,
  .article-body ul {
    margin-bottom: 1.25rem;
  }

  .article-quote {
    margin: 1.75rem 0;
    padding: 1.25rem;
    font-size: 1.05rem;
    line-height: 1.64;
  }

  .widget,
  .comment-box,
  .archive-day,
  .contact-card,
  .map-card,
  .service-table-card {
    padding: 1.1rem;
  }

  .comment-card {
    padding: 1rem;
  }

  .author-profile {
    gap: 1.1rem;
    padding: 1.15rem;
  }

  .author-profile__top {
    align-items: flex-start;
  }

  .editor-page__summary {
    justify-content: flex-start;
  }

  .headline-archive__heading {
    align-items: flex-start;
  }

  .headline-archive__filter {
    width: 100%;
  }

  .headline-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .author-profile__hero {
    grid-template-columns: 1fr;
  }

  .author-profile__name {
    font-size: 1.45rem;
  }

  .author-meta-grid {
    gap: 0.6rem;
    font-size: 0.8125rem;
  }

  .search-form,
  .archive-filter,
  .contact-form {
    gap: 0.85rem;
  }

  .search-form button,
  .archive-filter button,
  .contact-form button {
    width: 100%;
  }

  .contact-grid {
    gap: 1rem;
  }

  .traffic-city-picker {
    width: 100%;
    min-width: 0;
  }

  .traffic-map-frame,
  .traffic-map {
    min-height: 23rem;
  }

  .traffic-preview-badge {
    left: 0.75rem;
    right: 0.75rem;
    bottom: 0.75rem;
    padding: 0.75rem 0.85rem;
  }

  .traffic-map-link {
    width: 100%;
  }

  .contact-list li {
    font-size: 0.875rem;
    line-height: 1.6;
  }

  .news-list-card {
    gap: 0.75rem;
  }

  .news-list-card__thumb {
    width: 5.5rem;
    height: 4rem;
  }

  .news-list-card__title {
    font-size: 0.875rem;
    line-height: 1.32;
  }

  .widget-title__actions {
    width: 100%;
    margin-left: 0;
    justify-content: flex-start;
  }

  .author-showcase {
    padding: 0.95rem;
  }

  .author-showcase__card {
    min-height: 16.25rem;
    padding: 0.95rem;
  }

  .author-showcase__footer {
    flex-wrap: wrap;
  }

  .author-showcase__title {
    font-size: 0.95rem;
  }

  .author-showcase__avatar {
    width: 3.5rem;
    height: 3.5rem;
  }

  .author-showcase__bio {
    -webkit-line-clamp: 2;
  }

  .author-showcase__latest strong {
    font-size: 0.76rem;
  }

  .author-showcase__link {
    width: 100%;
  }

  .widget-select {
    width: 100%;
  }

  .widget-select select {
    width: 100%;
    min-height: 2.3rem;
    padding-right: 2rem;
    font-size: 0.7rem;
  }

  .service-hero {
    gap: 1rem;
    padding: 1.15rem;
  }

  .service-hero--market {
    padding: 1.05rem;
  }

  .service-hero--breaking .service-stats {
    width: 100%;
    margin-left: 0;
  }

  .service-kicker {
    margin-bottom: 0.55rem;
    font-size: 0.6875rem;
  }

  .service-title-row {
    gap: 0.85rem;
    margin-bottom: 0.55rem;
  }

  .service-league-filter {
    width: 100%;
    margin-left: 0;
  }

  .service-league-filter select {
    width: 100%;
    min-width: 0;
  }

  .service-title-icon,
  .service-hero--market .service-title-icon {
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 0.85rem;
  }

  .service-title.page-title {
    font-size: clamp(1.75rem, 8vw, 2.3rem);
    line-height: 1.04;
  }

  .service-hero--market .page-copy {
    font-size: 0.98rem;
    line-height: 1.4;
  }

  .service-summary {
    font-size: 0.95rem;
    line-height: 1.62;
  }

  .service-meta-row {
    margin-top: 0.8rem;
    gap: 0.5rem;
  }

  .service-meta-chip {
    min-height: 1.9rem;
    padding: 0.3rem 0.65rem;
    font-size: 0.75rem;
  }

  .service-meta-chip .icon {
    font-size: 0.85rem;
  }

  .service-stats {
    gap: 0.65rem;
  }

  .service-hero--market .service-stats,
  .service-hero--standings .service-stats {
    width: 100%;
    margin-left: 0;
  }

  .service-stat,
  .service-accent-card {
    padding: 0.9rem;
  }

  .service-stat strong,
  .service-accent-card strong {
    font-size: 1.12rem;
  }

  .service-current {
    padding: 1rem;
  }

  .service-current__temp {
    font-size: 2.45rem;
  }

  .service-current__summary {
    font-size: 0.95rem;
  }

  .service-current__meta {
    gap: 0.5rem;
    font-size: 0.75rem;
  }

  .service-table-wrap {
    margin-inline: -1.1rem;
    padding: 0 1.1rem 0.15rem;
    scrollbar-width: thin;
  }

  .breaking-item {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }

  .breaking-item__time {
    width: 5rem;
  }

  .breaking-showcase__stamp {
    align-items: flex-start;
  }

  .breaking-showcase__time {
    min-width: 4rem;
    min-height: 4rem;
    font-size: 1.2rem;
  }

  .service-table {
    min-width: 34rem;
  }

  .service-table th,
  .service-table td {
    padding: 0.78rem 0.7rem;
    font-size: 0.8125rem;
  }

  .forecast-card,
  .route-item {
    padding: 0.9rem;
  }

  .route-item__top,
  .route-item__meta {
    justify-content: flex-start;
  }

  .route-item__headline {
    width: 100%;
  }

  .prayer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .newspapers-strip {
    margin-top: 2.5rem;
    padding: 2.25rem 0;
  }

  .newspapers-strip__head {
    align-items: flex-start;
    flex-direction: column;
  }

  .newspapers-strip__actions {
    width: 100%;
    justify-content: flex-start;
  }

  .newspaper-row {
    gap: 0.85rem;
    margin-inline: -1rem;
    padding: 0 1rem 0.8rem;
  }

  .newspaper-card {
    flex-basis: 8.9rem;
    padding: 0.7rem;
  }

  .store-badges {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
  }
}

@media (max-width: 539px) {
  .service-title-row {
    gap: 0.85rem;
  }

  .service-title {
    width: 100%;
  }

  .service-city-filter {
    width: 100%;
  }

  .service-city-filter select {
    width: 100%;
  }

  .author-profile__top {
    flex-direction: column;
  }

  .author-profile--feature .author-profile__image {
    width: 5.5rem;
    height: 5.5rem;
  }

  .headline-archive__filter-row {
    flex-direction: column;
    align-items: stretch;
  }

  .headline-archive-grid {
    grid-template-columns: 1fr;
  }

  .article-meta-bar {
    gap: 0.85rem;
  }

  .article-meta {
    width: 100%;
  }

  .weather-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .weather-widget__skeleton-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-current__meta span {
    width: 100%;
    justify-content: center;
  }

  .prayer-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 1024px) {
  .home-utility-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .main-grid,
  .page-grid,
  .article-layout {
    grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
  }

  .sidebar {}

  .home-sidebar {
    gap: 1.35rem;
  }

  .results-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* External Link Confirmation Modal */
.ext-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(8px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.ext-modal-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

.ext-modal-card {
  background: #fff;
  width: 90%;
  max-width: 450px;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
  transform: translateY(20px);
  transition: transform 0.3s ease;
}

.ext-modal-overlay.is-visible .ext-modal-card {
  transform: translateY(0);
}

.ext-modal-header {
  padding: 2rem 2rem 1rem;
  text-align: center;
}

.ext-modal-icon {
  width: 64px;
  height: 64px;
  background: #fff7ed;
  color: #f97316;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
}

.ext-modal-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: #111827;
  margin-bottom: 0.75rem;
}

.ext-modal-body {
  padding: 0 2rem 2rem;
  text-align: center;
}

.ext-modal-text {
  color: #4b5563;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  font-size: 1rem;
}

.ext-modal-url {
  background: #f3f4f6;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  font-size: 0.85rem;
  color: #6b7280;
  word-break: break-all;
  margin-bottom: 2rem;
  border: 1px solid #e5e7eb;
}

.ext-modal-footer {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  padding: 0 2rem 2rem;
}

.ext-modal-btn {
  padding: 0.875rem;
  border-radius: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  border: none;
  font-size: 0.95rem;
}

.ext-modal-btn--confirm {
  background: #111827;
  color: #fff;
}

.ext-modal-btn--confirm:hover {
  background: #000;
}

.ext-modal-btn--cancel {
  background: #f3f4f6;
  color: #4b5563;
}

.ext-modal-btn--cancel:hover {
  background: #e5e7eb;
}

/* Dark Mode support */
[data-theme='dark'] .ext-modal-card {
  background: #1f2937;
}

[data-theme='dark'] .ext-modal-title {
  color: #f9fafb;
}

[data-theme='dark'] .ext-modal-text {
  color: var(--color-text-muted, #9ca3af);
}

[data-theme='dark'] .ext-modal-url {
  background: #111827;
  border-color: #374151;
  color: var(--color-text-muted, #9ca3af);
}

/* --- Detail Page Components (BTF) --- */

.audio-reader-tools {
  display: flex;
  align-items: center;
}

.audio-reader-tools .tool-button {
  background: none;
  border: none;
  cursor: pointer;
  color: #4b5563;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.audio-reader-tools .tool-button--stop {
  display: none;
  color: var(--color-primary);
}

.audio-reader-tools .tool-button span {
  font-weight: 600;
  font-size: 14px;
}

.font-resizer {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: #f3f4f6;
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
}

.font-resizer .font-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 14px;
  padding: 0.25rem;
  font-weight: bold;
}

.font-resizer span {
  font-size: 14px;
  font-weight: 600;
  min-width: 20px;
  text-align: center;
}

.article-sources {
  padding: 1.5rem;
  background: var(--color-surface, #f9fafb);
  border: 1px solid var(--color-border, transparent);
  border-radius: 8px;
  margin: 2rem 0;
}

.article-sources__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-muted, #6b7280);
  text-transform: uppercase;
  margin-bottom: 1rem;
}

.article-sources__grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  align-items: center;
}

.source-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.source-item img {
  height: 24px;
  width: auto;
  padding: 0 4px !important;
}

.source-item span {
  font-weight: 600;
  font-size: 14px;
}

.google-news-banner {
  margin: 2rem 0;
}

.google-news-banner a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 1rem;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.2s;
}

.google-news-banner a:hover {
  border-color: var(--color-primary);
}

.google-news-banner span {
  color: #111827;
  font-weight: 600;
}

/* ==========================================================================
   Article Comments Section
   ========================================================================== */
.article-comments {
  margin-top: 3.5rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--color-border);
}

.comments-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
}

.comment-form-box {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 12px);
  padding: 2.5rem;
  margin-bottom: 3.5rem;
  box-shadow: var(--shadow-sm);
}

.comment-form__title {
  font-size: 1.35rem;
  font-weight: 800;
  margin-bottom: 1.5rem;
  color: var(--color-text);
  letter-spacing: -0.01em;
}

.comment-form__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  margin-bottom: 1.25rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-group label {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.form-control {
  width: 100%;
  padding: 0.875rem 1rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  font-size: 0.95rem;
  color: var(--color-text);
  transition: all 0.2s ease;
}

.form-control:focus {
  outline: none;
  background: #fff;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 12%, transparent);
}

textarea.form-control {
  min-height: 140px;
  resize: vertical;
}

.comment-form__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  background: var(--color-primary);
  color: #fff;
  border: none;
  padding: 0.9rem 2.5rem;
  font-size: 0.95rem;
  font-weight: 800;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.comment-form__submit:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px color-mix(in srgb, var(--color-primary) 25%, transparent);
}

.comment-form__submit:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.comment-feedback {
  margin-bottom: 1.5rem;
  padding: 1rem 1.25rem;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  display: none;
  animation: slideInDown 0.3s ease-out;
}

.comment-feedback--success {
  background: #f0fdf4;
  color: #166534;
  border: 1px solid #bbf7d0;
  display: block;
}

.comment-feedback--error {
  background: #fef2f2;
  color: #991b1b;
  border: 1px solid #fecaca;
  display: block;
}

@keyframes slideInDown {
  from {
    transform: translateY(-10px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* Comment List */
.comment-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.comment-card {
  display: flex;
  gap: 1.25rem;
  padding: 1.5rem;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 12px);
  transition: border-color 0.2s ease;
}

.comment-card:hover {
  border-color: color-mix(in srgb, var(--color-primary) 30%, var(--color-border));
}

.comment-card__avatar {
  flex: 0 0 3rem;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-primary) 10%, #f1f5f9);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  font-weight: 800;
}

.comment-card__content {
  flex: 1;
}

.comment-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.comment-card__user {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.comment-card__name {
  font-weight: 800;
  color: var(--color-text);
  font-size: 0.95rem;
}

.comment-card__badge {
  font-size: 0.65rem;
  font-weight: 800;
  background: #f1f5f9;
  color: #64748b;
  padding: 0.15rem 0.45rem;
  border-radius: 4px;
  text-transform: uppercase;
}

.comment-card__date {
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.comment-card__text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--color-text);
  margin: 0;
}

@media (max-width: 640px) {
  .comment-form-box {
    padding: 1.5rem;
  }

  .comment-form__grid {
    grid-template-columns: 1fr;
  }

  .comment-card {
    padding: 1.25rem;
    gap: 1rem;
  }

  .comment-card__avatar {
    flex: 0 0 2.5rem;
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
  }
}

/* ==========================================================================
   Article Comments Section (Premium)
   ========================================================================== */
.article-comments {
  margin-top: 3.5rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--color-border);
}

.comments-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
}

.comment-form-box {
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  padding: 2.5rem;
  margin-bottom: 3.5rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
}

.comment-form__title {
  font-size: 1.4rem;
  font-weight: 800;
  margin-bottom: 1.5rem;
  color: var(--color-text, #111827);
  letter-spacing: -0.01em;
}

.comment-form__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  margin-bottom: 1.25rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-group label {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--color-text-muted, #6b7280);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.form-control {
  width: 100%;
  padding: 0.875rem 1rem;
  background: var(--color-bg-alt, #f8fafc);
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 8px;
  font-size: 0.95rem;
  color: var(--color-text, #111827);
  transition: all 0.2s ease;
}

.form-control:focus {
  outline: none;
  background: var(--color-surface, #fff);
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 12%, transparent);
}

textarea.form-control {
  min-height: 120px;
  resize: vertical;
}

.comment-form__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  background: var(--color-primary);
  color: #fff;
  border: none;
  padding: 0.9rem 2.5rem;
  font-size: 0.95rem;
  font-weight: 800;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.comment-form__submit:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px color-mix(in srgb, var(--color-primary) 25%, transparent);
}

.comment-form__submit:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

/* Feedback Styling */
.comment-feedback {
  margin-bottom: 1.5rem;
  padding: 1rem 1.25rem;
  border-radius: 10px;
  font-size: 0.925rem;
  font-weight: 600;
  display: none;
  animation: feedbackSlideIn 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.comment-feedback--success {
  background: color-mix(in srgb, #ecfdf5 80%, black);
  color: #10b981;
  border: 1px solid #10b981;
  display: block;
}

.night-mode .comment-feedback--success {
  background: #064e3b;
  color: #34d399;
  border-color: #065f46;
}

.comment-feedback--error {
  background: #fef2f2;
  color: #ef4444;
  border: 1px solid #ef4444;
  display: block;
}

.night-mode .comment-feedback--error {
  background: #450a0a;
  color: #f87171;
  border-color: #7f1d1d;
}

@keyframes feedbackSlideIn {
  from {
    transform: translateY(-10px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* Comment Cards */
.comment-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.comment-card {
  display: flex;
  gap: 1.25rem;
  padding: 1.75rem;
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border, #f1f5f9);
  border-radius: 16px;
  transition: all 0.2s ease;
}

.comment-card:hover {
  border-color: var(--color-primary);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.02);
}

.comment-card__avatar {
  flex: 0 0 3.25rem;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-primary) 10%, #f1f5f9);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  font-weight: 800;
}

.comment-card__content {
  flex: 1;
}

.comment-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.comment-card__user {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.comment-card__name {
  font-weight: 800;
  color: var(--color-text, #111827);
  font-size: 1rem;
}

.comment-card__date {
  font-size: 0.8rem;
  color: var(--color-text-muted, #64748b);
}

.comment-card__text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-text, #374151);
  margin: 0;
}

@media (max-width: 640px) {
  .comment-form-box {
    padding: 1.5rem;
  }

  .comment-form__grid {
    grid-template-columns: 1fr;
  }

  .comment-card {
    padding: 1.25rem;
    flex-direction: column;
    gap: 1rem;
  }

  .comment-card__avatar {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
  }
}

.tag-list--article {
  margin-top: 2rem;
}

.tag-list--article .section-title {
  font-size: 1.1rem;
  color: #6b7280;
  margin: 0 0 1rem;
  font-weight: 700;
}

.pagination--hidden {
  display: none;
}

/* Video Embed Styles */
.article-video {
  position: relative;
  margin-bottom: 1.25rem;
  overflow: hidden;
  border-radius: 8px;
  background: #000;
}

.embed-wrap {
  position: relative;
  width: 100%;
}

.embed-16x9 {
  padding-top: 56.25%;
}

.embed-slot {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.embed-slot iframe,
.embed-slot object,
.embed-slot embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* ==========================================================================
   Widget: Kategori Haberleri 2 (kategorihaberleri2.twig)
   ========================================================================== */
.kategori-grid-v2-container {
  margin-bottom: 1.25rem;
}

.kategori-grid-v2-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
}

.kategori-grid-v2-title {
  display: flex;
  color: var(--color-text);
  align-items: center;
  margin: 0;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--widget-theme-accent, var(--color-primary));
}

.kategori-grid-v2-title::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 1.5rem;
  background-color: var(--widget-theme-accent, var(--color-primary));
  margin-right: 0.75rem;
  border-radius: 4px;
}

.kategori-grid-v2-link {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--widget-theme-accent, var(--color-primary));
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  text-decoration: none;
}

.kategori-grid-v2-link svg {
  width: 1.1em;
  height: 1.1em;
}

.kategori-grid-v2 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.kg-card {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: var(--color-surface);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  border: 1px solid var(--color-border);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.kg-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.kg-card__badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  background: var(--widget-theme-accent, var(--color-primary));
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
  padding: 0.35rem 0.65rem;
  border-radius: 6px;
  z-index: 10;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.kg-card--tall {
  grid-row: span 2;
  height: 100%;
}

.kg-card--tall .kg-card__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.kg-card--tall .kg-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kg-card--tall .kg-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.5) 40%, rgba(0, 0, 0, 0) 70%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.75rem;
  z-index: 5;
}

.kg-card--tall .kg-title {
  color: #fff;
  font-size: 1.35rem;
  font-weight: 800;
  margin: 0 0 0.5rem;
  line-height: 1.25;
}

.kg-card--tall .kg-meta {
  color: #d1d5db;
}

.kg-card--small .kg-card__media {
  position: relative;
  width: 100%;
  padding-top: 60%;
  /* 5:3 Aspect ratio */
}

.kg-card--small .kg-card__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kg-card--small .kg-card__body {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.kg-card--small .kg-title {
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 800;
  margin: 0 0 0.85rem;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.kg-card--small .kg-meta {
  margin-top: auto;
  color: var(--color-text-muted, #9ca3af);
}

.kg-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.8rem;
  font-weight: 600;
}

.kg-meta svg {
  width: 1em;
  height: 1em;
  color: var(--widget-theme-accent, var(--color-primary));
}

@media (max-width: 991px) {
  .kategori-grid-v2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .kategori-grid-v2 {
    grid-template-columns: 1fr;
  }

  .kg-card--tall {
    grid-row: auto;
    min-height: 350px;
  }
}



.manset2 {
  width: 100%;
  margin: 1.25rem 0;
}

.manset2__inner {
  display: grid;
  grid-template-columns: 2.2fr 1fr;
  gap: 18px;
  align-items: stretch;
}

.manset2__main {
  position: relative;
  background: #fff;
  border: 1px solid #e5e5e5;
  border-radius: var(--radius-md, 12px);
  overflow: hidden;
}

.manset2__slides {
  position: relative;
  width: 100%;
  aspect-ratio: 780 / 400;
}

.manset2__slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  transition: opacity .45s ease, visibility .45s ease;
  z-index: 1;
}

.manset2__slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
}

.manset2__slide-link {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: #fff;
}

.manset2__image-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 780 / 400;
  overflow: hidden;
  background: #ddd;
}

.manset2__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.manset2__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--color-primary, #d20000) 0%, color-mix(in srgb, var(--color-primary, #d20000) 58%, transparent) 28%, rgba(0, 0, 0, 0.08) 60%, rgba(0, 0, 0, 0.05) 100%);
  pointer-events: none;
}

.manset2__caption {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 26px;
  z-index: 3;
}

.manset2__title {
  margin: 0;
  font-size: 36px;
  line-height: 1.05;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -.4px;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

.manset2__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9);
  color: var(--color-primary, #a10000);
  cursor: pointer;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.18);
  transition: all .25s ease;
}

.manset2__arrow:hover {
  background: #fff;
  transform: translateY(-50%) scale(1.06);
}

.manset2__arrow span {
  font-size: 28px;
  line-height: 1;
  font-weight: 700;
}

.manset2__arrow--prev {
  left: 14px;
}

.manset2__arrow--next {
  right: 14px;
}

.manset2__dots {
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 6;
}

.manset2__dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  border: 0;
  background: rgba(255, 255, 255, 0.65);
  cursor: pointer;
  transition: all .25s ease;
  padding: 0;
}

.manset2__dot.is-active,
.manset2__dot:hover {
  background: var(--color-primary, #c70000);
  transform: scale(1.08);
}

.manset2__side {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.manset2__card {
  background: #fff;
  border: 1px solid #e4e4e4;
  border-radius: var(--radius-md, 12px);
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
  transition: transform .2s ease, box-shadow .2s ease;
}

.manset2__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
}

.manset2__card-link {
  display: flex;
  gap: 10px;
  padding: 10px;
  text-decoration: none;
  color: inherit;
  align-items: flex-start;
}

.manset2__card-image-wrap {
  flex: 0 0 92px;
  width: 92px;
  height: 64px;
  border-radius: var(--radius-sm, 8px);
  overflow: hidden;
  background: #eee;
}

.manset2__card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.manset2__card-body {
  flex: 1;
  min-width: 0;
}

.manset2__card-title {
  margin: 0 0 8px;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 700;
  color: #222;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.manset2__meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: #7a7a7a;
}

.manset2__meta-icon {
  font-size: 8px;
  color: var(--color-primary, #b30000);
}

@media (max-width: 991px) {
  .manset2__inner {
    grid-template-columns: 1fr;
  }

  .manset2__title {
    font-size: 28px;
  }

  .manset2__side {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }
}

@media (max-width: 767px) {
  .manset2 {
    margin: 15px 0 25px;
  }

  .manset2__inner {
    gap: 12px;
  }

  .manset2__main {
    border-radius: 10px;
    overflow: hidden;
  }

  .manset2__slides {
    position: relative;
    min-height: 240px;
    height: 240px;
  }

  .manset2__slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }

  .manset2__image-wrap {
    aspect-ratio: 780 / 400;
    height: auto;
  }

  .manset2__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .manset2__caption {
    left: 14px;
    right: 14px;
    bottom: 18px;
  }

  .manset2__title {
    font-size: 16px;
    line-height: 1.2;
    font-weight: 700;
    text-transform: none;
  }

  .manset2__arrow {
    width: 34px;
    height: 34px;
  }

  .manset2__arrow span {
    font-size: 22px;
  }

  .manset2__arrow--prev {
    left: 10px;
  }

  .manset2__arrow--next {
    right: 10px;
  }

  .manset2__dots {
    bottom: 10px;
    gap: 6px;
  }

  .manset2__dot {
    width: 9px;
    height: 9px;
  }

  .manset2__side {
    margin-top: 0;
    gap: 8px;
  }

  .manset2__card-link {
    padding: 8px;
    gap: 8px;
  }

  .manset2__card-image-wrap {
    flex: 0 0 78px;
    width: 78px;
    height: 56px;
  }

  .manset2__card-title {
    font-size: 13px;
    line-height: 1.3;
    -webkit-line-clamp: 2;
  }

  .manset2__meta {
    font-size: 10px;
  }
}

.manset3 {
  width: 100%;
  margin: 1.25rem 0;
}

.manset3__inner {
  width: 100%;
}

.manset3__slider {
  position: relative;
  width: 100%;
  background: #fff;
  border-radius: var(--radius-md, 12px);
  overflow: hidden;
}

.manset3__slides {
  position: relative;
  width: 100%;
  aspect-ratio: 780 / 400;
}

.manset3__slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  transition: opacity .45s ease, visibility .45s ease;
  z-index: 1;
}

.manset3__slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
}

.manset3__link {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: #fff;
}

.manset3__media {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: #ddd;
}

.manset3__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.manset3__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--color-primary, #d20000) 0%, color-mix(in srgb, var(--color-primary, #d20000) 58%, transparent) 28%, rgba(0, 0, 0, 0.08) 60%, rgba(0, 0, 0, 0.05) 100%);
  pointer-events: none;
}

.manset3__caption {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 58px;
  z-index: 3;
}

.manset3__title {
  margin: 0;
  font-size: 38px;
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}

.manset3__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-primary, #8f0000);
  cursor: pointer;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.18);
  transition: all .25s ease;
}

.manset3__arrow:hover {
  background: #fff;
  transform: translateY(-50%) scale(1.06);
}

.manset3__arrow span {
  font-size: 28px;
  line-height: 1;
  font-weight: 700;
}

.manset3__arrow--prev {
  left: 16px;
}

.manset3__arrow--next {
  right: 16px;
}

.manset3__pager {
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  z-index: 6;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
}

.manset3__dot {
  width: 24px;
  height: 24px;
  border: 1px solid #d8d8d8;
  border-radius: 50%;
  background: #fff;
  color: #666;
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
  transition: all .25s ease;
  padding: 0;
}

.manset3__dot.is-active,
.manset3__dot:hover {
  background: var(--color-primary, #980000);
  border-color: var(--color-primary, #980000);
  color: #fff;
}

@media (max-width: 991px) {
  .manset3__slides {
    height: 400px;
  }

  .manset3__title {
    font-size: 28px;
  }
}

@media (max-width: 767px) {
  .manset3 {
    margin: 15px 0 25px;
  }

  .manset3__slider {
    border-radius: 14px;
  }

  .manset3__slides {
    aspect-ratio: 780 / 400;
    height: auto;
  }

  .manset3__caption {
    left: 16px;
    right: 16px;
    bottom: 62px;
  }

  .manset3__title {
    font-size: 17px;
    line-height: 1.2;
    font-weight: 800;
  }

  .manset3__arrow {
    width: 38px;
    height: 38px;
  }

  .manset3__arrow span {
    font-size: 24px;
  }

  .manset3__arrow--prev {
    left: 12px;
  }

  .manset3__arrow--next {
    right: 12px;
  }

  .manset3__pager {
    bottom: 12px;
    gap: 6px;
    padding: 7px 10px;
  }

  .manset3__dot {
    width: 22px;
    height: 22px;
    font-size: 11px;
  }
}

@media (max-width: 480px) {
  .manset3__slides {
    aspect-ratio: 780 / 400;
    height: auto;
  }

  .manset3__caption {
    bottom: 54px;
  }

  .manset3__title {
    font-size: 15px;
    line-height: 1.2;
  }

  .manset3__pager {
    padding: 6px 8px;
  }

  .manset3__dot {
    width: 20px;
    height: 20px;
    font-size: 10px;
  }
}

/* --- Cookie Banner Styles --- */
.cookie-banner {
  position: fixed;
  bottom: 24px;
  left: 24px;
  right: 24px;
  max-width: 640px;
  padding: 1.5rem;
  background: color-mix(in srgb, var(--color-surface) 88%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base, 12px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
  z-index: 2000;
  transform: translateY(120%);
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  display: none;
}

.cookie-banner--visible {
  display: block;
  transform: translateY(0);
}

.cookie-banner__content {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.25rem;
}

.cookie-banner__top {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
}

.cookie-banner__icon {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary);
  color: #fff;
  border-radius: 12px;
}

.cookie-banner__icon .icon {
  width: 1.25rem;
  height: 1.25rem;
}

.cookie-banner__text {
  flex: 1;
  min-width: 0;
}

.cookie-banner__text p {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--color-text);
  font-weight: 500;
}

.cookie-banner__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  border-top: 1px solid var(--color-border);
  padding-top: 1.25rem;
}

.cookie-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1rem;
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.2s ease;
  border: none;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.cookie-btn--primary {
  background: var(--color-primary);
  color: #fff;
  box-shadow: 0 4px 12px color-mix(in srgb, var(--color-primary) 30%, transparent);
}

.cookie-btn--primary:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
}

@media (max-width: 640px) {
  .cookie-banner {
    left: 12px;
    right: 12px;
    bottom: 12px;
    padding: 1rem;
    max-width: none;
  }
  .cookie-banner__content {
    gap: 0.75rem;
  }
  .cookie-btn {
    padding: 0.4rem 0.75rem;
  }
}

/* --- Comprehensive Cookie System Styles --- */
.cookie-btn--outline {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.cookie-btn--outline:hover {
  background: var(--color-surface-soft);
  border-color: var(--color-primary);
}

/* Modal Styles */
.cookie-modal {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.cookie-modal--visible {
  display: flex !important;
  opacity: 1;
}

.cookie-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}

.cookie-modal__container {
  position: relative;
  width: 100%;
  max-width: 560px;
  background: var(--color-surface);
  border-radius: var(--radius-base, 16px);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.25);
  overflow: hidden;
  transform: scale(0.9);
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.cookie-modal--visible .cookie-modal__container {
  transform: scale(1);
}

.cookie-modal__header {
  padding: 1.5rem;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cookie-modal__header h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 800;
}

.cookie-modal__close {
  background: transparent;
  border: none;
  font-size: 1.75rem;
  line-height: 1;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0.5rem;
}

.cookie-modal__body {
  padding: 1.5rem;
  max-height: 60vh;
  overflow-y: auto;
}

.cookie-option {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--color-border);
}

.cookie-option:last-child {
  border-bottom: none;
}

.cookie-option__info {
  flex: 1;
}

.cookie-option__info h4 {
  margin: 0 0 0.35rem;
  font-size: 1rem;
  font-weight: 700;
}

.cookie-option__info p {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  line-height: 1.4;
}

.cookie-modal__footer {
  padding: 1.5rem;
  background: var(--color-surface-soft);
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 1rem;
}

/* Toggle Switch Styles */
.cookie-switch {
  position: relative;
  display: inline-block;
  width: 48px;
  height: 24px;
}

.cookie-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.cookie-switch__slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background-color: #cbd5e1;
  transition: .3s;
  border-radius: 24px;
}

.cookie-switch__slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: .3s;
  border-radius: 50%;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.cookie-switch input:checked + .cookie-switch__slider {
  background-color: var(--color-primary);
}

.cookie-switch input:checked + .cookie-switch__slider:before {
  transform: translateX(24px);
}

.cookie-switch input:disabled + .cookie-switch__slider {
  opacity: 0.5;
  cursor: not-allowed;
}

@media (max-width: 640px) {
  .cookie-modal__footer {
    flex-direction: column-reverse;
  }
  .cookie-modal__footer .cookie-btn {
    width: 100%;
  }
}

/* Responsive hardening */
:where(.main-grid, .page-grid, .article-layout, .footer-grid, .featured-grid, .dual-section-grid, .video-grid, .gallery-grid, .related-grid, .contact-grid) > * {
  min-width: 0;
}

@media (max-width: 1023px) {
  .main-grid,
  .page-grid,
  .article-layout {
    grid-template-columns: minmax(0, 1fr);
    gap: clamp(1.5rem, 3vw, 2.25rem);
  }

  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2rem;
  }
}

@media (max-width: 639px) {
  .footer-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 1.5rem;
  }
}
