/*
Theme Name: KabarKini
Theme URI: https://example.com/kabarkini
Author: Ejha
Author URI: https://seputaraceh.id
Description: Tema portal berita modern bergaya magazine — dinamis, kontras tinggi, layout asimetris. Semua template kustom, tanpa bawaan WordPress.
Version: 4.18.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kabarkini
Tags: news, magazine, blog, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   §FONT  ProximaNova (self-host) — judul
   ------------------------------------------------------------
   File font TIDAK disertakan (font komersial). Letakkan file di
   assets/fonts/ dengan nama berikut, atau sesuaikan src di bawah:
     • proximanova-regular.woff2   (400)
     • proximanova-semibold.woff2  (600)
     • proximanova-extrabold.woff2 (800)
   Jika file belum ada, judul otomatis fallback ke Source Sans 3.
   ============================================================ */
@font-face{font-family:"Proxima Nova";font-style:normal;font-weight:400;font-display:swap;src:url("assets/fonts/proximanova-regular.woff2") format("woff2")}
@font-face{font-family:"Proxima Nova";font-style:normal;font-weight:600;font-display:swap;src:url("assets/fonts/proximanova-semibold.woff2") format("woff2")}
@font-face{font-family:"Proxima Nova";font-style:normal;font-weight:800;font-display:swap;src:url("assets/fonts/proximanova-extrabold.woff2") format("woff2")}

/* ============================================================
   §00  DESIGN TOKENS
   ============================================================ */
:root{
  /* ── WARNA AKSEN ──────────────────────────────────────────
     Aksen utama = ORANYE logo (#FF8500). Teks di atas aksen = PUTIH.
     accent-2 (kuning) & accent-red = warna brand cadangan (dipakai bila perlu). */
  --color-accent:        #FF8500;
  --color-accent-dark:   #E06F00;
  --color-accent-2:      #FFC300;   /* kuning sekunder (brand) */
  --color-accent-red:    #FF003D;   /* merah breaking (brand)  */
  --on-accent:           #ffffff;

  /* ── NETRAL ───────────────────────────────────────────────
     Hitam pekat khas magazine + skala abu-abu untuk teks & garis. */
  --color-ink:           #0a0a0a;   /* hitam utama (judul, bar)        */
  --color-body:          #2a2a2a;   /* teks isi                        */
  --color-muted:         #6b6b6b;   /* teks sekunder (meta, tanggal)   */
  --color-faint:         #a0a0a0;   /* teks paling redup (placeholder) */
  --color-line:          #e7e7e4;   /* garis halus                     */
  --color-line-strong:   #cfcfca;   /* garis lebih tegas               */
  --color-surface:       #ffffff;   /* latar utama                     */
  --color-surface-2:     #f5f4f0;   /* latar kartu/kotak               */
  --color-surface-3:     #ebeae4;   /* latar placeholder gambar        */
  --color-white:         #ffffff;   /* putih eksplisit (teks di bg gelap) */
  --color-on-dark:       #b9bcc2;   /* teks redup di atas latar gelap (topbar/footer) */

  /* ── TIPOGRAFI ────────────────────────────────────────────
     head = Libre Baskerville (judul/headline, serif klasik ramping).
     sans = Inter (UI, meta, navigasi).
     cat  = Source Sans 3 (badge/label kategori).
     title   = Proxima Nova → judul (fallback Source Sans 3).
     content = Heebo → isi artikel single (fallback Inter). */
  --font-head:    "Libre Baskerville", Georgia, "Times New Roman", serif;
  --font-sans:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-cat:     "Source Sans 3", "Inter", sans-serif;
  --font-body:    var(--font-sans);
  --font-title:   "Proxima Nova", "Source Sans 3", "Inter", sans-serif;
  --font-content: "Heebo", "Inter", -apple-system, sans-serif;

  /* ── SKALA TIPE (fluid, clamp) ─────────────────────────────
     Standar media internasional (NYT/Guardian): base ~16–17px,
     rasio ~1.25 (major third). Mobile→desktop proporsional.
       --step--1 : meta/caption/badge     ~13 → 14px
       --step-0  : UI/teks dasar          ~16 → 17px
       --step-1  : sub-judul/lead         ~19 → 21px
       --step-2  : judul kartu besar      ~24 → 30px
       --step-3  : judul section/single   ~30 → 40px
       --step-4  : judul halaman besar    ~38 → 52px
       --step-5  : display hero           ~46 → 68px */
  --step--1: clamp(.8125rem, .79rem + .12vw, .875rem);
  --step-0:  clamp(1rem,    .97rem + .15vw, 1.0625rem);
  --step-1:  clamp(1.1875rem, 1.12rem + .3vw, 1.3125rem);
  --step-2:  clamp(1.5rem,  1.3rem + 1vw,    1.875rem);
  --step-3:  clamp(1.875rem, 1.55rem + 1.6vw, 2.5rem);
  --step-4:  clamp(2.375rem, 1.9rem + 2.4vw, 3.25rem);
  --step-5:  clamp(2.875rem, 2.2rem + 3.4vw, 4.25rem);

  /* Ukuran JUDUL KARTU seragam (semua card list/grid pakai ini).
     Kecil & konsisten seperti portal berita referensi. */
  --title-card:  clamp(1rem, .95rem + .25vw, 1.125rem);   /* ~16–18px */
  --title-feat:  clamp(1.125rem, 1.05rem + .35vw, 1.3125rem); /* ~18–21px feature */
  --title-hero:  clamp(1.375rem, 1.1rem + 1.2vw, 1.75rem);  /* ~22–28px hero */

  /* ── LAYOUT ───────────────────────────────────────────────── */
  --wrap:        1320px;             /* lebar maksimum global       */
  --sidebar-w:   340px;              /* lebar sidebar tetap         */
  --col-gap:     1.5rem; /* jarak konten ↔ sidebar & antar-section, SAMA dengan jarak antar-widget sidebar (.widget{margin-bottom:1.5rem}) */
  --read-w:      720px;              /* lebar baca artikel          */

  /* ── BENTUK & EFEK ────────────────────────────────────────── */
  --radius-lg:   2px;                /* sudut kartu (magazine = tegas) */
  --shadow-sm:   0 2px 8px rgba(10,10,10,.06);
  --shadow-md:   0 10px 40px rgba(10,10,10,.14);
  --tr:          .2s cubic-bezier(.2,.7,.3,1);
}

/* ============================================================
   §01  RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--color-surface);color:var(--color-body);
  font-family:var(--font-body);font-size:var(--step-0);line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5,h6{margin:0;font-family:var(--font-head);color:var(--color-ink);line-height:1.15;font-weight:700;letter-spacing:0}
p{margin:0 0 1.1em}
:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}
.skip-link{position:absolute;left:-999px;top:0;background:var(--color-ink);color:var(--color-white);padding:.6rem 1rem;z-index:9999}
.skip-link:focus{left:8px;top:8px}

/* ============================================================
   §02  LAYOUT HELPERS
   ============================================================ */
/* ── KERANGKA: satu lebar, satu grid ───────────────────────── */
/* .wrap = lebar maksimum global, dipakai SEMUA halaman */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1rem,4vw,2.5rem)}

/* .layout = grid konten + sidebar. Dipakai SEMUA halaman. */
.layout{display:grid;grid-template-columns:minmax(0,1fr) var(--sidebar-w);gap:var(--col-gap);align-items:start}

/* Konten artikel (single/page) dibatasi lebar bacanya DI DALAM kolom,
   bukan dengan mengganti wrapper — supaya kerangka tetap sama. */
.content-area{min-width:0}
.entry{max-width:none;margin-inline:0}

/* Runtuh jadi 1 kolom: sidebar pindah ke bawah konten */
@media(max-width:1000px){
  .layout{grid-template-columns:1fr;gap:clamp(2.5rem,6vw,3.5rem)}
  .sidebar{position:static}
}

.section{margin-block:var(--col-gap)}

/* ── CAROUSEL — kartu kecil geser horizontal ───────────────── */
.carousel{position:relative;display:flex;align-items:center;gap:.6rem}
.carousel-track{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:.2rem 0 .6rem;flex:1 1 auto;min-width:0;scrollbar-width:none}
.carousel-track::-webkit-scrollbar{display:none}
.card-carousel{flex:0 0 220px;scroll-snap-align:start;display:flex;flex-direction:column;gap:.5rem}
.card-carousel .card-thumb{aspect-ratio:4/3;border-radius:var(--radius-lg)}
.card-carousel .card-content{display:flex;flex-direction:column;gap:.4rem}
.card-carousel .card-content .cat-tag{align-self:flex-start}
.card-carousel .card-title{font-size:.9375rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.carousel-arrow{flex:none;width:38px;height:38px;border-radius:50%;border:1px solid var(--color-line);background:var(--color-surface);font-size:1.3rem;line-height:1;cursor:pointer;transition:background var(--tr),opacity var(--tr)}
.carousel-arrow:hover{background:var(--color-surface-2)}
.carousel-arrow:disabled{opacity:.35;cursor:default}
@media(max-width:560px){.carousel-arrow{display:none}.card-carousel{flex-basis:160px}}

/* Panel navy untuk carousel section — biar beda dari section putih lain tapi tetap kalem */
.carousel-section{
  background:linear-gradient(160deg,#16243f,#0d1830);
  border-radius:var(--radius-lg);
  padding:clamp(1.2rem,2.5vw,1.8rem);
}
.carousel-section .sec-head .tagblock{background:var(--color-accent);color:var(--on-accent)}
.carousel-section .sec-head .rule{background:rgba(255,255,255,.2)}
.carousel-section .sec-head .more{background:var(--color-accent);color:var(--on-accent)}
.carousel-section .sec-head .more:hover{background:#fff;color:#0d1830}
.carousel-section .card-carousel .card-title a{color:#fff}
.carousel-section .card-carousel .card-title a:hover{color:var(--color-accent)}
.carousel-section .card-carousel .card-meta,
.carousel-section .card-carousel .card-meta time{color:#aab3c9}
.carousel-section .carousel-arrow{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.25);color:#fff}
.carousel-section .carousel-arrow:hover{background:rgba(255,255,255,.18)}
.carousel-section .carousel-arrow:disabled{opacity:.3}

/* "Kabar Pilihan" — TANPA background gelap (beda dari carousel kategori).
   Selektor dobel-class (.carousel-section.pilihan-section) agar pasti menang
   atas .carousel-section tanpa bergantung urutan. */
.carousel-section.pilihan-section{background:none;border-radius:0;padding-block:0;padding-inline:clamp(1rem,4vw,2.5rem)}
.pilihan-section .sec-head .tagblock{background:var(--color-ink);color:var(--color-white)}
.pilihan-section .sec-head .rule{background:var(--color-ink)}
.pilihan-section .card-carousel .card-title a{color:var(--color-ink)}
.pilihan-section .card-carousel .card-title a:hover{color:var(--color-accent-dark)}
.pilihan-section .card-carousel .card-meta,
.pilihan-section .card-carousel .card-meta time{color:var(--color-muted)}
.pilihan-section .carousel-arrow{background:var(--color-surface);border-color:var(--color-line);color:var(--color-ink)}
.pilihan-section .carousel-arrow:hover{background:var(--color-surface-2)}
/* "Kabar Pilihan" full-width seperti Hero (mentok kiri-kanan di dalam .wrap).
   Panah = overlay melayang di dalam tepi track (tidak keluar dari .wrap),
   sehingga track tetap penuh dan kartu sejajar Hero. */
.pilihan-section .carousel{display:block;position:relative}
.pilihan-section .carousel-track{padding-bottom:.6rem}
.pilihan-section .carousel-arrow{position:absolute;top:34%;transform:translateY(-50%);z-index:3;box-shadow:var(--shadow-md)}
.pilihan-section .carousel-arrow.prev{left:8px}
.pilihan-section .carousel-arrow.next{right:8px}
@media(max-width:560px){
  .pilihan-section .carousel-arrow{display:none}  /* di mobile cukup geser/swipe */
}
.section:first-child{margin-top:clamp(1.5rem,4vw,2.2rem)}
/* Beri ruang atas konsisten antara ticker/nav dan isi halaman */
.site-main>.wrap.layout:first-child,
.single .wrap.layout,
.page .wrap.layout{padding-top:clamp(1.5rem,4vw,2.5rem)}

/* Section heading — label kuning blok */
.sec-head{display:flex;align-items:center;gap:1rem;margin-bottom:1.6rem}
.sec-head h2{font-size:var(--step-2);text-transform:uppercase;letter-spacing:-.02em}
.sec-head .tagblock{background:var(--color-ink);color:var(--color-white);font-family:var(--font-sans);font-size:var(--step--1);font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .7rem}
.sec-head .rule{flex:1;height:3px;background:var(--color-ink)}
.sec-head .more{font-family:var(--font-sans);font-size:var(--step--1);font-weight:800;text-transform:uppercase;letter-spacing:.06em;background:var(--color-accent);color:var(--on-accent);padding:.4rem .8rem;white-space:nowrap}
.sec-head .more:hover{background:var(--color-ink);color:var(--color-white)}

/* ============================================================
   §03  HEADER / NAV  (topbar, masthead, bar navigasi sticky)
   ============================================================ */
/* Topbar: tanggal + cuaca (kiri), sosmed (kanan) */
.site-topbar{background:var(--color-ink);color:var(--color-on-dark);font-family:var(--font-sans);font-size:var(--step--1)}
.site-topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:38px}
.topbar-left{display:flex;align-items:center;gap:1.4rem;min-width:0}
.topbar-date{letter-spacing:.02em;text-transform:capitalize;font-weight:600;white-space:nowrap}
.topbar-weather{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;color:var(--color-accent);white-space:nowrap}
.topbar-social{display:flex;gap:.2rem}
.topbar-social a{width:30px;height:30px;display:grid;place-items:center;color:var(--color-on-dark)}
.topbar-social a:hover{color:var(--color-accent)}
.topbar-social svg{width:14px;height:14px;fill:currentColor}
@media(max-width:680px){.topbar-weather{display:none}}
@media(max-width:420px){.topbar-date{font-size:.72rem}}

/* Masthead: logo kiri + banner iklan kanan */
.site-masthead{background:var(--color-surface);border-bottom:1px solid var(--color-line)}
.masthead-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:clamp(1rem,2.5vw,1.6rem)}
.site-brand{font-family:var(--font-head);font-weight:700;font-size:clamp(1.7rem,1.1rem+2.2vw,3rem);letter-spacing:-.03em;color:var(--color-ink);line-height:.9;text-transform:uppercase}
.site-brand .dot{display:inline-block;background:var(--color-accent);width:.32em;height:.32em;margin-left:.08em;vertical-align:baseline}
.brand-tagline{font-family:var(--font-sans);font-size:var(--step--1);color:var(--color-muted);margin-top:.3rem;font-weight:600}
.site-branding .custom-logo{height:48px;width:auto;max-width:240px;object-fit:contain}
.site-branding .custom-logo-link{display:inline-block;line-height:0}
.masthead-ad{flex-shrink:0}
.ad-leaderboard{width:728px;max-width:100%;height:90px;background:var(--color-surface-2);border:2px dashed var(--color-line-strong);display:grid;place-items:center;color:var(--color-faint);font-family:var(--font-sans);font-size:var(--step--1);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
@media(max-width:920px){.masthead-ad{display:none}}

/* Header navigasi (sticky): menu kiri + aksi kanan, satu baris */
.site-header{position:sticky;top:0;z-index:500;background:var(--color-ink);transition:box-shadow var(--tr)}
.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){.admin-bar .site-header{top:46px}}
.site-header.is-stuck{box-shadow:var(--shadow-md)}
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:52px}

.primary-nav{min-width:0}
.primary-nav ul{display:flex;flex-wrap:nowrap}
.primary-nav a{display:block;padding:.95rem 1.05rem;font-family:var(--font-sans);font-weight:800;font-size:var(--step--1);letter-spacing:.05em;text-transform:uppercase;color:var(--color-white);position:relative;white-space:nowrap}
.primary-nav a:hover{background:#000;color:var(--color-accent)}
.primary-nav .current-menu-item>a{background:var(--color-accent);color:var(--on-accent)}
.primary-nav .sub-menu{display:none;position:absolute;background:#000;min-width:210px;z-index:600}
.primary-nav li{position:relative}
.primary-nav li:hover>.sub-menu{display:block}
.primary-nav .sub-menu a{color:var(--color-white);letter-spacing:.02em;text-transform:none;font-weight:600}
.primary-nav .sub-menu a:hover{background:var(--color-accent);color:var(--on-accent)}
/* Menu overflow "Selengkapnya" — diisi oleh JS saat item tak muat satu baris */
.primary-nav .menu-more{position:relative}
.primary-nav .menu-more>a{cursor:pointer}
.primary-nav .menu-more>a::after{content:"▾";margin-left:.4em;font-size:.85em}
.primary-nav .menu-more .sub-menu{right:0;left:auto}
.primary-nav .menu-more.is-open>.sub-menu{display:block}
.primary-nav .menu-more[hidden]{display:none}

.header-actions{display:flex;align-items:center;gap:.2rem;flex-shrink:0}
.icon-btn{width:44px;height:44px;display:grid;place-items:center;border:0;background:transparent;color:var(--color-white)}
.icon-btn:hover{background:var(--color-accent);color:var(--on-accent)}
.icon-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2.2}

.nav-toggle{display:none}
.mobile-panel{position:fixed;inset:0 0 0 auto;width:min(86vw,380px);background:var(--color-surface);transform:translateX(100%);transition:transform var(--tr);z-index:1000;box-shadow:var(--shadow-md);overflow-y:auto;padding:1.2rem}
.mobile-panel.open{transform:translateX(0)}
/* Tombol tutup: gelap agar terlihat di panel putih, ditempatkan di kanan atas */
.mobile-panel__close{display:flex;margin-left:auto;margin-bottom:.6rem;color:var(--color-ink)}
.mobile-panel__close:hover{background:var(--color-accent);color:var(--on-accent)}
.mobile-panel a{display:block;padding:.85rem .4rem;border-bottom:1px solid var(--color-line);font-family:var(--font-sans);font-weight:800;text-transform:uppercase;font-size:var(--step--1);letter-spacing:.04em}
.nav-scrim{position:fixed;inset:0;background:rgba(10,10,10,.55);opacity:0;visibility:hidden;transition:var(--tr);z-index:900}
.nav-scrim.open{opacity:1;visibility:visible}
.header-bar-brand{display:none;font-family:var(--font-head);font-weight:700;text-transform:uppercase;color:var(--color-white);font-size:1.1rem;letter-spacing:-.02em}
/* Logo di header sticky (latar gelap) → dibuat putih otomatis */
.header-bar-logo{height:30px;width:auto;max-width:170px;object-fit:contain;display:block;filter:brightness(0) invert(1)}
@media(max-width:880px){.primary-nav{display:none}.nav-toggle{display:grid}.header-bar-brand{display:block}.site-masthead{display:none}}

/* ============================================================
   §04  BADGE / META / KARTU
   ============================================================ */
/* Badge kategori (oranye) */
.cat-tag{display:inline-block;font-family:var(--font-cat);font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:var(--color-accent);color:var(--on-accent);padding:.25rem .55rem;line-height:1.2}

/* Judul kartu */
.card-title{font-family:var(--font-head);font-weight:700;letter-spacing:0;line-height:1.25;text-transform:none}
.card-title a:hover{color:var(--color-accent-dark)}

/* Meta: penulis · tanggal · menit baca */
.card-meta{font-family:var(--font-sans);font-size:var(--step--1);color:var(--color-muted);display:flex;gap:.55rem;align-items:center;flex-wrap:wrap;font-weight:500;margin-top:auto}
.card-meta .dot-sep::before{content:"›";margin-right:.55rem;color:var(--color-faint)}

/* Thumbnail kartu (rasio 16:10 default) */
.card-thumb{display:block;overflow:hidden;background:var(--color-surface-3);aspect-ratio:16/10;position:relative}
.card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.2,.7,.3,1)}
.card:hover .card-thumb img{transform:scale(1.06)}

/* Isi kartu (badge + judul + excerpt + meta) — kolom flex eksplisit
   supaya jarak antar elemen konsisten dan meta benar-benar nempel bawah. */
.card-content,
.card-body{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;gap:.5rem}
/* badge kategori jangan ikut stretch melebar - selalu sebesar kontennya saja */
.card-content .cat-tag,
.card-body .cat-tag{align-self:flex-start}

/* Kartu standar (varian 'std' dari kabarkini_card) */
.card-std{display:flex;flex-direction:column;gap:.55rem}
.card-std .card-title{font-size:var(--title-card)}
.card-std .cat-tag{align-self:flex-start}

/* Ringkasan: dibatasi 3 baris agar tinggi kartu seragam */
.card-excerpt{color:var(--color-muted);margin:0;font-size:.875rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ── KARTU BERBINGKAI ───────────────────────────────────────
   Latar tipis + border halus untuk kartu di grid "Terbaru".
   Gambar full-bleed di atas, teks diberi padding rapi di dalam. */
.grid-3 .card-std{
  background:var(--color-surface-2);
  border:1px solid var(--color-line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  gap:0;
  transition:border-color var(--tr),box-shadow var(--tr);
}
.grid-3 .card-std:hover{border-color:var(--color-line-strong);box-shadow:var(--shadow-sm)}
.grid-3 .card-std .card-thumb{aspect-ratio:16/10}
/* padding teks seragam di dalam kartu berbingkai */
.grid-3 .card-std .card-content{padding:1rem;gap:.6rem}
.grid-3 .card-std .cat-tag{align-self:flex-start}
/* judul dibatasi 2 baris agar tinggi blok judul seragam antar kartu */
.grid-3 .card-std .card-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.5em}
/* excerpt dijaga tinggi minimumnya agar baris meta sejajar antar kartu */
.grid-3 .card-std .card-excerpt{min-height:4.5em}
.grid-3 .card-std .card-meta{padding-top:.2rem;border-top:1px solid var(--color-line)}

/* ── MOBILE: format meta seragam untuk SEMUA list ───────────
   Susunan jadi:  "KATEGORI | 2 jam lalu"  (satu baris, di ATAS judul) → judul → excerpt.
   Kategori tanpa background (teks oranye polos). Pemisah "|".
   Cakupan: .card-content (kartu grid), .card-body (lead/feat & mini section
   kategori) dan .side-text (daftar samping hero).
   DIKECUALIKAN: hero slider (.slide) & kartu overlay (.overlay) — teks putih di
   atas gambar, biar tetap apa adanya. */
@media(max-width:820px){
  /* Parent jadi ROW-WRAP: kategori + tanggal mengisi baris pertama (sebaris),
     judul & excerpt dipaksa ke baris penuh sendiri via flex-basis:100%. */
  .card:not(.slide) .card-content,
  .card:not(.slide):not(.card-overlay) .card-body,
  .side-text{display:flex;flex-flow:row wrap;align-items:baseline;column-gap:.45rem;row-gap:.35rem}

  /* Baris 1 — kategori (oranye polos, tanpa background) + tanggal */
  .card:not(.slide) .card-content > .cat-tag,
  .card:not(.slide):not(.card-overlay) .card-body > .cat-tag,
  .side-text > .cat-tag{order:1;width:auto;flex:0 0 auto;align-self:auto;background:none;color:var(--color-accent);padding:0;font-size:var(--step--1);letter-spacing:.04em;line-height:1.2}
  .card:not(.slide) .card-content > .card-meta,
  .card:not(.slide):not(.card-overlay) .card-body > .card-meta,
  .side-text > .card-meta{order:2;flex:0 0 auto;width:auto;display:inline-flex;align-items:baseline;margin:0;padding:0;border-top:0}

  /* Baris berikutnya — judul, lalu excerpt (masing-masing penuh) */
  .card:not(.slide) .card-content > .card-title,
  .card:not(.slide):not(.card-overlay) .card-body > .card-title,
  .side-text > .card-title{order:3;flex:0 0 100%;width:100%;margin:0}
  .card:not(.slide) .card-content > .card-excerpt,
  .card:not(.slide):not(.card-overlay) .card-body > .card-excerpt{order:4;flex:0 0 100%;width:100%;margin:0}

  /* Pemisah "|" di depan tanggal */
  .card:not(.slide) .card-content > .card-meta .post-date::before,
  .card:not(.slide):not(.card-overlay) .card-body > .card-meta .post-date::before,
  .side-text > .card-meta .post-date::before{content:"|";margin-right:.45rem;color:var(--color-line-strong);font-weight:400}

  /* Sembunyikan "menit baca" di mobile → cukup "KATEGORI | tanggal" */
  .card:not(.slide) .card-content > .card-meta span.dot-sep,
  .card:not(.slide):not(.card-overlay) .card-body > .card-meta span.dot-sep,
  .story-body .card-meta span.dot-sep{display:none}
}

/* ============================================================
   §05  HERO  (slider 16:9 + list samping)
   ============================================================ */

/* SLIDER — rasio 16:9 */
.hero-slider{position:relative;overflow:hidden;background:var(--color-ink);aspect-ratio:16/9}
.slider-track{display:flex;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.hero-slider .slide{position:relative;flex:0 0 100%;min-width:100%;display:flex;align-items:flex-end;overflow:hidden}
.hero-slider .slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-slider .slide::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.92) 0%,rgba(10,10,10,.45) 50%,rgba(10,10,10,.05) 80%)}
.hero-slider .overlay{position:relative;z-index:2;padding:clamp(1.2rem,2.8vw,2.4rem);color:var(--color-white);max-width:88%}
.hero-slider .card-title{color:var(--color-white);font-size:var(--title-hero);margin:.5rem 0 .4rem;line-height:1.04}
.hero-slider .card-title a{color:var(--color-white)}
.hero-slider .card-title a:hover{color:var(--color-accent)}
.hero-slider .card-meta{color:#bdbdbd}
.hero-slider .card-meta .dot-sep::before{color:#888}
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border:0;background:rgba(10,10,10,.55);color:var(--color-white);font-size:1.8rem;line-height:1;display:grid;place-items:center;transition:var(--tr)}
.slider-arrow:hover{background:var(--color-accent);color:var(--on-accent)}
.slider-arrow.prev{left:0}
.slider-arrow.next{right:0}
.slider-dots{position:absolute;z-index:3;bottom:1rem;right:clamp(1.2rem,2.8vw,2.4rem);display:flex;gap:.4rem}
.slider-dots .dot{width:11px;height:11px;border:2px solid var(--color-white);background:transparent;border-radius:50%;cursor:pointer;padding:0;transition:var(--tr)}
.slider-dots .dot.is-active{background:var(--color-accent);border-color:var(--color-accent)}
@media(prefers-reduced-motion:reduce){.slider-track{transition:none}}

/* LIST samping — teks kiri, gambar kanan (4:3); tinggi total = tinggi slider */
.hero{display:grid;grid-template-columns:1.7fr 1fr;margin-top:1.8rem;align-items:start}
.hero-side{display:flex;flex-direction:column;gap:0;overflow:hidden;background:var(--color-surface-2);border-radius:var(--radius-lg)}
.side-item{display:flex;gap:1rem;padding:.7rem;min-height:0;flex:1 1 0;overflow:hidden;border-bottom:1px dashed var(--color-line-strong);transition:background .18s ease;align-items: center;}
.side-item:hover{background:var(--color-surface-3)}
.side-item:last-child{border-bottom:0}
.side-text{min-width:0;display:flex;flex-direction:column;gap:.3rem}
.side-text .cat-tag{align-self:flex-start}
.side-item .card-title{font-size:var(--title-card);line-height:1.18;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.side-item .card-meta{font-size:var(--step--1)}
.side-thumb{flex:0 0 128px;width:128px;aspect-ratio:16/9;height:auto;overflow:hidden}
.side-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.side-item:hover .side-thumb img{transform:scale(1.06)}
@media(max-width:820px){
  /* Hero MOBILE: hanya 1 post utama, STATIS (bukan slider). */
  .hero{grid-template-columns:1fr;margin-top:1.2rem;gap:1.2rem}
  .hero-side{display:none}                       /* sembunyikan daftar samping di mobile */
  .hero-slider .slider-arrow,
  .hero-slider .slider-dots{display:none}        /* sembunyikan kontrol slider */
  .hero-slider .slider-track{transform:none!important;display:block;height:100%}  /* batalkan geser horizontal */
  .hero-slider .slide{display:none}              /* tampilkan hanya slide aktif (pertama) */
  .hero-slider .slide.is-active{display:flex;height:100%}  /* isi penuh tinggi 16:9, tanpa area hitam */

  /* Teks hero diperkecil agar pas di layar sempit */
  .hero-slider .overlay{padding:1rem 1.1rem;max-width:100%}
  .hero-slider .card-title{font-size:clamp(1.05rem,4.5vw,1.3rem);line-height:1.15;margin:.4rem 0 .35rem}
  .hero-slider .slide::after{background:linear-gradient(to top,rgba(10,10,10,.94) 0%,rgba(10,10,10,.55) 45%,rgba(10,10,10,.1) 80%)}
}

/* Bento grid */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-3 .card{height:100%}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
/* ── SECTION BERBINGKAI: latar tipis + border ──────────────── */
.cat-section{background:var(--color-surface-2);border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:clamp(1.2rem,2.5vw,1.8rem)}
.cat-section .sec-head{margin-bottom:1.4rem}

/* ── SECTION KATEGORI — 3 VARIAN MAGAZINE ──────────────────── */
/* tagblock kini bisa berupa link */
a.tagblock:hover{background:var(--color-accent);color:var(--on-accent)}

/* VARIAN A — Lead + daftar bersih */
.layout-lead{display:grid;grid-template-columns:1.5fr 1fr;gap:1.5rem;align-items:start}
.layout-lead .card-feat{display:flex;flex-direction:column;gap:.7rem}
.layout-lead .card-feat .card-thumb{aspect-ratio:16/10}
.layout-lead .card-feat .card-title{font-size:var(--title-feat);line-height:1.15}
.layout-lead .card-feat .card-excerpt{font-size:.9375rem}
.story-list{display:flex;flex-direction:column}
.story{padding:0 0 1rem;margin-bottom:1rem;border-bottom:1px solid var(--color-line);position:relative;padding-left:1rem}
.story::before{content:"";position:absolute;left:0;top:.15em;width:3px;height:1.1em;background:var(--color-accent)}
.story:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.story-title{font-family:var(--font-head);font-weight:700;font-size:var(--title-card);line-height:1.15;margin-bottom:.35rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.story-link:hover .story-title{color:var(--color-accent-dark)}
/* Meta story-list: "KATEGORI | tanggal" sebaris, kategori oranye polos (tanpa background). */
.story-meta{display:flex;align-items:baseline;flex-wrap:wrap;gap:.3rem .45rem}
.story-meta .cat-tag{background:none;color:var(--color-accent);padding:0;font-size:var(--step--1);letter-spacing:.04em;line-height:1.2}
.story-meta .post-date::before{content:"|";margin-right:.45rem;color:var(--color-line-strong);font-weight:400}

/* Varian story-list dengan thumbnail (dipakai khusus section News, biar beda dari section lead lain) */
.story-list--thumb .story{display:flex;gap:.9rem;align-items:flex-start;padding-left:0}
.story-list--thumb .story::before{display:none}
.story-list--thumb .story-thumb{flex:none;display:block;width:84px;aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius-md, 6px)}
.story-list--thumb .story-thumb img{width:100%;height:100%;object-fit:cover}
.story-list--thumb .story-body{min-width:0}
.story-list--thumb .story-title{-webkit-line-clamp:2}
@media(max-width:780px){.layout-lead{grid-template-columns:1fr;gap:1.6rem}.layout-lead .card-feat{padding-bottom:1.4rem;border-bottom:3px solid var(--color-ink)}}

/* VARIAN B — Split: 2 besar + strip 3 mini */
.layout-split{display:flex;flex-direction:column;gap:clamp(1.6rem,3vw,2.4rem)}
.split-top{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.split-top .card-std{display:flex;flex-direction:column;gap:.6rem}
.split-top .card-std .card-thumb{aspect-ratio:16/9}
.split-top .card-std .card-title{font-size:var(--title-feat);line-height:1.15}
.split-bottom{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-line)}
.split-bottom .card-mini{display:grid;grid-template-columns:96px 1fr;gap:.9rem;align-items:start;padding-left:1.5rem;border-left:1px solid var(--color-line)}
.split-bottom .card-mini:first-child{padding-left:0;border-left:0}
.split-bottom .card-mini .card-thumb{aspect-ratio:1/1}
.split-bottom .card-mini .card-title{font-size:var(--title-card);line-height:1.25;margin-top:.4rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:3.75em}
.split-bottom .card-mini .card-body{min-width:0}
@media(max-width:780px){.split-top{grid-template-columns:1fr}.split-bottom{grid-template-columns:1fr}.split-bottom .card-mini{padding-left:0;border-left:0;padding-top:1.2rem;border-top:1px solid var(--color-line)}.split-bottom .card-mini:first-child{padding-top:0;border-top:0}}

/* VARIAN C — Overlay asimetris */
.layout-overlay{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:clamp(160px,17vw,210px);grid-auto-flow:dense;gap:1.5rem}
.layout-overlay .card-overlay{position:relative;overflow:hidden;background:var(--color-ink);display:flex;align-items:flex-end;grid-column:span 2}
.layout-overlay .card-overlay.is-big{grid-column:span 2;grid-row:span 2}
.layout-overlay .card-overlay img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.layout-overlay .card-overlay:hover img{transform:scale(1.06)}
.layout-overlay .card-overlay::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.9),rgba(10,10,10,.05) 70%)}
.layout-overlay .overlay{position:relative;z-index:2;padding:1.1rem;color:var(--color-white)}
.layout-overlay .card-title{color:var(--color-white);font-size:var(--title-card);line-height:1.12;margin-top:.4rem}
.layout-overlay .is-big .card-title{font-size:var(--title-hero)}
.layout-overlay .card-title a{color:var(--color-white)}
.layout-overlay .card-title a:hover{color:var(--color-accent)}
.layout-overlay .card-meta{color:#bdbdbd;margin-top:.4rem}
@media(max-width:780px){
  .layout-overlay{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .layout-overlay .card-overlay,.layout-overlay .card-overlay.is-big{grid-column:span 1;grid-row:span 1}
  .layout-overlay .is-big .card-title{font-size:var(--title-feat)}
}
@media(max-width:480px){.layout-overlay{grid-template-columns:1fr}}

/* grid-3 / grid-2 responsif */
@media(max-width:860px){.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.grid-3,.grid-2{grid-template-columns:1fr}}

/* ── MOBILE "Terbaru": kartu #1 tetap penuh, kartu #2+ jadi LIST horizontal
   (gambar kiri, teks kanan). Hanya berlaku di grid Terbaru beranda. */
@media(max-width:560px){
  .grid-3{gap:1rem}
  /* Kartu non-lead → baris: thumbnail kiri + konten kanan */
  .grid-3 .card-std:not(.card-lead){display:grid;grid-template-columns:120px 1fr;align-items:stretch;gap:0;overflow:hidden}
  .grid-3 .card-std:not(.card-lead) .card-thumb{aspect-ratio:1/1;height:100%}
  .grid-3 .card-std:not(.card-lead) .card-thumb img{width:100%;height:100%;object-fit:cover}
  .grid-3 .card-std:not(.card-lead) .card-content{padding:.7rem .9rem}
  /* Sembunyikan excerpt & seragamkan tinggi judul di varian list */
  .grid-3 .card-std:not(.card-lead) .card-excerpt{display:none}
  .grid-3 .card-std:not(.card-lead) .card-title{min-height:0;-webkit-line-clamp:3}
  .grid-3 .card-std:not(.card-lead) .card-meta{border-top:0;padding-top:0}
}



/* ============================================================
   §06  SINGLE POST
   ============================================================ */
.single-head{padding-top:.5rem}
.single-head .cat-tag{margin-bottom:1rem}
.single-title{font-family:var(--font-title);font-weight:800;font-size:clamp(1.75rem,1.3rem+1.8vw,2.4rem);letter-spacing:-.02em;margin-bottom:1rem;line-height:1.12}
.single-dek{font-family:var(--font-sans);font-size:var(--step-1);color:var(--color-muted);margin-bottom:1.6rem;line-height:1.5;font-weight:500}
.single-byline{display:flex;align-items:center;gap:.5rem .75rem;font-family:var(--font-sans);font-size:var(--step--1);color:var(--color-muted);flex-wrap:wrap;font-weight:600}
.single-byline strong{color:var(--color-ink)}
.single-byline strong a{color:inherit}

/* Byline ATAS (di bawah judul): Penulis · Nama Situs · Tanggal+jam */
.single-byline--top{padding-bottom:1.5rem;border-bottom:3px solid var(--color-ink);margin-bottom:0}
.single-byline--top .byline-site{color:var(--color-accent);font-weight:700}
.single-byline--top .byline-date::before{content:"·";margin-right:.6rem;color:var(--color-line-strong);font-weight:700}
.single-byline--top .byline-date{color:var(--color-muted);font-weight:600}

/* Byline BAWAH (setelah konten): Reporter: Nama | Editor: Nama (tanpa tanggal) */
.single-byline--bottom{padding:1.5rem 0;border-top:1px solid var(--color-line);margin:0}
.single-byline--bottom .byline-credit__role{color:var(--color-muted);font-weight:600}
.single-byline--bottom .byline-credit strong{color:var(--color-ink);font-weight:700}
.single-byline--bottom .byline-credit--sep::before{content:"|";margin-right:.75rem;color:var(--color-line-strong);font-weight:400}

.single-hero{margin:2.2rem 0}
.single-hero img{width:100%;background:var(--color-surface-3)}
.single-hero figcaption{font-family:var(--font-sans);font-size:var(--step--1);color:var(--color-muted);margin-top:.7rem;padding-left:1rem;border-left:3px solid var(--color-accent)}

.article-body{font-family:var(--font-content);font-size:var(--step-1);line-height:1.75;color:var(--color-body)}
.article-body p{margin:0 0 1.4em}
.article-body h2{font-family:var(--font-sans);font-size:var(--step-2);font-weight:800;margin:1.8em 0 .5em;text-transform:none;letter-spacing:-.01em}
.article-body h3{font-family:var(--font-sans);font-size:var(--step-1);font-weight:800;margin:1.5em 0 .4em}
.article-body h4,.article-body h5,.article-body h6{font-family:var(--font-sans);margin:1.4em 0 .4em}
.article-body a{color:var(--color-ink);text-decoration:underline;text-decoration-color:var(--color-accent);text-decoration-thickness:3px;text-underline-offset:3px}
.article-body a:hover{background:var(--color-accent)}
.article-body ul,.article-body ol{margin:0 0 1.4em;padding-left:1.4em}
.article-body ul li{list-style:none;position:relative;margin-bottom:.5em;padding-left:.4em}
.article-body ul li::before{content:"";position:absolute;left:-1em;top:.6em;width:.5em;height:.5em;background:var(--color-accent)}
.article-body ol li{list-style:decimal;margin-bottom:.5em}
/* Kutipan — gaya editorial bersih: garis aksen kiri, latar lembut.
   Font = Inter (sans), konsisten dengan body berita. */
.article-body blockquote{position:relative;margin:2em 0;padding:1.3em 1.6em 1.3em 2.2em;background:var(--color-surface-2);border-left:5px solid var(--color-accent);font-family:var(--font-content);font-size:var(--step-1);line-height:1.6;font-weight:500;color:var(--color-ink)}
.article-body blockquote::before{content:"\201C";position:absolute;left:.5rem;top:.05em;font-family:var(--font-head);font-size:2.4em;line-height:1;color:var(--color-accent);opacity:.5}
.article-body blockquote p{margin:0 0 .6em;font-family:var(--font-content);font-weight:500}
.article-body blockquote p:last-child{margin-bottom:0}
.article-body blockquote cite{display:block;font-size:var(--step--1);font-style:normal;font-family:var(--font-sans);color:var(--color-muted);margin-top:.8em;font-weight:700}
.article-body blockquote cite::before{content:"— "}
.article-body img,.article-body figure{margin:2em 0}
.article-body img{max-width:100%;height:auto}
/* WP menyuntik style="width:NNNpx" inline pada .wp-caption (output the_content);
   inline lebih tinggi prioritasnya dari class apa pun → !important wajib agar gambar tetap responsif. */
.article-body figure.wp-caption{max-width:100%!important;width:auto!important}
.article-body figcaption{font-family:var(--font-sans);font-size:var(--step--1);color:var(--color-muted);margin-top:.6rem;padding-left:1rem;border-left:3px solid var(--color-accent)}
.article-body pre{background:var(--color-ink);color:#eee;padding:1.2em;overflow:auto;font-size:.9rem;margin:0 0 1.4em}
.article-body code{background:var(--color-surface-3);padding:.15em .4em;font-size:.9em}
.article-body pre code{background:none;padding:0}
.article-body table{width:100%;border-collapse:collapse;margin:0 0 1.4em;font-family:var(--font-sans);font-size:var(--step-0)}
.article-body th,.article-body td{border:1px solid var(--color-line-strong);padding:.6em .8em;text-align:left}
.article-body th{background:var(--color-ink);color:var(--color-white);font-weight:700}
.article-body hr{border:0;border-top:3px solid var(--color-ink);margin:2.2em 0}

/* Tautan antar-halaman dari wp_link_pages() (artikel multi-halaman) — diberi gaya tema */
.page-links{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin:2em 0;font-family:var(--font-sans);font-weight:700}
.page-links a,.page-links > span{min-width:38px;height:38px;display:grid;place-items:center;padding:0 .5rem}
.page-links a{background:var(--color-surface-2);color:var(--color-body)}
.page-links a:hover{background:var(--color-ink);color:var(--color-white)}
.page-links > span:not(.page-links-title){background:var(--color-accent);color:var(--on-accent)}
.page-links .page-links-title{background:none;color:var(--color-muted);font-weight:600;padding-right:.6rem}

.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:2.5rem 0}
.post-tags a{font-family:var(--font-sans);font-size:var(--step--1);font-weight:700;background:var(--color-surface-2);padding:.4rem .8rem;color:var(--color-body)}
.post-tags a:hover{background:var(--color-accent);color:var(--on-accent)}
.share-bar{display:flex;align-items:center;gap:.5rem;padding:1.3rem 0;border-block:3px solid var(--color-ink);font-family:var(--font-sans)}
.share-bar span{font-size:var(--step--1);font-weight:800;color:var(--color-ink);text-transform:uppercase;letter-spacing:.06em;margin-right:.4rem}
.share-bar a{width:40px;height:40px;display:grid;place-items:center;background:var(--color-surface-2);color:var(--color-ink);transition:var(--tr)}
.share-bar a:hover{background:var(--color-accent)}
.share-bar a svg{width:17px;height:17px;fill:currentColor}

.author-box{display:flex;gap:1.2rem;padding:1.6rem;background:var(--color-ink);color:#dcdcdc;margin:2.5rem 0}
.author-box img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-box h4{font-family:var(--font-sans);font-size:var(--step-1);margin-bottom:.2rem;color:var(--color-white)}
.author-box p{margin:0;font-size:var(--step-0);color:#aaa}

.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2.5rem 0}
.post-nav a{display:block;padding:1.2rem;border:2px solid var(--color-line-strong);transition:var(--tr)}
.post-nav a:hover{border-color:var(--color-ink);background:var(--color-accent)}
.post-nav .label{font-family:var(--font-sans);font-size:var(--step--1);color:var(--color-muted);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:.3rem;font-weight:700}
.post-nav .next{text-align:right}
.post-nav .ptitle{font-family:var(--font-head);font-weight:700;font-size:var(--step-0);color:var(--color-ink)}
@media(max-width:560px){.post-nav{grid-template-columns:1fr}}
.read-progress{position:fixed;top:0;left:0;height:4px;width:0;background:var(--color-accent);z-index:1100;transition:width .1s linear}

/* ── "Baca Juga" (related) — kartu KHUSUS, beda dari kartu daftar biasa ──
   Layout horizontal: nomor urut + thumbnail kiri (4:3) + konten kanan,
   garis aksen di tepi kiri. Hanya dipakai di single.php. */
.related-section{margin-top:2.5rem}
.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.related-card{display:grid;grid-template-columns:120px 1fr;align-items:center;gap:1rem;padding:.9rem 1rem;background:var(--color-surface-2);border-left:4px solid var(--color-accent);transition:background .18s ease,transform .18s ease}
.related-card:hover{background:var(--color-surface-3);transform:translateX(2px)}
.related-card__thumb{display:block;aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-lg)}
.related-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.related-card:hover .related-card__thumb img{transform:scale(1.06)}
.related-card__body{min-width:0}
.related-card__title{font-family:var(--font-head);font-weight:700;font-size:var(--step-0);line-height:1.25;margin:.4rem 0 .35rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.related-card__title a{color:var(--color-ink)}
.related-card__title a:hover{color:var(--color-accent-dark)}
.related-card__meta{font-size:var(--step--1)}
@media(max-width:680px){
  .related-grid{grid-template-columns:1fr}
  .related-card{grid-template-columns:96px 1fr;gap:.8rem;padding:.7rem .8rem}
}

/* ============================================================
   §07  ARSIP / KATEGORI / PENCARIAN
   ============================================================ */
.page-hero{padding-block:clamp(2.2rem,5vw,3.5rem);border-bottom:3px solid var(--color-ink);margin-bottom:2.5rem}
.page-hero .eyebrow{font-family:var(--font-sans);font-size:var(--step--1);font-weight:800;letter-spacing:.1em;text-transform:uppercase;background:var(--color-accent);color:var(--on-accent);padding:.25rem .6rem;display:inline-block;margin-bottom:.9rem}
.page-hero h1{font-size:var(--step-5);letter-spacing:-.02em;line-height:1}
.page-hero .desc{color:var(--color-muted);max-width:62ch;margin-top:1rem;font-size:var(--step-1)}
.author-profile{display:flex;gap:1.2rem;align-items:center;margin-top:1.4rem}
.author-profile-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--color-accent)}
.author-profile-count{display:inline-block;font-family:var(--font-sans);font-size:var(--step--1);font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted)}
.author-profile-bio{margin:.4rem 0 0;color:var(--color-body);max-width:60ch}
.cat-bar{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.4rem}
.cat-bar a{font-family:var(--font-sans);font-size:var(--step--1);font-weight:700;padding:.45rem .9rem;background:var(--color-surface-2);color:var(--color-body)}
.cat-bar a:hover,.cat-bar a.active{background:var(--color-ink);color:var(--color-white)}

.archive-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.archive-grid .card{padding-bottom:1.8rem;border-bottom:1px solid var(--color-line)}
@media(max-width:620px){.archive-grid{grid-template-columns:1fr}}

.search-overlay{position:fixed;inset:0;background:var(--color-ink);z-index:1200;display:grid;place-items:center;opacity:0;visibility:hidden;transition:var(--tr)}
.search-overlay.open{opacity:1;visibility:visible}
.search-overlay form{width:min(720px,90vw)}
.search-overlay input{width:100%;border:0;border-bottom:4px solid var(--color-accent);background:transparent;color:var(--color-white);font-family:var(--font-head);font-weight:700;font-size:var(--step-3);padding:.4rem 0;outline:none}
.search-overlay input::placeholder{color:#555}
.search-overlay .hint{font-family:var(--font-sans);color:#888;margin-top:1rem}
.search-close{position:absolute;top:1.5rem;right:1.5rem;color:var(--color-white)}
.search-close:hover{background:var(--color-accent);color:var(--on-accent)}

.empty-state{text-align:center;padding:4rem 1rem;max-width:540px;margin-inline:auto}
.empty-state h1{font-size:var(--step-4);margin:.5rem 0}
.empty-state h2{font-size:var(--step-3);margin-bottom:.6rem}
.empty-state p{color:var(--color-muted)}
.empty-state__action{margin-top:1.5rem}                /* jarak tombol "Kembali" dari form pencarian */

/* Form pencarian standalone (mis. di 404 / luar sidebar).
   Aturan untuk versi di dalam .widget ada di §08. */
.search-form{display:flex;gap:.5rem;margin-top:1.2rem}
.search-form .search-field{flex:1;min-width:0;padding:.7rem .9rem;border:1px solid var(--color-line);background:var(--color-surface);font:inherit;border-radius:var(--radius)}

/* ============================================================
   §08  SIDEBAR  (100% custom — TIDAK ada widget bawaan WordPress)
   ------------------------------------------------------------
   sidebar.php hanya merender komponen buatan tema:
     • .widget            → kontainer <section> (kotak berbingkai)
     • .widget-title      → judul kotak (h3)
     • .popular-list      → daftar "Terpopuler"
     • .topic-list        → daftar "Topik Populer" (tag #pill)
     • .widget-ad         → slot iklan (Ads Manager)
   Karena tema TIDAK memakai register_sidebar()/dynamic_sidebar(),
   tidak ada styling untuk block/classic widget WP (wp-block-*,
   recentcomments, tagcloud, kalender, dsb) — itu memang tak dirender.
   ============================================================ */
.sidebar{position:sticky;top:calc(52px + 1rem)}

/* Kontainer kotak (jarak antar-kotak + bingkai) */
.widget{margin-bottom:1.5rem;font-family:var(--font-sans)}
.widget:last-child{margin-bottom:0}
.sidebar .widget{background:var(--color-surface-2);border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:1.2rem}
.sidebar .widget a{color:var(--color-ink)}
.sidebar .widget a:hover{color:var(--color-accent-dark)}

/* Judul kotak — pita gelap direntangkan ke tepi kotak, titik aksen di depan */
.widget-title{
  font-size:.9375rem;font-weight:700;font-family:var(--font-head);
  text-transform:uppercase;letter-spacing:-.01em;line-height:1.1;
  background:var(--color-ink);color:var(--color-white);
  padding:.5rem .8rem;margin:-1.2rem -1.2rem 1.1rem;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0
}
.widget-title::before{content:"";display:inline-block;width:.7em;height:.7em;background:var(--color-accent);margin-right:.5em;vertical-align:baseline}

/* Daftar "Terpopuler" — nomor urut beraksen */
.popular-list{counter-reset:pop;display:grid;gap:0}
.popular-list li{display:flex;gap:1rem;align-items:flex-start;padding:.9rem 0;border-bottom:1px solid var(--color-line)}
.popular-list li:last-child{border-bottom:0;padding-bottom:0}
.popular-list li::before{counter-increment:pop;content:counter(pop,decimal-leading-zero);font-family:var(--font-head);font-size:var(--step-1);font-weight:700;color:var(--color-accent);line-height:.8;min-width:1.6ch}
.popular-list .p-title{font-family:var(--font-head);font-weight:700;color:var(--color-ink);font-size:.9375rem;line-height:1.35}
.popular-list .p-title:hover{color:var(--color-accent-dark)}
.popular-list .p-meta{font-size:var(--step--1);color:var(--color-muted);margin-top:.2rem}

/* Daftar "Topik Populer" — tag berformat #NamaTag sebagai pill */
.topic-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0;list-style:none}
.topic-list li{margin:0}
.topic-list a{display:inline-block;font-family:var(--font-sans);font-weight:700;font-size:var(--step--1);color:var(--color-ink);background:var(--color-surface);border:1px solid var(--color-line);padding:.4rem .75rem;line-height:1.2;transition:background .15s ease,color .15s ease,border-color .15s ease}
.topic-list a:hover{background:var(--color-accent);border-color:var(--color-accent);color:var(--on-accent)}
.topic-list .topic-hash{color:var(--color-accent);font-weight:800;margin-right:.1em}
.topic-list a:hover .topic-hash{color:var(--on-accent)}

/* ── SLOT IKLAN (Ads Manager) ──────────────────────────────
   .kk-ad-slot dipakai di sidebar & beranda. Placeholder bergaris
   putus hanya tampil untuk admin yang login. */
.kk-ad-slot{position:relative}
.kk-ad-slot__label{display:block;font-size:9px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--color-faint);margin-bottom:.35rem}
.kk-ad-body{line-height:0}
.kk-ad-body img{max-width:100%;height:auto;display:block;margin-inline:auto}
.kk-ad-link{display:block}
/* Placeholder (hanya admin) */
.kk-ad-placeholder{background:var(--color-surface-2);border:2px dashed var(--color-line-strong);display:grid;place-items:center;gap:.2rem;min-height:120px;padding:1rem;text-align:center;line-height:1.3}
.kk-ad-placeholder__label{font-family:var(--font-sans);font-size:var(--step--1);text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--color-faint)}
.kk-ad-placeholder__hint{font-family:var(--font-sans);font-size:var(--step--2);color:var(--color-muted);font-weight:600}
/* Slot iklan beranda (full-width, di antara section) */
.kk-ad-slot--home-after-latest,
.kk-ad-slot--home-between-cat,
.kk-ad-slot--home-after-cat{margin-block:1.5rem;text-align:center}
.kk-ad-slot--home-after-latest .kk-ad-placeholder,
.kk-ad-slot--home-between-cat .kk-ad-placeholder,
.kk-ad-slot--home-after-cat .kk-ad-placeholder{min-height:90px}
/* Slot iklan sidebar mengisi penuh lebar kotak widget */
.widget-ad .kk-ad-placeholder{min-height:250px}
/* Slot iklan sidebar: tampil polos — tanpa background, border, padding,
   dan tanpa label widget. Hanya iklan saja. */
.sidebar .widget-ad{background:none;border:0;border-radius:0;padding:0}
.widget-ad .kk-ad-slot__label{display:none}
/* Strip iklan header & footer (full-width di dalam .wrap) */
.kk-ad-header-strip{margin-block:1rem;text-align:center}
.kk-ad-footer-strip{margin-block:1.5rem;text-align:center}

/* ============================================================
   §09  PAGINASI
   ============================================================ */
.pagination{display:flex;justify-content:center;gap:.4rem;margin:3rem 0;font-family:var(--font-sans)}
.pagination .page-numbers{min-width:46px;height:46px;display:grid;place-items:center;padding:0 .6rem;background:var(--color-surface-2);font-weight:800;color:var(--color-body)}
.pagination .page-numbers:hover{background:var(--color-ink);color:var(--color-white)}
.pagination .current{background:var(--color-accent);color:var(--on-accent)}
.pagination .dots{background:none}

/* ============================================================
   §10  KOMENTAR
   ============================================================ */
.comments-area{margin:3rem 0}
.comments-title{font-size:var(--step-2);margin-bottom:1.5rem;text-transform:uppercase}
.comment-list li{margin-bottom:1.5rem}
.comment-body{display:flex;gap:1rem}
.comment-body img{width:46px;height:46px;border-radius:50%}
.comment-meta{font-family:var(--font-sans);font-size:var(--step--1);color:var(--color-muted);margin-bottom:.3rem}
.comment-meta strong{color:var(--color-ink);font-size:var(--step-0)}
.comment-list .children{margin-left:2.5rem;margin-top:1.5rem}
.comment-form input,.comment-form textarea{width:100%;padding:.75rem .9rem;border:2px solid var(--color-line-strong);font:inherit;margin-bottom:1rem}
.comment-form textarea{min-height:140px}
.comment-form .submit{background:var(--color-accent);color:var(--on-accent);border:0;padding:.85rem 1.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.comment-form .submit:hover{background:var(--color-ink);color:var(--color-white)}

/* ============================================================
   §11  FOOTER
   ============================================================ */
.site-footer{background:var(--color-ink);color:var(--color-on-dark);margin-top:4rem;font-family:var(--font-sans)}
.footer-top{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr) var(--sidebar-w);gap:2rem;padding-block:3.5rem}
.footer-brand{margin-bottom:.8rem}
.footer-brand-text{font-family:var(--font-head);font-weight:700;font-size:2.2rem;color:var(--color-white);text-transform:uppercase;letter-spacing:-.02em}
.footer-brand .dot{display:inline-block;width:.3em;height:.3em;background:var(--color-accent)}
/* Logo di footer (latar gelap) → dibuat putih otomatis */
.footer-brand .custom-logo{height:46px;width:auto;max-width:220px;object-fit:contain;filter:brightness(0) invert(1)}
.footer-brand .custom-logo-link{display:inline-block;line-height:0}
.footer-col h4{font-size:var(--step--1);text-transform:uppercase;letter-spacing:.12em;color:var(--color-white);margin-bottom:1.1rem;font-weight:800;font-family:var(--font-sans)}
.footer-col li{margin-bottom:.55rem}
.footer-links{margin:0;padding:0;list-style:none}
.footer-links li{margin-bottom:.55rem}
.footer-links a{color:var(--color-on-dark);font-family:var(--font-sans);font-size:var(--step-0)}
.footer-col a:hover,.footer-links a:hover{color:var(--color-accent)}


.footer-social{display:flex;gap:.6rem;margin-top:1rem}
.footer-social a{width:40px;height:40px;display:grid;place-items:center;background:#1c1c1c}
.footer-social a:hover{background:var(--color-accent);color:var(--on-accent)}
.footer-social svg{width:17px;height:17px;fill:currentColor}
.footer-bottom{border-top:1px solid #222;padding-block:1.4rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:var(--step--1)}
@media(max-width:780px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-top{grid-template-columns:1fr}}

/* ============================================================
   §12  UTIL
   ============================================================ */
.btn{display:inline-block;font-family:var(--font-sans);font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:.8rem 1.5rem;background:var(--color-accent);color:var(--on-accent);transition:var(--tr)}
.btn:hover{background:var(--color-ink);color:var(--color-white)}
.btn-outline{background:transparent;border:2px solid var(--color-ink);color:var(--color-ink)}
.btn-outline:hover{background:var(--color-ink);color:var(--color-white)}
.no-scroll{overflow:hidden}

/* ============================================================
   §13  DARK MODE
   ============================================================ */
[data-theme="dark"]{
  --color-ink:         #f5f5f2;
  --color-body:        #cfcfca;
  --color-muted:       #8d8d86;
  --color-faint:       #5a5a55;
  --color-line:        #262624;
  --color-line-strong: #383834;
  --color-surface:     #0f0f0e;
  --color-surface-2:   #181816;
  --color-surface-3:   #222220;
  --on-accent:         var(--color-white);
}
[data-theme="dark"] .site-header{background:var(--color-surface);border-bottom-color:var(--color-accent)}
[data-theme="dark"] .site-topbar{background:var(--color-surface-2)}
[data-theme="dark"] .article-body pre,[data-theme="dark"] .author-box{background:#000}
/* Kutipan di dark mode: pakai latar gelap lembut (bukan hitam pekat) + teks terang */
[data-theme="dark"] .article-body blockquote{background:var(--color-surface-2);color:var(--color-white)}
[data-theme="dark"] .widget-title,[data-theme="dark"] .sec-head .tagblock{background:var(--color-accent);color:var(--on-accent)}
[data-theme="dark"] .article-body th{background:var(--color-accent);color:var(--on-accent)}
