/*
Theme Name: Swim Warriors
Theme URI: https://www.warriorsbb.sk
Author: Swim Warriors
Description: Profesionálna klubová téma pre plavecký klub Swim Warriors Zvolen. Responzívny dizajn s motívom plaveckých dráh.
Version: 1.5.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: swimwarriors
*/

:root{
  --navy:#07203A;
  --navy-2:#0C3050;
  --aqua:#1FB6D5;
  --aqua-soft:#9FE3F0;
  --gold:#F5B82E;
  --tile:#EDF6FA;
  --ink:#13283C;
  --ink-soft:#4A6075;
  --white:#FFFFFF;
  --radius:14px;
  --display:'Barlow Condensed',Arial Narrow,sans-serif;
  --body:'Barlow',Helvetica,Arial,sans-serif;
  --mono:'IBM Plex Mono',Consolas,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto} *{animation:none!important;transition:none!important}}
body{font-family:var(--body);color:var(--ink);background:var(--tile);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* ===== Oddeľovač – dráhové lano ===== */
.lane-rope{height:10px;background:
  repeating-linear-gradient(90deg,
    var(--aqua) 0 22px, var(--white) 22px 30px,
    var(--navy) 30px 52px, var(--white) 52px 60px);
  border-radius:99px;opacity:.9}

/* ===== Hlavička ===== */
.site-header{position:sticky;top:0;z-index:50;background:var(--navy);color:var(--white);
  box-shadow:0 2px 14px rgba(7,32,58,.35)}
.nav{max-width:1140px;margin:0 auto;display:flex;align-items:center;gap:18px;padding:12px 20px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.brand-mark{width:38px;height:38px;border-radius:50%;background:var(--aqua);
  display:grid;place-items:center;font-family:var(--display);font-weight:800;
  color:var(--navy);font-size:19px;letter-spacing:.5px;flex:none}
.brand-name{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:1.5px;line-height:1;color:#fff}
.brand-sub{font-size:11px;letter-spacing:2.5px;color:var(--aqua-soft);text-transform:uppercase}
.menu-main{margin-left:auto}
.menu-main ul{display:flex;gap:26px;list-style:none;font-weight:500;font-size:15px}
.menu-main a{text-decoration:none;opacity:.85;transition:opacity .15s;color:#fff}
.menu-main a:hover,.menu-main a:focus-visible{opacity:1;color:var(--aqua-soft)}
.menu-main .sub-menu{display:none}
.btn{display:inline-block;font-family:var(--display);font-weight:700;font-size:18px;
  letter-spacing:1px;text-transform:uppercase;text-decoration:none;
  padding:11px 26px;border-radius:8px;transition:transform .12s, box-shadow .12s;cursor:pointer;border:0}
.btn:focus-visible{outline:3px solid var(--aqua-soft);outline-offset:2px}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(245,184,46,.35)}
.btn-ghost{border:2px solid rgba(255,255,255,.55);color:var(--white)}
.btn-ghost:hover{border-color:var(--aqua);color:var(--aqua-soft)}
.nav .btn{padding:9px 20px;font-size:16px}
.hamburger{display:none;margin-left:auto;background:none;border:0;color:#fff;font-size:28px;cursor:pointer;line-height:1}

/* ===== Hero ===== */
.hero{background:
  radial-gradient(900px 420px at 85% -10%, rgba(31,182,213,.30), transparent 60%),
  linear-gradient(165deg,var(--navy) 0%, var(--navy-2) 55%, #0E3A5E 100%);
  color:var(--white);overflow:hidden;position:relative}
.hero-lanes{position:absolute;inset:0;opacity:.10;pointer-events:none;
  background:repeating-linear-gradient(0deg, transparent 0 86px, var(--aqua) 86px 88px)}
.hero-in{max-width:1140px;margin:0 auto;padding:84px 20px 70px;position:relative}
.eyebrow{font-family:var(--mono);font-size:13px;letter-spacing:2px;color:var(--aqua-soft);
  text-transform:uppercase;margin-bottom:14px}
.hero h1{font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(44px,7.5vw,86px);line-height:.96;letter-spacing:.5px;max-width:13ch;color:#fff}
.hero h1 .aq{color:var(--aqua)}
.hero p.lead{margin:22px 0 32px;font-size:clamp(16px,2vw,19px);max-width:54ch;color:#D7E6F2}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;margin-top:54px;border-top:1px solid rgba(255,255,255,.18);flex-wrap:wrap}
.stat{padding:20px 34px 4px 0;margin-right:34px}
.stat b{font-family:var(--mono);font-weight:600;font-size:30px;color:var(--aqua);display:block;line-height:1.1}
.stat span{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:#9FB6C9}

/* ===== Sekcie ===== */
.sw-section{padding:72px 20px}
.wrap{max-width:1140px;margin:0 auto}
.sec-eyebrow{font-family:var(--mono);font-size:13px;letter-spacing:2px;
  text-transform:uppercase;color:var(--aqua);margin-bottom:8px}
.sw-section h2,.cta-band h2{font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(32px,4.5vw,48px);line-height:1.02;color:var(--navy);margin-bottom:14px}
.sec-intro{color:var(--ink-soft);max-width:62ch;margin-bottom:42px}

/* ===== Programy = dráhy ===== */
.lanes{display:grid;gap:18px}
.lane{background:var(--white);border-radius:var(--radius);display:grid;
  grid-template-columns:88px 1fr auto;align-items:center;overflow:hidden;
  box-shadow:0 3px 14px rgba(7,32,58,.07);transition:transform .15s, box-shadow .15s}
.lane:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(7,32,58,.13)}
.lane-num{align-self:stretch;background:var(--navy);color:var(--aqua);
  font-family:var(--display);font-weight:800;font-size:34px;display:grid;
  place-items:center;position:relative}
.lane-num::after{content:"";position:absolute;right:-1px;top:0;bottom:0;width:6px;
  background:repeating-linear-gradient(180deg,var(--aqua) 0 14px,var(--white) 14px 20px)}
.lane-body{padding:24px 26px}
.lane-body h3{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:25px;letter-spacing:.5px;color:var(--navy)}
.lane-body .age{font-family:var(--mono);font-size:12.5px;color:var(--aqua);
  letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;display:block}
.lane-body p{color:var(--ink-soft);font-size:15px;max-width:58ch}
.lane-side{padding:22px 26px;text-align:right;min-width:185px}
.price{font-family:var(--mono);font-weight:600;font-size:25px;color:var(--navy);display:block}
.price small{font-size:12px;color:var(--ink-soft);font-family:var(--body);display:block;margin-bottom:12px}
.lane-side .btn{font-size:15px;padding:9px 18px;background:var(--aqua);color:var(--navy)}
.lane-side .btn:hover{box-shadow:0 6px 16px rgba(31,182,213,.4);transform:translateY(-2px)}

/* ===== Prečo my ===== */
.why{background:var(--navy);color:var(--white)}
.why h2{color:var(--white)}
.why .sec-eyebrow{color:var(--aqua-soft)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:40px}
.why-card{border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);
  padding:26px 22px;background:rgba(255,255,255,.04)}
.why-card .ico{width:44px;height:44px;border-radius:10px;background:var(--aqua);
  color:var(--navy);display:grid;place-items:center;font-size:22px;margin-bottom:16px}
.why-card h3{font-family:var(--display);font-weight:700;font-size:21px;
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;color:#fff}
.why-card p{font-size:14.5px;color:#C3D5E4}

/* ===== Aktuality ===== */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.news{background:var(--white);border-radius:var(--radius);padding:26px;
  box-shadow:0 3px 14px rgba(7,32,58,.07);display:flex;flex-direction:column;gap:10px}
.news time{font-family:var(--mono);font-size:12.5px;color:var(--aqua);letter-spacing:1px}
.news h3{font-family:var(--display);font-weight:700;font-size:22px;
  text-transform:uppercase;color:var(--navy);line-height:1.1}
.news h3 a{text-decoration:none}
.news h3 a:hover{color:var(--aqua)}
.news p{font-size:14.5px;color:var(--ink-soft);flex:1}
.news .more{font-weight:600;font-size:14px;color:var(--navy);text-decoration:none;
  border-bottom:2px solid var(--gold);align-self:flex-start}
.news .more:hover{color:var(--aqua)}

/* ===== CTA pás ===== */
.cta-band{background:linear-gradient(120deg,var(--aqua) 0%, #2ED0E6 100%);
  color:var(--navy);text-align:center;padding:72px 20px}
.cta-band h2{color:var(--navy);margin-bottom:10px}
.cta-band p{max-width:56ch;margin:0 auto 28px;font-weight:500}
.cta-band .btn-gold{font-size:21px;padding:14px 38px}

/* ===== Pätička ===== */
.site-footer{background:var(--navy);color:#B9CCDD;font-size:14.5px}
.foot{max-width:1140px;margin:0 auto;padding:54px 20px 30px;display:grid;
  grid-template-columns:1.3fr 1fr 1fr;gap:34px}
.foot h4{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:18px;letter-spacing:1px;color:var(--white);margin-bottom:12px}
.foot a{color:#B9CCDD;text-decoration:none}
.foot a:hover{color:var(--aqua-soft)}
.foot ul{list-style:none}
.foot li{margin-bottom:8px}
.foot .mono{font-family:var(--mono);font-size:13px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);text-align:center;
  padding:18px;font-size:13px;color:#7E97AC}

/* ===== Bežné stránky a články ===== */
.page-hero{background:linear-gradient(165deg,var(--navy) 0%, var(--navy-2) 100%);
  color:#fff;padding:54px 20px}
.page-hero h1{font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(34px,5vw,56px);line-height:1;color:#fff;max-width:1140px;margin:0 auto}
.page-hero .crumb{max-width:1140px;margin:0 auto 8px;font-family:var(--mono);
  font-size:12.5px;letter-spacing:1.5px;color:var(--aqua-soft);text-transform:uppercase}
.content-area{max-width:840px;margin:0 auto;padding:54px 20px}
.entry-content h2{font-family:var(--display);font-weight:700;text-transform:uppercase;
  color:var(--navy);font-size:30px;margin:34px 0 12px}
.entry-content h3{font-family:var(--display);font-weight:700;color:var(--navy);
  font-size:24px;margin:28px 0 10px}
.entry-content p{margin-bottom:16px}
.entry-content ul,.entry-content ol{margin:0 0 16px 24px}
.entry-content a{color:var(--aqua);font-weight:600}
.entry-content img{border-radius:var(--radius)}
.entry-meta{font-family:var(--mono);font-size:13px;color:var(--aqua);margin-bottom:24px}
.post-card{background:#fff;border-radius:var(--radius);padding:28px;margin-bottom:22px;
  box-shadow:0 3px 14px rgba(7,32,58,.07)}
.post-card h2{font-size:26px;margin:6px 0 10px}
.post-card h2 a{text-decoration:none;color:var(--navy)}
.post-card h2 a:hover{color:var(--aqua)}
.pagination{display:flex;gap:8px;justify-content:center;padding:10px 0 40px}
.pagination .page-numbers{padding:8px 14px;background:#fff;border-radius:8px;
  text-decoration:none;font-weight:600;color:var(--navy)}
.pagination .current{background:var(--navy);color:#fff}

/* ===== Fotografie (hero, dráhy, aktuality) ===== */
.hero-in.hero-has-img{display:grid;grid-template-columns:1.15fr .85fr;gap:44px;align-items:center}
.hero-has-img .hero-stats{grid-column:1 / -1}
.hero-img{position:relative}
.hero-img img{width:100%;height:420px;object-fit:cover;border-radius:var(--radius);
  border:3px solid rgba(31,182,213,.55);box-shadow:0 18px 44px rgba(0,0,0,.35)}
.hero-img::after{content:"";position:absolute;left:18px;right:-14px;bottom:-14px;height:10px;
  background:repeating-linear-gradient(90deg,var(--aqua) 0 22px,var(--white) 22px 30px,
    var(--navy-2) 30px 52px,var(--white) 52px 60px);border-radius:99px}
.lane-has-img{grid-template-columns:88px 200px 1fr auto}
.lane-img{align-self:stretch}
.lane-img img{width:100%;height:100%;min-height:150px;object-fit:cover}
.news-thumb{margin:-26px -26px 4px;display:block;overflow:hidden;
  border-radius:var(--radius) var(--radius) 0 0}
.news-thumb img{width:100%;height:170px;object-fit:cover;transition:transform .25s}
.news:hover .news-thumb img{transform:scale(1.04)}

/* ===== Klikateľné dráhy ===== */
.lane{position:relative}
.lane-link{position:absolute;inset:0;z-index:1;border-radius:var(--radius)}
.lane-link:focus-visible{outline:3px solid var(--aqua);outline-offset:2px}
.lane-side .btn{position:relative;z-index:2}
.lane-more{display:inline-block;margin-top:10px;font-family:var(--display);
  font-weight:700;font-size:15px;letter-spacing:.5px;text-transform:uppercase;
  color:var(--aqua);transition:color .15s}
.lane:hover .lane-more{color:var(--navy)}
.lane:hover .lane-body h3{color:var(--aqua)}

/* ===== Stránka Kontakt ===== */
.k-wrap{max-width:1140px;margin:0 auto;padding:48px 20px 64px;display:grid;gap:20px}
.k-card{background:var(--white);border-radius:var(--radius);padding:26px 28px;
  box-shadow:0 3px 14px rgba(7,32,58,.07)}
.k-gold{border-left:5px solid var(--gold);border-radius:0 var(--radius) var(--radius) 0}
.k-card h2{font-size:clamp(24px,3vw,30px);margin-bottom:8px}
.k-card h3{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:21px;letter-spacing:.5px;color:var(--navy);margin-bottom:10px}
.k-card p{color:var(--ink-soft);max-width:64ch}
.k-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.k-cta .btn-aqua{background:var(--aqua);color:var(--navy)}
.k-cta .btn-outline{border:2px solid var(--aqua);color:var(--navy)}
.k-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.k-list{list-style:none}
.k-list li{padding:7px 0;border-bottom:1px solid #E3EEF4;color:var(--ink-soft);font-size:15px}
.k-list li:last-child{border-bottom:0}
.k-list .mono{font-family:var(--mono);font-size:13.5px;color:var(--navy)}
.k-list a{color:var(--navy);text-decoration:none;font-weight:600}
.k-list a:hover{color:var(--aqua)}
.k-map{border-radius:10px;overflow:hidden;border:0;width:100%;height:320px;display:block}
.k-note{font-size:13px;color:var(--ink-soft);margin-top:14px}
.k-gdpr{font-size:12.5px;color:#8AA0B2;margin-top:12px}
@media (max-width:760px){
  .k-cols{grid-template-columns:1fr}
  .k-map{height:240px}
  .k-card{padding:20px}
}

/* ===== Sociálne siete – bočný panel na Aktualitách ===== */
.akt-wrap{max-width:1140px;margin:0 auto;padding:54px 20px}
.akt-ma-panel{display:grid;grid-template-columns:1fr 350px;gap:30px;align-items:start}
.akt-panel{position:sticky;top:84px;display:grid;gap:18px}
.social-nadpis{font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:26px;color:var(--navy)}
.social-card{background:var(--white);border-radius:var(--radius);padding:20px;
  box-shadow:0 3px 14px rgba(7,32,58,.07)}
.social-card h3{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:19px;letter-spacing:.5px;color:var(--navy);margin-bottom:12px}
.social-embed{border-radius:10px;overflow:hidden;background:#F2F8FB}
.social-ig-btn{display:inline-block;background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF);
  color:#fff;font-size:15px;padding:10px 20px}
.social-ig-btn:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(221,42,123,.35)}
@media (max-width:920px){
  .akt-ma-panel{grid-template-columns:1fr}
  .akt-panel{position:static}
}

/* ===== Responzivita ===== */
@media (max-width:920px){
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .news-grid{grid-template-columns:1fr 1fr}
  .hero-in.hero-has-img{grid-template-columns:1fr;gap:30px}
  .hero-img img{height:300px}
  .lane-has-img{grid-template-columns:64px 1fr}
  .lane-has-img .lane-img{grid-column:2;order:-1}
  .lane-has-img .lane-img img{min-height:0;height:160px}
  .lane-has-img .lane-body,.lane-has-img .lane-side{grid-column:2}
}
@media (max-width:760px){
  .menu-main{display:none;position:absolute;top:62px;left:0;right:0;background:var(--navy-2);
    box-shadow:0 12px 24px rgba(0,0,0,.3)}
  .menu-main.open{display:block}
  .menu-main ul{flex-direction:column;gap:0;padding:8px 0}
  .menu-main a{display:block;padding:14px 24px;border-bottom:1px solid rgba(255,255,255,.07)}
  .nav > .btn{display:none}
  .hamburger{display:block}
  .lane{grid-template-columns:64px 1fr}
  .lane-num{font-size:26px}
  .lane-side{grid-column:2;text-align:left;padding-top:0;display:flex;align-items:center;gap:18px}
  .price small{margin-bottom:0}
  .news-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr;gap:26px}
  .hero-in{padding:58px 20px 50px}
  .stat{padding:16px 22px 0 0;margin-right:18px}
  .stat b{font-size:24px}
  .sw-section{padding:54px 18px}
}
