/* ============================================================
   Marek Kratochvíl – osobní trenér
   Art direction: dark athletic base, electric-lime energy accent
   ============================================================ */

:root{
  --bg:        #0c0d0f;
  --bg-2:      #121317;
  --bg-3:      #17191e;
  --surface:   #1b1e24;
  --line:      rgba(255,255,255,.09);
  --line-2:    rgba(255,255,255,.16);
  --txt:       #f4f5f2;
  --txt-dim:   #a7abb2;
  --txt-mute:  #7d828b;

  --lime:      #cdfd50;
  --lime-2:    #b6ec2f;
  --orange:    #ff5a1f;
  --ink:       #0a0b0c;

  --grad-energy: linear-gradient(100deg,#cdfd50 0%,#8fe23a 45%,#ff8a1f 100%);

  --font-head: "Archivo", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;

  --maxw: 1200px;
  --pad: clamp(1.1rem, 4vw, 2.5rem);
  --radius: 18px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--txt);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--lime); color:var(--ink); }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }

.skip-link{
  position:fixed; left:1rem; top:-100px; z-index:1000;
  background:var(--lime); color:var(--ink); padding:.6rem 1rem;
  border-radius:8px; font-weight:700; transition:top .2s;
}
.skip-link:focus{ top:1rem; }

:focus-visible{ outline:3px solid var(--lime); outline-offset:3px; border-radius:4px; }

/* ---------- Buttons ---------- */
.btn{
  --b: var(--lime);
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--font-head); font-weight:800; letter-spacing:.01em;
  font-size:.95rem; text-transform:uppercase;
  padding:.85rem 1.5rem; border-radius:100px; border:2px solid transparent;
  cursor:pointer; transition:transform .25s var(--ease), box-shadow .25s, background .25s, color .25s;
  will-change:transform;
}
.btn--accent{ background:var(--lime); color:var(--ink); box-shadow:0 6px 22px -6px rgba(205,253,80,.55); }
.btn--accent:hover{ transform:translateY(-3px); box-shadow:0 14px 32px -8px rgba(205,253,80,.7); background:#dcff6e; }
.btn--ghost{ background:transparent; color:var(--txt); border-color:var(--line-2); }
.btn--ghost:hover{ transform:translateY(-3px); border-color:var(--lime); color:var(--lime); }
.btn--lg{ padding:1.05rem 1.9rem; font-size:1.02rem; }
.btn--full{ width:100%; }

.txt-accent{ color:var(--lime); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .35s, backdrop-filter .35s, border-color .35s, padding .35s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(12,13,15,.82);
  backdrop-filter:blur(14px) saturate(1.3);
  border-bottom-color:var(--line);
}
.nav__inner{
  max-width:var(--maxw); margin-inline:auto; padding:1rem var(--pad);
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.nav.is-scrolled .nav__inner{ padding-block:.7rem; }

.brand{ display:flex; align-items:center; gap:.7rem; }
.brand__mark{
  width:44px; height:44px; flex:none; display:grid; place-items:center;
  background:var(--grad-energy); color:var(--ink);
  font-family:var(--font-head); font-weight:900; font-size:1.05rem;
  border-radius:12px; transform:rotate(-4deg);
  box-shadow:0 6px 18px -6px rgba(205,253,80,.5);
}
.brand__text{ display:flex; flex-direction:column; line-height:1.15; }
.brand__text strong{ font-family:var(--font-head); font-weight:800; font-size:1.02rem; letter-spacing:-.01em; }
.brand__text span{ font-size:.72rem; color:var(--txt-mute); text-transform:uppercase; letter-spacing:.14em; }

.nav__links{ display:flex; align-items:center; gap:1.9rem; }
.nav__links > a:not(.btn){
  font-size:.92rem; font-weight:500; color:var(--txt-dim); position:relative; padding:.2rem 0;
  transition:color .2s;
}
.nav__links > a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px;
  background:var(--lime); transition:width .28s var(--ease);
}
.nav__links > a:not(.btn):hover{ color:var(--txt); }
.nav__links > a:not(.btn):hover::after{ width:100%; }
.nav__cta{ font-size:.82rem; padding:.65rem 1.2rem; }

.nav__toggle{
  display:none; flex-direction:column; gap:5px; width:44px; height:44px;
  background:transparent; border:1px solid var(--line-2); border-radius:12px;
  cursor:pointer; align-items:center; justify-content:center;
}
.nav__toggle span{ width:20px; height:2px; background:var(--txt); transition:transform .3s, opacity .3s; }
.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); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:center; padding:8rem var(--pad) 4rem;
  max-width:var(--maxw); margin-inline:auto; overflow:hidden;
}
.hero__bg{ position:absolute; inset:0; z-index:-1; }
.hero__bg img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  object-position:center 30%; filter:grayscale(.35) contrast(1.05) brightness(.55);
}
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg,var(--bg) 8%, rgba(12,13,15,.72) 45%, rgba(12,13,15,.35) 100%),
    linear-gradient(0deg,var(--bg) 2%, transparent 40%);
}
.hero__grid{
  position:absolute; inset:0; opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),
                   linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 70% 40%, #000 0%, transparent 62%);
}
.hero__glow{
  position:absolute; top:8%; right:-6%; width:46vw; height:46vw; max-width:620px; max-height:620px;
  background:radial-gradient(circle, rgba(205,253,80,.28), transparent 68%);
  filter:blur(20px);
}

.hero__content{ position:relative; max-width:830px; }
.hero__eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.82rem; text-transform:uppercase; letter-spacing:.14em;
  color:var(--txt-dim); font-weight:600; margin-bottom:1.6rem;
  border:1px solid var(--line); padding:.5rem .9rem; border-radius:100px;
  background:rgba(12,13,15,.4);
}
.pulse-dot{ width:9px; height:9px; border-radius:50%; background:var(--lime); box-shadow:0 0 0 0 rgba(205,253,80,.7); animation:pulse 2s infinite; }
@keyframes pulse{ 70%{ box-shadow:0 0 0 10px rgba(205,253,80,0);} 100%{ box-shadow:0 0 0 0 rgba(205,253,80,0);} }

.hero__title{
  font-family:var(--font-head); font-weight:900; line-height:.92;
  font-size:clamp(3rem, 9vw, 7.2rem); letter-spacing:-.02em; text-transform:uppercase;
  margin-bottom:1.6rem;
}
.hero__title span{ display:block; }
.hero__title-accent{
  color:transparent; -webkit-text-stroke:2px var(--lime);
  text-stroke:2px var(--lime);
}
.hero__title em{ font-style:italic; color:var(--lime); text-transform:none; }
.hero__title span:last-child{ font-size:.42em; font-weight:800; letter-spacing:-.01em; text-transform:none; line-height:1.05; margin-top:.5rem; color:var(--txt-dim); }

.hero__lead{ font-size:clamp(1.05rem,2.2vw,1.28rem); color:var(--txt-dim); max-width:56ch; margin-bottom:2.2rem; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:2.6rem; }

.hero__proof{ list-style:none; display:flex; flex-wrap:wrap; gap:2rem 2.6rem; }
.hero__proof li{ font-size:.92rem; color:var(--txt-mute); }
.hero__proof strong{ display:block; font-family:var(--font-head); font-weight:800; font-size:1.5rem; color:var(--txt); }

.hero__badge{
  position:absolute; right:var(--pad); bottom:3rem; z-index:2;
  width:150px; height:150px; border-radius:50%; display:grid; place-content:center; text-align:center;
  background:var(--grad-energy); color:var(--ink);
  box-shadow:0 20px 50px -14px rgba(205,253,80,.6);
  animation:float 5s ease-in-out infinite; transform:rotate(-8deg);
}
.hero__badge-num{ font-family:var(--font-head); font-weight:900; font-size:2.6rem; line-height:1; }
.hero__badge-txt{ font-family:var(--font-head); font-weight:800; font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; }
@keyframes float{ 50%{ transform:translateY(-12px) rotate(-8deg);} }

/* ---------- Marquee ---------- */
.marquee{ background:var(--lime); color:var(--ink); overflow:hidden; padding:.7rem 0; border-block:2px solid var(--ink); }
.marquee__track{
  display:flex; gap:2.2rem; align-items:center; width:max-content;
  font-family:var(--font-head); font-weight:900; font-size:1.5rem; text-transform:uppercase; letter-spacing:.02em;
  animation:scroll 24s linear infinite;
}
.marquee__track .dot{ font-size:.7rem; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ============================================================
   TRUST / COUNTERS
   ============================================================ */
.trust{ background:var(--bg-2); border-bottom:1px solid var(--line); }
.trust__grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1rem;
  padding-block:clamp(2.5rem,5vw,4rem);
}
.stat{ text-align:center; padding:1rem; border-right:1px solid var(--line); }
.stat:last-child{ border-right:0; }
.stat__num{
  display:block; font-family:var(--font-head); font-weight:900;
  font-size:clamp(2.2rem,4.6vw,3.4rem); line-height:1; color:var(--lime); letter-spacing:-.02em;
  font-variant-numeric:tabular-nums; white-space:nowrap;
}
.stat__unit{ font-size:.5em; margin-left:.14em; letter-spacing:0; }
.stat__label{ display:block; margin-top:.6rem; font-size:.86rem; color:var(--txt-mute); text-transform:uppercase; letter-spacing:.1em; }

/* ============================================================
   SECTIONS
   ============================================================ */
.section{ padding-block:clamp(4rem,9vw,7.5rem); position:relative; }
.section--dark{ background:var(--bg-2); }

.section__head{ max-width:720px; margin:0 auto clamp(2.5rem,5vw,3.8rem); text-align:center; }
.section__head--left{ margin-inline:0; text-align:left; }
.section__kicker{
  display:inline-block; font-family:var(--font-head); font-weight:800;
  font-size:.8rem; text-transform:uppercase; letter-spacing:.22em; color:var(--lime);
  margin-bottom:1rem; position:relative; padding-left:2.4rem;
}
.section__kicker::before{ content:""; position:absolute; left:0; top:50%; width:1.8rem; height:2px; background:var(--lime); }
.section__head:not(.section__head--left) .section__kicker{ padding-left:0; }
.section__head:not(.section__head--left) .section__kicker::before{ display:none; }
.section__title{
  font-family:var(--font-head); font-weight:900; line-height:1.02;
  font-size:clamp(2.1rem,5.2vw,3.7rem); letter-spacing:-.02em; text-transform:uppercase;
}
.section__intro{ margin-top:1.2rem; color:var(--txt-dim); font-size:1.06rem; }

/* ---------- Program cards ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.card{
  position:relative; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:2rem 1.7rem; overflow:hidden;
  transition:transform .35s var(--ease), border-color .35s, background .35s;
}
.card::before{
  content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--grad-energy);
  transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease);
}
.card:hover{ transform:translateY(-6px); border-color:var(--line-2); background:var(--bg-3); }
.card:hover::before{ transform:scaleX(1); }
.card__index{ font-family:var(--font-head); font-weight:900; font-size:1rem; color:var(--txt-mute); }
.card__title{ font-family:var(--font-head); font-weight:800; font-size:1.35rem; margin:.6rem 0 .7rem; letter-spacing:-.01em; }
.card p{ color:var(--txt-dim); font-size:.98rem; }
.card__list{ list-style:none; margin-top:1.2rem; display:grid; gap:.55rem; }
.card__list li{ position:relative; padding-left:1.5rem; font-size:.92rem; color:var(--txt-mute); }
.card__list li::before{ content:"→"; position:absolute; left:0; color:var(--lime); font-weight:700; }
.card--feature{ background:linear-gradient(160deg,#1f2229,#15171c); border-color:rgba(205,253,80,.28); }
.card__tag{
  position:absolute; top:1.4rem; right:-.3rem; background:var(--lime); color:var(--ink);
  font-family:var(--font-head); font-weight:800; font-size:.68rem; text-transform:uppercase; letter-spacing:.08em;
  padding:.3rem .8rem; border-radius:6px 0 0 6px;
}
.card--cta{ background:var(--grad-energy); color:var(--ink); display:flex; flex-direction:column; justify-content:center; }
.card--cta .card__title{ color:var(--ink); }
.card--cta p{ color:rgba(10,11,12,.78); font-weight:500; }
.card--cta::before{ display:none; }
.card__arrow{ font-family:var(--font-head); font-weight:900; font-size:2.2rem; margin-top:1rem; transition:transform .3s var(--ease); }
.card--cta:hover .card__arrow{ transform:translateX(10px); }

/* ---------- Before / After ---------- */
.ba{ max-width:860px; margin-inline:auto; }
.ba__slider{
  position:relative; aspect-ratio:16/10; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line-2); user-select:none; box-shadow:0 30px 70px -30px rgba(0,0,0,.8);
}
.ba__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ba__before{ position:absolute; inset:0; width:50%; overflow:hidden; border-right:3px solid var(--lime); }
.ba__before .ba__img{ width:auto; min-width:100%; }
.ba__tag{
  position:absolute; top:1rem; z-index:3; font-family:var(--font-head); font-weight:800;
  font-size:.78rem; letter-spacing:.1em; padding:.35rem .8rem; border-radius:100px; backdrop-filter:blur(6px);
}
.ba__tag--before{ left:1rem; background:rgba(12,13,15,.7); color:#fff; }
.ba__tag--after{ right:1rem; background:var(--lime); color:var(--ink); }
.ba__range{ position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:ew-resize; margin:0; z-index:5; }
.ba__handle{
  position:absolute; top:50%; left:50%; z-index:4; transform:translate(-50%,-50%);
  width:52px; height:52px; border-radius:50%; background:var(--lime); color:var(--ink);
  display:grid; place-items:center; font-size:.9rem; font-weight:700; pointer-events:none;
  box-shadow:0 6px 20px -4px rgba(0,0,0,.6);
}
.ba__caption{ text-align:center; margin-top:1.2rem; color:var(--txt-dim); }
.ba__caption strong{ color:var(--lime); }

.promeny__mini{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:2.5rem; }
.mini{ position:relative; border-radius:14px; overflow:hidden; border:1px solid var(--line); }
.mini img{ width:100%; height:260px; object-fit:cover; filter:grayscale(.2); transition:transform .5s var(--ease), filter .4s; }
.mini:hover img{ transform:scale(1.06); filter:grayscale(0); }
.mini figcaption{
  position:absolute; inset:auto 0 0 0; padding:1.4rem 1rem .9rem;
  background:linear-gradient(0deg,rgba(12,13,15,.92),transparent);
  display:flex; flex-direction:column;
}
.mini figcaption strong{ font-family:var(--font-head); font-weight:800; }
.mini figcaption span{ color:var(--lime); font-size:.88rem; font-weight:600; }

/* ---------- Pricing ---------- */
.pricing{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; align-items:start; }
.price{
  position:relative; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:2.2rem 1.8rem; transition:transform .35s var(--ease), border-color .35s;
}
.price:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.price--hi{ background:linear-gradient(165deg,#20242c,#15171c); border-color:var(--lime); box-shadow:0 24px 60px -30px rgba(205,253,80,.5); }
.price__ribbon{
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--lime); color:var(--ink); font-family:var(--font-head); font-weight:800;
  font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; padding:.35rem 1rem; border-radius:100px; white-space:nowrap;
}
.price__name{ font-family:var(--font-head); font-weight:800; font-size:1.2rem; }
.price__val{ font-family:var(--font-head); font-weight:900; font-size:1.2rem; color:var(--txt-mute); margin:1rem 0 .2rem; }
.price__val span{ font-size:3rem; color:var(--txt); letter-spacing:-.02em; }
.price--hi .price__val span{ color:var(--lime); }
.price__per{ color:var(--txt-mute); font-size:.9rem; margin-bottom:1.4rem; }
.price__list{ list-style:none; display:grid; gap:.7rem; margin-bottom:1.8rem; }
.price__list li{ position:relative; padding-left:1.7rem; color:var(--txt-dim); font-size:.95rem; }
.price__list li::before{ content:"✓"; position:absolute; left:0; color:var(--lime); font-weight:800; }
.cenik__note{ text-align:center; margin-top:2rem; color:var(--txt-dim); }
.cenik__note strong{ color:var(--lime); }

/* ---------- Steps ---------- */
.steps{ list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; counter-reset:s; }
.step{
  position:relative; padding:2rem 1.5rem; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--radius);
  transition:transform .35s var(--ease), border-color .35s;
}
.step:hover{ transform:translateY(-6px); border-color:var(--lime); }
.step__num{
  font-family:var(--font-head); font-weight:900; font-size:2.8rem; line-height:1;
  color:transparent; -webkit-text-stroke:1.5px var(--lime); display:block; margin-bottom:1rem;
}
.step h3{ font-family:var(--font-head); font-weight:800; font-size:1.2rem; margin-bottom:.6rem; }
.step p{ color:var(--txt-dim); font-size:.95rem; }

/* ---------- About ---------- */
.about{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.about__media{ position:relative; }
.about__media img{ width:100%; border-radius:var(--radius); border:1px solid var(--line-2); filter:grayscale(.15); }
.about__media::before{
  content:""; position:absolute; inset:-14px -14px auto auto; width:60%; height:60%; z-index:-1;
  background:var(--grad-energy); border-radius:var(--radius); opacity:.5; filter:blur(8px);
}
.about__badge{
  position:absolute; bottom:1.4rem; left:-1rem; background:var(--bg); border:1px solid var(--lime);
  border-radius:14px; padding:.9rem 1.3rem; text-align:center; box-shadow:0 14px 40px -14px rgba(0,0,0,.7);
}
.about__badge strong{ display:block; font-family:var(--font-head); font-weight:900; font-size:2.2rem; color:var(--lime); line-height:1; }
.about__badge span{ font-size:.78rem; color:var(--txt-mute); text-transform:uppercase; letter-spacing:.08em; }
.about__text p{ color:var(--txt-dim); margin-top:1.1rem; font-size:1.03rem; }
.about__text em{ color:var(--txt); font-style:italic; }
.creds{ list-style:none; margin:1.8rem 0; display:grid; gap:.7rem; }
.creds li{ position:relative; padding-left:1.9rem; color:var(--txt); font-size:.98rem; }
.creds li::before{
  content:"✦"; position:absolute; left:0; top:.05rem; color:var(--lime); font-weight:800;
}

/* ---------- Reviews ---------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.review{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:2rem 1.8rem; display:flex; flex-direction:column; gap:1rem;
  transition:transform .35s var(--ease), border-color .35s;
}
.review:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.review__stars{ color:var(--lime); letter-spacing:.15em; font-size:1.05rem; }
.review blockquote{ font-size:1.05rem; line-height:1.6; color:var(--txt); }
.review figcaption strong{ display:block; font-family:var(--font-head); font-weight:800; }
.review figcaption span{ color:var(--txt-mute); font-size:.88rem; }

/* ---------- FAQ ---------- */
.faq-wrap{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.faq{ display:grid; gap:.9rem; }
.faq__item{
  background:var(--surface); border:1px solid var(--line); border-radius:14px; overflow:hidden;
  transition:border-color .3s;
}
.faq__item[open]{ border-color:var(--line-2); }
.faq__item summary{
  cursor:pointer; list-style:none; padding:1.25rem 1.5rem;
  font-family:var(--font-head); font-weight:700; font-size:1.05rem;
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:"+"; color:var(--lime); font-size:1.6rem; font-weight:400; transition:transform .3s; line-height:1; }
.faq__item[open] summary::after{ transform:rotate(45deg); }
.faq__body{ padding:0 1.5rem 1.4rem; }
.faq__body p{ color:var(--txt-dim); }

/* ---------- Contact ---------- */
.contact{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.contact__list{ list-style:none; margin-top:2rem; display:grid; gap:1.1rem; }
.contact__list li{ display:flex; align-items:center; gap:1rem; font-size:1.05rem; }
.contact__ico{
  width:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:12px;
  background:var(--bg-3); border:1px solid var(--line-2); color:var(--lime); font-size:1.1rem;
}
.contact__list a:hover{ color:var(--lime); }

.form{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,2.4rem); display:grid; gap:1.1rem;
}
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field{ display:flex; flex-direction:column; gap:.4rem; }
.field label{ font-size:.85rem; font-weight:600; color:var(--txt-dim); }
.field input, .field select, .field textarea{
  font-family:var(--font-body); font-size:1rem; color:var(--txt);
  background:var(--bg); border:1px solid var(--line-2); border-radius:10px;
  padding:.8rem .9rem; transition:border-color .2s, box-shadow .2s; width:100%;
}
.field textarea{ resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--lime); box-shadow:0 0 0 3px rgba(205,253,80,.18);
}
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%23cdfd50' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.4rem; }
.field--invalid input, .field--invalid select{ border-color:var(--orange); }
.field__err{ font-size:.8rem; color:var(--orange); min-height:1rem; }
.form__note{ font-size:.8rem; color:var(--txt-mute); text-align:center; }
.form__success{
  background:rgba(205,253,80,.12); border:1px solid var(--lime); color:var(--lime);
  padding:1rem; border-radius:12px; text-align:center; font-weight:600;
}

.map{ margin-top:clamp(2.5rem,5vw,4rem); border-radius:var(--radius); overflow:hidden; border:1px solid var(--line-2); filter:saturate(.9); }
.map iframe{ display:block; filter:grayscale(.6) invert(.9) hue-rotate(180deg) contrast(.9); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--bg-2); border-top:1px solid var(--line); padding-top:clamp(3rem,6vw,4.5rem); }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem; padding-bottom:3rem; }
.footer__brand p{ color:var(--txt-dim); margin-top:1rem; }
.footer__brand strong{ font-family:var(--font-head); color:var(--txt); }
.footer__claim{ color:var(--lime) !important; font-family:var(--font-head); font-weight:800; font-size:1.05rem; }
.footer__col h3{ font-family:var(--font-head); font-weight:800; font-size:.85rem; text-transform:uppercase; letter-spacing:.14em; color:var(--txt-mute); margin-bottom:1rem; }
.footer__col p{ color:var(--txt-dim); margin-bottom:.5rem; font-size:.95rem; }
.footer__col a:hover{ color:var(--lime); }
.footer__bottom{
  border-top:1px solid var(--line); padding:1.5rem var(--pad);
  max-width:var(--maxw); margin-inline:auto;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  color:var(--txt-mute); font-size:.85rem;
}

/* ---------- Sticky CTA ---------- */
.sticky-cta{
  position:fixed; right:1.2rem; bottom:1.2rem; z-index:90;
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--lime); color:var(--ink); font-family:var(--font-head); font-weight:800;
  text-transform:uppercase; font-size:.9rem; letter-spacing:.02em;
  padding:.9rem 1.4rem; border-radius:100px; box-shadow:0 10px 30px -8px rgba(205,253,80,.6);
  transform:translateY(140%); transition:transform .4s var(--ease), background .25s;
}
.sticky-cta.is-visible{ transform:translateY(0); }
.sticky-cta:hover{ background:#dcff6e; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal].is-in{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .cards, .pricing, .reviews{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .about, .faq-wrap, .contact{ grid-template-columns:1fr; }
  .about__media{ max-width:460px; }
  .trust__grid{ grid-template-columns:repeat(2,1fr); gap:0; }
  .stat:nth-child(2n){ border-right:0; }
  .stat{ border-bottom:1px solid var(--line); padding-block:1.6rem; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
}

@media (max-width:720px){
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(84vw,340px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:1.6rem;
    background:var(--bg-2); border-left:1px solid var(--line); padding:2rem;
    transform:translateX(100%); transition:transform .4s var(--ease); z-index:99;
  }
  .nav__links.is-open{ transform:translateX(0); }
  .nav__links > a:not(.btn){ font-size:1.2rem; }
  .nav__cta{ font-size:1rem; padding:.9rem 1.6rem; }
  .nav__toggle{ display:flex; z-index:100; }
  .hero__badge{ width:118px; height:118px; bottom:1.5rem; }
  .hero__badge-num{ font-size:2rem; }
  .promeny__mini{ grid-template-columns:1fr; }
  .mini img{ height:320px; }
}

@media (max-width:520px){
  .cards, .pricing, .reviews, .steps{ grid-template-columns:1fr; }
  .form__row{ grid-template-columns:1fr; }
  .trust__grid{ grid-template-columns:1fr; }
  .stat{ border-right:0; }
  .footer__grid{ grid-template-columns:1fr; }
  .footer__bottom{ flex-direction:column; }
  .hero__title-accent{ -webkit-text-stroke-width:1.5px; }
}
