/* ===========================================================
   Hopsa Bavsa — prenájom skákacích hradov
   Mobile-first, playful, brand colours from the catalogue.
   =========================================================== */

:root{
  --yellow:#FFC60B; --yellow-2:#FFD84D; --yellow-soft:#FFF4CC;
  --orange:#FF7A1A; --orange-2:#FF5C00;
  --blue:#2E7BFF;   --blue-2:#1B57D6;
  --purple:#7B3FB8; --red:#EE3D52; --pink:#FF5BA0; --green:#2FBE6E;
  --ink:#241B4E; --ink-soft:#5b5478;
  --cream:#FFFDF6; --white:#fff;
  --shadow-s:0 6px 18px rgba(36,27,78,.10);
  --shadow-m:0 14px 34px rgba(36,27,78,.14);
  --shadow-l:0 26px 60px rgba(36,27,78,.20);
  --radius:26px; --radius-s:16px;
  --ring:0 0 0 4px rgba(46,123,255,.35);
  --container:1180px;
  --accent:var(--blue); --accent-soft:#e9f1ff;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; font-family:"Nunito",system-ui,-apple-system,"Segoe UI",sans-serif;
  color:var(--ink); background:var(--cream); line-height:1.6;
  font-size:clamp(16px,1rem + .2vw,18px); -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,.brand,.btn,.pill,.eyebrow{font-family:"Fredoka",system-ui,sans-serif;font-weight:600}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue-2);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:10px}

.container{width:min(100% - 36px,var(--container));margin-inline:auto}

.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:12px 18px;border-radius:0 0 12px 0;z-index:200}
.skip:focus{left:0}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--blue); --bg2:var(--blue-2);
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  padding:.85em 1.4em;border-radius:999px;font-size:1.02rem;line-height:1;
  color:#fff;background:linear-gradient(180deg,var(--bg),var(--bg2));
  box-shadow:0 8px 0 0 rgba(0,0,0,.24), var(--shadow-s);
  box-shadow:0 8px 0 0 color-mix(in srgb,var(--bg2) 70%,#000), var(--shadow-s);
  border:none;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;
  text-align:center;
}
.btn:hover{text-decoration:none;transform:translateY(-2px);box-shadow:0 10px 0 0 color-mix(in srgb,var(--bg2) 70%,#000),var(--shadow-m)}
.btn:active{transform:translateY(4px);box-shadow:0 4px 0 0 color-mix(in srgb,var(--bg2) 70%,#000),var(--shadow-s)}
.btn--call{--bg:#34C759;--bg2:#1FA84A}
.btn--ghost{--bg:#fff;--bg2:#f0eefb;color:var(--ink);box-shadow:0 8px 0 0 #d9d4ee,var(--shadow-s)}
.btn--ghost:hover{box-shadow:0 10px 0 0 #d9d4ee,var(--shadow-m)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);
  -webkit-backdrop-filter:saturate(1.4) blur(10px);backdrop-filter:saturate(1.4) blur(10px);border-bottom:2px solid #fff0c2}
.nav{display:flex;align-items:center;gap:14px;padding:8px 0;min-height:64px}
.brand{display:flex;align-items:center}
.brand img{height:48px;width:auto}
.nav__links{display:none;margin-inline:auto;gap:8px}
.nav__links a{color:var(--ink);font-weight:700;padding:9px 13px;border-radius:12px;font-family:"Nunito",sans-serif}
.nav__links a:hover{background:var(--yellow-soft);text-decoration:none;color:var(--ink)}
.nav__call{display:none;padding:.6em 1.05em;font-size:.95rem}
.burger{margin-left:auto;width:46px;height:46px;border:none;background:var(--yellow);border-radius:14px;
  display:grid;place-content:center;gap:5px;cursor:pointer;box-shadow:var(--shadow-s)}
.burger span{display:block;width:22px;height:3px;border-radius:3px;background:var(--ink);transition:.25s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

@media (min-width:980px){
  .nav__links{display:flex}
  .nav__call{display:inline-flex}
  .burger{display:none}
  .brand img{height:54px}
}
/* mobile dropdown */
@media (max-width:979px){
  .nav__links{position:absolute;inset:64px 0 auto 0;flex-direction:column;background:#fff;
    padding:10px 16px 18px;box-shadow:var(--shadow-m);border-bottom:3px solid var(--yellow);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.25s;gap:4px}
  .nav__links.open{transform:none;opacity:1;pointer-events:auto}
  .nav__links a{padding:13px 12px;border-radius:12px;border-bottom:1px solid #f3f0fb}
}

/* ---------- Hero ---------- */
.hero{position:relative;text-align:center;
  background:radial-gradient(120% 100% at 50% -10%,var(--yellow-2) 0%,var(--yellow) 55%,#FFB300 100%);
  padding:40px 0 96px;overflow:hidden}
.hero__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.hero__logo{width:min(78vw,360px);height:auto;filter:drop-shadow(0 12px 18px rgba(120,70,0,.22));
  animation:floaty 5s ease-in-out infinite}
.hero h1{font-size:clamp(1.9rem,5.4vw,3.4rem);line-height:1.05;margin:.5em 0 .2em;color:var(--ink);
  text-shadow:0 2px 0 #fff5cf}
.hero__lead{max-width:640px;font-size:clamp(1.05rem,2.4vw,1.3rem);color:var(--ink);font-weight:700}
.hero__lead strong{color:var(--orange-2)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin:26px 0 10px}
.hero__badges{list-style:none;display:flex;flex-wrap:wrap;gap:10px 18px;justify-content:center;
  margin:18px 0 0;padding:0;font-weight:800;color:var(--ink)}
.hero__badges li{display:flex;align-items:center;gap:.45em;background:rgba(255,255,255,.82);
  padding:8px 14px;border-radius:999px;box-shadow:var(--shadow-s)}
.hero__badges b{color:#0f7a3d}
.hero__wave{position:absolute;left:0;right:0;bottom:-1px;height:70px;
  background:var(--cream);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='70' viewBox='0 0 1440 70' preserveAspectRatio='none'%3E%3Cpath d='M0 70 V30 C180 70 320 0 540 18 C760 36 900 70 1080 44 C1240 22 1340 8 1440 28 V70 Z' fill='%23000'/%3E%3C/svg%3E") bottom/100% 100% no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='70' viewBox='0 0 1440 70' preserveAspectRatio='none'%3E%3Cpath d='M0 70 V30 C180 70 320 0 540 18 C760 36 900 70 1080 44 C1240 22 1340 8 1440 28 V70 Z' fill='%23000'/%3E%3C/svg%3E") bottom/100% 100% no-repeat}

/* clouds & bubbles */
.hero__decor{position:absolute;inset:0;z-index:1;pointer-events:none}
.cloud{position:absolute;background:#fff;border-radius:100px;opacity:.9;
  box-shadow:30px 0 0 6px #fff,-30px 4px 0 0 #fff}
.cloud::before{content:"";position:absolute;background:#fff;border-radius:50%;width:50%;height:140%;left:22%;top:-55%}
.cloud--1{width:90px;height:30px;top:12%;left:8%;animation:drift 18s linear infinite}
.cloud--2{width:120px;height:38px;top:20%;right:10%;left:auto;animation:drift 24s linear infinite reverse}
.cloud--3{width:70px;height:24px;top:54%;left:14%;animation:drift 30s linear infinite}
.bubble{position:absolute;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.9),rgba(255,255,255,.15) 45%,rgba(120,160,255,.12) 70%);
  border:1px solid rgba(255,255,255,.55)}
.bubble--1{width:46px;height:46px;top:30%;left:6%;animation:floaty 7s ease-in-out infinite}
.bubble--2{width:26px;height:26px;top:16%;left:40%;animation:floaty 6s ease-in-out infinite .6s}
.bubble--3{width:60px;height:60px;top:60%;right:8%;animation:floaty 9s ease-in-out infinite .3s}
.bubble--4{width:18px;height:18px;top:70%;left:30%;animation:floaty 5s ease-in-out infinite}

@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes drift{0%{transform:translateX(0)}50%{transform:translateX(26px)}100%{transform:translateX(0)}}

/* ---------- Ponuka pills ---------- */
.ponuka{margin-top:-34px;position:relative;z-index:5}
.ponuka__grid{display:flex;flex-wrap:wrap;gap:10px 12px;justify-content:center;
  background:#fff;border:2px solid #fff0c2;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-m)}
.pill{display:inline-flex;align-items:center;gap:.5em;padding:.6em 1.05em;border-radius:999px;
  background:var(--yellow-soft);color:var(--ink);font-weight:600;font-size:1rem;transition:.15s}
.pill:hover{background:var(--yellow);text-decoration:none;transform:translateY(-2px)}

/* ---------- Sections ---------- */
.section{padding:62px 0;scroll-margin-top:80px}
.section--alt{background:linear-gradient(180deg,#fff,#fbf6ff);border-block:2px solid #f1ebfb}
.sec-head{text-align:center;max-width:680px;margin:0 auto 38px}
.eyebrow{display:inline-block;margin:0 0 8px;color:var(--orange-2);font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;font-size:.82rem;background:#fff2e0;padding:5px 12px;border-radius:999px}
.sec-head h2{font-size:clamp(1.7rem,4.4vw,2.6rem);margin:0 0 .3em;color:var(--ink)}
.sec-sub{margin:0;color:var(--ink-soft);font-weight:600}
.cat{display:flex;align-items:center;gap:.5em;font-size:clamp(1.25rem,3vw,1.7rem);
  margin:42px 0 18px;color:var(--ink);scroll-margin-top:110px}
.cat span{display:grid;place-content:center;width:1.7em;height:1.7em;border-radius:14px;
  background:var(--yellow-soft);font-size:.85em}

/* ---------- Attraction cards ---------- */
.grid{display:grid;grid-template-columns:1fr;gap:20px}
@media (min-width:560px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:920px){.grid{grid-template-columns:repeat(3,1fr)}}

.card{position:relative;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-s);
  overflow:hidden;border:2px solid #f1ecfb;display:flex;flex-direction:column;
  transition:transform .16s ease,box-shadow .16s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-l)}
.card::before{content:"";display:block;height:8px;background:var(--accent)}
.card__media{position:relative;padding:18px 18px 6px;
  background:radial-gradient(120% 90% at 50% 0%,var(--accent-soft),#fff 78%)}
.card__media img{margin-inline:auto;height:180px;width:auto;object-fit:contain;
  filter:drop-shadow(0 10px 12px rgba(36,27,78,.16));transition:transform .2s ease}
.card:hover .card__media img{transform:scale(1.05) rotate(-1deg)}
.card__body{padding:6px 20px 20px;display:flex;flex-direction:column;flex:1}
.card__title{font-size:1.28rem;margin:6px 0 12px;color:var(--ink)}
.stats{list-style:none;margin:0 0 12px;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.stats li{display:flex;align-items:center;gap:.5em;background:#f8f6ff;border-radius:12px;padding:8px 10px;font-size:.86rem}
.stats__i{font-size:1.05rem;line-height:1}
.stats b{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);font-weight:800}
.stats span span,.stats li>span:last-child{font-weight:800;color:var(--ink)}
.card__note{margin:0 0 14px;font-size:.82rem;color:var(--ink-soft);display:flex;align-items:center;gap:.4em}
.card__note::before{content:"⚠️"}
.card__cta{margin-top:auto;align-self:flex-start;padding:.6em 1.2em;border-radius:999px;
  background:var(--accent);color:#fff;font-weight:800;font-family:"Fredoka",sans-serif;
  box-shadow:0 5px 0 0 rgba(0,0,0,.22);
  box-shadow:0 5px 0 0 color-mix(in srgb,var(--accent) 65%,#000);transition:.12s}
.card__cta:hover{text-decoration:none;transform:translateY(-2px);
  box-shadow:0 7px 0 0 color-mix(in srgb,var(--accent) 65%,#000)}
.card__cta:active{transform:translateY(3px);box-shadow:0 2px 0 0 color-mix(in srgb,var(--accent) 65%,#000)}

/* accent variants */
.c-blue  {--accent:var(--blue);  --accent-soft:#e8f0ff}
.c-yellow{--accent:#F5A800;      --accent-soft:#fff3d4}
.c-purple{--accent:var(--purple);--accent-soft:#f1e7fb}
.c-red   {--accent:var(--red);   --accent-soft:#ffe7ea}
.c-green {--accent:var(--green); --accent-soft:#e3f8ec}
.c-orange{--accent:var(--orange);--accent-soft:#ffeede}
.c-pink  {--accent:var(--pink);  --accent-soft:#ffe6f2}

/* ---------- Extras (doplnky) ---------- */
.xgrid{display:grid;grid-template-columns:1fr;gap:22px}
@media (min-width:760px){.xgrid{grid-template-columns:repeat(2,1fr)}}
.xcard{display:flex;gap:6px;flex-direction:column;background:#fff;border-radius:var(--radius);
  border:2px solid #f1ecfb;box-shadow:var(--shadow-s);overflow:hidden;transition:transform .16s,box-shadow .16s}
.xcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-l)}
@media (min-width:560px){.xcard{flex-direction:row;align-items:stretch}}
.xcard__media{flex:0 0 42%;display:grid;place-items:center;padding:16px;
  background:radial-gradient(120% 100% at 30% 20%,var(--accent-soft),#fff 80%)}
.xcard__media img{height:150px;width:auto;object-fit:contain;filter:drop-shadow(0 8px 10px rgba(36,27,78,.18))}
.xcard__body{padding:18px 20px 20px}
.xcard__body h3{display:flex;align-items:center;gap:.45em;font-size:1.3rem;margin:0 0 .35em;color:var(--ink)}
.xcard__emoji{font-size:1.2em}
.xcard__body p{margin:0 0 12px;color:var(--ink-soft);font-weight:600;font-size:.95rem}
.xchips{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.xchips li{background:var(--accent-soft);border-radius:999px;padding:6px 12px;font-size:.82rem;font-weight:700;color:var(--ink)}
.xchips b{color:var(--ink-soft);text-transform:uppercase;font-size:.68rem;letter-spacing:.04em;margin-right:.35em}

/* ---------- Prečo my ---------- */
.feat{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:620px){.feat{grid-template-columns:repeat(2,1fr)}}
@media (min-width:980px){.feat{grid-template-columns:repeat(4,1fr)}}
.feat__item{background:#fff;border:2px solid #f1ecfb;border-radius:var(--radius);padding:26px 22px;text-align:center;
  box-shadow:var(--shadow-s);transition:transform .16s}
.feat__item:hover{transform:translateY(-5px)}
.feat__i{display:inline-grid;place-content:center;width:68px;height:68px;border-radius:22px;font-size:2rem;
  background:linear-gradient(180deg,var(--yellow-2),var(--yellow));box-shadow:var(--shadow-s);margin-bottom:12px}
.feat__item:nth-child(2) .feat__i{background:linear-gradient(180deg,#7ea9ff,var(--blue))}
.feat__item:nth-child(3) .feat__i{background:linear-gradient(180deg,#ff9a5a,var(--orange))}
.feat__item:nth-child(4) .feat__i{background:linear-gradient(180deg,#ff8ec0,var(--pink))}
.feat__item h3{margin:.2em 0 .35em;font-size:1.2rem;color:var(--ink)}
.feat__item p{margin:0;color:var(--ink-soft);font-weight:600;font-size:.92rem}

/* ---------- Galéria ---------- */
.gallery{columns:2;column-gap:14px}
@media (min-width:680px){.gallery{columns:3}}
@media (min-width:1000px){.gallery{columns:4}}
.shot{display:block;margin:0 0 14px;border-radius:var(--radius-s);overflow:hidden;
  break-inside:avoid;box-shadow:var(--shadow-s);border:3px solid #fff;transition:transform .18s,box-shadow .18s}
.shot:hover{transform:scale(1.02) rotate(.5deg);box-shadow:var(--shadow-m)}
.shot img{width:100%;height:auto;display:block}

/* ---------- CTA band ---------- */
.cta-band{background:radial-gradient(120% 140% at 50% 0%,var(--blue) 0%,var(--blue-2) 100%);color:#fff;
  border-radius:0;text-align:center}
.cta-band__inner{max-width:680px;margin-inline:auto}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,4.4vw,2.4rem);margin:0 0 .3em}
.cta-band p{margin:0 0 22px;font-weight:700;color:#dce8ff}
.cta-band .btn--ghost{--bg:#fff;--bg2:#eaf0ff}

/* ---------- Kontakt ---------- */
.kontakt__wrap{display:grid;grid-template-columns:1fr;gap:30px}
@media (min-width:900px){.kontakt__wrap{grid-template-columns:1fr 1fr;align-items:start}}
.contacts{list-style:none;margin:22px 0 0;padding:0;display:grid;gap:12px}
.contacts li{display:flex;align-items:center;gap:14px;background:#fff;border:2px solid #f1ecfb;
  border-radius:var(--radius-s);padding:14px 16px;box-shadow:var(--shadow-s)}
.contacts li>span{font-size:1.5rem;width:48px;height:48px;display:grid;place-content:center;
  border-radius:14px;background:var(--yellow-soft);flex:0 0 auto}
.contacts b{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:800}
.contacts a,.contacts div>span,.contacts li>div{font-weight:800;color:var(--ink)}
.kontakt__form{background:#fff;border:2px solid #f1ecfb;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-m)}
.kontakt__form h3{margin:0 0 14px;font-size:1.35rem;color:var(--ink)}
.kontakt__form label{display:block;font-weight:800;font-size:.85rem;color:var(--ink);margin-bottom:13px}
.kontakt__form input,.kontakt__form textarea{width:100%;margin-top:6px;padding:12px 14px;border:2px solid #e7e1f5;
  border-radius:14px;font:inherit;font-weight:600;color:var(--ink);background:#fbfaff;transition:.15s}
.kontakt__form input:focus,.kontakt__form textarea:focus{border-color:var(--blue);background:#fff;
  outline:3px solid rgba(46,123,255,.45);outline-offset:2px}
.kontakt__form textarea{resize:vertical}
.kontakt__form .btn{width:100%;margin-top:4px}
.form-note{margin:12px 0 0;font-size:.82rem;color:var(--ink-soft);font-weight:600}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#cfc7ec;padding:46px 0 30px;margin-bottom:84px}
.footer__grid{display:grid;grid-template-columns:1fr;gap:26px}
@media (min-width:720px){.footer__grid{grid-template-columns:1.4fr 1fr 1fr}.site-footer{margin-bottom:0}}
.footer__logo{height:64px;width:auto;background:#fff;border-radius:16px;padding:8px 12px;margin-bottom:12px}
.site-footer p{margin:.25em 0}
.site-footer a{color:#fff;font-weight:700}
.footer__col h4{font-family:"Fredoka",sans-serif;color:#fff;margin:0 0 10px;font-size:1.05rem}
.footer__bottom{display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between;
  border-top:1px solid #3a3070;margin-top:30px;padding-top:18px;font-size:.85rem;color:#b8afd9}

/* ---------- Mobile sticky call bar ---------- */
.callbar{position:fixed;left:12px;right:12px;bottom:12px;z-index:90;display:flex;align-items:center;
  justify-content:center;gap:.5em;padding:15px;border-radius:18px;font-family:"Fredoka",sans-serif;font-weight:600;
  color:#fff;background:linear-gradient(180deg,#34C759,#1FA84A);
  box-shadow:0 10px 26px rgba(20,120,60,.45);font-size:1.08rem}
.callbar:hover{text-decoration:none}
@media (min-width:980px){.callbar{display:none}}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;display:none;place-items:center;
  background:rgba(20,14,46,.86);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:18px}
.lightbox.open{display:grid}
.lightbox img{max-width:92vw;max-height:84vh;border-radius:16px;border:4px solid #fff;
  box-shadow:var(--shadow-l);background:#fff}
.lightbox__close{position:absolute;top:14px;right:18px;width:48px;height:48px;border:none;border-radius:50%;
  background:#fff;color:var(--ink);font-size:1.7rem;line-height:1;cursor:pointer;box-shadow:var(--shadow-s)}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border:none;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--ink);font-size:2rem;line-height:1;cursor:pointer;box-shadow:var(--shadow-s)}
.lightbox__prev{left:14px}
.lightbox__next{right:14px}
.lightbox__nav:hover,.lightbox__close:hover{background:var(--yellow)}

/* ===========================================================
   COLORFUL THEME v2 — väčšie logá, pestrofarebné sekcie,
   bohatšie hero (slnko, balóny, konfety, vlnkové prechody)
   =========================================================== */

/* nikdy nie stroho biele pozadie */
body{background:#FFF6DA}

/* ---- Väčšie logo v hlavičke + pätičke ---- */
.brand img{height:60px}
@media (min-width:980px){.brand img{height:68px}}
.nav{min-height:74px}
@media (max-width:979px){.nav__links{inset:80px 0 auto 0}}
.footer__logo{height:104px;padding:12px 18px;border-radius:20px}

/* ---- Bohatšie HERO ---- */
.hero{background:
  radial-gradient(60% 50% at 82% 8%, rgba(255,241,166,.9), rgba(255,241,166,0) 60%),
  radial-gradient(135% 120% at 50% -28%, #86CCFF 0%, #BFE6FF 24%, #FFE76E 64%, #FFC60B 100%);
  padding:32px 0 104px}
.hero__logo{width:min(88vw,440px);animation:floaty 5.5s ease-in-out infinite}
.hero h1{font-size:clamp(2rem,5.8vw,3.6rem);text-shadow:0 3px 0 #fff,0 4px 14px rgba(80,60,0,.14)}
.hero__wave{height:64px;background:#CDEAFF}

/* slnko */
.sun{position:absolute;top:-70px;right:-46px;width:230px;height:230px;border-radius:50%;z-index:1;
  background:radial-gradient(circle,#FFF4B0 0%,#FFD93B 52%,rgba(255,217,59,0) 72%)}

/* väčšie obláčiky */
.cloud--1{width:118px;height:38px;top:9%;left:5%}
.cloud--2{width:150px;height:46px;top:15%;right:7%;left:auto}
.cloud--3{width:92px;height:30px;top:52%;left:11%}
.cloud--4{position:absolute;background:#fff;border-radius:100px;opacity:.92;width:108px;height:34px;top:46%;right:11%;
  box-shadow:30px 0 0 6px #fff,-30px 4px 0 0 #fff;animation:drift 26s linear infinite reverse}
.cloud--4::before{content:"";position:absolute;background:#fff;border-radius:50%;width:50%;height:140%;left:22%;top:-55%}

/* farebné balóny */
.balloon{position:absolute;width:44px;height:56px;border-radius:50%/46% 46% 56% 56%;z-index:1;
  box-shadow:inset -7px -10px 16px rgba(0,0,0,.13);animation:floaty 7s ease-in-out infinite}
.balloon::before{content:"";position:absolute;top:9px;left:9px;width:12px;height:17px;border-radius:50%;
  background:rgba(255,255,255,.55)}
.balloon::after{content:"";position:absolute;left:50%;top:98%;width:2px;height:42px;
  background:rgba(255,255,255,.7);transform:translateX(-50%)}
.balloon--a{top:12%;left:4%;background:#FF5A6E;animation-duration:6s}
.balloon--b{top:23%;right:6%;background:#3E8BFF;animation-duration:7.6s;animation-delay:.4s}
.balloon--c{top:55%;left:8%;background:#34C36B;animation-duration:8s;animation-delay:.2s}
.balloon--d{top:60%;right:5%;background:#FF6FB3;animation-duration:6.6s;animation-delay:.6s}
.balloon--e{top:8%;left:80%;background:#9B5DE5;animation-duration:7.2s;animation-delay:.9s}
@media (max-width:620px){.balloon--e,.balloon--d{display:none}}

/* konfety (jeden prvok, veľa box-shadow bodiek) */
.confetti{position:absolute;top:0;left:0;width:9px;height:9px;border-radius:2px;background:transparent;z-index:1;
  box-shadow:14vw 16vh 0 0 #FF5A6E, 78vw 11vh 0 0 #3E8BFF, 28vw 38vh 0 0 #34C36B,
    64vw 44vh 0 0 #FF6FB3, 20vw 60vh 0 0 #9B5DE5, 86vw 56vh 0 0 #FFB020,
    50vw 7vh 0 0 #34C36B, 8vw 48vh 0 0 #3E8BFF, 90vw 30vh 0 0 #FF5A6E, 38vw 70vh 0 0 #FFB020;
  animation:floaty 9s ease-in-out infinite}

/* pilulky pod hero ladia do modra */
.ponuka{margin-top:0;padding:30px 0 8px;background:#CDEAFF}

/* ---- Pestrofarebné sekcie + vlnkové prechody ---- */
.section{position:relative}
.section::before{content:"";position:absolute;left:0;right:0;top:0;height:46px;transform:translateY(-100%);
  background:var(--sec,transparent);pointer-events:none;z-index:1;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='46' viewBox='0 0 1440 46' preserveAspectRatio='none'%3E%3Cpath d='M0 46 V20 C200 46 360 0 600 14 C840 28 980 46 1180 28 C1320 16 1382 8 1440 18 V46 Z' fill='%23000'/%3E%3C/svg%3E") bottom/100% 100% no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='46' viewBox='0 0 1440 46' preserveAspectRatio='none'%3E%3Cpath d='M0 46 V20 C200 46 360 0 600 14 C840 28 980 46 1180 28 C1320 16 1382 8 1440 18 V46 Z' fill='%23000'/%3E%3C/svg%3E") bottom/100% 100% no-repeat}

#atrakcie{--sec:#CDEAFF;background:linear-gradient(180deg,#CDEAFF,#A6D4FF)}
#atrakcie::before{display:none}
#doplnky{--sec:#FFD9EE;background:linear-gradient(180deg,#FFD9EE,#EFCBFF);border-block:0}
.preco{--sec:#FFE7A8;background:linear-gradient(180deg,#FFE7A8,#FFD06A)}
#galeria{--sec:#C6F3E4;background:linear-gradient(180deg,#C6F3E4,#BCE6FF);border-block:0}
.cta-band{--sec:#2E7BFF}
.kontakt{--sec:#D9F6CA;background:linear-gradient(180deg,#D9F6CA,#FFEDA6)}

/* pútavejšie nadpisy sekcií */
.sec-head h2{text-shadow:0 2px 0 rgba(255,255,255,.6)}
.cat span{background:#fff;box-shadow:var(--shadow-s)}

/* tmavá vlna do pätičky */
.site-footer{position:relative}
.site-footer::before{content:"";position:absolute;left:0;right:0;top:0;height:46px;transform:translateY(-100%);
  background:var(--ink);pointer-events:none;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='46' viewBox='0 0 1440 46' preserveAspectRatio='none'%3E%3Cpath d='M0 46 V20 C200 46 360 0 600 14 C840 28 980 46 1180 28 C1320 16 1382 8 1440 18 V46 Z' fill='%23000'/%3E%3C/svg%3E") bottom/100% 100% no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='46' viewBox='0 0 1440 46' preserveAspectRatio='none'%3E%3Cpath d='M0 46 V20 C200 46 360 0 600 14 C840 28 980 46 1180 28 C1320 16 1382 8 1440 18 V46 Z' fill='%23000'/%3E%3C/svg%3E") bottom/100% 100% no-repeat}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}
