/* ============================================================
   Hravé Pieskovisko – vlastné štýly (mimo pôvodnej šablóny)
   Značka: #ec9600 / #d67922 (oranžová), #fdfbe8 (krém),
           #1e6a31 (zelená), #f0dfc2 (béžová)
   ============================================================ */

/* ---------- Helper triedy (náhrada za bývalé inline styly) ---------- */
.nav-center { justify-content: center !important; }
.hero-h1 { font-size: 1.875rem; margin: 1.25rem 0 .9375rem 0 !important; }
.hero-h1--tight { font-size: 1.875rem; margin: 0 0 .9375rem 0 !important; }
.about-ico { max-width: 253px; }
.bookio-frame { min-height: 294px; }
.map-frame { border: 0; filter: grayscale(100%); }
.footer-legal { font-size: .85rem; opacity: .85; }
.footer-legal a { color: #fff; text-decoration: underline; }

/* Aktuality – každý oznam vlastný rámček (rozostup) */
.newsline + .newsline { margin-top: 1.5rem; }

/* ============================================================
   SEKCIA: Letné tábory
   ============================================================ */
#letne-tabory.hpt-section{background:#f0dfc2;padding-block:clamp(2.5rem,1.5rem + 3vw,5rem);font-family:'Lato',sans-serif;}
.hpt-container{width:100%;max-width:1100px;margin-inline:auto;padding-inline:1.25rem;}
.hpt-card{position:relative;overflow:hidden;background:#fff;border-radius:1.75rem;padding:clamp(1.75rem,1rem + 3vw,3.5rem);box-shadow:0 1.25rem 3rem rgba(214,121,34,.16);text-align:center;}
.hpt-card::before{content:"";position:absolute;inset:0 0 auto 0;height:.5rem;background:linear-gradient(90deg,#ec9600,#d67922);}
.hpt-badge{display:inline-block;background:#d67922;color:#fff;font-weight:700;font-size:clamp(.72rem,.66rem + .2vw,.88rem);letter-spacing:.4px;text-transform:uppercase;padding:.45rem 1.1rem;border-radius:999px;margin-bottom:1.25rem;}
.hpt-title{font-family:'Alegreya sans',sans-serif;font-weight:800;color:#d67922;font-size:clamp(1.9rem,1.3rem + 2.6vw,3.25rem);line-height:1.15;text-transform:none;margin:0 0 1rem;}
.hpt-lead{font-size:clamp(1rem,.95rem + .35vw,1.2rem);color:#696767;line-height:1.65;max-width:46rem;margin:0 auto 2.5rem;}
.hpt-lead strong{color:#d67922;}
.hpt-agebox{display:flex;align-items:center;justify-content:center;gap:.6rem;flex-wrap:wrap;background:linear-gradient(135deg,#fff4d6,#ffe9b8);border:2px dashed #ec9600;color:#7a5410;font-weight:800;font-size:clamp(1rem,.95rem + .4vw,1.25rem);border-radius:1rem;padding:1rem 1.4rem;max-width:40rem;margin:0 auto 2.5rem;}
.hpt-agebox .big{font-size:1.4em;}
.hpt-subtitle{font-family:'Alegreya sans',sans-serif;font-weight:800;color:#d67922;font-size:clamp(1.35rem,1.1rem + 1vw,1.9rem);text-transform:none;margin:0 0 1.35rem;}
.hpt-activities{list-style:none;margin:0 0 2.75rem;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem;}
.hpt-activities li{background:#fdfbe8;border:1.5px solid #f3e6b0;color:#5a4a2a;font-weight:600;font-size:clamp(.9rem,.85rem + .2vw,1.05rem);padding:.55rem 1.15rem;border-radius:999px;transition:transform .2s ease,background .2s ease;}
.hpt-activities li:hover{transform:translateY(-3px);background:#fff4d6;}
.hpt-turnusy{display:grid;grid-template-columns:1fr;gap:1rem;margin:0 0 2.5rem;}
.hpt-turnus{display:flex;flex-direction:column;gap:.4rem;background:linear-gradient(135deg,#ffffff,#fdfbe8);border:2px solid #f3e6b0;border-radius:1.25rem;padding:1.6rem 1rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;}
.hpt-turnus:hover{transform:translateY(-5px);border-color:#ec9600;box-shadow:0 .75rem 1.5rem rgba(236,150,0,.18);}
.hpt-turnus-num{font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;color:#d67922;}
.hpt-turnus-date{font-family:'Alegreya sans',sans-serif;font-weight:800;font-size:clamp(1.3rem,1.1rem + .7vw,1.7rem);color:#4a3f2a;}
.hpt-turnus-price{font-weight:700;font-size:1.05rem;color:#d67922;}
.hpt-note{font-size:clamp(.95rem,.9rem + .25vw,1.1rem);color:#696767;line-height:1.65;max-width:42rem;margin:0 auto 2rem;}
.hpt-cta{display:inline-flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,#ec9600,#d67922);color:#fff!important;text-decoration:none;border:0;cursor:pointer;font-family:'Alegreya sans',sans-serif;font-weight:800;font-size:clamp(1.1rem,1rem + .5vw,1.45rem);text-transform:uppercase;letter-spacing:.5px;padding:1.05rem 2.6rem;border-radius:999px;box-shadow:0 .75rem 1.5rem rgba(214,121,34,.4);transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;}
.hpt-cta:hover,.hpt-cta:focus{transform:translateY(-4px) scale(1.03);box-shadow:0 1rem 2rem rgba(214,121,34,.5);filter:brightness(1.05);color:#fff!important;}
.hpt-cta-hint{display:block;margin-top:.9rem;font-size:.85rem;font-style:italic;color:#9a8f7a;}
@media (min-width:640px){.hpt-turnusy{grid-template-columns:repeat(3,1fr);}}
@media (prefers-reduced-motion:reduce){.hpt-activities li,.hpt-turnus,.hpt-cta{transition:none;}}

/* ============================================================
   Viackrokový modal prihlášky do tábora (.hpcm-*)
   ============================================================ */
.hpcm-overlay{position:fixed;inset:0;z-index:9999;display:none;align-items:flex-start;justify-content:center;padding:1rem;background:rgba(58,40,15,.55);backdrop-filter:blur(3px);overflow-y:auto;-webkit-overflow-scrolling:touch;}
.hpcm-overlay.open{display:flex;}
.hpcm{font-family:'Lato',sans-serif;background:#fffdf7;width:100%;max-width:40rem;margin:auto;border-radius:1.5rem;box-shadow:0 1.5rem 4rem rgba(58,40,15,.35);overflow:hidden;animation:hpcmIn .25s ease;}
@keyframes hpcmIn{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
.hpcm__head{position:relative;background:linear-gradient(135deg,#ec9600,#d67922);color:#fff;padding:1.4rem 1.5rem 1.25rem;}
.hpcm__head h2{font-family:'Alegreya Sans','Lato',sans-serif;font-weight:800;font-size:clamp(1.3rem,1.1rem + 1vw,1.7rem);margin:0;}
.hpcm__close{position:absolute;top:.9rem;right:1rem;background:rgba(255,255,255,.2);border:0;color:#fff;width:2.2rem;height:2.2rem;border-radius:50%;font-size:1.3rem;line-height:1;cursor:pointer;transition:background .15s ease;}
.hpcm__close:hover{background:rgba(255,255,255,.35);}
.hpcm__steplabel{font-size:.85rem;font-weight:700;opacity:.95;margin-top:.35rem;}
.hpcm__bar{height:.4rem;background:rgba(255,255,255,.3);border-radius:999px;margin-top:.7rem;overflow:hidden;}
.hpcm__bar span{display:block;height:100%;background:#fff;border-radius:999px;transition:width .3s ease;width:25%;}
.hpcm__dots{display:flex;gap:.4rem;margin-top:.7rem;}
.hpcm__dots i{flex:1;height:.35rem;background:rgba(255,255,255,.3);border-radius:999px;transition:background .3s ease;}
.hpcm__dots i.done{background:#fff;}
.hpcm__body{padding:1.5rem;}
.hpcm__agebox{display:flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,#fff4d6,#ffe9b8);border:2px dashed #ec9600;color:#7a5410;font-weight:800;border-radius:.85rem;padding:.75rem 1rem;margin-bottom:1.25rem;font-size:.95rem;}
.hpcm__agebox .big{font-size:1.3em;}
.hpcm-step{display:none;}
.hpcm-step.active{display:block;animation:hpcmFade .2s ease;}
@keyframes hpcmFade{from{opacity:0}to{opacity:1}}
.hpcm-step h3{font-family:'Alegreya Sans','Lato',sans-serif;color:#d67922;font-weight:800;font-size:1.2rem;margin:0 0 1rem;}
.hpcm-field{margin-bottom:1rem;}
.hpcm-field label{display:block;font-weight:700;font-size:.92rem;margin-bottom:.35rem;color:#3a3326;}
.hpcm-field .req{color:#d64545;}
.hpcm-field input,.hpcm-field textarea,.hpcm-field select{width:100%;font:inherit;padding:.7rem .85rem;border:1.5px solid #ece3cb;border-radius:.7rem;background:#fff;color:#3a3326;transition:border-color .15s ease,box-shadow .15s ease;}
.hpcm-field input:focus,.hpcm-field textarea:focus,.hpcm-field select:focus{outline:0;border-color:#ec9600;box-shadow:0 0 0 .2rem rgba(236,150,0,.18);}
.hpcm-field input.err,.hpcm-field textarea.err,.hpcm-field select.err{border-color:#d64545;box-shadow:0 0 0 .2rem rgba(214,69,69,.15);}
.hpcm-field textarea{min-height:5.5rem;resize:vertical;}
.hpcm-field .hint{font-weight:400;font-size:.8rem;color:#8a8170;margin-top:.3rem;}
.hpcm-gdpr{display:flex;gap:.5rem;align-items:flex-start;background:#eef6f0;border:1px solid #cfe6d6;border-radius:.7rem;padding:.6rem .75rem;font-size:.8rem;color:#2f6b41;margin-top:.4rem;line-height:1.45;}
.hpcm-gdpr a{color:#1e6a31;font-weight:700;text-decoration:underline;}
.hpcm-turnusy{display:grid;gap:.6rem;}
.hpcm-turnus{display:flex;align-items:center;justify-content:center;text-align:center;gap:.7rem;border:2px solid #ece3cb;border-radius:.8rem;padding:.85rem 1rem;cursor:pointer;transition:border-color .15s ease,background .15s ease;font-weight:700;}
.hpcm-turnus:hover{background:#fff7e6;}
.hpcm-turnus input{width:1.2rem;height:1.2rem;margin:0;accent-color:#ec9600;flex:0 0 auto;align-self:center;}
.hpcm-turnus span{line-height:1.2;}
.hpcm-turnus.sel{border-color:#ec9600;background:#fff4d6;}
.hpcm__foot{display:flex;gap:.7rem;justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;border-top:1px solid #ece3cb;background:#fff;}
.hpcm-btn{display:inline-flex;align-items:center;gap:.45rem;justify-content:center;font:inherit;font-weight:800;cursor:pointer;border:0;padding:.75rem 1.5rem;border-radius:.75rem;background:linear-gradient(135deg,#ec9600,#d67922);color:#fff;box-shadow:0 .4rem 1rem rgba(214,121,34,.3);transition:transform .15s ease,filter .15s ease;}
.hpcm-btn:hover{transform:translateY(-2px);filter:brightness(1.05);}
.hpcm-btn[disabled]{opacity:.6;cursor:default;transform:none;filter:none;}
.hpcm-btn--ghost{background:transparent;color:#d67922;box-shadow:none;border:1.5px solid #ece3cb;}
.hpcm-btn--ghost:hover{background:#fdfbe8;}
.hpcm-err{display:none;background:#fde8e8;border:1.5px solid #f3bcbc;color:#d64545;font-weight:700;border-radius:.7rem;padding:.7rem .9rem;margin-bottom:1rem;font-size:.9rem;}
.hpcm-err.show{display:block;}
.hpcm-thanks{display:none;text-align:center;padding:1rem .5rem 1.5rem;}
.hpcm-thanks.show{display:block;animation:hpcmFade .3s ease;}
.hpcm-thanks .emoji{font-size:4rem;line-height:1;margin-bottom:.5rem;animation:hpcmPop .5s ease;}
@keyframes hpcmPop{0%{transform:scale(0)}70%{transform:scale(1.15)}100%{transform:scale(1)}}
.hpcm-thanks h3{font-family:'Alegreya Sans','Lato',sans-serif;color:#d67922;font-size:1.6rem;margin:.25rem 0 .75rem;}
.hpcm-thanks p{color:#5a4a2a;font-size:1.05rem;line-height:1.6;max-width:28rem;margin:0 auto 1.5rem;}
.hpcm-hp{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;}
.hpcm-btn--back{visibility:hidden;}
@media (max-width:560px){.hpcm__foot{flex-direction:column-reverse;}.hpcm__foot .hpcm-btn{width:100%;}}
@media (prefers-reduced-motion:reduce){.hpcm,.hpcm-step,.hpcm-thanks,.hpcm-thanks .emoji{animation:none;}}

/* ============================================================
   404 / chybová stránka – animovaný smajlík
   ============================================================ */
.err-page{min-height:100svh;margin:0;display:flex;align-items:center;justify-content:center;padding:2rem 1.25rem;font-family:'Lato',sans-serif;background:radial-gradient(circle at 50% 0%,#ffe9c2,transparent 60%),#fdfbe8;color:#3a3326;text-align:center;}
.err-box{max-width:34rem;}
.err-face{width:9rem;height:9rem;margin:0 auto 1.75rem;border-radius:50%;background:linear-gradient(135deg,#ffd23f,#ec9600);box-shadow:0 1rem 2.5rem rgba(214,121,34,.35);position:relative;animation:errBob 2.6s ease-in-out infinite;}
.err-face::before,.err-face::after{content:"";position:absolute;top:3.1rem;width:1.1rem;height:1.1rem;border-radius:50%;background:#3a3326;animation:errBlink 4s infinite;}
.err-face::before{left:2.5rem;}
.err-face::after{right:2.5rem;}
.err-face .mouth{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);width:3.2rem;height:1.7rem;border:.32rem solid #3a3326;border-top:0;border-radius:0 0 3.2rem 3.2rem;}
.err-face .tear{position:absolute;top:4rem;left:2.7rem;width:.7rem;height:.7rem;background:#5fbdf0;border-radius:50% 50% 50% 0;transform:rotate(45deg);animation:errTear 2.6s ease-in-out infinite;}
@keyframes errBob{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-12px) rotate(3deg)}}
@keyframes errBlink{0%,92%,100%{transform:scaleY(1)}96%{transform:scaleY(.1)}}
@keyframes errTear{0%,100%{transform:rotate(45deg) translateY(0);opacity:.85}50%{transform:rotate(45deg) translateY(6px);opacity:1}}
.err-code{font-family:'Alegreya Sans','Lato',sans-serif;font-weight:900;font-size:clamp(3.5rem,2.5rem + 6vw,6rem);line-height:1;color:#d67922;margin:0;}
.err-title{font-family:'Alegreya Sans','Lato',sans-serif;font-weight:800;font-size:clamp(1.4rem,1.1rem + 1.4vw,2rem);margin:.5rem 0 .75rem;color:#3a3326;}
.err-text{font-size:clamp(1rem,.95rem + .25vw,1.15rem);color:#7a6f59;line-height:1.6;margin:0 auto 2rem;max-width:26rem;}
.err-btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#ec9600,#d67922);color:#fff;text-decoration:none;font-weight:800;padding:.9rem 1.9rem;border-radius:999px;box-shadow:0 .6rem 1.4rem rgba(214,121,34,.35);transition:transform .15s ease,filter .15s ease;}
.err-btn:hover{transform:translateY(-3px);filter:brightness(1.05);color:#fff;}
@media (prefers-reduced-motion:reduce){.err-face,.err-face .tear{animation:none;}}
