/*
Theme Name: Wiras News
Theme URI: https://wiramas.com/
Author: Sosiakita
Description: Tema micro untuk /news — listing + single fokus baca, SEO/Schema, FAQ, Quick Summary, TOC, share icons, related, breadcrumb, header+topbar, footer corporate.
Version: 1.3.1
Text Domain: wiras-news
*/

:root{
  --wiras-red:#e81c25;
  --wiras-dark:#000;
  --wiras-muted:#6b6b6b;
  --wiras-soft:#f5f6f7;
  --wiras-bg:#fff;

  /* Nudge halus agar logo header segaris rail kiri (atur -10..0 px sesuai kebutuhan) */
  --logo-nudge-desktop:-25px;
  --logo-nudge-mobile:-10px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--wiras-bg);color:#111;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:var(--wiras-red);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}

/* Containers */
.container{width:min(1200px,92%);margin:0 auto}
.reading-container{width:min(820px,92%);margin:50px auto}
section{padding:0}

/* Typography */
h1,h2,h3,h4,h5,h6{font-family:Raleway,Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#000}
.entry-header h1{font-size:clamp(28px,4.2vw,42px);line-height:1.18;margin:8px 0 10px}

/* ===== Topbar ===== */
.topbar{background:#111;color:#fff;font-size:14px}
.topbar .inner{display:flex;gap:18px;align-items:center;justify-content:flex-end;padding:8px 0}
.topbar a{color:#fff;display:flex;align-items:center;gap:8px}

/* ===== Header (sticky & sejajar grid) ===== */
.site-header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid #eee}
.site-header .container{width:min(1200px,92%);margin:0 auto;padding:0} /* sejajar rail */
.site-header .row{display:flex;align-items:center;justify-content:flex-start;gap:28px;padding:12px 0}
.brand{display:flex;align-items:center}
.custom-logo{max-height:65px;height:auto;width:auto;display:block;margin-left:var(--logo-nudge-desktop)} /* desktop nudge */
@media (max-width:640px){ .custom-logo{max-height:40px} }

/* Desktop nav */
.primary-nav ul{list-style:none;display:flex;gap:22px;margin:0;padding:0}
.primary-nav a{color:#111;font-weight:600}

/* Mobile trigger */
.menu-toggle{display:none;background:transparent;border:0;width:44px;height:44px;border-radius:10px}
.menu-toggle svg{width:24px;height:24px}
@media (max-width:900px){ .primary-nav{display:none} .menu-toggle{display:block} }

/* Mobile overlay menu — fullwidth, center, font besar */
.mobile-menu{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .25s;z-index:1100}
.mobile-menu .inner{position:absolute;inset:0;background:#fff;display:grid;grid-template-rows:auto 1fr;padding:18px}
.mobile-menu[data-open="1"]{opacity:1;pointer-events:auto}
.mobile-menu .close{background:#f5f5f5;border:1px solid #eee;border-radius:10px;padding:8px 12px;justify-self:start}
.mobile-menu ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:20px;align-items:center;justify-content:center;height:100%}
.mobile-menu a{display:block;padding:10px 12px;border-radius:10px;color:#111;font-weight:700;font-size:22px}
.mobile-menu a:hover{background:#f7f7f7}

/* ===== HERO ===== */
.grid.hero4{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin:16px 0 22px}
.grid.hero4 .big,.grid.hero4 .tile{position:relative;border-radius:14px;overflow:hidden;background:#f4f4f4}
.grid.hero4 img{width:100%;height:100%;object-fit:cover}
.grid.hero4 .caption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));color:#fff;font-weight:800}
.grid.hero4 .meta-date{font-weight:600;opacity:.9;margin-top:4px}
.grid.hero4 .side{display:grid;grid-template-columns:1fr;gap:18px}

/* Hover/zoom — hero */
.grid.hero4 .big,.grid.hero4 .tile{transition:transform .25s ease,box-shadow .25s ease}
.grid.hero4 .big img,.grid.hero4 .tile img{transition:transform .32s ease}
.grid.hero4 .big:hover,.grid.hero4 .tile:hover,.grid.hero4 .big.is-hover,.grid.hero4 .tile.is-hover{transform:translateY(-4px);box-shadow:0 12px 26px rgba(0,0,0,.08)}
.grid.hero4 .big:hover img,.grid.hero4 .tile:hover img,.grid.hero4 .big.is-hover img,.grid.hero4 .tile.is-hover img{transform:scale(1.045)}

/* ===== Filter bar ===== */
.filterbar{border:1px solid #eee;border-radius:12px;padding:12px 14px;background:#fafafa;margin:12px 0 22px}
.filterbar .btn{background:var(--wiras-red);color:#fff;border:none;border-radius:10px;padding:.55rem .9rem;cursor:pointer}

/* ===== Cards grid ===== */
.grid.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:1024px){ .grid.cards{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){ .grid.cards{grid-template-columns:1fr} }

.card{border:1px solid #eee;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;background:#fff;transition:transform .25s ease, box-shadow .25s ease}
.card .thumb{aspect-ratio:16/10;background:#f4f4f4;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .32s ease}
.card .body{padding:12px 14px}
.card .meta{color:#666;font-size:13px;margin-top:4px}

/* Hover/zoom — cards */
.card:hover,.card.is-hover{transform:translateY(-4px);box-shadow:0 12px 26px rgba(0,0,0,.08)}
.card:hover .thumb img,.card.is-hover .thumb img{transform:scale(1.045)}

/* Stagger appear */
.grid.cards > a.card{opacity:0;transform:translateY(12px);animation:wiras-rise .45s ease forwards}
.grid.cards > a.card:nth-child(1){animation-delay:.0s}
.grid.cards > a.card:nth-child(2){animation-delay:.05s}
.grid.cards > a.card:nth-child(3){animation-delay:.1s}
.grid.cards > a.card:nth-child(4){animation-delay:.15s}
.grid.cards > a.card:nth-child(5){animation-delay:.2s}
.grid.cards > a.card:nth-child(6){animation-delay:.25s}
.grid.cards > a.card:nth-child(7){animation-delay:.3s}
.grid.cards > a.card:nth-child(8){animation-delay:.35s}
.grid.cards > a.card:nth-child(9){animation-delay:.4s}
@keyframes wiras-rise{to{opacity:1;transform:none}}

/* ===== Pagination (longgar) ===== */
.pagination{margin:24px 0;display:flex;flex-wrap:wrap;gap:12px}
.pagination .page-link .page-numbers{display:inline-block;padding:9px 15px;border:1px solid #eee;border-radius:10px;margin:0 3px;line-height:1.1}
.pagination .page-link .current{background:var(--wiras-red);color:#fff;border-color:var(--wiras-red)}

/* ===== Breadcrumb ===== */
.breadcrumb{font-size:14px;color:#666;margin:6px 0 10px}
.breadcrumb a{color:#666}

/* ===== Single post elements ===== */
.entry-meta{color:#666;font-size:14px;margin-bottom:12px}
.featured{margin:14px 0;border-radius:12px;overflow:hidden}
.toc{border:1px solid #eee;border-radius:12px;padding:12px 14px;background:#fafafa;margin:16px 0;position:relative}
.toc h3{margin:0 0 8px 0;font-size:16px;display:flex;align-items:center;justify-content:space-between}
.toc .toggle{font-size:13px;border:1px solid #ddd;border-radius:8px;background:#fff;padding:4px 8px;cursor:pointer}
.toc ol{margin:8px 0 0 18px;padding:0}
.toc li{margin:4px 0}
.quick-summary{border-left:4px solid var(--wiras-red);background:#fff5f5;padding:12px 14px;border-radius:8px;margin:16px 0;color:#333}
.tags{margin:18px 0}
.tags a{background:#f5f5f5;border-radius:999px;padding:6px 10px;margin-right:6px;display:inline-block;color:#333}

/* Share icons */
.share{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:10px 0}
.share .label{font-weight:700;color:#333;margin-right:6px}
.share a{border:1px solid #eee;border-radius:10px;padding:6px;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px}
.share svg{display:block}

/* Author box */
.author-box{display:flex;gap:14px;align-items:center;border:1px solid #eee;border-radius:12px;padding:12px 14px;background:#fff;margin:22px 0}
.author-box .name{font-weight:800}

/* Comments */
.comment-respond{border:1px solid #eee;border-radius:12px;padding:16px;background:#fff;margin:24px 0}
.comment-respond h3{margin-top:0;font-size:18px;font-weight:800}
.comment-form p{margin:10px 0}
.comment-form label{display:block;font-weight:600;margin-bottom:4px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;padding:.7rem .8rem;border:1px solid #ddd;border-radius:10px}
.comment-form textarea{min-height:140px}
.comment-form .submit{background:var(--wiras-red);color:#fff;border:none;border-radius:10px;padding:.7rem 1rem;cursor:pointer}
.comment-list{list-style:none;margin:0 0 16px 0;padding:0}
.comment-list .comment{border-bottom:1px solid #f0f0f0;padding:12px 0}
.comment-meta{font-size:13px;color:#666}

/* ===== Related grid (2 kolom desktop / 1 kolom mobile) ===== */
.related .items{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media (max-width:900px){ .related .items{grid-template-columns:1fr} }
.related .items .card .thumb{aspect-ratio:16/9}

/* ===== Footer ===== */
.site-footer{background:var(--wiras-red);color:#fff;margin-top:100px} /* ruang putih lebih lebar */
.site-footer a{color:#fff}
.footer-top{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center;padding:50px 0} /* tinggi footer lebih besar */
.footer-brand .logo{display:flex;align-items:center}
.footer-brand .logo img{max-height:56px;height:auto;width:auto}
.footer-info{display:grid;grid-auto-rows:auto;gap:10px}
.footer-info .item{display:flex;gap:10px;align-items:center}
.footer-info svg{flex:0 0 18px}
.footer-bottom{text-align:center;border-top:1px solid rgba(255,255,255,.25);padding:16px 0;color:#fff}

/* Footer mobile -> 1 kolom berurutan */
@media (max-width:900px){
  .footer-top{grid-template-columns:1fr;gap:16px}
}

/* ===== To Top button (SVG) ===== */
.to-top{position:fixed;right:18px;bottom:18px;z-index:1200;width:44px;height:44px;border-radius:999px;border:1px solid #eee;background:#fff;color:#111;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(0,0,0,.12);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .25s, transform .25s}
.to-top.show{opacity:1;pointer-events:auto}
.to-top:hover{transform:translateY(-2px)}

/* ===== Spacing di bawah header ===== */
.site-header + .container,
.site-header + .reading-container,
.site-header + section,
.site-header + main,
.site-header + div { margin-top:40px !important; }
@media (min-width:900px){
  .site-header + .container,
  .site-header + .reading-container,
  .site-header + section,
  .site-header + main,
  .site-header + div { margin-top:50px !important; }
}

/* === Mobile header: burger di kanan === */
@media (max-width:900px){
  .site-header .row{justify-content:space-between !important;gap:14px !important}
  .primary-nav{display:none !important}
  .menu-toggle{margin-left:auto !important;width:44px;height:44px}
  .custom-logo{margin-left:var(--logo-nudge-mobile)} /* nudge mobile */
}

/* === HERO: mobile carousel swipe untuk tile kanan (Opsi B) === */
@media (max-width:640px){
  .grid.hero4{grid-template-columns:1fr;gap:14px}
  .grid.hero4 .side{
    display:grid;
    grid-auto-flow:column;
    grid-auto-columns:85%;
    gap:12px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    padding-bottom:6px;
    -webkit-overflow-scrolling:touch;
  }
  .grid.hero4 .side .tile{scroll-snap-align:start}
  .grid.hero4 .caption{
    padding:14px;font-size:16px;line-height:1.25;
    background:linear-gradient(180deg,transparent 10%,rgba(0,0,0,.65));
  }
}

/* === [Patch] FILTER NAV (search + category chips) === */
.filter-nav{border:1px solid #eee;border-radius:12px;padding:12px 14px;background:#fafafa;margin:12px 0 22px;display:flex;gap:16px;align-items:center;justify-content:space-between}
.filter-nav .search{display:flex;gap:8px;align-items:center;flex:1}
.filter-nav .search input[type=search]{flex:1;border:1px solid #ddd;border-radius:10px;padding:.6rem .8rem;background:#fff}
.filter-nav .search button{border:1px solid #ddd;background:#fff;border-radius:10px;padding:.55rem .9rem;cursor:pointer}
.filter-nav .cats{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;max-width:60%}
.filter-nav .chip{display:inline-block;border:1px solid #eee;border-radius:999px;padding:8px 12px;background:#fff;color:#333;text-decoration:none;white-space:nowrap}
.filter-nav .chip.active{background:var(--wiras-red);color:#fff;border-color:var(--wiras-red)}
@media (max-width:900px){ .filter-nav{flex-direction:column;align-items:stretch} .filter-nav .cats{max-width:none;overflow:auto} }

/* === [Patch] Footer 3 columns === */
.footer-top{display:grid;grid-template-columns:1.2fr 1.2fr .9fr;gap:24px;align-items:start;padding:50px 0}
.footer-col h4.footer-heading{margin:0 0 10px;font-size:18px;font-weight:800;color:#fff}
.footer-col .company-desc{margin:10px 0 0;color:#fff;font-weight:300;opacity:.95}
.office-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.office-list .item{display:flex;gap:10px;align-items:flex-start;color:#fff;font-weight:300}
.office-list svg{flex:0 0 18px}
.footer-links a{display:block;margin:8px 0;color:#fff;font-weight:300;opacity:.95;text-decoration:none}
.footer-links a:hover{opacity:1;text-decoration:underline}

@media (max-width:900px){ .footer-top{grid-template-columns:1fr} }

/* ===== WIRAS: Footer, Search Cards, Back-to-Top (paste at the end) ===== */

/* Align logo & about text */
.site-footer .footer-top{align-items:start}
.site-footer .footer-col.footer-about .footer-logo-wrap,
.site-footer .footer-col.footer-about .footer-logo-wrap .custom-logo-link{
  margin:0!important; padding:0!important; line-height:0;
}
.site-footer .footer-col.footer-about img.custom-logo,
.site-footer .footer-col.footer-about .footer-logo{
  display:block; margin:0!important; height:auto;
}
.site-footer .footer-col.footer-about .about-text{ margin-left:0!important; }

/* Footer headings: bold putih */
.site-footer .footer-col h4{ color:#fff!important; font-weight:800!important; }

/* Footer body: light putih */
.site-footer .footer-col p,
.site-footer .footer-col li,
.site-footer .footer-col a,
.site-footer .footer-links a{
  color:#fff!important; font-weight:300!important; text-decoration:none;
}
.site-footer .footer-links a:hover{ text-decoration:underline; }

/* Ikon footer ikut putih */
.site-footer .footer-list .ico,
.site-footer .footer-list .ico svg{ color:#fff!important; stroke:currentColor; }

/* Default link footer putih */
.site-footer a{ color:#fff!important; }

/* --- Search grid/card compat --- */
.grid.cards .card .body{ padding:12px 14px; }
.grid.cards .card .title{ font-size:22px; line-height:1.3; margin:6px 0 8px; }
.grid.cards .card .title a{ text-decoration:none; color:#111; }
.grid.cards .card .title a:hover{ color:var(--wiras-red, #e3372e); }
.grid.cards .card .readmore{
  display:inline-block; color:var(--wiras-red, #e3372e); font-weight:700; text-decoration:none; margin-top:.3rem;
}

/* --- Hide kategori "Uncategorized" pada chips kategori --- */
.filter-nav .cats a[href*="/category/uncategorized/"]{ display:none!important; }

/* --- Back-to-Top: style & override agar tidak ikut putih total --- */
#backToTop, #toTop, .toTop, .back-to-top, a.back-to-top, .scroll-top, .go-top, .gotop{
  position:fixed; right:22px; bottom:22px;
  width:52px; height:52px; border-radius:999px;
  background:#fff; color:var(--wiras-red, #e3372e);
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(0,0,0,.06); box-shadow:0 8px 18px rgba(0,0,0,.16);
  text-decoration:none; z-index:9999; cursor:pointer;
}
.site-footer .back-to-top,
.site-footer a.back-to-top,
.site-footer #backToTop,
.site-footer #toTop{
  color:var(--wiras-red, #e3372e)!important; background:#fff!important;
}
#backToTop svg, #toTop svg, .toTop svg, .back-to-top svg, .scroll-top svg, .go-top svg, .gotop svg{
  width:22px; height:22px; stroke:currentColor; fill:none; stroke-width:2;
}
#backToTop:hover, #toTop:hover, .toTop:hover, .back-to-top:hover, .scroll-top:hover, .go-top:hover, .gotop:hover{
  background:var(--wiras-red, #e3372e); color:#fff;
}
@media (max-width:900px){
  #backToTop, #toTop, .toTop, .back-to-top, a.back-to-top, .scroll-top, .go-top, .gotop{
    right:16px; bottom:16px; width:46px; height:46px;
  }
}

/* === MOBILE POLISH === */

/* 1) Kategori (chips) di atas grid -> jadi 1 baris swipe, tidak turun */
@media (max-width:640px){
  .filter-nav{ gap:10px; }
  .filter-nav .cats{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:nowrap;              /* kunci: jangan bungkus */
    overflow-x:auto;               /* bisa di-swipe */
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;
    padding:6px 2px 10px;
    justify-content:center;        /* ganti ke flex-start kalau mau rata kiri */
    mask-image:linear-gradient(90deg,transparent,#000 12px,#000 calc(100% - 12px),transparent);
  }
  .filter-nav .cats::after{content:'';flex:0 0 12px;} /* ruang napas di ujung */
  .filter-nav .chip{
    flex:0 0 auto;                 /* item tetap satu baris */
    padding:6px 12px;              /* sedikit lebih kecil */
    font-size:14px;
    scroll-snap-align:center;
    white-space:nowrap;
  }
}

/* === FIX: chip terakhir ("Semua") kepotong di kanan === */
@media (max-width:640px){
  .filter-nav .cats{
    /* ruang ekstra di kanan agar item terakhir bisa tampak penuh */
    padding-right:24px;
    scroll-padding-right:24px;

    /* pertahankan efek fade tapi geser batas aman sedikit lebih dalam */
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 16px, #000 calc(100% - 28px), transparent);
            mask-image: linear-gradient(90deg, transparent, #000 16px, #000 calc(100% - 28px), transparent);
  }
  /* spacer real di ujung agar scroll area memang lebih lebar */
  .filter-nav .cats::after{ content:''; flex:0 0 28px; }

  /* snap yang lebih “nempel” ke item */
  .filter-nav .chip{ scroll-snap-stop: always; }
}

/* OPSI SEDERHANA (kalau masih terasa kepotong di beberapa device):
   Matikan fade di mobile */
@media (max-width:640px){
  .filter-nav .cats.no-fade,
  .filter-nav .cats.disable-fade{
    -webkit-mask-image:none; mask-image:none;
  }
}
/* Tambahkan class .no-fade di HTML jika mau mematikan fadanya khusus halaman itu */

  
  /* optional: sembunyikan scrollbar webkit
  .filter-nav .cats::-webkit-scrollbar{display:none}
  */


/* 2) Share Artikel -> tetap satu baris, swipe kalau sempit */
@media (max-width:640px){
  .share{
    gap:8px;
    flex-wrap:nowrap;              /* cegah turun baris */
    overflow-x:auto;               /* bisa di-swipe */
    -webkit-overflow-scrolling:touch;
    padding-bottom:6px;
    justify-content:center;        /* ganti ke flex-start jika mau rata kiri */
  }
  .share .label{
    font-size:14px;
    flex:0 0 auto;
    margin-right:4px;
    white-space:nowrap;            /* teks label tidak pecah */
  }
  .share a{
    width:34px; height:34px;       /* ikon sedikit lebih kecil agar muat */
    flex:0 0 34px;
  }
  .share svg{ width:18px; height:18px; }
}

/* === Post body media safety === */
.post-content img,
.entry-content img,
.article-body img,
.post-body img,
.wp-block-image img,
figure img {
  display: block;
  max-width: 100% !important;   /* menahan gambar di dalam lebar kontainer */
  height: auto !important;      /* rasio aman */
}

/* Figure & caption tidak overflow */
.entry-content figure,
.wp-caption { max-width: 100%; overflow: hidden; }
.wp-caption .wp-caption-text { 
  font-size: .875rem; 
  color: var(--wiras-muted,#6b6b6b); 
  text-align: center; 
  margin-top: .35rem; 
}

/* Matikan “full/wide” yang bikin keluar kontainer */
.entry-content .alignfull,
.entry-content .alignwide {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Align left/right tetap rapi di desktop, kembali penuh di mobile */
@media (min-width: 768px){
  .entry-content img.alignleft  { float:left;  margin:0 1rem 1rem 0;  max-width: min(50%,100%); }
  .entry-content img.alignright { float:right; margin:0 0 1rem 1rem; max-width: min(50%,100%); }
}
@media (max-width: 767px){
  .entry-content img.alignleft,
  .entry-content img.alignright { float:none; margin:0 auto 1rem; }
}