/* ===== Authors strip (YS style — cream cards) ===== */
.op-ys {
  background: oklch(96.5% 0.012 80);
  padding: 40px 0;
  margin-top: 32px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: clip;
  position: relative;
  isolation: isolate;
}
.op-ys-row {
  min-width: 0;
}
.op-ys-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 22px;
}
.op-ys-title {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 28px;
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--ink);
  position: relative;
  padding-bottom: 6px;
}
.op-ys-title::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 36px; height: 3px;
  background: var(--accent); border-radius: 2px;
}
.op-ys-title-link {
  color: inherit;
  text-decoration: none;
}
.op-ys-title-link:hover {
  color: var(--accent-ink);
}
.op-ys-arrows { display: flex; gap: 8px; }
.op-ys-arr {
  width: 40px; height: 40px;
  background: #fff;
  border: 1px solid oklch(86% 0.012 80);
  border-radius: 8px;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .15s, border-color .15s;
}
.op-ys-arr:hover:not(:disabled) { background: var(--ink); color: #fff; border-color: var(--ink); }
.op-ys-arr:disabled { opacity: 0.4; cursor: default; }

.op-ys-track-wrap {
  overflow: hidden;
  min-width: 0;
  isolation: isolate;
}
.op-ys-track {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  padding-bottom: 4px;
  --op-ys-cols: 4;
}
.op-ys-track::-webkit-scrollbar { display: none; }
.op-ys-card {
  flex: 0 0 calc((100% - (var(--op-ys-cols, 4) - 1) * 12px) / var(--op-ys-cols, 4));
  min-width: 0;
  max-width: 100%;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  background: oklch(95% 0.015 80);
  border-radius: 10px;
  padding: 0 22px 16px;
  display: flex;
  flex-direction: column;
  height: auto;
  position: relative;
  overflow: hidden;
  color: var(--ink);
  transition: transform .2s, box-shadow .2s;
  isolation: isolate;
}
.op-ys-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px -16px rgba(15,20,35,0.18);
  color: var(--ink);
}

.op-ys-top {
  position: relative;
  height: 170px;
  margin: 0 -22px 16px;
  flex-shrink: 0;
  overflow: hidden;
}
.op-ys-num {
  position: absolute;
  left: 0;
  top: 0;
  max-height: 100%;
  overflow: hidden;
  font-family: var(--font-archivo), var(--font-sans);
  font-weight: 900;
  font-size: min(200px, 42vw);
  line-height: 0.85;
  color: oklch(90% 0.018 80);
  letter-spacing: -0.05em;
  z-index: 0;
  pointer-events: none;
}
.op-ys-author {
  position: absolute;
  left: 22px; bottom: 16px;
  z-index: 2;
  display: flex; flex-direction: column;
}
.op-ys-name {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 17px;
  color: var(--accent);
  letter-spacing: -0.015em;
  line-height: 1;
}
.op-ys-surname {
  font-family: var(--font-sans);
  font-weight: 900;
  font-size: 30px;
  color: var(--accent);
  letter-spacing: -0.028em;
  line-height: 1;
  margin-top: 4px;
}
.op-ys-photo {
  position: absolute;
  right: 0;
  top: 0;
  width: min(56%, 220px);
  height: 100%;
  z-index: 1;
  overflow: hidden;
}
.op-ys-photo-img {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  max-width: 100%;
  max-height: 100%;
  border-radius: 0 10px 0 0;
  aspect-ratio: auto !important;
}
.op-ys-photo-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.op-ys-content {
  flex: 0 0 auto;
  display: flex; flex-direction: column;
  z-index: 2; position: relative;
}
.op-ys-h {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 19px;
  line-height: 1.2;
  letter-spacing: -0.022em;
  color: var(--ink);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ===== Featured row (gündem + trending + ad) ===== */
.fs-row { padding: 32px 0; position: relative; }
.fs-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 32px;
  align-items: stretch;
}

/* LEFT story */
.fs-main { min-width: 0; }
.fs-cat { margin-bottom: 16px; }
.fs-cat-label {
  display: inline-block;
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.018em;
  color: var(--ink);
  padding-bottom: 6px;
  position: relative;
}
.fs-cat-label::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 30px; height: 3px;
  background: var(--accent); border-radius: 2px;
}

.fs-media {
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  background: #000;
  margin-bottom: 14px;
}
.fs-media-img { position: relative; }
.fs-duration {
  position: absolute; top: 12px; left: 14px;
  color: #fff;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  display: inline-flex; align-items: center; gap: 4px;
  z-index: 2;
}
.fs-mute {
  position: absolute; bottom: 14px; left: 14px;
  color: #fff;
  z-index: 2;
  opacity: 0.85;
}
.fs-brandmark {
  position: absolute; top: 14px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-sans);
  font-weight: 900;
  font-style: italic;
  font-size: 22px;
  letter-spacing: -0.022em;
  color: #fff;
  z-index: 2;
  text-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.fs-bm-it { color: #fff; }
.fs-bm-haber { color: rgba(255,255,255,0.85); font-weight: 600; }

.fs-social {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0;
  margin-bottom: 8px;
}
.fs-social-l, .fs-social-r { display: flex; gap: 16px; align-items: center; }
.fs-iconbtn {
  background: transparent;
  border: 0;
  color: var(--ink);
  cursor: pointer;
  padding: 8px;
  min-width: 48px;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  touch-action: manipulation;
  transition: opacity .15s;
}
.fs-iconbtn:hover { opacity: 0.65; }

.fs-title {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 22px;
  line-height: 1.22;
  letter-spacing: -0.022em;
  margin: 0 0 14px;
  color: var(--ink);
}
.fs-body {
  font-family: var(--font-sans);
  font-size: 14.5px;
  line-height: 1.6;
  color: oklch(28% 0.014 260);
  margin: 0 0 18px;
}

.fs-comment {
  display: flex; align-items: center; gap: 10px;
  border-top: 1px solid oklch(90% 0.006 250);
  padding-top: 14px;
}
.fs-comment-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: oklch(94% 0.006 250);
  color: oklch(50% 0.014 260);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.fs-comment input {
  flex: 1;
  border: 0; outline: 0;
  background: transparent;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink);
  padding: 6px 0;
}
.fs-comment input::placeholder { color: oklch(56% 0.014 260); }
.fs-comment-send {
  background: transparent;
  border: 0;
  color: var(--accent);
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  padding: 4px 8px;
}
.fs-comment-send:hover { color: var(--accent-ink); }

/* RIGHT — kutu haber: Gündem ile aynı yükseklik, 6 eşit satır */
.fs-kutu-stack {
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
}
/* Gündem başlığı (.fs-cat) ile hizalı boşluk */
.fs-kutu-spacer {
  flex: 0 0 auto;
  height: 42px;
  margin-bottom: 16px;
}
.fs-kutu-list {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  grid-template-rows: repeat(6, minmax(48px, 1fr));
  gap: 12px;
}
.fs-kutu-card {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 10px;
  min-height: 48px;
  padding: 8px 10px;
  touch-action: manipulation;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 1px 2px rgba(15, 20, 35, 0.04);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.fs-kutu-card:hover {
  border-color: oklch(86% 0.008 250);
  box-shadow: 0 4px 14px -8px rgba(15, 20, 35, 0.14);
}
.fs-kutu-media {
  position: relative;
  flex: 0 0 88px;
  width: 88px;
  min-height: 0;
  border-radius: 8px;
  overflow: hidden;
  background: var(--bg-3);
}
.fs-kutu-photo {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: auto !important;
  border-radius: 0;
}
.fs-kutu-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.fs-kutu-card:hover .fs-kutu-photo img { transform: scale(1.03); }
.fs-kutu-title {
  flex: 1 1 auto;
  min-width: 0;
  align-self: center;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 12.5px;
  line-height: 1.3;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin: 0;
  padding: 0 2px 0 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color .15s;
}
.fs-kutu-card:hover .fs-kutu-title { color: var(--accent); }

/* Trending numbered list (galeri, kategori vb.) */
.tr-list { min-width: 0; }
.tr-head { margin-bottom: 16px; }
.tr-title {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.018em;
  margin: 0;
  padding-bottom: 6px;
  position: relative;
  color: var(--ink);
}
.tr-title::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 30px; height: 3px;
  background: var(--accent); border-radius: 2px;
}
.tr-title-sep { color: var(--ink-3); margin: 0 2px; font-weight: 400; }
.tr-items { list-style: none; padding: 0; margin: 0; border: 1px solid oklch(91% 0.006 250); border-radius: 8px; background: #fff; overflow: hidden; }
.tr-item { border-bottom: 1px solid oklch(94% 0.006 250); }
.tr-item:last-child { border-bottom: 0; }
.tr-link {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  color: var(--ink);
  transition: background .15s;
}
.tr-link:hover { background: oklch(98% 0.005 250); color: var(--ink); }
.tr-link:hover .tr-h { color: var(--accent); }
.tr-h {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 14.5px;
  line-height: 1.32;
  letter-spacing: -0.012em;
  margin: 0;
  color: var(--ink);
  transition: color .15s;
}
.tr-num {
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: 38px;
  letter-spacing: -0.04em;
  color: oklch(86% 0.008 250);
  line-height: 1;
  flex-shrink: 0;
}

/* AD column */
.fs-sky {}

/* Responsive */
@media (max-width: 1280px) {
  .fs-grid { grid-template-columns: minmax(0, 1fr) 380px; }
  .op-ys-track { --op-ys-cols: 3; }
}
@media (max-width: 1100px) {
  .fs-grid { grid-template-columns: 1fr; }
  .op-ys-track { --op-ys-cols: 2; }
}
@media (max-width: 960px) {
  .op-ys-track { gap: 10px; --op-ys-cols: 1.12; }
}
@media (max-width: 720px) {
  .op-ys-num { font-size: min(150px, 38vw); }
  .op-ys-surname { font-size: 26px; }
  .op-ys-track { --op-ys-cols: 1.08; }
  .fs-kutu-spacer { height: 0; margin-bottom: 12px; }
  .fs-kutu-list { gap: 16px; }
  .fs-kutu-card { min-height: 56px; }
  .fs-kutu-media { flex: 0 0 72px; width: 72px; }
  .fs-kutu-title { font-size: 12px; -webkit-line-clamp: 2; }
  .tr-num { font-size: 28px; }
}


/* =============================================================
   Alt Manşet Kutu Haber — 4 (veya 5) kutu, hero altında.
   Manşetten bağımsız haber kartları (tasarım referansı).
============================================================= */
.shb-section {
  padding: 22px 0 8px;
  background: var(--bg);
}
.shb-grid {
  display: grid;
  gap: 18px;
}
.shb-count-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.shb-count-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.shb-count-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.shb-count-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.shb-count-1 { grid-template-columns: 1fr; }

.shb-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  box-shadow:
    0 1px 2px rgba(15, 20, 35, 0.04),
    0 8px 22px -16px rgba(15, 20, 35, 0.10);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  min-width: 0;
}
.shb-card:hover {
  transform: translateY(-2px);
  border-color: oklch(86% 0.008 250);
  box-shadow:
    0 2px 4px rgba(15, 20, 35, 0.05),
    0 18px 32px -16px rgba(15, 20, 35, 0.18);
}

.shb-media {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--bg-3);
}
.shb-photo {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: auto !important;
  border-radius: 0;
}
.shb-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.shb-card:hover .shb-photo img { transform: scale(1.04); }

.shb-tag {
  position: absolute;
  top: 10px;
  left: 10px;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.12em;
  padding: 4px 8px;
  border-radius: 3px;
  text-transform: uppercase;
  color: #fff;
  background: var(--ink);
  backdrop-filter: blur(4px);
}
.shb-tag-default { background: rgba(15, 20, 30, 0.82); }
.shb-tag-live,
.shb-tag-breaking { background: var(--accent); }

.shb-body {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1 1 auto;
  min-width: 0;
}
.shb-title {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.22;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin: 0;
  text-wrap: balance;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color .15s;
}
.shb-card:hover .shb-title { color: var(--accent); }
.shb-spot {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--ink-2);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.shb-time {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
  letter-spacing: 0.02em;
  margin-top: 2px;
}

/* Reklam kutusu — diğer kartlarla aynı yükseklik, görsel tüm alanı kaplar */
.shb-card-ad {
  display: flex;
  flex-direction: column;
  padding: 0;
  cursor: default;
  height: 100%;
}
.shb-card-ad:hover {
  transform: none;
  box-shadow:
    0 1px 2px rgba(15, 20, 35, 0.04),
    0 8px 22px -16px rgba(15, 20, 35, 0.10);
}
.shb-card-ad .ad-card,
.shb-card-ad .shb-ad-live {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  width: 100%;
  height: 100%;
  min-height: 0;
  margin: 0;
  border: none;
  box-shadow: none;
  background: transparent;
}
.shb-card-ad .ad-card > a {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  text-decoration: none;
}
.shb-card-ad .ad-label {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 6px;
  border-radius: 3px;
  background: rgba(15, 20, 30, 0.72);
  color: #fff;
}
.shb-card-ad .ad-card {
  position: relative;
}
.shb-card-ad .ad-image-wrap {
  flex: 1 1 auto;
  width: 100%;
  height: 100%;
  min-height: 0;
  aspect-ratio: unset !important;
  overflow: hidden;
  background: var(--bg-3);
  line-height: 0;
}
.shb-card-ad .ad-image-wrap img {
  width: 100%;
  height: 100% !important;
  object-fit: cover;
  display: block;
}

@media (max-width: 1200px) {
  .shb-count-5 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  /* 5. kutu haber sığmaz — reklam slotu asla gizlenmez */
  .shb-count-5 .shb-card:nth-child(5):not(.shb-card-ad) { display: none; }
}
@media (max-width: 960px) {
  .shb-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 14px; }
  .shb-count-5 .shb-card:nth-child(5) { display: flex; }
  .shb-title { font-size: 15.5px; }
}
@media (max-width: 560px) {
  .shb-grid { grid-template-columns: 1fr !important; }
}

@media (hover: none) {
  .shb-tag { backdrop-filter: none; }
}

/* Featured row — link styling: news photo + headline both clickable */
.fs-media-link { display: block; color: inherit; text-decoration: none; }
.fs-title-link { color: inherit; text-decoration: none; transition: color .15s; }
.fs-title-link:hover { color: var(--accent); }
