/* ==========================================================
   Arena Garuda — style.css
   Premium Sport Magazine — Liga 1, Timnas, Liga Eropa
========================================================== */

:root{
  /* surface */
  --bg-base:#0A0E1A;
  --bg-elev:#131A2E;
  --bg-elev-2:#1A2238;
  --bg-card:rgba(255,255,255,0.04);
  --bg-card-hover:rgba(255,255,255,0.07);

  /* lines & strokes */
  --line:rgba(255,255,255,0.06);
  --border:rgba(255,255,255,0.10);
  --border-strong:rgba(225,29,72,0.40);

  /* accents */
  --red:#E11D48;
  --red-bright:#F43F5E;
  --gold:#FCD34D;
  --gold-soft:#FDE68A;
  --blue:#3B82F6;
  --green:#10B981;

  /* text */
  --text:#F8FAFC;
  --muted:#CBD5E1;
  --soft:#94A3B8;
  --dim:#64748B;

  /* shape */
  --r-xl:24px;
  --r-lg:18px;
  --r-md:12px;
  --r-sm:8px;
  --r-pill:999px;

  /* motion */
  --t:.25s cubic-bezier(.2,.7,.2,1);
  --t-slow:.45s cubic-bezier(.2,.7,.2,1);

  /* layout */
  --maxw:1240px;
}

/* ===== Reset & base ===== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--bg-base);
  background-image:
    radial-gradient(900px 500px at 90% -10%, rgba(225,29,72,.08), transparent 60%),
    radial-gradient(700px 400px at -5% 12%, rgba(252,211,77,.05), transparent 55%);
  background-attachment:fixed;
  min-height:100vh;
  line-height:1.6;
  overflow-x:hidden;
  font-feature-settings:"cv02","cv03","cv04","cv11","ss01";
}

a{color:var(--red-bright);text-decoration:none;transition:color var(--t)}
a:hover{color:#fb7185}
img,svg{max-width:100%;display:block}

h1,h2,h3,h4,h5{font-weight:800;line-height:1.12;margin:0 0 12px;color:#fff;letter-spacing:-.025em}
h1{font-size:clamp(2.2rem,4.5vw,3.4rem);letter-spacing:-.035em}
h2{font-size:clamp(1.6rem,3vw,2.2rem);letter-spacing:-.025em}
h3{font-size:1.15rem;letter-spacing:-.01em}
h4{font-size:1rem;letter-spacing:-.005em}
p{margin:0 0 14px;color:var(--muted)}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:60px 0;position:relative}
.section-sm{padding:40px 0}
.section-tight{padding:24px 0}

.center{text-align:center}
.muted{color:var(--muted)}
.dim{color:var(--soft)}
.tight{letter-spacing:-.025em}

/* ===== TOPBAR ===== */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(10,14,26,.88);
  border-bottom:1px solid var(--line);
  backdrop-filter:saturate(160%) blur(16px);
  -webkit-backdrop-filter:saturate(160%) blur(16px);
}
.topbar-wrap{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;max-width:var(--maxw);margin:0 auto;gap:18px;
}

/* === LOGO (simple elegan ala Goal.com) === */
.brand{
  display:inline-flex;align-items:center;gap:10px;
  color:#fff;font-weight:900;font-size:1.15rem;
  letter-spacing:-.035em;text-decoration:none;
}
.brand .mark{
  width:34px;height:34px;border-radius:9px;
  background-image:url("/favicon.svg");
  background-size:cover;background-position:center;
  position:relative;flex-shrink:0;
  box-shadow:0 4px 14px rgba(225,29,72,.35);
}
.brand .name{
  display:inline-flex;align-items:baseline;gap:1px;
  font-weight:900;
}
.brand .name .dot{
  color:var(--red);font-size:1.3em;line-height:0;margin:0 1px;
}

/* === NAV === */
.nav{display:flex;gap:0;align-items:center;list-style:none;margin:0;padding:0}
.nav a{
  color:var(--muted);font-weight:600;padding:10px 16px;
  transition:all var(--t);font-size:.92rem;
  position:relative;
}
.nav a:hover{color:#fff}
.nav a.active{color:#fff}
.nav a.active::after{
  content:"";position:absolute;bottom:-15px;left:16px;right:16px;
  height:2px;background:var(--red);
}

.cta-search{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--muted);cursor:pointer;transition:all var(--t);
}
.cta-search:hover{background:rgba(255,255,255,.08);color:#fff}

.menu-toggle{
  display:none;background:transparent;border:1px solid var(--border);color:#fff;
  padding:8px 10px;border-radius:8px;cursor:pointer;
}

/* ===== TICKER (live score-style strip) ===== */
.ticker{
  background:linear-gradient(90deg, rgba(225,29,72,.08), rgba(252,211,77,.04) 50%, rgba(225,29,72,.08));
  border-bottom:1px solid var(--line);
  overflow:hidden;
  position:relative;
}
.ticker-track{
  display:flex;align-items:center;gap:36px;padding:10px 24px;
  white-space:nowrap;animation:tickerScroll 40s linear infinite;
}
.ticker-item{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.84rem;color:var(--muted);font-weight:500;
}
.ticker-item .lbl{color:var(--gold);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem}
.ticker-item .scr{color:#fff;font-weight:800;letter-spacing:-.01em}
.ticker-item .vs{color:var(--soft);font-size:.78rem;margin:0 4px}
@keyframes tickerScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 18px;border-radius:var(--r-sm);font-weight:700;cursor:pointer;
  border:1px solid transparent;font-size:.9rem;transition:all var(--t);
  text-decoration:none;font-family:inherit;letter-spacing:-.005em;
}
.btn-primary{
  background:var(--red);color:#fff;box-shadow:0 6px 18px rgba(225,29,72,.28);
}
.btn-primary:hover{background:var(--red-bright);transform:translateY(-1px);box-shadow:0 10px 24px rgba(225,29,72,.4);color:#fff}
.btn-ghost{background:rgba(255,255,255,.04);color:#fff;border-color:var(--border)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--border-strong)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid #fff}
.btn-outline:hover{background:#fff;color:var(--bg-base)}
.btn-sm{padding:7px 13px;font-size:.82rem;border-radius:6px}

/* ===== Tag / Label ===== */
.tag{
  display:inline-block;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:4px;color:#fff;
  background:var(--red);
}
.tag.gold{background:var(--gold);color:var(--bg-base)}
.tag.blue{background:var(--blue);color:#fff}
.tag.green{background:var(--green);color:#fff}
.tag.outline{background:transparent;border:1px solid var(--border);color:var(--muted)}

.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 11px;border-radius:var(--r-pill);
  font-size:.74rem;color:var(--muted);font-weight:600;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--red)}
.pill.live .dot{background:var(--red);box-shadow:0 0 8px var(--red);animation:liveBlink 1.5s infinite}
.pill.live{color:#fff;border-color:var(--red);background:rgba(225,29,72,.12)}
@keyframes liveBlink{50%{opacity:.4}}

.meta{
  display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-size:.78rem;color:var(--soft);font-weight:500;
}
.meta .sep{color:var(--dim)}
.meta a{color:var(--muted);font-weight:600}
.meta a:hover{color:#fff}

/* ===== HERO featured article ===== */
.hero-featured{
  display:grid;grid-template-columns:1.4fr .9fr;gap:24px;
  margin:30px 0;
}
.feat-main{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(135deg,#1a2238,#0a0e1a);
  border:1px solid var(--border);
  min-height:480px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:36px;
}
.feat-main::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    linear-gradient(180deg,transparent 30%, rgba(10,14,26,.7) 70%, rgba(10,14,26,.95)),
    radial-gradient(circle at 70% 30%, rgba(225,29,72,.35), transparent 60%),
    linear-gradient(135deg, #1f2a44, #0a0e1a);
}
.feat-main::after{
  content:"";position:absolute;inset:0;z-index:0;opacity:.15;
  background-image:repeating-linear-gradient(45deg, transparent, transparent 6px, rgba(255,255,255,.04) 6px, rgba(255,255,255,.04) 7px);
}
.feat-main > *{position:relative;z-index:1}
.feat-main .tag{margin-bottom:14px}
.feat-main h1{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:14px}
.feat-main p{color:var(--muted);font-size:1rem;max-width:560px;margin-bottom:18px}

.feat-side{display:flex;flex-direction:column;gap:14px}
.feat-mini{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);padding:18px;
  display:flex;gap:14px;align-items:flex-start;
  transition:all var(--t);text-decoration:none;color:inherit;
}
.feat-mini:hover{background:var(--bg-card-hover);border-color:var(--border-strong);transform:translateX(2px)}
.feat-mini .num{
  font-size:1.8rem;font-weight:900;color:var(--red);
  line-height:1;flex-shrink:0;font-feature-settings:"tnum";
  letter-spacing:-.04em;
}
.feat-mini .body h3{font-size:.98rem;margin:0 0 4px;line-height:1.3}
.feat-mini .body .meta{font-size:.74rem}

/* ===== Section heading ===== */
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:24px;gap:20px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:14px;
}
.section-head .left{display:flex;align-items:center;gap:14px}
.section-head .left::before{
  content:"";width:4px;height:24px;background:var(--red);border-radius:2px;
}
.section-head h2{margin:0;font-size:1.4rem;letter-spacing:-.02em}
.section-head .right a{
  color:var(--muted);font-size:.84rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  display:inline-flex;align-items:center;gap:4px;
}
.section-head .right a:hover{color:#fff}

/* ===== Article cards (general grid) ===== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cards-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cards-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}

.card-article{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);overflow:hidden;
  transition:all var(--t);text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
}
.card-article:hover{background:var(--bg-card-hover);border-color:var(--border-strong);transform:translateY(-3px)}
.card-article .thumb{
  height:180px;position:relative;
  background:linear-gradient(135deg,#1f2a44,#0a0e1a);
  display:flex;align-items:flex-end;padding:14px;
}
.card-article .thumb::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 40%, rgba(225,29,72,.25), transparent 60%),
    linear-gradient(135deg, #1a2238, #0a0e1a);
}
.card-article .thumb .tag{position:relative;z-index:1}
.card-article .thumb.gold::before{background:radial-gradient(circle at 30% 40%, rgba(252,211,77,.25), transparent 60%), linear-gradient(135deg,#1a2238,#0a0e1a)}
.card-article .thumb.blue::before{background:radial-gradient(circle at 30% 40%, rgba(59,130,246,.25), transparent 60%), linear-gradient(135deg,#1a2238,#0a0e1a)}
.card-article .thumb.green::before{background:radial-gradient(circle at 30% 40%, rgba(16,185,129,.25), transparent 60%), linear-gradient(135deg,#1a2238,#0a0e1a)}
.card-article .body{padding:18px;flex:1;display:flex;flex-direction:column;gap:8px}
.card-article h3{font-size:1.05rem;line-height:1.3;margin:0;color:#fff}
.card-article .excerpt{font-size:.9rem;color:var(--muted);margin:0;flex:1}
.card-article .meta{margin-top:auto;padding-top:8px}

/* Compact card (no thumb) */
.card-compact{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);padding:18px;
  transition:all var(--t);text-decoration:none;color:inherit;
  display:block;
}
.card-compact:hover{background:var(--bg-card-hover);border-color:var(--border-strong)}
.card-compact .tag{margin-bottom:10px}
.card-compact h3{font-size:1rem;margin-bottom:6px;line-height:1.35}
.card-compact .meta{font-size:.74rem}

/* ===== Pillar nav (chips for category) ===== */
.pillar-chips{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:30px;
  padding-bottom:16px;border-bottom:1px solid var(--line);
}
.pillar-chip{
  padding:8px 16px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--muted);font-weight:600;font-size:.86rem;cursor:pointer;
  text-decoration:none;transition:all var(--t);
}
.pillar-chip:hover{background:rgba(255,255,255,.08);color:#fff}
.pillar-chip.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ===== STATS PANEL (tabel-like) ===== */
.stats-panel{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);overflow:hidden;
}
.stats-panel .sp-head{
  padding:14px 18px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:rgba(255,255,255,.02);
}
.stats-panel .sp-head h3{margin:0;font-size:.95rem;color:#fff}
.stats-panel .sp-head .meta{font-size:.74rem}
.stats-row{
  display:grid;grid-template-columns:36px 1fr auto;gap:14px;align-items:center;
  padding:12px 18px;border-bottom:1px solid var(--line);
  font-size:.92rem;
}
.stats-row:last-child{border-bottom:0}
.stats-row .rank{
  font-weight:800;color:var(--soft);font-size:.84rem;text-align:center;
  font-feature-settings:"tnum";
}
.stats-row .rank.top{color:var(--gold)}
.stats-row .name{color:#fff;font-weight:600}
.stats-row .name small{color:var(--soft);font-weight:400;margin-left:6px;font-size:.78rem}
.stats-row .val{color:var(--red-bright);font-weight:800;font-feature-settings:"tnum"}

/* ===== Match card (livescore-style) ===== */
.match-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);padding:16px;
  transition:all var(--t);
}
.match-card:hover{background:var(--bg-card-hover);border-color:var(--border-strong)}
.match-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.74rem;color:var(--soft);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.match-row{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center}
.match-team{display:flex;align-items:center;gap:8px}
.match-team.away{justify-content:flex-end;flex-direction:row-reverse}
.match-team .badge{
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(135deg,#1f2a44,#0a0e1a);
  border:1px solid var(--border);display:grid;place-items:center;
  font-weight:900;font-size:.7rem;color:#fff;flex-shrink:0;
}
.match-team .nm{font-weight:600;font-size:.92rem}
.match-score{
  font-weight:900;font-size:1.4rem;letter-spacing:-.02em;
  font-feature-settings:"tnum";text-align:center;min-width:60px;
}
.match-score .vs{color:var(--soft);font-size:.92rem;font-weight:500}

/* ===== Article body (single article page) ===== */
.article-page{max-width:780px;margin:0 auto}
.article-page .breadcrumb{margin:18px 0 14px;color:var(--soft);font-size:.84rem}
.article-page .breadcrumb a{color:var(--red-bright)}
.article-page .breadcrumb .sep{color:var(--dim);margin:0 6px}
.article-page .a-hero{margin-bottom:28px}
.article-page .a-hero .tag{margin-bottom:18px}
.article-page .a-hero h1{font-size:clamp(2rem,3.5vw,2.8rem);margin-bottom:14px;letter-spacing:-.025em}
.article-page .a-hero .lead{font-size:1.1rem;color:var(--muted);line-height:1.55}
.article-page .a-hero .meta{margin-top:18px;font-size:.86rem}
.article-page .a-hero .meta a{color:var(--red-bright)}

.article-cover{
  height:340px;border-radius:var(--r-lg);overflow:hidden;
  background:
    linear-gradient(135deg, rgba(225,29,72,.25), transparent 50%),
    linear-gradient(135deg, #1f2a44, #0a0e1a);
  position:relative;margin-bottom:32px;
  display:flex;align-items:flex-end;padding:28px;
  border:1px solid var(--border);
}
.article-cover::before{
  content:"";position:absolute;inset:0;opacity:.12;
  background-image:repeating-linear-gradient(45deg, transparent, transparent 6px, rgba(255,255,255,.06) 6px, rgba(255,255,255,.06) 7px);
}

.article-prose p{font-size:1.05rem;line-height:1.75;color:var(--muted);margin-bottom:18px}
.article-prose p:first-of-type::first-letter{
  font-size:3.6rem;font-weight:800;float:left;line-height:.85;
  padding:6px 12px 0 0;color:var(--red);
}
.article-prose h2{font-size:1.55rem;margin:36px 0 14px;letter-spacing:-.02em}
.article-prose h2::before{
  content:"";display:inline-block;width:4px;height:22px;background:var(--red);
  border-radius:2px;margin-right:12px;vertical-align:-3px;
}
.article-prose h3{font-size:1.2rem;margin:28px 0 12px}
.article-prose ul,.article-prose ol{padding-left:22px;color:var(--muted);margin-bottom:18px}
.article-prose ul li,.article-prose ol li{margin-bottom:8px;line-height:1.65}
.article-prose blockquote{
  margin:24px 0;padding:18px 22px;
  background:rgba(225,29,72,.06);border-left:3px solid var(--red);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  font-style:italic;color:var(--text);
}
.article-prose a.int{color:var(--red-bright);font-weight:600;border-bottom:1px solid rgba(244,63,94,.3)}
.article-prose a.int:hover{border-bottom-color:var(--red-bright)}
.article-prose a.ext{color:var(--gold);font-weight:600}
.article-prose a.ext::after{content:" ↗";font-size:.8em;opacity:.7}

.article-prose .stat-highlight{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);padding:20px;margin:24px 0;
}
.article-prose .stat-highlight .big{
  font-size:2.8rem;font-weight:900;color:var(--gold);
  line-height:1;letter-spacing:-.04em;font-feature-settings:"tnum";
}
.article-prose .stat-highlight .lbl{font-size:.78rem;color:var(--soft);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.article-prose .stat-highlight p{margin:0;color:var(--muted)}

.ref-box{
  margin:28px 0;padding:18px 20px;border-radius:var(--r-md);
  background:rgba(252,211,77,.05);border:1px solid rgba(252,211,77,.2);
}
.ref-box .hd{
  display:flex;align-items:center;gap:8px;
  color:var(--gold);font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;margin-bottom:10px;
}
.ref-box .hd::before{content:"📚"}
.ref-box ul{margin:0;padding-left:18px}
.ref-box ul li{margin-bottom:6px;font-size:.92rem}
.ref-box a{color:var(--gold-soft)}

.article-foot{
  margin:40px 0 0;padding:24px 0;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
}
.byline{display:flex;align-items:center;gap:12px}
.byline .avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--red),var(--gold));
  display:grid;place-items:center;font-weight:900;color:var(--bg-base);
}
.byline .info{display:flex;flex-direction:column}
.byline .info strong{font-size:.92rem;color:#fff}
.byline .info span{font-size:.78rem;color:var(--soft)}

.share-row{display:flex;gap:8px;align-items:center}
.share-row .lbl{font-size:.78rem;color:var(--soft);font-weight:600;margin-right:4px}
.share-btn{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--muted);
  cursor:pointer;transition:all var(--t);text-decoration:none;
}
.share-btn:hover{background:rgba(255,255,255,.08);color:#fff}

/* ===== Related articles ===== */
.related-block{margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.related-block h2{font-size:1.2rem;margin-bottom:18px}

/* ===== FAQ ===== */
.faq{display:grid;gap:10px;max-width:840px;margin:0 auto}
.faq-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;transition:all var(--t)}
.faq-q{
  width:100%;text-align:left;background:transparent;border:0;color:#fff;
  padding:16px 20px;font-weight:600;font-size:.96rem;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:12px;font-family:inherit;
}
.faq-q .chev{color:var(--red);transition:transform var(--t)}
.faq-a{padding:0 20px 0;max-height:0;overflow:hidden;transition:all var(--t);color:var(--muted)}
.faq-item.open .faq-a{padding:0 20px 18px;max-height:420px}
.faq-item.open .faq-q .chev{transform:rotate(180deg)}
.faq-item.open{background:rgba(225,29,72,.04);border-color:rgba(225,29,72,.22)}

/* ===== Form ===== */
.form{max-width:620px;margin:0 auto;display:grid;gap:12px}
.form .field{display:flex;flex-direction:column;gap:6px}
.form label{font-size:.86rem;color:var(--muted);font-weight:600}
.form input,.form textarea{
  background:rgba(10,14,26,.55);border:1px solid var(--border);color:#fff;
  border-radius:var(--r-sm);padding:12px 14px;font:inherit;outline:none;transition:all var(--t);
}
.form input:focus,.form textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(225,29,72,.15)}
.form textarea{min-height:140px;resize:vertical}
.form-msg{padding:12px 14px;border-radius:var(--r-sm);display:none;font-size:.9rem}
.form-msg.success{display:block;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.3);color:#6ee7b7}
.form-msg.error{display:block;background:rgba(225,29,72,.12);border:1px solid rgba(225,29,72,.3);color:#fda4af}

/* ===== Newsletter CTA ===== */
.newsletter{
  background:linear-gradient(135deg, rgba(225,29,72,.10), rgba(252,211,77,.06));
  border:1px solid var(--border);border-radius:var(--r-lg);
  padding:36px;text-align:center;
  position:relative;overflow:hidden;
}
.newsletter::before{
  content:"";position:absolute;inset:0;opacity:.04;
  background-image:repeating-linear-gradient(45deg, transparent, transparent 8px, #fff 8px, #fff 9px);
}
.newsletter > *{position:relative}
.newsletter h2{font-size:1.6rem;margin-bottom:8px}
.newsletter p{color:var(--muted);max-width:480px;margin:0 auto 18px}
.newsletter-form{display:flex;gap:8px;max-width:440px;margin:0 auto;flex-wrap:wrap}
.newsletter-form input{
  flex:1;min-width:200px;background:rgba(10,14,26,.6);border:1px solid var(--border);color:#fff;
  border-radius:var(--r-sm);padding:12px 14px;font:inherit;outline:none;
}
.newsletter-form input:focus{border-color:var(--red)}

/* ===== Disclaimer note (small, non-intrusive) ===== */
.note-box{
  background:rgba(255,255,255,.025);border-left:3px solid var(--red);
  padding:12px 16px;border-radius:0 var(--r-sm) var(--r-sm) 0;
  font-size:.86rem;color:var(--soft);
}
.note-box strong{color:#fff}

/* ===== Legal prose (privacy/terms) ===== */
.legal-prose p,.legal-prose li{color:var(--muted)}
.legal-prose h2{margin-top:28px;font-size:1.2rem}
.legal-prose h2::before{content:"";display:inline-block;width:3px;height:18px;background:var(--red);border-radius:2px;margin-right:10px;vertical-align:-2px}
.legal-prose ul{padding-left:20px}

/* ===== FOOTER ===== */
.footer{
  margin-top:60px;padding:54px 0 24px;
  background:linear-gradient(180deg, var(--bg-base), #06090f);
  border-top:1px solid var(--line);position:relative;
}
.footer::before{
  content:"";position:absolute;top:-1px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--red),var(--gold),var(--red),transparent);
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
.footer h4{font-size:.78rem;color:#fff;margin-bottom:14px;text-transform:uppercase;letter-spacing:.1em;font-weight:800}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer ul a{color:var(--muted);font-size:.9rem;font-weight:500}
.footer ul a:hover{color:#fff}
.footer-brand{display:flex;flex-direction:column;gap:14px}
.footer-brand p{color:var(--soft);font-size:.9rem;margin:0;max-width:300px}
.footer-bottom{
  margin-top:36px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  color:var(--dim);font-size:.82rem;
}
.footer-bottom .social{display:flex;gap:6px}
.footer-bottom .social a{
  width:32px;height:32px;border-radius:6px;display:grid;place-items:center;
  background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--muted);
  transition:all var(--t);
}
.footer-bottom .social a:hover{color:#fff;background:rgba(255,255,255,.08)}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(14px);transition:all .55s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Back to top ===== */
.to-top{
  position:fixed;right:18px;bottom:18px;z-index:60;
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;cursor:pointer;
  background:var(--red);color:#fff;
  border:0;box-shadow:0 8px 22px rgba(225,29,72,.4);opacity:0;pointer-events:none;
  transition:all var(--t);font-weight:900;
}
.to-top.show{opacity:1;pointer-events:auto}
.to-top:hover{transform:translateY(-3px);background:var(--red-bright)}

/* ===== Responsive ===== */
@media (max-width:1024px){
  .hero-featured{grid-template-columns:1fr;gap:18px}
  .feat-main{min-height:380px}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .section{padding:44px 0}
  .nav{
    position:fixed;inset:62px 12px auto 12px;flex-direction:column;align-items:stretch;
    background:rgba(10,14,26,.97);backdrop-filter:blur(14px);
    border:1px solid var(--border);border-radius:var(--r-md);padding:10px;gap:2px;
    transform:translateY(-10px);opacity:0;pointer-events:none;transition:all var(--t);
  }
  .nav.show{transform:none;opacity:1;pointer-events:auto}
  .nav a{padding:11px 14px;border-radius:6px}
  .nav a.active::after{display:none}
  .nav a.active{background:rgba(225,29,72,.12);color:#fff}
  .menu-toggle{display:inline-flex}
  .cta-search{display:none}
  .cards-grid,.cards-grid-2,.cards-grid-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .feat-main{padding:24px}
  .feat-main h1{font-size:1.5rem}
  .article-prose h2{font-size:1.3rem}
  .article-cover{height:240px;padding:20px}
  .newsletter{padding:24px}
}
@media (max-width:480px){
  .container{padding:0 18px}
  .feat-main{min-height:320px}
  .article-prose p:first-of-type::first-letter{font-size:2.8rem}
}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important}
  .reveal{opacity:1;transform:none}
  .ticker-track{animation:none}
}

/* ==========================================================
   PHASE 1+2+3 UX UPGRADE
========================================================== */

/* ===== Skip to content (a11y) ===== */
.skip-link{
  position:absolute;top:-100px;left:0;
  background:var(--red);color:#fff;padding:12px 18px;
  font-weight:700;text-decoration:none;z-index:9999;
  border-radius:0 0 8px 0;
  transition:top .2s;
}
.skip-link:focus{top:0;color:#fff}

/* ===== Focus states (a11y) ===== */
*:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:4px;
}
.btn:focus-visible,.nav a:focus-visible,.cta-search:focus-visible,
.tab-pill:focus-visible,.faq-q:focus-visible,.share-btn:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
}
a:focus-visible{text-decoration:underline}

/* ===== Improved contrast for accessibility ===== */
:root{
  --soft:#A9B6C7;       /* lebih terang dari #94A3B8, WCAG AA pass */
  --dim:#7A8A9E;
}

/* ===== Tap targets min 44px ===== */
.nav a{min-height:44px;display:inline-flex;align-items:center}
.btn,.tab-pill,.cta-search,.share-btn,.menu-toggle{min-height:44px;min-width:44px}
.btn-sm{min-height:36px}
.pill{min-height:28px}

/* ==========================================================
   READING PROGRESS BAR (Phase 2)
========================================================== */
.read-progress{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:100;
  background:transparent;pointer-events:none;
}
.read-progress .bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--red),var(--gold));
  transition:width .1s linear;
  box-shadow:0 0 8px rgba(225,29,72,.5);
}

/* ==========================================================
   COUNT-UP ANIMATION (Phase 2)
========================================================== */
.count-up{
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum";
}

/* ==========================================================
   THEME TOGGLE (Phase 2) — Light theme via [data-theme="light"]
========================================================== */
[data-theme="light"]{
  --bg-base:#FFFFFF;
  --bg-elev:#F8FAFC;
  --bg-elev-2:#F1F5F9;
  --bg-card:rgba(15,23,42,0.04);
  --bg-card-hover:rgba(15,23,42,0.07);
  --line:rgba(15,23,42,0.08);
  --border:rgba(15,23,42,0.12);
  --border-strong:rgba(225,29,72,0.45);
  --text:#0F172A;
  --muted:#475569;
  --soft:#64748B;
  --dim:#94A3B8;
}
[data-theme="light"] body{
  background:var(--bg-base);
  background-image:
    radial-gradient(900px 500px at 90% -10%, rgba(225,29,72,.05), transparent 60%),
    radial-gradient(700px 400px at -5% 12%, rgba(252,211,77,.04), transparent 55%);
}
[data-theme="light"] body::before{
  background-image:radial-gradient(rgba(15,23,42,.04) 1px, transparent 1px);
}
[data-theme="light"] h1,[data-theme="light"] h2,[data-theme="light"] h3,
[data-theme="light"] h4,[data-theme="light"] h5{color:#0F172A}
[data-theme="light"] .brand,[data-theme="light"] .brand .name{color:#0F172A}
[data-theme="light"] .topbar{background:rgba(255,255,255,.88);border-bottom-color:var(--line)}
[data-theme="light"] .nav a{color:var(--muted)}
[data-theme="light"] .nav a:hover,[data-theme="light"] .nav a.active{color:#0F172A}
[data-theme="light"] .feat-main{
  background:linear-gradient(135deg,#E2E8F0,#F8FAFC);
  border:1px solid var(--border);
}
[data-theme="light"] .feat-main::before{
  background:
    linear-gradient(180deg,transparent 30%, rgba(255,255,255,.7) 70%, rgba(255,255,255,.95)),
    radial-gradient(circle at 70% 30%, rgba(225,29,72,.18), transparent 60%),
    linear-gradient(135deg, #E2E8F0, #F1F5F9);
}
[data-theme="light"] .feat-main h1,[data-theme="light"] .feat-main p{color:#0F172A}
[data-theme="light"] .card-article,[data-theme="light"] .card-compact,
[data-theme="light"] .match-card,[data-theme="light"] .feat-mini,
[data-theme="light"] .stats-panel,[data-theme="light"] .article-body,
[data-theme="light"] .widget{
  background:#FFFFFF;border-color:var(--border);
}
[data-theme="light"] .card-article h3,[data-theme="light"] .card-compact h3,
[data-theme="light"] .feat-mini h3{color:#0F172A}
[data-theme="light"] .thumb{background:linear-gradient(135deg,#E2E8F0,#F8FAFC) !important}
[data-theme="light"] .thumb::before{
  background:radial-gradient(circle at 30% 40%, rgba(225,29,72,.18), transparent 60%),linear-gradient(135deg,#E2E8F0,#F1F5F9) !important;
}
[data-theme="light"] .ticker{background:linear-gradient(90deg, rgba(225,29,72,.06), rgba(252,211,77,.03) 50%, rgba(225,29,72,.06))}
[data-theme="light"] .form input,[data-theme="light"] .form textarea,
[data-theme="light"] .widget .field input,[data-theme="light"] .widget .field textarea,
[data-theme="light"] .newsletter-form input{background:#FFFFFF;color:#0F172A;border-color:var(--border)}
[data-theme="light"] .article-cover{background:linear-gradient(135deg,rgba(225,29,72,.18),transparent 50%),linear-gradient(135deg,#E2E8F0,#F1F5F9)}
[data-theme="light"] .article-prose p{color:var(--muted)}
[data-theme="light"] .footer{background:linear-gradient(180deg,#F1F5F9,#E2E8F0)}
[data-theme="light"] .footer h4{color:#0F172A}
[data-theme="light"] .footer-brand p,[data-theme="light"] .footer ul a{color:var(--muted)}

/* ===== Theme toggle button ===== */
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--muted);cursor:pointer;transition:all var(--t);
  min-width:44px;min-height:44px;
}
.theme-toggle:hover{background:rgba(255,255,255,.08);color:#fff}
[data-theme="light"] .theme-toggle{background:rgba(15,23,42,.04);color:var(--muted)}
[data-theme="light"] .theme-toggle:hover{background:rgba(15,23,42,.08);color:#0F172A}
.theme-toggle .sun{display:none}
.theme-toggle .moon{display:block}
[data-theme="light"] .theme-toggle .sun{display:block}
[data-theme="light"] .theme-toggle .moon{display:none}

/* ==========================================================
   MOBILE BOTTOM NAV (Phase 2)
========================================================== */
.bottom-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:55;
  background:rgba(10,14,26,.96);backdrop-filter:blur(16px);
  border-top:1px solid var(--line);
  padding:8px 0 calc(8px + env(safe-area-inset-bottom));
  justify-content:space-around;
}
[data-theme="light"] .bottom-nav{background:rgba(255,255,255,.96)}
.bottom-nav a{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  color:var(--soft);font-size:.68rem;font-weight:600;
  padding:6px 12px;border-radius:8px;
  text-decoration:none;flex:1;min-height:54px;
  justify-content:center;transition:color var(--t);
}
.bottom-nav a:hover,.bottom-nav a.active{color:var(--red)}
.bottom-nav a svg{width:22px;height:22px}
.bottom-nav a span{line-height:1}

/* Push body content up on mobile to account for bottom nav */
@media (max-width:768px){
  .bottom-nav{display:flex}
  body{padding-bottom:68px}
  .to-top{bottom:78px}
}

/* ==========================================================
   HIDE-ON-SCROLL TOPBAR (Phase 2)
========================================================== */
.topbar{transition:transform .3s ease}
.topbar.hidden{transform:translateY(-100%)}

/* ==========================================================
   SHARE BUTTONS — visual feedback when copied
========================================================== */
.share-btn.copied{background:var(--green);color:#fff;border-color:var(--green)}
.copy-toast{
  position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--green);color:#fff;padding:10px 20px;border-radius:8px;
  font-weight:600;font-size:.88rem;opacity:0;pointer-events:none;
  transition:all .25s ease;z-index:200;
}
.copy-toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ==========================================================
   SEARCH (Phase 3)
========================================================== */
.search-overlay{
  position:fixed;inset:0;z-index:90;display:none;
  background:rgba(5,8,22,.85);backdrop-filter:blur(8px);
  align-items:flex-start;justify-content:center;padding:80px 20px 20px;
}
.search-overlay.show{display:flex}
[data-theme="light"] .search-overlay{background:rgba(15,23,42,.5)}
.search-box{
  background:var(--bg-elev);border:1px solid var(--border);
  border-radius:var(--r-lg);max-width:620px;width:100%;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.search-input-wrap{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;border-bottom:1px solid var(--line);
}
.search-input-wrap svg{flex-shrink:0;color:var(--muted)}
.search-box input{
  flex:1;background:transparent;border:0;color:var(--text);
  font:inherit;font-size:1.05rem;outline:none;padding:8px 0;
}
.search-close{
  background:transparent;border:0;color:var(--muted);cursor:pointer;
  font-size:1.4rem;padding:4px 8px;border-radius:6px;
}
.search-close:hover{color:var(--text);background:rgba(255,255,255,.05)}
.search-results{max-height:60vh;overflow-y:auto;padding:6px}
.search-result{
  display:block;padding:12px 14px;border-radius:8px;
  text-decoration:none;color:var(--text);
  transition:background .15s ease;
}
.search-result:hover,.search-result.focus{background:rgba(225,29,72,.08)}
.search-result .cat{font-size:.7rem;color:var(--red);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.search-result h4{margin:4px 0 2px;font-size:.95rem;color:var(--text)}
.search-result p{margin:0;font-size:.82rem;color:var(--soft)}
.search-empty{padding:30px 18px;text-align:center;color:var(--soft);font-size:.92rem}

/* ==========================================================
   BOOKMARK BUTTON (Phase 3)
========================================================== */
.bookmark-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--muted);transition:all var(--t);
  min-width:44px;min-height:44px;
}
.bookmark-btn:hover{color:var(--gold);background:rgba(252,211,77,.1)}
.bookmark-btn.saved{color:var(--gold);background:rgba(252,211,77,.15);border-color:rgba(252,211,77,.3)}
.bookmark-btn.saved svg{fill:currentColor}

/* ==========================================================
   SKELETON LOADERS (Phase 3)
========================================================== */
.skeleton{
  background:linear-gradient(90deg,
    rgba(255,255,255,.04) 0%,
    rgba(255,255,255,.08) 50%,
    rgba(255,255,255,.04) 100%);
  background-size:200% 100%;
  animation:skeleton-pulse 1.5s infinite;
  border-radius:8px;
}
@keyframes skeleton-pulse{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* ==========================================================
   IMAGE WRAPPER — lazy + aspect ratio
========================================================== */
.img-wrap{
  position:relative;overflow:hidden;background:var(--bg-card);
}
.img-wrap.ar-16-9{aspect-ratio:16/9}
.img-wrap.ar-4-3{aspect-ratio:4/3}
.img-wrap.ar-1-1{aspect-ratio:1/1}
.img-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;
}
.img-wrap:hover img{transform:scale(1.04)}

/* Replace article thumb when image exists */
.card-article .thumb-img{
  height:180px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#1f2a44,#0a0e1a);
}
.card-article .thumb-img img{width:100%;height:100%;object-fit:cover}
.card-article .thumb-img .tag{position:absolute;top:12px;left:12px;z-index:1}

/* ==========================================================
   ARTICLE COVER WITH IMAGE
========================================================== */
.article-cover-img{
  height:340px;border-radius:var(--r-lg);overflow:hidden;
  position:relative;margin-bottom:32px;border:1px solid var(--border);
}
.article-cover-img img{width:100%;height:100%;object-fit:cover}
.article-cover-img .meta-overlay{
  position:absolute;inset:auto 0 0 0;padding:20px 28px;
  background:linear-gradient(transparent, rgba(0,0,0,.85));
  color:#fff;
}

/* ==========================================================
   PRINT STYLESHEET (Phase 1)
========================================================== */
@media print{
  .topbar,.bottom-nav,.to-top,.theme-toggle,
  .read-progress,.share-row,.newsletter,.ticker,
  .footer,.cta-search,.menu-toggle{display:none !important}
  body{background:#fff;color:#000}
  .article-body p,.article-body li{color:#000}
  a{color:#000;text-decoration:underline}
  .article-cover,.article-cover-img{display:none}
  .container{max-width:100%}
}

/* ==========================================================
   PLACEHOLDER for data-driven content
========================================================== */
.data-placeholder{
  background:rgba(252,211,77,.05);border:1px dashed rgba(252,211,77,.3);
  border-radius:var(--r-md);padding:20px 24px;
  color:var(--gold-soft);font-size:.92rem;
  display:flex;gap:14px;align-items:flex-start;
}
.data-placeholder .icon{
  width:32px;height:32px;border-radius:8px;display:grid;place-items:center;
  background:rgba(252,211,77,.15);color:var(--gold);font-weight:800;flex-shrink:0;
}
.data-placeholder strong{color:var(--gold);display:block;margin-bottom:4px}
.data-placeholder a{color:var(--gold);font-weight:600;text-decoration:underline}

/* ==========================================================
   ZERO-UPLOAD COVER SYSTEM — Magazine-style cover via CSS only
========================================================== */

/* === ARTICLE COVER MAGAZINE STYLE === */
.article-cover{
  position:relative;height:380px;border-radius:var(--r-lg);
  overflow:hidden;margin-bottom:32px;
  border:1px solid var(--border);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:32px;
  background:
    radial-gradient(circle at 30% 30%, rgba(225,29,72,.35), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(252,211,77,.20), transparent 50%),
    linear-gradient(135deg, #1F2937, #0A0E1A);
}
.article-cover::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(45deg, transparent, transparent 8px, rgba(255,255,255,.04) 8px, rgba(255,255,255,.04) 9px),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.08) 1px, transparent 60px);
  background-size:auto, 200px 200px;
  background-position:0 0, 0 0;
  opacity:.5;
}
.article-cover::after{
  content:"";position:absolute;right:-40px;bottom:-40px;
  width:240px;height:240px;border-radius:50%;
  border:2px solid rgba(255,255,255,.06);
  pointer-events:none;
}
.article-cover > *{position:relative;z-index:1}
.article-cover .cv-cat{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:var(--r-pill);
  font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(255,255,255,.12);backdrop-filter:blur(8px);
  color:#fff;border:1px solid rgba(255,255,255,.2);
  align-self:flex-start;
}
.article-cover .cv-cat .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.article-cover .cv-title{
  font-size:clamp(1.4rem,3vw,2rem);font-weight:900;color:#fff;
  line-height:1.15;letter-spacing:-.025em;
  max-width:90%;margin:0;
  text-shadow:0 2px 20px rgba(0,0,0,.4);
}
.article-cover .cv-foot{
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;
}
.article-cover .cv-meta{
  font-size:.82rem;color:rgba(255,255,255,.85);font-weight:600;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.article-cover .cv-meta .sep{color:rgba(255,255,255,.5)}
.article-cover .cv-brand{
  font-size:.7rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}

/* Color variants per kategori */
.article-cover.cv-timnas{
  background:
    radial-gradient(circle at 30% 30%, rgba(225,29,72,.5), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(252,211,77,.25), transparent 50%),
    linear-gradient(135deg, #4a0f1f, #0A0E1A);
}
.article-cover.cv-liga1{
  background:
    radial-gradient(circle at 30% 30%, rgba(59,130,246,.4), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(225,29,72,.20), transparent 50%),
    linear-gradient(135deg, #1e3a5f, #0A0E1A);
}
.article-cover.cv-eropa{
  background:
    radial-gradient(circle at 30% 30%, rgba(168,85,247,.4), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(59,130,246,.20), transparent 50%),
    linear-gradient(135deg, #2d1b69, #0A0E1A);
}
.article-cover.cv-stats{
  background:
    radial-gradient(circle at 30% 30%, rgba(16,185,129,.35), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(252,211,77,.2), transparent 50%),
    linear-gradient(135deg, #064e3b, #0A0E1A);
}
.article-cover.cv-analisa{
  background:
    radial-gradient(circle at 30% 30%, rgba(252,211,77,.4), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(225,29,72,.2), transparent 50%),
    linear-gradient(135deg, #4a3a0f, #0A0E1A);
}

/* === ENHANCED CARD THUMB with TITLE OVERLAY === */
.card-article .thumb-rich{
  height:200px;position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:16px;
  background:
    radial-gradient(circle at 30% 30%, rgba(225,29,72,.30), transparent 55%),
    linear-gradient(135deg, #1F2937, #0A0E1A);
}
.card-article .thumb-rich::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(45deg, transparent, transparent 6px, rgba(255,255,255,.04) 6px, rgba(255,255,255,.04) 7px);
  opacity:.6;
}
.card-article .thumb-rich::after{
  content:"";position:absolute;right:-30px;bottom:-30px;width:120px;height:120px;
  border-radius:50%;border:2px solid rgba(255,255,255,.06);pointer-events:none;
}
.card-article .thumb-rich > *{position:relative;z-index:1}
.card-article .thumb-rich .tag{align-self:flex-start}
.card-article .thumb-rich .thumb-title{
  font-size:1.4rem;font-weight:900;color:#fff;line-height:1.1;
  letter-spacing:-.02em;margin:0;
  text-shadow:0 2px 12px rgba(0,0,0,.4);
}

/* Color variants for card thumbs */
.card-article .thumb-rich.t-timnas{background:radial-gradient(circle at 30% 30%, rgba(225,29,72,.45), transparent 55%),linear-gradient(135deg,#4a0f1f,#0A0E1A)}
.card-article .thumb-rich.t-liga1{background:radial-gradient(circle at 30% 30%, rgba(59,130,246,.35), transparent 55%),linear-gradient(135deg,#1e3a5f,#0A0E1A)}
.card-article .thumb-rich.t-eropa{background:radial-gradient(circle at 30% 30%, rgba(168,85,247,.35), transparent 55%),linear-gradient(135deg,#2d1b69,#0A0E1A)}
.card-article .thumb-rich.t-stats{background:radial-gradient(circle at 30% 30%, rgba(16,185,129,.30), transparent 55%),linear-gradient(135deg,#064e3b,#0A0E1A)}
.card-article .thumb-rich.t-analisa{background:radial-gradient(circle at 30% 30%, rgba(252,211,77,.30), transparent 55%),linear-gradient(135deg,#4a3a0f,#0A0E1A)}

/* === FEATURED HERO ENHANCED (homepage) === */
.feat-main{
  position:relative;
  background:
    radial-gradient(circle at 70% 30%, rgba(225,29,72,.4), transparent 55%),
    radial-gradient(circle at 20% 80%, rgba(252,211,77,.18), transparent 50%),
    linear-gradient(135deg, #1F2937, #0A0E1A);
}
.feat-main::after{
  content:"";position:absolute;right:-60px;top:-60px;
  width:300px;height:300px;border-radius:50%;
  border:3px solid rgba(255,255,255,.05);pointer-events:none;
}

/* Mobile adjustments */
@media (max-width:768px){
  .article-cover{height:300px;padding:24px}
  .article-cover .cv-title{font-size:1.3rem}
  .card-article .thumb-rich{height:160px}
  .card-article .thumb-rich .thumb-title{font-size:1.1rem}
}

/* Light theme adjustments */
[data-theme="light"] .article-cover{
  background:
    radial-gradient(circle at 30% 30%, rgba(225,29,72,.25), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(252,211,77,.15), transparent 50%),
    linear-gradient(135deg, #F1F5F9, #E2E8F0);
}
[data-theme="light"] .article-cover .cv-title{color:#0F172A;text-shadow:0 2px 12px rgba(255,255,255,.4)}
[data-theme="light"] .article-cover .cv-cat{background:rgba(15,23,42,.08);color:#0F172A;border-color:rgba(15,23,42,.15)}
[data-theme="light"] .article-cover .cv-meta{color:rgba(15,23,42,.7)}
[data-theme="light"] .article-cover .cv-brand{color:rgba(15,23,42,.5)}
[data-theme="light"] .card-article .thumb-rich{background:radial-gradient(circle at 30% 30%, rgba(225,29,72,.2), transparent 55%),linear-gradient(135deg,#F1F5F9,#E2E8F0)}
[data-theme="light"] .card-article .thumb-rich .thumb-title{color:#0F172A;text-shadow:0 1px 8px rgba(255,255,255,.5)}

/* ==========================================================
   UNSPLASH IMAGE OVERLAY SUPPORT
   Add image background + dark overlay for text readability
========================================================== */

.article-cover.cv-img{
  background-size:cover;
  background-position:center;
  /* fallback gradient kalau image gagal load */
}
.article-cover.cv-img::before{
  background:
    linear-gradient(135deg, rgba(10,14,26,.65), rgba(10,14,26,.85)),
    radial-gradient(circle at 30% 30%, rgba(225,29,72,.25), transparent 55%);
  z-index:1;
}
.article-cover.cv-img::after{display:none}
.article-cover.cv-img > *{position:relative;z-index:2}

/* Light theme overlay */
[data-theme="light"] .article-cover.cv-img::before{
  background:
    linear-gradient(135deg, rgba(15,23,42,.55), rgba(15,23,42,.75)),
    radial-gradient(circle at 30% 30%, rgba(225,29,72,.18), transparent 55%);
}
[data-theme="light"] .article-cover.cv-img .cv-title{color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.6)}
[data-theme="light"] .article-cover.cv-img .cv-cat{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.3)}
[data-theme="light"] .article-cover.cv-img .cv-meta{color:rgba(255,255,255,.9)}
[data-theme="light"] .article-cover.cv-img .cv-brand{color:rgba(255,255,255,.75)}

/* Rich thumb with image */
.card-article .thumb-rich.t-img{
  background-size:cover;
  background-position:center;
}
.card-article .thumb-rich.t-img::before{
  background:
    linear-gradient(180deg, rgba(10,14,26,.3), rgba(10,14,26,.85)),
    repeating-linear-gradient(45deg, transparent, transparent 6px, rgba(255,255,255,.02) 6px, rgba(255,255,255,.02) 7px);
}
.card-article .thumb-rich.t-img::after{display:none}

/* Hero feat-main with image */
.feat-main.cv-img{
  background-size:cover;
  background-position:center;
}
.feat-main.cv-img::before{
  background:
    linear-gradient(180deg, transparent 30%, rgba(10,14,26,.85) 75%, rgba(10,14,26,.95)),
    linear-gradient(135deg, rgba(225,29,72,.25), transparent 50%);
  z-index:1;
}
.feat-main.cv-img > *{position:relative;z-index:2}

/* ==========================================================
   UEFA CL-STYLE TEAM BADGES + ENHANCED MATCH CARDS
========================================================== */

/* Enhanced match badge — UEFA Champions League style */
.match-team .badge{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,#1f2a44,#0a0e1a);
  border:2px solid rgba(255,255,255,.15);
  display:grid;place-items:center;
  font-weight:900;font-size:.72rem;color:#fff;flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.1);
  position:relative;letter-spacing:-.02em;
  text-shadow:0 1px 2px rgba(0,0,0,.5);
}
.match-team .badge::before{
  content:"";position:absolute;inset:3px;border-radius:50%;
  border:1px solid rgba(255,255,255,.08);pointer-events:none;
}

/* Team color variants — public domain colors only */
.match-team .badge.persija    {background:linear-gradient(135deg,#FF6B00,#C53D00)}
.match-team .badge.persib     {background:linear-gradient(135deg,#0042A6,#001F5C)}
.match-team .badge.bali       {background:linear-gradient(135deg,#D32F2F,#7F1D1D)}
.match-team .badge.psm        {background:linear-gradient(135deg,#C41E1E,#7F1010)}
.match-team .badge.persebaya  {background:linear-gradient(135deg,#10B981,#064E3B)}
.match-team .badge.madura     {background:linear-gradient(135deg,#DC2626,#1F2937)}
.match-team .badge.persis     {background:linear-gradient(135deg,#FCD34D,#92400E);color:#1F2937;text-shadow:none}
.match-team .badge.indonesia  {background:linear-gradient(135deg,#DC2626,#FCFCFC);color:#fff}
.match-team .badge.eu-red     {background:linear-gradient(135deg,#DC2626,#7F1D1D)}
.match-team .badge.eu-blue    {background:linear-gradient(135deg,#1E40AF,#0F172A)}
.match-team .badge.eu-sky     {background:linear-gradient(135deg,#0EA5E9,#0C4A6E)}
.match-team .badge.eu-yellow  {background:linear-gradient(135deg,#FCD34D,#92400E);color:#1F2937;text-shadow:none}
.match-team .badge.eu-purple  {background:linear-gradient(135deg,#7C3AED,#3B0764)}

/* Make match card more prominent */
.match-card{
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  border:1px solid var(--border);
  border-radius:var(--r-md);padding:18px;
  transition:all var(--t);position:relative;overflow:hidden;
}
.match-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--red), var(--gold), var(--red), transparent);
  opacity:.4;
}
.match-card:hover::before{opacity:.8}

.match-team .nm{font-weight:700;font-size:.94rem;letter-spacing:-.01em}
.match-score{
  font-weight:900;font-size:1.5rem;letter-spacing:-.025em;
  font-feature-settings:"tnum";text-align:center;min-width:70px;
}
.match-score .vs{
  color:var(--soft);font-size:.7rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  background:rgba(255,255,255,.04);padding:5px 11px;border-radius:var(--r-pill);
  border:1px solid var(--border);
}

/* === IMAGE-BACKED CARD-COMPACT === */
.card-compact.img-bg{
  background-size:cover;
  background-position:center;
  position:relative;overflow:hidden;
  min-height:180px;
  display:flex;flex-direction:column;justify-content:space-between;
  color:#fff;
}
.card-compact.img-bg::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(10,14,26,.35) 0%, rgba(10,14,26,.55) 50%, rgba(10,14,26,.92) 100%);
}
.card-compact.img-bg > *{position:relative;z-index:1}
.card-compact.img-bg h3{color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.card-compact.img-bg .meta{color:rgba(255,255,255,.85)}
.card-compact.img-bg .meta span{color:rgba(255,255,255,.85)}
.card-compact.img-bg:hover{transform:translateY(-3px)}

[data-theme="light"] .card-compact.img-bg::before{
  background:linear-gradient(180deg, rgba(15,23,42,.25) 0%, rgba(15,23,42,.45) 50%, rgba(15,23,42,.85) 100%);
}

/* === STADIUM-STYLE STATS PANEL HEAD === */
.stats-panel{position:relative;overflow:hidden}
.stats-panel.with-bg .sp-head{
  background:linear-gradient(180deg, rgba(225,29,72,.08), transparent), rgba(255,255,255,.02);
}

/* === Featured pillar with image === */
.feat-mini.img-bg{
  background-size:cover;
  background-position:center;
  position:relative;overflow:hidden;
  min-height:120px;
}
.feat-mini.img-bg::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg, rgba(10,14,26,.92) 0%, rgba(10,14,26,.7) 60%, rgba(10,14,26,.5) 100%);
}
.feat-mini.img-bg > *{position:relative;z-index:1}

/* Image attribution footer note */
.img-attribution{
  font-size:.72rem;color:var(--dim);text-align:center;
  padding:8px;margin-top:4px;
}
.img-attribution a{color:var(--soft)}

/* ==========================================================
   COMPREHENSIVE MOBILE FIX
========================================================== */

@media (max-width:768px){
  /* === Topbar — compact for mobile === */
  .topbar-wrap{padding:10px 14px;gap:8px}
  .brand{font-size:.95rem;gap:7px}
  .brand .mark{width:28px;height:28px}

  .topbar-wrap > div{gap:4px}
  .cta-search,.theme-toggle{width:36px;height:36px;min-width:36px;min-height:36px}
  .menu-toggle{padding:6px 8px}

  /* === Hero featured — stack mobile === */
  .hero-featured{grid-template-columns:1fr;gap:14px;margin:18px 0}
  .feat-main{min-height:300px;padding:22px}
  .feat-main h1{font-size:1.4rem;line-height:1.2}
  .feat-main p{font-size:.92rem}
  .feat-main .meta{font-size:.74rem}

  /* Feat-mini cards rapikan */
  .feat-mini{padding:14px;gap:10px}
  .feat-mini .num{font-size:1.3rem}
  .feat-mini .body h3{font-size:.88rem}
  .feat-mini .body .meta{font-size:.7rem}

  /* === Section heading === */
  .section{padding:36px 0}
  .section-sm{padding:24px 0}
  .section-head{margin-bottom:18px;padding-bottom:10px;flex-direction:row;align-items:center;gap:10px}
  .section-head .left::before{height:18px}
  .section-head h2{font-size:1.15rem}
  .section-head .right{align-self:auto}
  .section-head .right a{font-size:.72rem}

  /* === Cards grid — full stack === */
  .cards-grid,.cards-grid-2,.cards-grid-4{grid-template-columns:1fr;gap:14px}

  /* === Card article — compact === */
  .card-article .thumb,.card-article .thumb-img{height:160px}
  .card-article .thumb-rich{height:140px;padding:12px}
  .card-article .thumb-rich .thumb-title{font-size:1rem}
  .card-article .body{padding:14px;gap:6px}
  .card-article h3{font-size:.95rem;line-height:1.3}
  .card-article .excerpt{font-size:.82rem;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
  .card-article .meta{font-size:.7rem;gap:6px}

  /* === Article cover — smaller on mobile === */
  .article-cover{height:240px;padding:18px}
  .article-cover .cv-title{font-size:1.1rem;line-height:1.2}
  .article-cover .cv-cat{padding:4px 10px;font-size:.66rem}
  .article-cover .cv-meta{font-size:.72rem;gap:6px}
  .article-cover .cv-brand{font-size:.62rem}

  /* === Ticker — smaller text === */
  .ticker-track{padding:8px 14px;gap:24px}
  .ticker-item{font-size:.76rem}
  .ticker-item .lbl{font-size:.66rem}

  /* === Match cards === */
  .match-card{padding:14px}
  .match-team .badge{width:34px;height:34px;font-size:.66rem}
  .match-team .nm{font-size:.82rem}
  .match-score{font-size:1.2rem;min-width:50px}
  .match-score .vs{font-size:.62rem;padding:3px 8px}
  .match-head{font-size:.66rem;flex-wrap:wrap;gap:4px}

  /* === Stats panel === */
  .stats-panel .sp-head{padding:12px 14px}
  .stats-panel .sp-head h3{font-size:.86rem}
  .stats-row{padding:10px 14px;font-size:.84rem;grid-template-columns:30px 1fr auto;gap:10px}
  .stats-row .rank{font-size:.76rem}
  .stats-row .name{font-size:.84rem}
  .stats-row .name small{display:block;margin-left:0;font-size:.7rem;margin-top:2px}
  .stats-row .val{font-size:.82rem}

  /* === Article body / single article === */
  .article-page .a-hero h1{font-size:1.5rem;line-height:1.25;letter-spacing:-.02em}
  .article-page .a-hero .lead{font-size:.95rem;line-height:1.55}
  .article-page .a-hero .meta{font-size:.76rem}
  .article-prose p{font-size:.96rem;line-height:1.7;margin-bottom:14px}
  .article-prose h2{font-size:1.2rem;margin:24px 0 10px}
  .article-prose h3{font-size:1.05rem;margin:20px 0 8px}
  .article-prose ul,.article-prose ol{padding-left:20px}
  .article-prose li{font-size:.94rem}
  .article-prose blockquote{padding:14px 16px;font-size:.95rem}
  .article-prose .stat-highlight{grid-template-columns:1fr;text-align:center;padding:16px;gap:8px}
  .article-prose .stat-highlight .big{font-size:2.2rem}
  .article-prose p:first-of-type::first-letter{font-size:2.4rem;padding:4px 8px 0 0}
  .article-foot{flex-direction:column;align-items:flex-start;gap:12px;padding:18px 0}
  .ref-box{padding:14px 16px;font-size:.86rem}

  /* === Newsletter === */
  .newsletter{padding:22px}
  .newsletter h2{font-size:1.25rem}
  .newsletter p{font-size:.88rem}
  .newsletter-form{flex-direction:column;gap:8px}
  .newsletter-form input{min-width:0;width:100%}
  .newsletter-form .btn{width:100%}

  /* === FAQ === */
  .faq-q{padding:14px 16px;font-size:.9rem}
  .faq-a{padding:0 16px 0}
  .faq-item.open .faq-a{padding:0 16px 14px}

  /* === Form === */
  .form input,.form textarea{font-size:1rem;padding:11px 13px}
  .form-msg{font-size:.86rem}

  /* === Footer === */
  .footer{padding:36px 0 20px;margin-top:36px}
  .footer-grid{gap:24px}
  .footer h4{font-size:.74rem}
  .footer ul a{font-size:.84rem}
  .footer-brand p{font-size:.84rem}
  .footer-bottom{margin-top:24px;padding-top:14px;font-size:.76rem;flex-direction:column;text-align:center}

  /* === Pillar chips === */
  .pillar-chips{gap:6px;margin-bottom:18px;padding-bottom:12px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .pillar-chips::-webkit-scrollbar{display:none}
  .pillar-chip{padding:7px 13px;font-size:.78rem;flex-shrink:0}

  /* === Container padding === */
  .container{padding:0 16px}

  /* === Data placeholder === */
  .data-placeholder{padding:14px 16px;font-size:.86rem;gap:10px}
  .data-placeholder .icon{width:28px;height:28px;font-size:.84rem}

  /* === Note box === */
  .note-box{padding:12px 14px;font-size:.82rem}

  /* === Read progress bar === */
  .read-progress{height:2px}

  /* === Bottom nav improvements === */
  .bottom-nav a{font-size:.62rem;padding:4px 8px;min-height:50px;gap:2px}
  .bottom-nav a svg{width:18px;height:18px}

  /* === Search overlay === */
  .search-overlay{padding:60px 14px 14px}
  .search-box{border-radius:var(--r-md)}
  .search-input-wrap{padding:12px 14px}
  .search-box input{font-size:1rem}
  .search-result{padding:10px 12px}
  .search-result h4{font-size:.9rem}
  .search-result p{font-size:.78rem}
}

@media (max-width:480px){
  /* === Extra small mobile === */
  .topbar-wrap{padding:8px 12px;gap:6px}
  .brand .name{font-size:.85rem}
  .brand-meta small{display:none}
  .cta-search,.theme-toggle{width:32px;height:32px;min-width:32px;min-height:32px}
  .cta-search svg,.theme-toggle svg{width:14px;height:14px}

  .hero-featured{margin:14px 0}
  .feat-main{min-height:260px;padding:18px}
  .feat-main h1{font-size:1.2rem}

  .article-cover{height:200px;padding:16px}
  .article-cover .cv-title{font-size:1rem}

  .card-article .thumb-rich{height:120px;padding:10px}
  .card-article .thumb-rich .thumb-title{font-size:.88rem}

  .stats-row{grid-template-columns:24px 1fr auto;gap:8px;padding:10px 12px}
  .stats-row .name{font-size:.8rem}
  .stats-row .val{font-size:.78rem}

  .footer-grid{gap:18px}
  .footer ul{gap:6px}

  body{padding-bottom:64px}
  .bottom-nav{padding:6px 0 calc(6px + env(safe-area-inset-bottom))}
  .bottom-nav a{font-size:.58rem;min-height:46px;padding:3px 6px}
  .bottom-nav a svg{width:16px;height:16px}
  .to-top{bottom:74px;width:38px;height:38px}
}

/* === Touch-friendly improvements === */
@media (hover:none) and (pointer:coarse){
  .card-article:hover,.card-compact:hover,.feat-mini:hover{transform:none}
  .btn:active,.btn-primary:active,.btn-ghost:active{transform:scale(.97)}
}

/* ==========================================================
   NEWS WIDGET (live news section di pillar pages)
========================================================== */

.news-widget-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
@media (max-width:1024px){.news-widget-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:768px){.news-widget-grid{grid-template-columns:1fr}}

.news-widget-item{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-md);padding:16px;
  transition:all var(--t);text-decoration:none;color:inherit;
  display:flex;flex-direction:column;gap:8px;
  position:relative;overflow:hidden;
}
.news-widget-item:hover{
  background:var(--bg-card-hover);border-color:var(--border-strong);
  transform:translateY(-2px);
}
.news-widget-item::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--src-color,var(--red));opacity:.7;
}
.news-widget-item:hover::before{opacity:1;width:4px}

.news-widget-item .nw-meta{
  display:flex;align-items:center;justify-content:space-between;
  gap:8px;font-size:.72rem;
}
.news-widget-item .nw-source{
  color:var(--src-color,var(--red));font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
}
.news-widget-item .nw-source::after{content:" ↗";opacity:.6;font-size:.9em}
.news-widget-item .nw-time{color:var(--soft);font-weight:500}
.news-widget-item .nw-title{
  margin:0;font-size:.95rem;line-height:1.35;color:var(--text);font-weight:700;
}
.news-widget-item .nw-excerpt{
  margin:0;font-size:.84rem;color:var(--muted);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
