:root{
  --dk:#060f24; --md:#184e9a; --yl:#f7c800; --text:#fff; --dim:#b5c7e6;
  --header-h:78px;
  --hero-h: clamp(420px, 46vh, 760px);
  --container-w:min(1600px,96vw);
  --good:#22c55e; --bad:#ef4444; --line:#1e2a4a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Helvetica Neue',Arial,sans-serif;
  color:var(--text); background:var(--dk); min-height:100svh;
  background-image:
    radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    radial-gradient(1200px 800px at top right, rgba(24,78,154,.25), transparent 60%),
    radial-gradient(1000px 700px at bottom left, rgba(247,200,0,.08), transparent 60%),
    linear-gradient(#06122a,#040b1e);
  background-size:20px 20px,20px 20px,auto,auto,auto;
  background-position:0 0,10px 10px,center,center,center;
}

/* a fix fejléc miatt ne takarjon ki címeket */
.anchor-target{scroll-margin-top:120px;}

/* ===== HEADER ===== */
header.site-header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; gap:clamp(10px,2vw,24px);
  padding:12px clamp(16px,4vw,40px);
  background:rgba(4,10,24,.65);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
  min-height:var(--header-h); overflow:hidden;
  transition:background .25s, box-shadow .25s;
}
header.site-header.scrolled{ background:rgba(8,26,58,.9); box-shadow:0 8px 24px rgba(0,0,0,.35) }

/* LOGÓ – valós kép, nem vágja le */
.logo{
  width: clamp(64px, 5.2vw, 92px);
  height: clamp(64px, 5.2vw, 92px);
  border-radius:50%;
  display:grid; place-items:center;
  background:transparent; z-index:1; flex:0 0 auto;
  overflow:hidden; border:none;
  aspect-ratio:1/1;
}
.logo-img{
  width:100%; height:100%; display:block;
  object-fit:contain;
  object-position:center;
}

nav.main-nav{
  flex:1; display:flex; align-items:center; justify-content:center;
  gap: clamp(8px, 1vw, 16px);
  flex-wrap: nowrap; white-space: nowrap;
  overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: thin;
}
.btn{
  position:relative; isolation:isolate; flex:0 0 auto;
  padding:clamp(9px,.9vw,12px) clamp(16px,1.6vw,22px);
  border-radius:28px; border:1px solid rgba(255,255,255,.18);
  color:#eaf0ff; font-weight:900; letter-spacing:.3px; text-transform:uppercase;
  background:linear-gradient(90deg, rgba(11,30,63,.70), rgba(11,30,63,.70)) padding-box,
             linear-gradient(90deg, rgba(24,78,154,.35), rgba(247,200,0,.35)) border-box;
  text-decoration:none; transition:transform .18s, color .18s, border-color .18s, background-position .45s ease;
  background-size:200% 100%; background-position:0% 0%;
}
.btn:hover{ background-position:100% 0% }
.btn::after{
  content:""; position:absolute; left:16px; right:16px; bottom:-1px; height:3px; border-radius:3px;
  background:linear-gradient(90deg,var(--yl),#ffd54d,var(--yl));
  transform:scaleX(0); transform-origin:left; transition:transform .3s cubic-bezier(.2,.7,.2,1); opacity:.95;
}
.btn:hover::after{ transform:scaleX(1) }
.btn.active{ color:var(--yl); border-color:rgba(247,200,0,.55) }
.btn.active::after{ transform:scaleX(1) }
.btn:focus-visible{ outline:3px solid rgba(247,200,0,.65); outline-offset:2px }

/* ===== HERO ===== */
.hero{
  position:relative; min-height:var(--hero-h);
  display:flex; align-items:flex-start; justify-content:center;
  padding:calc(var(--header-h) + 18px) clamp(16px, 2vw, 40px) clamp(22px, 4vh, 48px);
  overflow:hidden;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.hero-inner{
  max-width:var(--container-w); width:100%;
  margin-inline:auto; position:relative; z-index:1; display:flex; justify-content:center;
}
.glass{
  position:relative;
  width:100%; max-width:var(--container-w);
  min-height: clamp(160px, 24vh, 360px);
  display:grid; grid-template-columns:1fr; justify-items:center; align-content:center; text-align:center;
  padding:clamp(20px,2.4vw,32px);
  border-radius:18px; background:rgba(255,255,255,.06);
  backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,.12); overflow:hidden;
  margin-top: clamp(6px, 6vh, 80px);
}
.fullname{margin:0; font-weight:900; font-size:clamp(26px,4.2vw,56px)}
.quote{color:var(--dim); font-size:clamp(14px,1.3vw,18px)}

.divider{height:8px;width:100%;background:linear-gradient(270deg,var(--yl),var(--md),var(--yl));background-size:400% 400%; margin:clamp(14px,2vh,28px) 0}
.divider-label{text-align:center; font-size:clamp(20px,2vw,32px); font-weight:900; text-transform:uppercase; color:var(--text); margin:-10px 0}

/* ===== FŐ TÁMOGATÓ BANNER ===== */
.sponsor-banner{
  margin:40px auto; max-width:var(--container-w);
  padding:clamp(24px,3vw,40px);
  border-radius:18px;
  background: linear-gradient(#06122a,#040b1e);
  border:1px solid rgba(255,255,255,.10);
  min-height:clamp(240px,34vh,440px);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
  overflow: hidden;
}
.sponsor-banner a{ display:block; width:100%; height:100%; border-radius:inherit; overflow:hidden; }
.sponsor-banner a:focus-visible{ outline:3px solid rgba(247,200,0,.65); outline-offset:3px; }
.sponsor-img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ===== MATCHES TIMELINE ===== */
.matches-section{margin:clamp(32px,7vh,68px) auto; max-width:var(--container-w); padding:0 clamp(16px,2vw,24px)}
.legend{display:flex; gap:12px; align-items:center; justify-content:center; color:var(--dim); font-size:14px; margin-bottom:16px; flex-wrap:wrap}
.legend .dot{width:10px;height:10px;border-radius:50%}
.legend .played .dot{background:var(--good)} .legend .upcoming .dot{background:var(--bad)}
.timeline{position:relative; margin:0; padding:28px 0 0; list-style:none}
.timeline::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#33406a,var(--line),#33406a);transform:translateX(-50%); border-radius:2px; box-shadow:0 0 0 1px rgba(255,255,255,.05), 0 0 18px rgba(24,78,154,.35)}
.timeline-item{position:relative;width:50%;padding:18px 22px;opacity:0;transform:translateY(10px);transition:.45s}
.timeline-item.show{opacity:1;transform:translateY(0)}
.timeline-item.left{left:0;text-align:right} .timeline-item.right{left:50%}
.timeline-item::after{content:""; position:absolute; top:28px; width:16px; height:16px; border-radius:50%; background:#0c1b3a; border:3px solid var(--yl); box-shadow:0 0 0 3px #0c1b3a}
.timeline-item.left::after{ right:-8px } .timeline-item.right::after{ left:-8px }
.match-card{ position:relative; display:inline-block; max-width:min(720px,48vw); background:linear-gradient(180deg,rgba(7,14,30,.92),rgba(8,16,34,.92)); border:1px solid rgba(255,255,255,.16); border-radius:18px; padding:18px 20px; box-shadow:0 14px 32px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.05); backdrop-filter: blur(6px); color:#eaf0ff; }
.timeline-item.left .match-card{ border-left:4px solid rgba(255,255,255,.16) }
.timeline-item.right .match-card{ border-right:4px solid rgba(255,255,255,.16) }
.match-title{ margin:2px 0 10px; font-size:clamp(18px,2vw,24px); font-weight:900; color:#fff }
.match-meta{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end }
.timeline-item.right .match-meta{ justify-content:flex-start }
.tag{ display:inline-flex; align-items:center; gap:8px; padding:7px 12px; border-radius:999px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); font-weight:800; letter-spacing:.2px; font-size:14px }
.tag .dot{width:10px;height:10px;border-radius:50%}
.tag.venue{ opacity:.9 }
.match-desc{ margin:10px 0 0; color:#b5c7e6; font-size:clamp(14px,1.1vw,16px) }
.timeline-item.played .match-card{ border-color: rgba(34,197,94,.55); box-shadow:0 14px 32px rgba(0,0,0,.55), 0 0 26px rgba(34,197,94,.12) }
.timeline-item.played .tag.status{ background:rgba(34,197,94,.12); border-color:rgba(34,197,94,.45); color:#bbf7d0 }
.timeline-item.played .tag.status .dot{ background:var(--good) }
.timeline-item.upcoming .match-card{ border-color: rgba(239,68,68,.55); box-shadow:0 14px 32px rgba(0,0,0,.55), 0 0 26px rgba(239,68,68,.12) }
.timeline-item.upcoming .tag.status{ background:rgba(239,68,68,.12); border-color:rgba(239,68,68,.45); color:#fecaca }
.timeline-item.upcoming .tag.status .dot{ background:var(--bad) }

/* ===== Edzői nyilatkozat – lenyitható ===== */
.match-card details.coach{
  margin-top:12px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  border-radius:12px;
  padding:10px 12px;
}
.match-card details.coach summary{
  cursor:pointer; font-weight:900; display:flex; align-items:center; gap:10px; list-style:none;
}
.match-card details.coach summary::-webkit-details-marker{ display:none; }
.match-card details.coach .chev{ margin-left:auto; transition:transform .2s ease; }
.match-card details.coach[open] .chev{ transform:rotate(180deg); }
.match-card details.coach .coach-body{ margin-top:8px; color:#c8d5f3; font-size:14px; line-height:1.45; }

/* ===== KAPCSOLAT, HÍRLEVÉL ===== */
.newsletter{max-width:min(1100px,94vw); margin:40px auto 80px; padding:clamp(18px,2vw,28px);
  background:radial-gradient(120% 140% at 85% -10%, rgba(247,200,0,.12), transparent 40%), radial-gradient(100% 100% at -10% 120%, rgba(24,78,154,.18), transparent 40%), linear-gradient(180deg,#0b1e3f,#0a1731);
  border:1px solid rgba(255,255,255,.12); border-radius:16px; box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.newsletter h3{font-size:clamp(20px,2.2vw,28px);font-weight:900;margin:0 0 6px;color:#eaf0ff}
.newsletter p{margin:0 0 10px;color:#b5c7e6}
.newsletter form{display:grid;gap:clamp(12px,1.2vw,18px)}
.newsletter .inline{display:flex;gap:12px;align-items:stretch}
.newsletter input[type="email"]{flex:1;padding:clamp(12px,1.2vw,16px);border-radius:12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:var(--text)}
.newsletter .actions{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap}
.newsletter button#subscribeBtn{padding:clamp(12px,1.2vw,16px) clamp(18px,1.6vw,22px);border:none;border-radius:12px;font-weight:900;background:var(--yl);color:#111936;cursor:pointer;box-shadow:0 8px 30px rgba(247,200,0,.35);transition:.2s}
.newsletter button#subscribeBtn.subscribed{ background: linear-gradient(145deg,#22c55e,#16a34a); color:#0b2d16; box-shadow:0 8px 28px rgba(22,163,74,.35) }
.newsletter button#unsubscribeBtn{padding:clamp(12px,1.2vw,16px) clamp(16px,1.4vw,20px);border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff;border-radius:12px;font-weight:800;cursor:pointer}
.newsletter .form-msg{font-size:14px}
.newsletter .form-msg.ok{color:#86efac}
.newsletter .form-msg.err{color:#fca5a5}
.newsletter label.agree{display:flex;align-items:center;gap:10px;font-size:clamp(12px,1vw,14px);color:#b5c7e6}
.dl-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;text-decoration:none;font-weight:800}

.contacts{ max-width: var(--container-w); margin: 20px auto 80px; padding: 0 clamp(16px,2vw,24px); }
.contact-grid{ display: grid; grid-template-columns: 2fr 1fr; gap: clamp(14px,2vw,28px); }
.contact-card{ background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 16px; padding: clamp(14px,1.6vw,22px); position: relative; overflow: hidden; }
.contact-card::after{ content:""; position:absolute; top:-40%; left:-10%; width:20%; height:180%; background:linear-gradient(120deg,transparent,rgba(255,255,255,.12),transparent); transform:translateX(-120%) rotate(12deg); transition:.8s; pointer-events:none }
.contact-card:hover::after{ transform:translateX(420%) rotate(12deg) }
.map-embed{ position: relative; border-radius: 12px; overflow: hidden; box-shadow: 0 10px 28px rgba(0,0,0,.35); aspect-ratio: 16 / 9; }
.map-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; filter: saturate(1.05) contrast(1.05); }
.map-caption{ margin-top: 10px; color: var(--dim); font-size: 14px; }
.info-list{ display:grid; gap:12px }
.info-row{ display:grid; grid-template-columns: 40px 1fr; gap:10px; align-items:center; padding:10px; border-radius:12px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08) }
.icon{ width:40px; height:40px; border-radius:10px; display:grid; place-items:center; background: linear-gradient(145deg, var(--yl), var(--md)); color: #111936; font-weight:900 }
.info-row a{ color:#eaf0ff; text-decoration:none } .info-row a:hover{text-decoration:underline}
.socials{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px }
.social-btn{ display:inline-grid; place-items:center; width:44px; height:44px; border-radius:12px; border:1px solid rgba(255,255,255,.22); background:rgba(255,255,255,.06); color:#fff; text-decoration:none; transition:.2s }
.social-btn:hover{ transform:translateY(-2px); box-shadow:0 8px 20px rgba(24,78,154,.45) }
/* >>> FIX: négyzetes ikonméret, nem torzul */
.social-btn svg{ width:22px; height:22px; display:block; }

/* ===== TÁMOGATÓK GRID — 3 oszlop × 2 sor ===== */
.sponsors{
  background:#000;
  padding: 18px 0 24px;
}
.sponsor-wrap{
  width: 100%;
  max-width: none;
  margin: 0 auto;
  padding: 0 12px;
}
.sponsor-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  align-items: stretch;
}
.sponsor-item{
  display:flex; align-items:center; justify-content:center;
  background:#000;
  border:1px solid #111;
  border-radius:12px;
  height: clamp(110px, 11vw, 160px);
  padding: 10px;
  overflow:hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  text-decoration:none; color:inherit;
}
.sponsor-item:focus-visible{ outline:3px solid rgba(247,200,0,.65); outline-offset:3px; }
.sponsor-item img{
  width:100%; height:100%;
  object-fit: contain; object-position:center;
  display:block;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.35));
}

.site-footer{ background:#000; color:#7a86a8; text-align:center; padding:18px; border-top:1px solid #111 }
.to-top{position:fixed;right:clamp(10px,2vw,24px);bottom:clamp(10px,3vh,28px);z-index:60;opacity:0;transform:translateY(10px);transition:.3s}
.to-top.show{opacity:1;transform:translateY(0)}
.to-top button{padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:rgba(6,15,36,.7);color:#fff;font-weight:800;cursor:pointer}

/* ======= RESPONSIVE ======= */
@media (max-width:1200px){
  .sponsor-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width:900px){
  :root{ --header-h:64px; }
  header.site-header{ padding:10px 14px; gap:10px; }
  nav.main-nav{ justify-content:flex-start; column-gap:8px; }
  .btn{ padding:10px 14px; font-size:12px; letter-spacing:.25px; }
  .logo{ width:56px; height:56px; aspect-ratio:1/1; }
  .glass{ margin-top: clamp(10px, 4vh, 40px); padding:16px; }
  .newsletter .inline{ flex-direction: column; }
  .newsletter .actions{ width:100%; }
  .newsletter button#subscribeBtn,
  .newsletter button#unsubscribeBtn,
  .newsletter input[type="email"]{ width:100%; }
}
@media (max-width:640px){
  .sponsor-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:420px){
  .sponsor-grid{ grid-template-columns: 1fr; }
}

@media (max-width:960px){
  .contact-grid{ grid-template-columns:1fr; }
  .timeline::before{left:12px}
  .timeline-item,.timeline-item.left,.timeline-item.right{width:100%;left:0;text-align:left;padding-left:38px}
  .timeline-item::after{ left:5px; right:auto }
  .match-card{ max-width:100% }
  nav.main-nav{justify-content:flex-start}
}
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}
