/*
Theme Name: Gazzetta
Theme URI: https://gazzetta.hu
Author: webkit.hu
Description: Gazzetta.hu sporthírportál téma — klasszikus PHP-alapú, ACF Pro + egyéni bejegyzéstípusok.
Tags: news, two-columns, custom-menu, featured-images, translation-ready, custom-colors
Version: 0.1.0
Requires at least: 6.4
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gazzetta
*/
:root{--ink:#070a14;--ink-2:#0d1224;--panel:#121833;--panel-2:#171e3d;--line:rgba(255,255,255,.08);--line-strong:rgba(255,255,255,.16);--text:#eef1fb;--muted:#9aa3c4;--faint:#69718f;--cobalt:#89CFF0;--cobalt-bright:#a9dcf6;--cobalt-soft:rgba(137,207,240,.16);--live:#ff3b54;--gold:#ffc24b;--green:#2bd47d;--sans:'Public Sans',system-ui,sans-serif;--display:'Archivo',system-ui,sans-serif;--mono:'Spline Sans Mono',monospace;--maxw:1320px}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;background-image:radial-gradient(1200px 600px at 78% -8%,rgba(137,207,240,.13),transparent 60%),radial-gradient(900px 500px at -5% 8%,rgba(137,207,240,.07),transparent 55%);background-attachment:fixed}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--cobalt-bright);z-index:100;box-shadow:0 0 10px var(--cobalt-bright);transition:width .08s linear}
.ticker{background:var(--ink-2);border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12.5px;overflow:hidden}
.ticker .wrap{display:flex;align-items:center;gap:18px;height:38px}
.ticker-label{display:inline-flex;align-items:center;gap:7px;color:var(--live);font-weight:600;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.ticker-label .dot{width:7px;height:7px;border-radius:50%;background:var(--live);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,59,84,.55)}70%{box-shadow:0 0 0 7px rgba(255,59,84,0)}100%{box-shadow:0 0 0 0 rgba(255,59,84,0)}}
.ticker-track{display:flex;gap:30px;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.ticker-flow{display:flex;gap:30px;white-space:nowrap;animation:scrollx 38s linear infinite}
.ticker:hover .ticker-flow{animation-play-state:paused}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{display:inline-flex;align-items:center;gap:9px;color:var(--muted)}
.ticker-item b{color:var(--text);font-weight:600}
.ticker-item .sc{color:var(--cobalt-bright);font-weight:600}
.ticker-item .ft{color:var(--faint);font-size:10.5px;letter-spacing:.04em}
header.site{position:sticky;top:0;z-index:50;background:rgba(7,10,20,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:28px;height:70px}
.logo-wrap{display:flex;flex-direction:column;gap:3px}
.neon{font-family:'Pacifico',cursive;font-weight:400;color:#eef4ff;line-height:1;letter-spacing:.5px;display:inline-block;transform:rotate(-3deg);transform-origin:left center;text-shadow:0 0 3px rgba(255,255,255,.95),0 0 7px rgba(190,212,255,.9),0 0 16px var(--cobalt-bright),0 0 30px var(--cobalt),0 0 54px var(--cobalt),0 0 80px rgba(137,207,240,.6);animation:neon-breathe 5.5s ease-in-out infinite}
.neon .hu{font-size:.42em;vertical-align:.7em;margin-left:2px;color:#cfe0ff;text-shadow:0 0 4px rgba(255,255,255,.8),0 0 10px var(--cobalt-bright),0 0 20px var(--cobalt)}
.neon .flick{animation:neon-flicker 7s infinite steps(1)}
@keyframes neon-breathe{0%,100%{filter:brightness(1)}50%{filter:brightness(1.08)}}
@keyframes neon-flicker{0%,41%,44%,47%,100%{opacity:1}42%,45%{opacity:.35}43%,46%{opacity:.85}}
@media (prefers-reduced-motion:reduce){.neon,.neon .flick{animation:none}}
.powered-h{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;color:var(--faint);text-transform:uppercase;line-height:1;padding-left:1px}
.powered-h span{color:var(--cobalt-bright);font-weight:600;letter-spacing:.12em}
.mainmenu{display:flex;align-items:center;gap:4px;margin-left:6px}
.mainmenu a{font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:.01em;color:var(--muted);padding:8px 13px;border-radius:9px;transition:color .15s,background .15s;white-space:nowrap}
.mainmenu a:hover{color:var(--text);background:rgba(255,255,255,.04)}
.mainmenu a.active{color:var(--text)}
.mainmenu a.active::after{content:'';display:block;height:2px;width:18px;margin:5px auto -2px;background:var(--cobalt-bright);border-radius:2px}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.search{display:flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:0 12px;height:40px;color:var(--faint);transition:border-color .15s;min-width:210px}
.search:focus-within{border-color:var(--cobalt)}
.search input{background:none;border:none;outline:none;color:var(--text);font-size:13.5px;width:100%;font-family:var(--sans)}
.search input::placeholder{color:var(--faint)}
.btn-live{display:inline-flex;align-items:center;gap:7px;height:40px;padding:0 16px;background:var(--cobalt);color:#fff;border-radius:10px;font-family:var(--display);font-weight:700;font-size:13.5px;transition:background .15s}
.btn-live:hover{background:var(--cobalt-bright)}
.btn-live .dot{width:6px;height:6px;border-radius:50%;background:#fff}
.ad{position:relative;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(135deg,rgba(255,255,255,.012) 0 12px,transparent 12px 24px),var(--ink-2);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.ad::before{content:'Hirdetés';position:absolute;top:8px;right:11px;z-index:3;font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);background:rgba(7,10,20,.6);padding:2px 7px;border-radius:5px}
.ad .ad-empty{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--faint);font-family:var(--display);font-weight:600;pointer-events:none}
.ad .ad-empty .sz{font-family:var(--mono);font-size:10.5px;opacity:.7;font-weight:500}
.ad image-slot{width:100%;height:100%}
.ad-band{background:rgba(13,18,36,.4);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0}
.ad-billboard{height:250px}
.ad-leaderboard{height:120px;margin:10px 0 28px}
.ad-rect{height:300px}
.ad-halfpage{height:600px}
.breadcrumb{display:flex;align-items:center;gap:9px;padding:22px 0 0;font-family:var(--mono);font-size:12px;color:var(--faint);flex-wrap:wrap}
.breadcrumb a:hover{color:var(--cobalt-bright)}
.breadcrumb .sep{opacity:.5}
.breadcrumb .cur{color:var(--muted)}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 348px;gap:48px;padding:18px 0 40px;align-items:start}
.article{min-width:0}
.art-kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:.07em;text-transform:uppercase;color:#fff;background:var(--cobalt);padding:6px 13px;border-radius:7px;margin-bottom:18px}
h1.art-title{font-family:var(--display);font-weight:900;font-size:clamp(32px,4.4vw,52px);line-height:1.03;letter-spacing:-.026em;text-wrap:balance;margin-bottom:18px}
.art-dek{font-size:20px;line-height:1.5;color:var(--muted);max-width:62ch;text-wrap:pretty}
.art-meta{display:flex;align-items:center;gap:14px;margin:26px 0;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);flex-wrap:wrap}
.author-mini{display:flex;align-items:center;gap:12px}
.author-mini .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--cobalt),#7a3bff);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:16px;color:#fff;flex-shrink:0}
.author-mini .nm{font-family:var(--display);font-weight:700;font-size:15px}
.author-mini .role{font-family:var(--mono);font-size:11.5px;color:var(--faint);margin-top:2px}
.art-meta .tinfo{font-family:var(--mono);font-size:12px;color:var(--muted);display:flex;align-items:center;gap:10px}
.art-meta .tinfo .d{width:4px;height:4px;border-radius:50%;background:var(--faint)}
.share{margin-left:auto;display:flex;align-items:center;gap:8px}
.share-btn{width:38px;height:38px;border-radius:9px;border:1px solid var(--line);background:var(--panel);display:grid;place-items:center;color:var(--muted);transition:all .15s}
.share-btn:hover{color:#fff;border-color:var(--cobalt);background:var(--cobalt-soft)}
.art-hero{border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.art-hero image-slot{width:100%;height:480px}
.art-caption{font-family:var(--mono);font-size:11.5px;color:var(--faint);padding:11px 2px 0;display:flex;gap:8px}
.art-caption .credit{margin-left:auto;opacity:.8}
.art-body{font-size:18px;line-height:1.72;color:#d7ddee;max-width:70ch;margin-top:30px}
.art-body>p{margin-bottom:24px;text-wrap:pretty}
.art-body>p.lead-cap::first-letter{font-family:var(--display);font-weight:900;font-size:64px;float:left;line-height:.82;padding:6px 12px 0 0;color:var(--cobalt-bright)}
.art-body h2{font-family:var(--display);font-weight:800;font-size:27px;letter-spacing:-.015em;color:var(--text);margin:42px 0 16px;line-height:1.15}
.art-body a.inline{color:var(--cobalt-bright);border-bottom:1px solid rgba(77,119,255,.4)}
.art-body a.inline:hover{border-color:var(--cobalt-bright)}
.art-body strong{color:var(--text);font-weight:700}
.art-body ul{margin:0 0 24px;padding-left:2px;list-style:none;display:flex;flex-direction:column;gap:12px}
.art-body ul li{position:relative;padding-left:26px}
.art-body ul li::before{content:'';position:absolute;left:3px;top:11px;width:8px;height:8px;border-radius:2px;background:var(--cobalt);transform:rotate(45deg)}
.pullquote{margin:38px 0;padding:4px 0 4px 28px;border-left:4px solid var(--cobalt)}
.pullquote p{font-family:var(--display);font-weight:700;font-size:27px;line-height:1.25;letter-spacing:-.015em;color:var(--text);text-wrap:balance}
.pullquote cite{display:block;margin-top:13px;font-family:var(--mono);font-size:12.5px;color:var(--cobalt-bright);font-style:normal}
.inline-fig{margin:36px 0}
.inline-fig .frame{border-radius:14px;overflow:hidden;border:1px solid var(--line);height:340px}
.inline-fig image-slot{width:100%;height:100%}
.inline-fig figcaption{font-family:var(--mono);font-size:11.5px;color:var(--faint);margin-top:10px}
.statbar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin:36px 0}
.statbar .cell{background:var(--panel);padding:20px 18px}
.statbar .num{font-family:var(--display);font-weight:900;font-size:30px;letter-spacing:-.02em;color:var(--cobalt-bright);line-height:1}
.statbar .lab{font-family:var(--mono);font-size:10.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;margin-top:8px}
.art-inline-ad{height:120px;margin:36px 0}
.art-tags{display:flex;flex-wrap:wrap;gap:8px;margin:36px 0}
.art-tags .t{font-family:var(--mono);font-size:12px;color:var(--muted);background:var(--panel);border:1px solid var(--line);padding:7px 13px;border-radius:999px;transition:all .15s}
.art-tags .t:hover{color:var(--text);border-color:var(--cobalt)}
.author-box{display:flex;gap:18px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px;margin:36px 0}
.author-box .big-av{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--cobalt),#7a3bff);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:22px;color:#fff;flex-shrink:0}
.author-box .ab-name{font-family:var(--display);font-weight:800;font-size:18px}
.author-box .ab-role{font-family:var(--mono);font-size:11.5px;color:var(--cobalt-bright);margin:3px 0 10px}
.author-box p{font-size:14px;color:var(--muted);line-height:1.55;max-width:60ch}
.author-box .ab-follow{margin-top:14px;display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:700;font-size:13px;color:#fff;background:var(--cobalt);padding:8px 15px;border-radius:9px;transition:background .15s}
.author-box .ab-follow:hover{background:var(--cobalt-bright)}
.sec-head{display:flex;align-items:center;gap:14px;margin:0 0 20px}
.sec-head .bar{width:4px;height:22px;background:var(--cobalt);border-radius:2px}
.sec-head h2{font-family:var(--display);font-weight:900;font-size:21px;letter-spacing:-.01em;text-transform:uppercase}
.related{padding:44px 0}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rel-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .15s,transform .15s}
.rel-card:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.rel-card .ph{height:168px;overflow:hidden}
.rel-card .ph image-slot{width:100%;height:100%}
.rel-card .b{padding:15px 16px 17px;display:flex;flex-direction:column;gap:9px;flex:1}
.rel-card .k{font-family:var(--display);font-weight:700;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--cobalt-bright)}
.rel-card h3{font-family:var(--display);font-weight:700;font-size:17px;line-height:1.16;letter-spacing:-.012em;text-wrap:balance}
.rel-card:hover h3{color:var(--cobalt-bright)}
.rel-card .m{margin-top:auto;font-family:var(--mono);font-size:11px;color:var(--faint)}
aside.rail{display:flex;flex-direction:column;gap:26px;position:sticky;top:90px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:15px 17px;border-bottom:1px solid var(--line)}
.panel-head .t{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:14px}
.panel-head .t .ic{width:22px;height:22px;border-radius:6px;background:var(--cobalt-soft);display:grid;place-items:center;color:var(--cobalt-bright)}
.panel-head .more{font-family:var(--mono);font-size:11px;color:var(--faint)}
.read-list{display:flex;flex-direction:column}
.read-item{display:grid;grid-template-columns:26px 1fr;gap:13px;padding:13px 17px;border-bottom:1px solid var(--line);align-items:start;transition:background .15s}
.read-item:last-child{border-bottom:none}
.read-item:hover{background:rgba(255,255,255,.025)}
.read-item .rk{font-family:var(--display);font-weight:800;font-size:19px;color:var(--cobalt-bright);line-height:1;opacity:.85}
.read-item h4{font-family:var(--display);font-weight:700;font-size:14px;line-height:1.22;letter-spacing:-.01em}
.read-item:hover h4{color:var(--cobalt-bright)}
.read-item .m{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:5px}
.nl{background:linear-gradient(155deg,var(--panel-2),var(--panel));border:1px solid var(--line-strong);border-radius:14px;padding:22px;position:relative;overflow:hidden}
.nl::before{content:'';position:absolute;top:-40px;right:-40px;width:140px;height:140px;background:radial-gradient(circle,rgba(137,207,240,.35),transparent 70%)}
.nl .k{font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--cobalt-bright);margin-bottom:9px}
.nl h3{font-family:var(--display);font-weight:800;font-size:20px;line-height:1.12;letter-spacing:-.015em;margin-bottom:8px}
.nl p{font-size:13px;color:var(--muted);margin-bottom:16px}
.nl form{display:flex;flex-direction:column;gap:9px}
.nl input{background:var(--ink);border:1px solid var(--line-strong);border-radius:9px;height:42px;padding:0 13px;color:var(--text);font-size:13.5px;font-family:var(--sans);outline:none;transition:border-color .15s}
.nl input:focus{border-color:var(--cobalt)}
.nl button{height:42px;background:var(--cobalt);color:#fff;border-radius:9px;font-family:var(--display);font-weight:700;font-size:14px;transition:background .15s}
.nl button:hover{background:var(--cobalt-bright)}
.nl .ok{display:none;font-family:var(--display);font-weight:700;font-size:14px;color:var(--green);align-items:center;gap:8px;padding:10px 0}
.nl.done form{display:none}
.nl.done .ok{display:flex}
footer.site{background:var(--ink-2);border-top:1px solid var(--line);padding:50px 0 30px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid var(--line)}
.foot-brand .neon{font-size:26px;margin-bottom:16px}
.foot-brand p{color:var(--muted);font-size:13.5px;max-width:38ch;line-height:1.55}
.foot-social{display:flex;gap:10px;margin-top:18px}
.foot-social a{width:38px;height:38px;border-radius:10px;background:var(--panel);border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:all .15s}
.foot-social a:hover{color:#fff;border-color:var(--cobalt);background:var(--cobalt-soft)}
.foot-col h4{font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-bottom:15px}
.foot-col a{display:block;color:var(--muted);font-size:13.5px;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:var(--text)}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;font-family:var(--mono);font-size:11.5px;color:var(--faint)}
.foot-bottom .links{display:flex;gap:20px}
.foot-bottom .links a:hover{color:var(--muted)}
@media (max-width:1080px){.article-layout{grid-template-columns:1fr}aside.rail{position:static}.rel-grid{grid-template-columns:repeat(2,1fr)}.mainmenu,.search{display:none}.foot-top{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.wrap{padding:0 18px}.art-hero image-slot{height:280px}.statbar{grid-template-columns:repeat(2,1fr)}.rel-grid{grid-template-columns:1fr}}

/* ===== Téma-kiegészítés: hamburger / mobilmenü (nincs a gazette.css-ben) ===== */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:40px;border:1px solid var(--line);border-radius:10px;background:var(--panel);padding:0 10px;margin-left:auto}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--text);border-radius:2px;transition:transform .2s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.logo-wrap .neon{font-size:27px}
@media (max-width:1080px){
	.nav-toggle{display:flex}
	.nav-right{margin-left:14px}
	.mainmenu{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;background:rgba(7,10,20,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:8px 0}
	header.site .wrap.nav{position:relative}
	.nav-open .mainmenu{display:flex}
	.mainmenu a{padding:14px 28px;border-radius:0;font-size:16px}
	.nav-open .search{display:flex;order:5;width:100%;margin-top:10px}
}

/* Reduced-motion: a ticker-marquee megállítása (a11y) */
@media (prefers-reduced-motion:reduce){.ticker-flow{animation:none}}

/* ===== WordPress kép-integráció (a prototípus <image-slot> helyett valós <img>) ===== */
.hero-main > img.gz-bg,
.vid > img.gz-bg,
.story > img.gz-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: -2;
}
.hs-thumb img,
.card .ph img,
.hrow-thumb img,
.tr-player .face img,
.sponsor-logo img,
.partner-logo img,
.ad img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.sponsor-logo img,
.partner-logo img,
.ad img {
	object-fit: contain;
}

/* Skip-link (a11y) */
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
.skip-link:focus{position:fixed;top:8px;left:8px;width:auto;height:auto;clip:auto;z-index:100000;background:var(--cobalt);color:#fff;padding:10px 16px;border-radius:8px;font-family:var(--display);font-weight:700}


/* ========================================================================
   FŐOLDAL KOMPONENS-STÍLUSOK (a Gazette Főoldal.html inline <style>-jából,
   amit a Phase 1 gazette.css import kihagyott — chiprail/hero/kártyák/
   storyk/tabella/transfer/videó/sponzor + reszponzív töréspontok)
   ======================================================================== */
  /* ===== CHIP RAIL ===== */
  .chiprail { border-bottom: 1px solid var(--line); background: rgba(13,18,36,0.4); }
  .chiprail .wrap { display: flex; align-items: center; gap: 9px; height: 54px; overflow-x: auto; scrollbar-width: none; }
  .chiprail .wrap::-webkit-scrollbar { display: none; }
  .chip {
    flex-shrink: 0; font-family: var(--display); font-weight: 600; font-size: 13px;
    color: var(--muted); padding: 7px 15px; border-radius: 999px; border: 1px solid var(--line);
    background: var(--panel); transition: all .15s; white-space: nowrap; letter-spacing: 0.01em;
  }
  .chip:hover { color: var(--text); border-color: var(--line-strong); }
  .chip.active { background: var(--cobalt); border-color: var(--cobalt); color: #fff; }
  .chip-sep { width: 1px; height: 22px; background: var(--line); flex-shrink: 0; margin: 0 4px; }

  /* ===== SECTION HEADERS ===== */
  .sec-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 20px; gap: 16px; }
  .sec-title { display: flex; align-items: center; gap: 12px; font-family: var(--display); font-weight: 800; font-size: 21px; letter-spacing: -0.01em; }
  .sec-title .bar { width: 4px; height: 21px; background: var(--cobalt-bright); border-radius: 2px; }
  .sec-more { font-family: var(--display); font-weight: 600; font-size: 13px; color: var(--cobalt-bright); display: inline-flex; align-items: center; gap: 5px; transition: gap .15s; }
  .sec-more:hover { gap: 9px; }

  /* ===== HERO ===== */
  .hero { padding: 34px 0 8px; }
  .hero-grid { display: grid; grid-template-columns: 1.62fr 1fr; gap: 22px; }
  .hero-main {
    position: relative; border-radius: 18px; overflow: hidden; border: 1px solid var(--line);
    min-height: 520px; display: flex; flex-direction: column; justify-content: flex-end;
    isolation: isolate;
  }
  .hero-main image-slot { position: absolute; inset: 0; width: 100%; height: 100%; z-index: -2; }
  .hero-main::after {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background: linear-gradient(178deg, rgba(7,10,20,0.05) 0%, rgba(7,10,20,0.18) 42%, rgba(7,10,20,0.82) 78%, rgba(7,10,20,0.96) 100%);
  }
  .hero-main .body { padding: 34px; }
  .hero-tag {
    display: inline-flex; align-items: center; gap: 8px; font-family: var(--display); font-weight: 700;
    font-size: 11.5px; letter-spacing: 0.07em; text-transform: uppercase; color: #fff;
    background: var(--cobalt); padding: 6px 12px; border-radius: 7px; margin-bottom: 16px;
  }
  .hero-main h1 {
    font-family: var(--display); font-weight: 900; font-size: 44px; line-height: 1.02;
    letter-spacing: -0.025em; text-wrap: balance; margin-bottom: 14px;
    text-shadow: 0 2px 24px rgba(0,0,0,0.45);
  }
  .hero-main p { color: #d6dbf0; font-size: 16px; max-width: 60ch; text-shadow: 0 1px 12px rgba(0,0,0,0.5); }
  .hero-meta { display: flex; align-items: center; gap: 14px; margin-top: 18px; font-size: 12.5px; color: #b7bfe0; font-family: var(--mono); }
  .hero-meta .av { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg, var(--cobalt), #7a3bff); display: grid; place-items: center; font-family: var(--display); font-weight: 700; font-size: 11px; color: #fff; }
  .hero-meta .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--faint); }

  .hero-side { display: flex; flex-direction: column; gap: 14px; }
  .hs-card {
    display: grid; grid-template-columns: 96px 1fr; gap: 14px; background: var(--panel);
    border: 1px solid var(--line); border-radius: 14px; padding: 12px; transition: border-color .15s, transform .15s;
    flex: 1; align-items: center;
  }
  .hs-card:hover { border-color: var(--line-strong); transform: translateY(-2px); }
  .hs-thumb { width: 96px; height: 78px; border-radius: 10px; overflow: hidden; }
  .hs-thumb image-slot { width: 100%; height: 100%; }
  .hs-body .k { font-family: var(--display); font-weight: 700; font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cobalt-bright); margin-bottom: 6px; }
  .hs-body h3 { font-family: var(--display); font-weight: 700; font-size: 15.5px; line-height: 1.18; letter-spacing: -0.01em; text-wrap: balance; }
  .hs-body .t { font-family: var(--mono); font-size: 11px; color: var(--faint); margin-top: 7px; }

  /* ===== MAIN LAYOUT ===== */
  .layout { display: grid; grid-template-columns: 1fr 348px; gap: 40px; padding: 44px 0 30px; align-items: start; }
  .feed { display: flex; flex-direction: column; gap: 40px; }

  /* story cards grid */
  .card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
  .card {
    background: var(--panel); border: 1px solid var(--line); border-radius: 14px; overflow: hidden;
    display: flex; flex-direction: column; transition: border-color .15s, transform .15s;
  }
  .card:hover { border-color: var(--line-strong); transform: translateY(-3px); }
  .card .ph { height: 168px; overflow: hidden; position: relative; }
  .card .ph image-slot { width: 100%; height: 100%; }
  .card .ph .badge {
    position: absolute; top: 11px; left: 11px; z-index: 2; font-family: var(--display); font-weight: 700;
    font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: #fff;
    background: rgba(7,10,20,0.7); backdrop-filter: blur(6px); padding: 5px 9px; border-radius: 6px; border: 1px solid var(--line-strong);
  }
  .card .ph .badge.live { background: var(--live); border-color: transparent; }
  .card .cbody { padding: 15px 16px 17px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
  .card .cbody h3 { font-family: var(--display); font-weight: 700; font-size: 17px; line-height: 1.16; letter-spacing: -0.012em; text-wrap: balance; }
  .card:hover .cbody h3 { color: var(--cobalt-bright); }
  .card .cbody p { font-size: 13.5px; color: var(--muted); line-height: 1.45; }
  .card .cfoot { margin-top: auto; display: flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 11px; color: var(--faint); }
  .card .cfoot .cat { color: var(--cobalt-bright); font-weight: 600; }

  /* horizontal list */
  .hlist { display: flex; flex-direction: column; }
  .hrow {
    display: grid; grid-template-columns: 150px 1fr; gap: 18px; padding: 18px 0;
    border-top: 1px solid var(--line); align-items: center; transition: padding-left .18s;
  }
  .hrow:first-child { border-top: none; padding-top: 4px; }
  .hrow:hover { padding-left: 8px; }
  .hrow-thumb { width: 150px; height: 96px; border-radius: 11px; overflow: hidden; }
  .hrow-thumb image-slot { width: 100%; height: 100%; }
  .hrow-body .k { font-family: var(--display); font-weight: 700; font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cobalt-bright); margin-bottom: 7px; }
  .hrow-body h3 { font-family: var(--display); font-weight: 700; font-size: 19px; line-height: 1.16; letter-spacing: -0.015em; text-wrap: balance; }
  .hrow:hover .hrow-body h3 { color: var(--cobalt-bright); }
  .hrow-body p { font-size: 13.5px; color: var(--muted); margin-top: 7px; line-height: 1.45; max-width: 62ch; }
  .hrow-body .meta { font-family: var(--mono); font-size: 11px; color: var(--faint); margin-top: 9px; display: flex; gap: 9px; align-items: center; }

  /* ===== SIDEBAR ===== */
  aside.rail { display: flex; flex-direction: column; gap: 26px; position: sticky; top: 90px; }
  .panel { background: var(--panel); border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
  .panel-head { display: flex; align-items: center; justify-content: space-between; padding: 15px 17px; border-bottom: 1px solid var(--line); }
  .panel-head .t { display: flex; align-items: center; gap: 9px; font-family: var(--display); font-weight: 800; font-size: 14px; letter-spacing: 0.01em; }
  .panel-head .t .ic { width: 22px; height: 22px; border-radius: 6px; background: var(--cobalt-soft); display: grid; place-items: center; color: var(--cobalt-bright); }
  .panel-head .more { font-family: var(--mono); font-size: 11px; color: var(--faint); }

  /* league table */
  .table-tabs { display: flex; gap: 4px; padding: 10px 12px; border-bottom: 1px solid var(--line); }
  .table-tabs button { font-family: var(--display); font-weight: 600; font-size: 11.5px; color: var(--muted); padding: 5px 10px; border-radius: 7px; transition: all .15s; }
  .table-tabs button.active { background: var(--cobalt-soft); color: var(--cobalt-bright); }
  table.standings { width: 100%; border-collapse: collapse; font-size: 13px; }
  table.standings th { font-family: var(--mono); font-weight: 500; font-size: 10px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--faint); text-align: center; padding: 9px 6px; border-bottom: 1px solid var(--line); }
  table.standings th:first-child { text-align: left; padding-left: 17px; }
  table.standings th.pts { color: var(--cobalt-bright); }
  table.standings td { padding: 9px 6px; text-align: center; border-bottom: 1px solid rgba(255,255,255,0.04); font-family: var(--mono); font-size: 12.5px; color: var(--muted); }
  table.standings tr:last-child td { border-bottom: none; }
  table.standings td.team { text-align: left; padding-left: 17px; display: flex; align-items: center; gap: 9px; font-family: var(--sans); font-weight: 600; color: var(--text); font-size: 13px; }
  table.standings td.pts { color: var(--text); font-weight: 600; }
  .pos { display: inline-grid; place-items: center; width: 19px; height: 19px; border-radius: 5px; font-size: 10.5px; font-weight: 600; background: rgba(255,255,255,0.05); color: var(--muted); }
  .pos.ucl { background: rgba(137,207,240,0.22); color: var(--cobalt-bright); }
  .pos.uel { background: rgba(43,212,125,0.16); color: var(--green); }
  .pos.rel { background: rgba(255,59,84,0.16); color: var(--live); }
  .crest { width: 18px; height: 18px; border-radius: 4px; display: grid; place-items: center; font-family: var(--display); font-weight: 800; font-size: 9px; color: #fff; flex-shrink: 0; }
  .legend { display: flex; gap: 14px; padding: 11px 17px; font-family: var(--mono); font-size: 10px; color: var(--faint); }
  .legend span { display: inline-flex; align-items: center; gap: 5px; }
  .legend i { width: 8px; height: 8px; border-radius: 2px; }

  /* trending */
  .trend-list { display: flex; flex-direction: column; }
  .trend-item { display: grid; grid-template-columns: 26px 1fr; gap: 13px; padding: 13px 17px; border-bottom: 1px solid var(--line); align-items: start; transition: background .15s; }
  .trend-item:last-child { border-bottom: none; }
  .trend-item:hover { background: rgba(255,255,255,0.025); }
  .trend-item .rk { font-family: var(--display); font-weight: 800; font-size: 19px; color: var(--cobalt-bright); line-height: 1; opacity: 0.85; }
  .trend-item h4 { font-family: var(--display); font-weight: 700; font-size: 14px; line-height: 1.22; letter-spacing: -0.01em; }
  .trend-item:hover h4 { color: var(--cobalt-bright); }
  .trend-item .m { font-family: var(--mono); font-size: 10.5px; color: var(--faint); margin-top: 5px; }

  /* newsletter */
  .nl { background: linear-gradient(155deg, var(--panel-2), var(--panel)); border: 1px solid var(--line-strong); border-radius: 14px; padding: 22px; position: relative; overflow: hidden; }
  .nl::before { content: ''; position: absolute; top: -40px; right: -40px; width: 140px; height: 140px; background: radial-gradient(circle, rgba(137,207,240,0.35), transparent 70%); }
  .nl .k { font-family: var(--display); font-weight: 700; font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; color: var(--cobalt-bright); margin-bottom: 9px; }
  .nl h3 { font-family: var(--display); font-weight: 800; font-size: 20px; line-height: 1.12; letter-spacing: -0.015em; margin-bottom: 8px; }
  .nl p { font-size: 13px; color: var(--muted); margin-bottom: 16px; }
  .nl-form { display: flex; flex-direction: column; gap: 9px; }
  .nl-form input { background: var(--ink); border: 1px solid var(--line-strong); border-radius: 9px; height: 42px; padding: 0 13px; color: var(--text); font-size: 13.5px; font-family: var(--sans); outline: none; transition: border-color .15s; }
  .nl-form input:focus { border-color: var(--cobalt); }
  .nl-form button { height: 42px; background: var(--cobalt); color: #fff; border-radius: 9px; font-family: var(--display); font-weight: 700; font-size: 14px; transition: background .15s; }
  .nl-form button:hover { background: var(--cobalt-bright); }
  .nl .ok { display: none; font-family: var(--display); font-weight: 700; font-size: 14px; color: var(--green); align-items: center; gap: 8px; padding: 10px 0; }
  .nl.done .nl-form { display: none; }
  .nl.done .ok { display: flex; }

  /* poll */
  .poll { padding: 17px; }
  .poll .q { font-family: var(--display); font-weight: 700; font-size: 15px; line-height: 1.25; margin-bottom: 14px; }
  .poll-opt { position: relative; border: 1px solid var(--line); border-radius: 9px; padding: 11px 13px; margin-bottom: 8px; cursor: pointer; overflow: hidden; transition: border-color .15s; }
  .poll-opt:hover { border-color: var(--line-strong); }
  .poll-opt .fill { position: absolute; inset: 0; background: var(--cobalt-soft); width: 0; transition: width .6s cubic-bezier(.2,.7,.2,1); z-index: 0; }
  .poll-opt .lbl { position: relative; z-index: 1; display: flex; justify-content: space-between; font-size: 13.5px; font-weight: 500; }
  .poll-opt .pct { font-family: var(--mono); font-size: 12px; color: var(--cobalt-bright); opacity: 0; transition: opacity .3s; }
  .poll.voted .poll-opt { cursor: default; }
  .poll.voted .poll-opt .pct { opacity: 1; }
  .poll .total { font-family: var(--mono); font-size: 11px; color: var(--faint); margin-top: 11px; text-align: center; }

  /* ===== TRANSFER STRIP ===== */
  .strip { background: var(--ink-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 40px 0; }
  .transfer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
  .tr-card { background: var(--panel); border: 1px solid var(--line); border-radius: 13px; padding: 16px; transition: border-color .15s, transform .15s; }
  .tr-card:hover { border-color: var(--cobalt); transform: translateY(-2px); }
  .tr-card .status { display: inline-flex; align-items: center; gap: 6px; font-family: var(--display); font-weight: 700; font-size: 10px; letter-spacing: 0.05em; text-transform: uppercase; padding: 4px 9px; border-radius: 6px; margin-bottom: 13px; }
  .tr-card .status.done { background: rgba(43,212,125,0.14); color: var(--green); }
  .tr-card .status.talks { background: rgba(255,194,75,0.14); color: var(--gold); }
  .tr-card .status.rumour { background: rgba(154,163,196,0.12); color: var(--muted); }
  .tr-player { display: flex; align-items: center; gap: 12px; margin-bottom: 13px; }
  .tr-player .face { width: 46px; height: 46px; border-radius: 11px; overflow: hidden; flex-shrink: 0; }
  .tr-player .face image-slot { width: 100%; height: 100%; }
  .tr-player .nm { font-family: var(--display); font-weight: 800; font-size: 16px; letter-spacing: -0.01em; }
  .tr-player .ppos { font-family: var(--mono); font-size: 10.5px; color: var(--faint); margin-top: 2px; }
  .tr-move { display: flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 12px; color: var(--muted); }
  .tr-move .arrow { color: var(--cobalt-bright); }
  .tr-fee { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: baseline; }
  .tr-fee .lab { font-family: var(--mono); font-size: 10px; color: var(--faint); text-transform: uppercase; letter-spacing: 0.05em; }
  .tr-fee .val { font-family: var(--display); font-weight: 800; font-size: 17px; color: var(--text); }

  /* ===== VIDEO ROW ===== */
  .video-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 18px; }
  .vid { position: relative; border-radius: 14px; overflow: hidden; border: 1px solid var(--line); min-height: 200px; display: flex; align-items: flex-end; isolation: isolate; transition: transform .15s; }
  .vid.big { min-height: 300px; }
  .vid:hover { transform: translateY(-2px); }
  .vid image-slot { position: absolute; inset: 0; width: 100%; height: 100%; z-index: -2; }
  .vid::after { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(7,10,20,0.1) 30%, rgba(7,10,20,0.9) 100%); }
  .vid .play { position: absolute; top: 14px; left: 14px; width: 40px; height: 40px; border-radius: 50%; background: rgba(137,207,240,0.92); display: grid; place-items: center; backdrop-filter: blur(4px); }
  .vid .dur { position: absolute; top: 20px; right: 14px; font-family: var(--mono); font-size: 11px; background: rgba(7,10,20,0.7); padding: 3px 8px; border-radius: 5px; color: #fff; }
  .vid .vb { padding: 16px; }
  .vid .vb .k { font-family: var(--display); font-weight: 700; font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cobalt-bright); margin-bottom: 7px; }
  .vid .vb h3 { font-family: var(--display); font-weight: 700; font-size: 16px; line-height: 1.15; letter-spacing: -0.01em; text-shadow: 0 1px 10px rgba(0,0,0,0.5); }
  .vid.big .vb h3 { font-size: 23px; }

  /* ===== STORIES ===== */
  .stories { padding: 14px 0 4px; }
  .stories-track {
    display: flex; gap: 14px; overflow-x: auto; scrollbar-width: none;
    padding: 4px 2px 14px; scroll-snap-type: x proximity;
  }
  .stories-track::-webkit-scrollbar { display: none; }
  .story {
    position: relative; flex-shrink: 0; width: 152px; height: 216px; border-radius: 16px;
    overflow: hidden; border: 1px solid var(--line); scroll-snap-align: start;
    display: flex; flex-direction: column; justify-content: flex-end; isolation: isolate;
    transition: transform .15s, border-color .15s;
  }
  .story:hover { transform: translateY(-3px); border-color: var(--line-strong); }
  .story image-slot { position: absolute; inset: 0; width: 100%; height: 100%; z-index: -2; }
  .story::after { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(7,10,20,0.05) 30%, rgba(7,10,20,0.85) 100%); }
  .story .avatar {
    position: absolute; top: 11px; left: 11px; width: 38px; height: 38px; border-radius: 50%;
    padding: 2px; background: linear-gradient(135deg, var(--cobalt-bright), #7a3bff); z-index: 2;
  }
  .story .avatar .inner { width: 100%; height: 100%; border-radius: 50%; overflow: hidden; border: 2px solid var(--ink); background: var(--panel); display: grid; place-items: center; font-family: var(--display); font-weight: 800; font-size: 12px; color: var(--text); }
  .story .new {
    position: absolute; top: 14px; right: 11px; z-index: 2; font-family: var(--display); font-weight: 700;
    font-size: 9px; letter-spacing: 0.07em; text-transform: uppercase; color: #fff;
    background: var(--cobalt); padding: 3px 7px; border-radius: 5px;
  }
  .story .scap { padding: 12px; }
  .story .scap .who { font-family: var(--mono); font-size: 10px; color: #c5cbe6; margin-bottom: 3px; }
  .story .scap h4 { font-family: var(--display); font-weight: 700; font-size: 13.5px; line-height: 1.16; letter-spacing: -0.01em; text-shadow: 0 1px 8px rgba(0,0,0,0.5); }
  .story.add {
    background: var(--panel); border: 1px dashed var(--line-strong); justify-content: center; align-items: center;
    cursor: pointer; gap: 12px;
  }
  .story.add:hover { border-color: var(--cobalt); background: var(--panel-2); }
  .story.add .plus { width: 46px; height: 46px; border-radius: 50%; background: var(--cobalt-soft); display: grid; place-items: center; color: var(--cobalt-bright); }
  .story.add .lbl { font-family: var(--display); font-weight: 700; font-size: 13px; text-align: center; padding: 0 14px; line-height: 1.25; }
  .story.add .sub { font-family: var(--mono); font-size: 10px; color: var(--faint); }

  /* ===== AD ZONES ===== */
  .ad {
    position: relative; display: flex; align-items: center; justify-content: center;
    background:
      repeating-linear-gradient(135deg, rgba(255,255,255,0.012) 0 12px, transparent 12px 24px),
      var(--ink-2);
    border: 1px solid var(--line); border-radius: 12px; overflow: hidden;
  }
  .ad::before {
    content: 'Hirdetés'; position: absolute; top: 8px; right: 11px; z-index: 3;
    font-family: var(--mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--faint); background: rgba(7,10,20,0.6); padding: 2px 7px; border-radius: 5px;
  }
  .ad .ad-empty {
    display: flex; flex-direction: column; align-items: center; gap: 6px;
    color: var(--faint); font-family: var(--display); font-weight: 600; pointer-events: none;
  }
  .ad .ad-empty .sz { font-family: var(--mono); font-size: 10.5px; opacity: 0.7; font-weight: 500; }
  .ad image-slot { width: 100%; height: 100%; }
  .ad-billboard { height: 250px; margin: 0; }
  .ad-band { background: rgba(13,18,36,0.4); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 26px 0; }
  .ad-leaderboard { height: 130px; }
  .ad-rect { height: 300px; }
  .ad-halfpage { height: 600px; }

  /* gutter wing skyscrapers — only on very wide screens */
  .ad-wing {
    position: fixed; top: 120px; width: 160px; height: 600px; z-index: 30; display: none;
  }
  .ad-wing.left { left: max(12px, calc((100vw - var(--maxw)) / 2 - 176px)); }
  .ad-wing.right { right: max(12px, calc((100vw - var(--maxw)) / 2 - 176px)); }
  @media (min-width: 1720px) { .ad-wing { display: flex; } }

  /* sticky bottom bar ad */
  .ad-sticky {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 60;
    background: rgba(13,18,36,0.96); backdrop-filter: blur(14px);
    border-top: 1px solid var(--line-strong); padding: 10px 0;
    transform: translateY(100%); transition: transform .4s cubic-bezier(.2,.7,.2,1);
  }
  .ad-sticky.show { transform: translateY(0); }
  .ad-sticky .wrap { display: flex; align-items: center; justify-content: center; position: relative; }
  .ad-sticky .ad { height: 90px; width: 728px; max-width: 100%; }
  .ad-sticky .close {
    position: absolute; right: 28px; top: 50%; transform: translateY(-50%);
    width: 28px; height: 28px; border-radius: 50%; background: var(--panel);
    border: 1px solid var(--line-strong); display: grid; place-items: center; color: var(--muted);
    transition: color .15s, border-color .15s;
  }
  .ad-sticky .close:hover { color: var(--text); border-color: var(--cobalt); }

  /* ===== MAIN SPONSOR ===== */
  .sponsor { background: var(--ink-2); border-top: 1px solid var(--line); padding: 42px 0; }
  .sponsor-main {
    display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 34px;
    background: linear-gradient(120deg, var(--panel-2), var(--panel));
    border: 1px solid var(--line-strong); border-radius: 18px; padding: 30px 36px;
    position: relative; overflow: hidden;
  }
  .sponsor-main::before { content: ''; position: absolute; top: -60px; right: -30px; width: 240px; height: 240px; background: radial-gradient(circle, rgba(137,207,240,0.22), transparent 70%); }
  .sponsor-lede .k { font-family: var(--display); font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cobalt-bright); margin-bottom: 8px; }
  .sponsor-lede h3 { font-family: var(--display); font-weight: 800; font-size: 24px; line-height: 1.1; letter-spacing: -0.015em; }
  .sponsor-lede p { color: var(--muted); font-size: 13.5px; margin-top: 7px; max-width: 46ch; }
  .sponsor-logo {
    width: 230px; height: 96px; border-radius: 12px; overflow: hidden;
    background: #fff; position: relative; z-index: 1; flex-shrink: 0;
  }
  .sponsor-logo image-slot { width: 100%; height: 100%; }
  .sponsor-cta {
    position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 8px;
    height: 46px; padding: 0 22px; background: var(--cobalt); color: #fff; border-radius: 11px;
    font-family: var(--display); font-weight: 700; font-size: 14px; white-space: nowrap; transition: background .15s;
  }
  .sponsor-cta:hover { background: var(--cobalt-bright); }
  .sponsor-partners { display: flex; align-items: center; gap: 16px; margin-top: 26px; flex-wrap: wrap; }
  .sponsor-partners .lab { font-family: var(--mono); font-size: 11px; color: var(--faint); text-transform: uppercase; letter-spacing: 0.08em; margin-right: 4px; }
  .partner-logo { width: 124px; height: 54px; border-radius: 10px; overflow: hidden; background: var(--panel); border: 1px solid var(--line); }
  .partner-logo image-slot { width: 100%; height: 100%; }

  /* ===== FOOTER ===== */
  footer.site { background: var(--ink-2); border-top: 1px solid var(--line); padding: 50px 0 30px; margin-top: 0; }
  .foot-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 36px; border-bottom: 1px solid var(--line); }
  .foot-brand .logo { font-size: 28px; margin-bottom: 14px; }
  .foot-brand .powered { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; color: var(--faint); margin: -8px 0 16px; }
  .foot-brand .powered span { color: var(--cobalt-bright); font-weight: 600; letter-spacing: 0.1em; }
  .foot-brand p { color: var(--muted); font-size: 13.5px; max-width: 38ch; line-height: 1.55; }
  .foot-social { display: flex; gap: 10px; margin-top: 18px; }
  .foot-social a { width: 38px; height: 38px; border-radius: 10px; background: var(--panel); border: 1px solid var(--line); display: grid; place-items: center; color: var(--muted); transition: all .15s; }
  .foot-social a:hover { color: #fff; border-color: var(--cobalt); background: var(--cobalt-soft); }
  .foot-col h4 { font-family: var(--display); font-weight: 800; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--faint); margin-bottom: 15px; }
  .foot-col a { display: block; color: var(--muted); font-size: 13.5px; padding: 5px 0; transition: color .15s; }
  .foot-col a:hover { color: var(--text); }
  .foot-bottom { display: flex; align-items: center; justify-content: space-between; padding-top: 24px; font-family: var(--mono); font-size: 11.5px; color: var(--faint); }
  .foot-bottom .links { display: flex; gap: 20px; }
  .foot-bottom .links a:hover { color: var(--muted); }

  @media (max-width: 1080px) {
    .hero-grid { grid-template-columns: 1fr; }
    .layout { grid-template-columns: 1fr; }
    aside.rail { position: static; }
    .transfer-grid { grid-template-columns: repeat(2, 1fr); }
    .video-grid { grid-template-columns: 1fr; }
    .card-grid { grid-template-columns: repeat(2, 1fr); }
    .sponsor-main { grid-template-columns: 1fr; gap: 22px; text-align: center; justify-items: center; }
    .sponsor-lede p { margin-left: auto; margin-right: auto; }
    .sponsor-partners { justify-content: center; }
  }
  @media (max-width: 680px) {
    .card-grid, .transfer-grid { grid-template-columns: 1fr; }
    .mainmenu, .search { display: none; }
    .hero-main h1 { font-size: 32px; }
    .hrow { grid-template-columns: 1fr; }
    .hrow-thumb { width: 100%; height: 180px; }
    .foot-top { grid-template-columns: 1fr 1fr; }
  }

/* WP nav-menü: <li> bullet-reset (a prototípus bare <a>-t használt, a wp_nav_menu <li>-t ad) */
.mainmenu,
.mainmenu li,
.foot-col ul,
.foot-col li {
	list-style: none;
	margin: 0;
	padding: 0;
}
.mainmenu li {
	display: inline-flex;
}

/* Babakék akcent: az akcent-kitöltésű elemeken sötét szöveg (kontraszt/olvashatóság) */
.btn-live,
.art-kicker,
.author-box .ab-follow,
.nl button,
.nl-form button,
.skip-link:focus,
.chip.active,
.hero-tag,
.sponsor-cta,
.story .new {
	color: #0a1428;
}
.btn-live .dot {
	background: #0a1428;
}
.vid .play svg {
	fill: #0a1428;
}
