:root{
  --bg:#0c0e0d; --bg-2:#13160f; --surface:#15180f;
  --line:rgba(255,255,255,.10); --line-soft:rgba(255,255,255,.06);
  --lime:#c8ff3e; --lime-ink:#0c0e0d; --stripe:#eef0e9;
  --tx:#f2f3ee; --tx-2:#b3b8ac; --tx-3:#7b8072;
  --f:'Archivo','Liberation Sans','Segoe UI',system-ui,sans-serif;
  --pad:clamp(22px,5vw,40px);
  --hd:68px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%;overflow:hidden;background:var(--bg);-webkit-text-size-adjust:100%}
body{height:100%;font-family:var(--f);background:var(--bg);color:var(--tx);font-size:17px;line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;overflow-y:auto;scroll-snap-type:y mandatory}
main{height:auto}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--lime);outline-offset:3px}
.wrap{max-width:1240px;margin:0 auto;padding:0 var(--pad)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:13px;letter-spacing:.04em;color:var(--lime);text-transform:uppercase}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--lime)}
h2.title{font-weight:800;font-size:clamp(28px,4.6vw,46px);line-height:1.08;letter-spacing:-.01em;margin:16px 0 0}
.section-lead{color:var(--tx-2);font-size:clamp(16px,1.6vw,18px);line-height:1.65;max-width:60ch;margin-top:16px}

.btn-lg{padding:15px 26px;font-size:16px}
.btn svg{width:20px;height:20px;flex:0 0 auto}

/* HERO */
.hero{position:relative;height:100vh;height:100svh;overflow:hidden;background:var(--bg);border-bottom:1px solid var(--line-soft);scroll-snap-align:start;scroll-snap-stop:always}
.hero-zone{position:absolute;inset:0;max-width:1240px;margin:0 auto;padding:0 var(--pad);z-index:1;overflow:visible}
.hero-zone::before{content:"";position:absolute;top:0;bottom:0;left:69%;right:0;pointer-events:none;background:var(--lime)}
.hero-fig{position:absolute;right:var(--pad);bottom:0;transform:none;transform-origin:bottom right;width:min(46vw,540px);height:auto;max-width:calc(50% - var(--pad));max-height:calc(100vh - var(--hd) - 24px);object-fit:contain;object-position:bottom right;filter:grayscale(1) contrast(1.28) brightness(.98)}
.hero-inner{position:relative;z-index:2;min-height:100%;display:flex;flex-direction:column;justify-content:center;padding-top:calc(var(--hd) + 32px);padding-bottom:72px}
.hero-copy{max-width:45%}
.hero h1{font-weight:800;font-size:clamp(53px,8.7vw,120px);line-height:.96;letter-spacing:-.03em;margin:18px 0 0}
.hero h1 .last{color:var(--lime)}
.hero-sub{margin-top:22px;font-size:clamp(17px,1.9vw,21px);line-height:1.55;color:var(--tx-2);max-width:42ch}
.hero-actions{margin-top:34px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.icon-btn{display:inline-grid;place-items:center;width:32px;height:32px;color:var(--tx-2);transition:color .14s}
.icon-btn:hover{color:var(--lime)}
.icon-btn svg{width:32px;height:32px}
.hero-call{color:var(--tx-3);font-weight:500;font-size:14px}
.hero-free{margin-top:18px;font-weight:600;font-size:14px;letter-spacing:.01em;color:var(--lime);display:inline-flex;align-items:center;gap:9px}
.hero-free::before{content:"";width:7px;height:7px;background:var(--lime);transform:rotate(45deg)}

/* SECTION SHELL */
section.block{display:grid;height:100vh;height:100svh;padding:calc(var(--hd) + 24px) 0 clamp(48px,6vw,72px);border-bottom:1px solid var(--line-soft);overflow:hidden;scroll-snap-align:start;scroll-snap-stop:always}
section.block.alt{background:var(--bg-2)}
section#clanky{height:100vh;height:100svh;overflow:hidden;align-content:center}
footer{scroll-snap-align:end;scroll-snap-stop:always}

.block-head{margin-bottom:clamp(32px,4.5vw,52px)}

/* CO TRÉNUJU */
.disc{display:grid;grid-template-columns:1fr 1fr;gap:0 56px}
.disc .it{padding:24px 0;border-top:1px solid var(--line)}
.disc .it h3{font-weight:700;font-size:21px;letter-spacing:-.01em;display:flex;align-items:baseline;gap:12px}
.disc .it h3::before{content:"";width:8px;height:8px;background:var(--lime);flex:0 0 auto;transform:translateY(-2px)}
.disc .it p{margin-top:9px;color:var(--tx-2);font-size:15.5px;line-height:1.58;padding-left:20px}
.learn-link{position:relative;display:inline-flex;align-items:center;gap:8px;margin-top:12px;margin-left:20px;font-weight:700;font-size:14px;color:var(--lime);transition:color .16s ease,transform .16s ease}
.learn-link::after{content:"";width:16px;height:1px;background:currentColor;transform-origin:left center;transition:transform .16s ease}
.learn-link:hover{color:var(--tx);transform:translateX(2px)}
.learn-link:hover::after{transform:scaleX(1.35)}

/* ZÁKLADY */
.cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.card{display:flex;flex-direction:column;min-width:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface);transition:transform .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-3px);border-color:rgba(200,255,62,.42);background:rgba(200,255,62,.035);box-shadow:0 16px 44px rgba(0,0,0,.28)}
.card-media{aspect-ratio:1/1;display:block;background:linear-gradient(135deg,rgba(200,255,62,.18),rgba(200,255,62,.05) 38%,rgba(255,255,255,.03) 100%),linear-gradient(160deg,#141712,#0f1110);border-bottom:1px solid var(--line-soft)}
.card-media.has-image{background:none;position:relative}
.card-media.has-image img{display:block;width:100%;height:100%;object-fit:cover;filter:grayscale(1);transition:filter .2s ease}
.card:hover .card-media.has-image img{filter:none}
.card-body{display:flex;flex:1;flex-direction:column;padding:16px}
.card-tag{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--lime)}
.card-title{margin-top:10px;font-weight:800;font-size:20px;line-height:1.18;letter-spacing:-.02em}
.card-text{margin-top:10px;color:var(--tx-2);font-size:15px;line-height:1.55}
.cards--compact{gap:12px}
.cards--compact .card-media{aspect-ratio:2.2/1}
.cards--compact .card-body{padding:12px 14px}
.cards--compact .card-title{font-size:18px;margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cards--compact .card-text{font-size:14px;line-height:1.5;margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* CENÍK */
.price{border-top:1px solid var(--line)}
.price a{display:flex;align-items:baseline;justify-content:space-between;gap:20px;padding:22px 4px;border-bottom:1px solid var(--line-soft);transition:background .14s,padding-left .14s}
.price a:hover{background:rgba(200,255,62,.06);padding-left:12px}
.price .name{font-weight:700;font-size:clamp(17px,1.9vw,21px);letter-spacing:-.01em}
.price .name .dur{color:var(--tx-3);font-weight:500;font-size:.82em;margin-left:10px}
.price .name .tag{display:inline-block;font-weight:600;font-size:11px;letter-spacing:.04em;color:var(--lime);border:1px solid rgba(200,255,62,.45);border-radius:2px;padding:2px 7px;margin-left:10px;vertical-align:middle}
.price .amt{font-weight:800;font-size:clamp(19px,2.2vw,26px);white-space:nowrap;letter-spacing:-.01em}
.price .amt.free{color:var(--lime)}
.price .amt small{font-weight:600;font-size:.5em;color:var(--tx-3);margin-left:3px}

/* KDE */
section#kde{padding-top:calc(var(--hd) + 18px);padding-bottom:clamp(28px,4vw,48px)}
section#kde .block-head{margin-bottom:clamp(20px,2.8vw,30px)}
.gym-layout{height:min(520px,calc(100vh - 250px));min-height:360px;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(300px,.85fr);grid-template-rows:auto minmax(0,1fr) auto;grid-template-areas:"gallery address" "gallery map" "gallery online";gap:14px 24px}
.gym-gallery{grid-area:gallery;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:minmax(0,1fr) clamp(72px,10vh,96px);gap:10px;min-width:0;min-height:0}
.gym-gallery figure{overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--bg)}
.gym-gallery figure:first-child{grid-column:1/-1}
.gym-gallery a{position:relative;display:block;width:100%;height:100%;overflow:hidden}
.gym-gallery img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .2s,filter .2s}
.gallery-zoom{position:absolute;right:10px;bottom:10px;width:38px;height:38px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.2);border-radius:50%;background:rgba(12,14,13,.82);color:var(--lime);opacity:0;transform:translateY(4px);transition:opacity .16s,transform .16s,background .16s,color .16s}
.gallery-zoom svg{width:21px;height:21px}
.gym-gallery a:hover img,.gym-gallery a:focus-visible img{transform:scale(1.025);filter:brightness(.82)}
.gym-gallery a:hover .gallery-zoom,.gym-gallery a:focus-visible .gallery-zoom{opacity:1;transform:none}
.gym-gallery a:hover .gallery-zoom{background:var(--lime);color:var(--lime-ink)}
.gym-address{grid-area:address;padding:16px 18px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}
.gym-address h3,.gym-online h3{font-weight:700;font-size:19px;letter-spacing:-.01em}
.gym-address p,.gym-online p{color:var(--tx-2);font-size:14.5px;line-height:1.5;margin-top:5px}
.gym-address .btn{margin-top:12px;padding:9px 14px;font-size:14px}
.gym-map{grid-area:map;min-height:0;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--bg)}
.gym-map iframe{width:100%;height:100%;min-height:170px;display:block;border:0;filter:grayscale(.2) contrast(1.05)}
.gym-online{grid-area:online;padding:14px 18px;border-top:2px solid var(--lime);background:var(--surface)}

/* KONTAKT */
section#kontakt{display:flex;flex-direction:column;padding:calc(var(--hd) + 20px) 0 0}
.contact{flex:1;display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-content:center}
.contact .info{display:flex;flex-direction:column;gap:16px;margin-top:8px}
.contact .info .row{display:flex;gap:14px;align-items:center;color:inherit}
.contact .info .ic{flex:0 0 auto;width:32px;height:32px;display:grid;place-items:center;color:var(--lime);transition:color .14s}
.contact .info .ic svg{width:32px;height:32px}
.contact .info .rc{display:flex;flex-direction:column;min-width:0}
.contact .info .l{color:var(--tx-3);font-size:13px;font-weight:600;letter-spacing:.02em}
.contact .info .v{font-weight:700;font-size:19px;letter-spacing:-.01em;margin-top:3px}
.contact .info .s{color:var(--tx-2);font-size:14px;margin-top:3px}
.contact .info a.row:hover .v{color:var(--lime)}
.contact .info a.row:hover .ic{color:var(--lime)}
.info-or{color:var(--tx-3);font-size:13px;font-weight:600;letter-spacing:.02em;margin:8px 0 0;padding-top:16px;border-top:1px solid var(--line-soft)}
.form{display:flex;flex-direction:column;background:var(--surface);border:1.5px solid rgba(255,255,255,.16);border-radius:14px;box-shadow:6px 6px 0 rgba(0,0,0,.32);padding:clamp(20px,2.6vw,30px)}
.form .grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.field{display:flex;flex-direction:column;margin-bottom:16px}
.field label{font-weight:600;font-size:14px;color:var(--tx-2);margin-bottom:8px}
.field input,.field select,.field textarea{background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--tx);font-family:var(--f);font-size:16px;line-height:1.4;width:100%}
.field input,.field select{height:52px;padding:0 16px}
.field textarea{padding:13px 16px;min-height:150px;resize:vertical}
.message-field{flex:1;min-height:0}
.message-field textarea{flex:1}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--lime)}
.field select{appearance:none;-webkit-appearance:none;text-overflow:ellipsis;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' data-icon='hugeicons:arrow-down-01' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23b3b8ac' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M18 9s-4.419 6-6 6s-6-6-6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:18px;background-position:right 16px center;padding-right:42px}
.form-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:4px}
.form-foot .note{color:var(--tx-3);font-size:12.5px;line-height:1.5;max-width:300px}
.ok{display:none;background:rgba(200,255,62,.1);border:1px solid var(--lime);color:var(--lime);border-radius:8px;font-size:14px;padding:13px 14px;margin-bottom:16px}
.ok.show{display:block}
.ok.error{background:rgba(255,96,96,.1);border-color:#ff6060;color:#ff9090}
.form button:disabled{cursor:wait;opacity:.62}
.honeypot{position:absolute!important;left:-10000px!important;width:1px!important;height:1px!important;overflow:hidden!important}

/* PHOTOSWIPE */
.pswp{--pswp-bg:#080a07;--pswp-placeholder-bg:#13160f;--pswp-icon-color:#c8ff3e;--pswp-icon-color-secondary:#c8ff3e;--pswp-error-text-color:#f2f3ee}
.pswp__button{color:var(--lime)}
.pswp__button .pswp__icn{fill:none}
.pswp__button--arrow--next .pswp__icn{transform:none}
.pswp__counter{color:var(--tx);text-shadow:none;font-family:var(--f);font-weight:600;opacity:1}

@media(prefers-reduced-motion:reduce){body{scroll-snap-type:none}}
@media(max-height:680px){body{scroll-snap-type:none}}

@media(max-height:1000px) and (min-width:861px){
  .hero-inner{padding-top:calc(var(--hd) + 18px);padding-bottom:36px}
  .hero h1{font-size:clamp(40px,7vw,76px);margin-top:10px}
  .hero-sub{margin-top:14px}
  .hero-actions{margin-top:20px}
  .hero-free{margin-top:10px}
  section.block{padding:calc(var(--hd) + 12px) 0 26px}
  .block-head{margin-bottom:22px}
  h2.title{font-size:clamp(24px,3.6vw,34px)}
  .section-lead{margin-top:10px}
  .disc .it{padding:14px 0}
  .price a{padding:14px 4px}
  .gym-layout{height:min(420px,calc(100vh - 210px));min-height:300px}
  .form{padding:clamp(14px,2vw,20px)}
  .field{margin-bottom:10px}
  .form .grid{margin-bottom:10px}
  .contact{gap:36px}
  .contact .info{gap:10px;margin-top:6px}
  .cards--compact{gap:10px}
  .cards--compact .card-media{aspect-ratio:2.4/1}
  .cards--compact .card-body{padding:10px 12px}
  .cards--compact .card-title{font-size:16px;margin-top:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .cards--compact .card-text{font-size:13px;line-height:1.4;margin-top:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
}

@media(max-height:820px) and (min-width:861px){
  .hero-inner{padding-top:calc(var(--hd) + 10px);padding-bottom:22px}
  .hero h1{font-size:clamp(32px,6vw,56px);margin-top:8px}
  .hero-sub{margin-top:10px;font-size:clamp(15px,1.6vw,17px)}
  .hero-actions{margin-top:14px}
  .hero-free{margin-top:8px}
  section.block{padding:calc(var(--hd) + 8px) 0 16px}
  .block-head{margin-bottom:14px}
  h2.title{font-size:clamp(20px,3vw,26px)}
  .section-lead{margin-top:6px;font-size:15px}
  .disc .it{padding:10px 0}
  .disc .it p{margin-top:5px}
  .price a{padding:9px 4px}
  .gym-layout{height:min(300px,calc(100vh - 190px));min-height:240px}
  .form{padding:clamp(10px,1.6vw,16px)}
  .field{margin-bottom:6px}
  .form .grid{margin-bottom:6px}
  .contact{gap:24px}
  .contact .info{gap:6px;margin-top:4px}
  .cards--compact{gap:8px}
  .cards--compact .card-media{aspect-ratio:2/1}
  .cards--compact .card-body{padding:6px 8px}
  .cards--compact .card-title{font-size:13px;margin-top:3px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
  .cards--compact .card-text{display:none}
}

/* MOBILE / TABLET */
@media(max-width:860px){
  html{overflow:auto;height:auto}
  body{height:auto;overflow-y:visible;scroll-snap-type:none;font-size:16px}

  .hero{min-height:0;height:auto;-webkit-mask-image:linear-gradient(to bottom,#000 calc(100% - 72px),transparent 100%);mask-image:linear-gradient(to bottom,#000 calc(100% - 72px),transparent 100%)}
  .hero-zone::before{left:69%;clip-path:none}
  .hero-inner{padding-top:calc(var(--hd) + 24px);padding-bottom:56px}
  .hero-copy{max-width:52%}
  .hero h1{font-size:clamp(34px,11vw,52px)}
  .hero-sub{font-size:14px;margin-top:14px;max-width:none}
  .hero-actions{margin-top:22px;gap:12px}
  .btn-lg{padding:13px 18px;font-size:15px}
  .icon-btn{width:32px;height:32px}
  .icon-btn svg{width:32px;height:32px}
  .hero-free{margin-top:14px;font-size:13px}

  section.block{height:auto;min-height:0;overflow:visible;padding:calc(var(--hd) + 32px) 0 56px}
  .disc{grid-template-columns:1fr;gap:0}
  .cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  section#kde{padding-top:calc(var(--hd) + 32px);padding-bottom:56px}
  .gym-layout{height:auto;min-height:0;display:grid;grid-template-columns:1fr;grid-template-rows:auto;grid-template-areas:"address" "gallery" "map" "online";gap:18px}
  .gym-gallery{display:flex;height:auto;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;scrollbar-width:thin}
  .gym-gallery figure,.gym-gallery figure:first-child{flex:0 0 min(82vw,460px);height:250px;scroll-snap-align:start}
  .gallery-zoom{opacity:1;transform:none}
  .gym-map{height:300px}
  .gym-online{padding:18px}

  /* CONTACT */
  section#kontakt{height:auto;overflow:visible;display:block;padding:calc(var(--hd) + 32px) 0 0}
  section#clanky{height:auto;min-height:0;overflow:visible}
  section#kontakt{padding-bottom:clamp(40px,6vw,64px)}
  .contact{display:block}
  .contact .info{margin-top:28px}
  .form{margin-top:28px}
  .form .grid{grid-template-columns:1fr;gap:0}
  .message-field{display:flex;flex:auto}
  .field textarea{min-height:150px}
}
@media(max-width:520px){

  .hero-copy{max-width:54%}
  .cards{grid-template-columns:1fr;gap:14px}
  .form-foot{flex-direction:column;align-items:stretch}
  .form-foot .btn{width:100%}
}
