/* UKS Wawelno — strona pokazowa. Marka „Matchday" (zieleń/złoto),
   ocieplona pod stronę dla rodziców i dzieci. Bez build-stepu. */

:root{
  /* Marka – Pitch Green */
  --green-50:#e9f6ee; --green-100:#cfeadb; --green-200:#a9dcc0;
  --green-500:#22a364; --green-600:#1c8a57; --green-700:#156a43;
  --green-800:#0f4e31; --green-900:#0b3a25;
  /* Akcent – Medal Gold */
  --gold:#f5b62e; --gold-600:#e0a116; --gold-soft:#fbe7c0;
  /* Neutralne (ciepłe) */
  --ink:#0d1f17; --text:#27332c; --muted:#5f6f66; --line:#e4ebe0;
  --bg:#f6f8f1; --surface:#ffffff; --surface-2:#eef3ea; --cream:#fbfcf7;
  /* Status / semantyka pomocnicza */
  --ok:#136b3e; --ok-bg:#e3f4e9;
  --radius:22px; --radius-sm:14px; --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(13,31,23,.05), 0 8px 24px -16px rgba(13,31,23,.20);
  --shadow:0 2px 4px rgba(13,31,23,.06), 0 24px 48px -28px rgba(13,31,23,.30);
  --maxw:1120px;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:140px}
body{
  margin:0; font-family:var(--sans); background:var(--bg); color:var(--text);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased;
  font-variant-numeric:tabular-nums;
}
img{max-width:100%; display:block}
a{color:var(--green-700); text-decoration:none}
a:hover{color:var(--green-800)}
h1,h2,h3,h4{color:var(--ink); line-height:1.12; letter-spacing:-0.02em; margin:0}
h1{font-size:clamp(2.1rem,5vw,3.4rem); font-weight:850}
h2{font-size:clamp(1.6rem,3.4vw,2.4rem); font-weight:850}
h3{font-size:1.18rem; font-weight:800; letter-spacing:-0.01em}
p{margin:0 0 1rem}
.container{max-width:var(--maxw); margin:0 auto; padding:0 20px}
.section{padding:72px 0}
.section--tint{background:var(--cream)}
.center{text-align:center}
.eyebrow{
  display:inline-block; font-size:.78rem; font-weight:800; letter-spacing:.10em;
  text-transform:uppercase; color:var(--green-700); background:var(--green-50);
  border:1px solid var(--green-100); padding:5px 12px; border-radius:var(--radius-pill); margin-bottom:14px;
}
.lead{font-size:1.12rem; color:var(--muted); max-width:60ch}
.section .center .lead{margin-left:auto; margin-right:auto}

/* ---------- Buttons (tactile, „klikalne" jak Duolingo) ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px; font:inherit; font-weight:800;
  letter-spacing:.01em; cursor:pointer; border:none; border-radius:var(--radius-pill);
  padding:14px 24px; transition:transform .08s ease, box-shadow .15s, background .15s; white-space:nowrap;
}
.btn:active{transform:translateY(2px)}
.btn-primary{background:var(--green-600); color:#fff; box-shadow:0 4px 0 0 var(--green-800)}
.btn-primary:hover{background:var(--green-700); color:#fff}
.btn-primary:active{box-shadow:0 2px 0 0 var(--green-800)}
.btn-gold{background:var(--gold); color:#3a2a00; box-shadow:0 4px 0 0 var(--gold-600)}
.btn-gold:hover{background:#ffc44d; color:#3a2a00}
.btn-gold:active{box-shadow:0 2px 0 0 var(--gold-600)}
.btn-ghost{background:#fff; color:var(--green-800); border:2px solid var(--green-200)}
.btn-ghost:hover{background:var(--green-50); color:var(--green-800)}
.btn-lg{padding:16px 28px; font-size:1.05rem}
.btn-block{width:100%; justify-content:center}

/* ---------- Announcement bar ---------- */
.topbar{
  background:var(--green-900); color:#dff0e6; font-size:.86rem;
  display:flex; justify-content:center; gap:18px; padding:8px 16px; text-align:center;
}
.topbar strong{color:#fff}
.topbar .tb-phone{color:var(--gold); font-weight:800; white-space:nowrap}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50; background:rgba(246,248,241,.86);
  backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid var(--line);
}
.nav{display:flex; align-items:center; gap:18px; height:68px}
.brand{display:flex; align-items:center; gap:11px; font-weight:900; color:var(--ink);
  letter-spacing:-0.01em; font-size:1.05rem}
.brand .crest{width:40px; height:40px; border-radius:11px; box-shadow:var(--shadow-sm)}
.brand .crest-txt{display:flex; flex-direction:column; line-height:1; gap:2px}
.brand .crest-txt b{font-size:1.02rem}
.brand .crest-txt span{font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--green-700); font-weight:800}
.nav-links{display:flex; gap:4px; margin-left:8px}
.nav-links a{
  color:var(--text); font-weight:700; font-size:.95rem; padding:9px 13px; border-radius:10px;
}
.nav-links a:hover{background:var(--green-50); color:var(--green-800)}
.nav-cta{margin-left:auto; display:flex; align-items:center; gap:12px}
.nav-phone{font-weight:800; color:var(--green-800); white-space:nowrap}
.nav-toggle{display:none; background:none; border:none; cursor:pointer; padding:8px; border-radius:10px}
.nav-toggle:hover{background:var(--green-50)}
.nav-toggle svg{display:block}

/* ---------- Hero ---------- */
.hero{position:relative; overflow:hidden;
  background:linear-gradient(165deg,#fbfcf7 0%, #eef6ee 55%, #e3f1e6 100%);
  border-bottom:1px solid var(--line);
}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
  padding:64px 0 72px}
.hero h1{margin-bottom:18px}
.hero .lead{font-size:1.22rem; color:#3a4a40; margin-bottom:28px}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:18px}
.hero-note{display:flex; align-items:center; gap:9px; color:var(--muted); font-size:.95rem; font-weight:600}
.hero-note .dot{width:9px; height:9px; border-radius:50%; background:var(--gold)}

/* Hero artwork: zielone „boisko" + piłka + naklejki */
.hero-art{position:relative; min-height:340px; display:grid; place-items:center}
.pitch{
  width:100%; max-width:440px; aspect-ratio:1/1; border-radius:32px; position:relative;
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(255,255,255,.16), transparent 60%),
    repeating-linear-gradient(180deg, var(--green-600) 0 14%, var(--green-700) 14% 28%);
  box-shadow:var(--shadow), inset 0 0 0 6px rgba(255,255,255,.10);
  display:grid; place-items:center; overflow:hidden;
}
.pitch::before{content:""; position:absolute; inset:22px; border:3px solid rgba(255,255,255,.45); border-radius:22px}
.pitch::after{content:""; position:absolute; left:50%; top:22px; bottom:22px; width:3px; transform:translateX(-50%); background:rgba(255,255,255,.45)}
.pitch .circle{position:absolute; width:120px; height:120px; border:3px solid rgba(255,255,255,.45); border-radius:50%}
.pitch .ball{width:128px; height:128px; position:relative; z-index:2; filter:drop-shadow(0 12px 20px rgba(0,0,0,.28))}
.sticker{position:absolute; background:#fff; border-radius:16px; padding:10px 14px; box-shadow:var(--shadow);
  font-weight:800; font-size:.86rem; color:var(--ink); display:flex; align-items:center; gap:8px; z-index:3}
.sticker .emoji{font-size:1.1rem}
.sticker.s1{top:8px; left:-6px; transform:rotate(-6deg)}
.sticker.s2{bottom:30px; right:-10px; transform:rotate(5deg)}
.sticker.s3{bottom:-10px; left:30px; transform:rotate(-3deg); background:var(--gold); color:#3a2a00}

/* ---------- Feature cards ---------- */
.grid{display:grid; gap:18px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:24px; box-shadow:var(--shadow-sm)}
.feature .ic{width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:var(--green-50); color:var(--green-700); font-size:1.5rem; margin-bottom:14px}
.feature h3{margin-bottom:7px}
.feature p{color:var(--muted); margin:0; font-size:.98rem}
.feature:nth-child(2) .ic{background:var(--gold-soft); color:var(--gold-600)}

/* ---------- Group cards ---------- */
.group{display:flex; flex-direction:column; padding:0; overflow:hidden}
.group .head{padding:22px 24px; background:linear-gradient(160deg,var(--green-700),var(--green-800)); color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:12px}
.group:nth-child(2) .head{background:linear-gradient(160deg,#1c7a4c,#0f5a38)}
.group .head h3{color:#fff; font-size:1.4rem}
.group .age{background:var(--gold); color:#3a2a00; font-weight:900; font-size:.82rem; padding:6px 12px; border-radius:var(--radius-pill); white-space:nowrap}
.group .body{padding:22px 24px}
.group .body > p{color:var(--muted); font-size:.97rem}
.group dl{display:grid; gap:10px; margin:16px 0}
.group dl .r{display:flex; gap:10px; align-items:flex-start}
.group dl dt{font-weight:800; color:var(--ink); min-width:130px; font-size:.92rem}
.group dl dd{margin:0; color:var(--text); font-size:.95rem}
.chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:6px}
.chip{background:var(--green-50); color:var(--green-800); border:1px solid var(--green-100);
  border-radius:var(--radius-pill); padding:6px 12px; font-size:.85rem; font-weight:700}

/* ---------- Pricing ---------- */
.price-card{max-width:520px; margin:0 auto; text-align:center; position:relative; overflow:hidden;
  border:2px solid var(--green-200)}
.price-card .ribbon{position:absolute; top:16px; right:-38px; transform:rotate(45deg);
  background:var(--gold); color:#3a2a00; font-weight:900; font-size:.72rem; letter-spacing:.08em;
  padding:6px 48px; text-transform:uppercase}
.price-amt{font-size:3.4rem; font-weight:900; color:var(--ink); letter-spacing:-0.03em; line-height:1}
.price-amt .per{font-size:1rem; font-weight:700; color:var(--muted); letter-spacing:0}
.price-list{list-style:none; margin:22px 0; padding:0; text-align:left; display:grid; gap:11px}
.price-list li{display:flex; gap:11px; align-items:flex-start; font-weight:600}
.price-list li svg{flex:none; margin-top:3px}

/* ---------- Location ---------- */
.loc .card{display:flex; flex-direction:column; gap:6px}
.loc .season{display:inline-flex; align-items:center; gap:8px; font-weight:900; color:var(--green-700);
  text-transform:uppercase; letter-spacing:.06em; font-size:.8rem}
.loc h3{margin:4px 0}
.loc p{color:var(--muted); margin:0 0 14px}
.loc a.maplink{font-weight:800; display:inline-flex; align-items:center; gap:6px}

/* ---------- About values ---------- */
.values .card{text-align:center}
.values .ic{margin:0 auto 12px}

/* ---------- Form ---------- */
.enroll-grid{display:grid; grid-template-columns:1fr 1.1fr; gap:36px; align-items:start}
.form-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px; box-shadow:var(--shadow)}
.field{margin-bottom:14px}
.field label{display:block; font-size:.82rem; font-weight:800; letter-spacing:.03em; text-transform:uppercase;
  color:var(--muted); margin-bottom:6px}
.field input, .field select, .field textarea{
  width:100%; font:inherit; padding:13px 14px; border:1px solid #cdd8c8; border-radius:var(--radius-sm);
  background:#fff; color:var(--text); transition:border-color .15s, box-shadow .15s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--green-600); box-shadow:0 0 0 3px rgba(245,182,46,.35);
}
.field textarea{min-height:84px; resize:vertical}
.field .req{color:var(--green-600)}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.form-msg{border-radius:var(--radius-sm); padding:12px 14px; font-weight:700; font-size:.95rem; margin-top:6px; display:none}
.form-msg.ok{display:block; background:var(--ok-bg); color:var(--ok); border:1px solid #bfe6cd}
.form-msg.err{display:block; background:#fbe6e4; color:#b3261e; border:1px solid #f4cdc9}
.enroll-aside ul{list-style:none; padding:0; margin:16px 0 0; display:grid; gap:12px}
.enroll-aside li{display:flex; gap:11px; align-items:flex-start; color:var(--text); font-weight:600}

/* ---------- Contact strip ---------- */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.contact-grid .card{display:flex; align-items:center; gap:16px}
.contact-grid .ic{width:54px; height:54px; border-radius:14px; background:var(--green-50); color:var(--green-700);
  display:grid; place-items:center; font-size:1.5rem; flex:none}
.contact-grid .card b{display:block; color:var(--ink); font-size:1.1rem}

/* ---------- FAQ accordion ---------- */
.faq{max-width:780px; margin:0 auto; display:grid; gap:12px}
.faq-item{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); overflow:hidden}
.faq-q{width:100%; text-align:left; background:none; border:none; cursor:pointer; font:inherit;
  font-weight:800; color:var(--ink); padding:18px 20px; display:flex; align-items:center; justify-content:space-between; gap:14px;
  list-style:none}
.faq-q::-webkit-details-marker{display:none}
.faq-q::marker{content:""}
.faq-q:hover{background:var(--green-50)}
.faq-q . chevron{transition:transform .2s}
.faq-icon{flex:none; transition:transform .25s ease; color:var(--green-700)}
.faq-item[open] .faq-icon{transform:rotate(180deg)}
.faq-a{padding:0 20px 18px; color:var(--text)}
.faq-a p{margin:0 0 .5rem}
.faq-a ul{margin:.2rem 0; padding-left:1.1rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-900); color:#cfe3d6; padding:48px 0 28px; margin-top:8px}
.foot-grid{display:flex; justify-content:space-between; gap:32px; flex-wrap:wrap; align-items:flex-start}
.site-footer .brand b, .site-footer .brand{color:#fff}
.site-footer .crest-txt span{color:var(--gold)}
.foot-about{max-width:42ch; color:#aacbb7; margin-top:14px}
.foot-links{display:flex; gap:18px; flex-wrap:wrap; align-items:center}
.foot-links a{color:#cfe3d6; font-weight:700}
.foot-links a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:28px; padding-top:18px;
  font-size:.86rem; color:#8fb6a1; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap}

/* ---------- Reveal-on-scroll ---------- */
.reveal{opacity:0; transform:translateY(14px); transition:opacity .5s ease, transform .5s ease}
.reveal.in{opacity:1; transform:none}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr; gap:28px; padding:40px 0 52px}
  .hero-art{order:-1; min-height:280px}
  .enroll-grid{grid-template-columns:1fr; gap:24px}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav-links{
    position:absolute; top:68px; left:0; right:0; background:var(--surface); border-bottom:1px solid var(--line);
    flex-direction:column; gap:0; padding:8px; box-shadow:var(--shadow); display:none;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:13px; border-radius:10px}
  .nav-toggle{display:block}
  .nav-phone{display:none}
  .topbar .tb-text{display:none}
  .grid-4{grid-template-columns:1fr}
  .group dl dt{min-width:0}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  .reveal{opacity:1; transform:none; transition:none}
  .btn:active{transform:none}
  .toast{transition:none}
}

/* ---------- Stats band (akademia) ---------- */
.stats-band{background:linear-gradient(160deg,var(--green-700),var(--green-900)); color:#fff;
  padding:34px 0; border-bottom:4px solid var(--gold)}
.stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; text-align:center}
.stats-band .stat b{display:block; font-size:2.7rem; font-weight:900; color:var(--gold); line-height:1; letter-spacing:-0.02em}
.stats-band .stat span{display:block; margin-top:7px; font-size:.76rem; font-weight:800; letter-spacing:.09em;
  text-transform:uppercase; color:#cfe3d6}
@media (max-width:640px){.stats-grid{grid-template-columns:repeat(2,1fr); gap:26px 18px}}

/* ---------- Recruit banner ---------- */
.recruit-banner{display:flex; align-items:center; gap:16px; flex-wrap:wrap;
  background:linear-gradient(120deg,var(--green-50),#fff); border:2px solid var(--green-200);
  border-radius:var(--radius); padding:18px 22px; margin-bottom:24px; box-shadow:var(--shadow-sm)}
.recruit-banner .rb-badge{background:var(--green-600); color:#fff; font-weight:800; font-size:.85rem;
  padding:9px 15px; border-radius:var(--radius-pill); white-space:nowrap}
.recruit-banner p{margin:0; font-weight:700; color:var(--ink); flex:1; min-width:220px}
.recruit-banner .btn{margin-left:auto}
.btn-sm{padding:9px 16px; font-size:.92rem}

/* ---------- Toast / pop-up naborów ---------- */
.toast{position:fixed; left:18px; bottom:18px; z-index:80; max-width:344px; background:#fff;
  border:1px solid var(--line); border-left:5px solid var(--gold); border-radius:16px; box-shadow:var(--shadow);
  padding:16px 18px 16px 16px; display:flex; gap:13px; transform:translateY(160%); opacity:0; pointer-events:none;
  transition:transform .45s cubic-bezier(.2,.8,.2,1), opacity .45s}
.toast.show{transform:none; opacity:1; pointer-events:auto}
.toast-emoji{font-size:1.7rem; line-height:1.1}
.toast-body b{color:var(--ink); display:block; margin-bottom:2px}
.toast-body p{margin:0 0 11px; font-size:.9rem; color:var(--muted); line-height:1.45}
.toast-x{position:absolute; top:8px; right:9px; background:none; border:none; font-size:1.35rem; line-height:1;
  color:var(--muted); cursor:pointer; padding:2px 7px; border-radius:8px}
.toast-x:hover{background:var(--surface-2); color:var(--ink)}
@media (max-width:560px){.toast{left:12px; right:12px; bottom:12px; max-width:none}}
