/* BudeFotka — Navy + Gold design system */
:root{
  --background: 222 47% 11%;
  --foreground: 40 30% 95%;
  --card: 222 40% 15%;
  --muted: 222 30% 20%;
  --muted-fg: 40 15% 70%;
  --border: 222 30% 25%;
  --primary: 42 75% 58%;
  --primary-contrast: 222 47% 11%;
  --primary-glow: 42 85% 68%;
  --secondary: 222 35% 18%;
  --gradient-to: 38 70% 48%;
  --shadow-glow: 0 18px 40px -12px hsl(42 75% 58% / 0.35);
  --shadow-elegant: 0 10px 32px -12px hsl(0 0% 0% / 0.5);
  --shadow-vibrant: 0 20px 50px -15px hsl(42 75% 58% / 0.4);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:hsl(var(--background));color:hsl(var(--foreground));line-height:1.55}
h1,h2,h3,h4,h5,h6{font-family:"Cormorant Garamond",Georgia,serif;letter-spacing:.025em;margin:0 0 .5rem;font-weight:700}
.font-display{font-family:"Cormorant Garamond",Georgia,serif;letter-spacing:.03em;font-weight:700}
.font-script{font-family:"Dancing Script",cursive;font-weight:600}
h1{font-size:clamp(2.4rem,5vw,4rem);line-height:1.05;text-transform:uppercase}
h2{font-size:clamp(2rem,4vw,3rem);text-transform:uppercase;text-align:center}
h3{font-size:1.4rem}
img{max-width:100%;height:auto;display:block;border-radius:14px}
a{color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.kicker{font-family:"Dancing Script",cursive;color:hsl(var(--primary)/.9);font-size:1.4rem;text-align:center;margin:0 0 .5rem}
.lead{color:hsl(var(--muted-fg));text-align:center;max-width:42rem;margin:0 auto 2rem}
.gold{color:hsl(var(--primary))}
.section{padding:80px 0;border-bottom:1px solid hsl(var(--border)/.4)}
.section.alt{background:hsl(var(--secondary)/.4)}
.center{text-align:center}

/* Header */
.site-header{position:sticky;top:0;background:hsl(var(--background)/.85);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid hsl(var(--border)/.5);z-index:30}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
@media(max-width:899px){.site-header .container{padding-left:28px;padding-right:28px}.nav{padding:12px 0;gap:12px}}
.brand{font-family:"Cormorant Garamond",serif;font-weight:700;text-decoration:none;color:hsl(var(--primary));font-size:1.7rem;text-transform:uppercase;letter-spacing:.05em}
.menu{display:none;gap:22px;align-items:center}
.menu a{color:hsl(var(--muted-fg));text-decoration:none;font-size:.95rem}
.menu a:hover{color:hsl(var(--primary))}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;padding:0;background:transparent;border:1px solid hsl(var(--border)/.6);border-radius:10px;cursor:pointer}
.nav-toggle span{display:block;width:20px;height:2px;background:hsl(var(--primary));margin:0 auto;border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.nav-toggle[aria-expanded="true"]{border-color:hsl(var(--primary)/.5)}
.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)}
.nav-cta{padding:9px 16px;font-size:.9rem;border-radius:10px}
@media(min-width:900px){.menu{display:flex}.nav-toggle{display:none}.nav-actions .nav-cta{display:none}.menu-heading{display:none}}
@media(max-width:899px){
  .menu{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;display:flex;flex-direction:column;align-items:stretch;gap:0;padding:88px 20px 32px;background:hsl(var(--background));border-top:1px solid hsl(var(--border)/.5);transform:translateY(-12px);opacity:0;visibility:hidden;pointer-events:none;transition:transform .25s ease,opacity .2s ease,visibility 0s linear .25s;overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:40}
  .menu.is-open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto;transition:transform .25s ease,opacity .2s ease,visibility 0s}
  .menu a{padding:16px 4px;font-size:1.15rem;border-bottom:1px solid hsl(var(--border)/.3);font-family:"Cormorant Garamond",serif;font-weight:600;letter-spacing:.02em;color:hsl(var(--foreground))}
  .menu a:last-child{border-bottom:none}
  .menu .btn{margin-top:auto;align-self:stretch;padding:16px 20px;font-size:1.1rem;font-family:"Cormorant Garamond",serif;font-weight:600;letter-spacing:.02em;text-align:center;justify-content:center;border-bottom:none;animation:none;box-shadow:none}
  .menu-heading{display:block;margin:0 0 14px;padding:0 4px 14px;font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-weight:600;color:hsl(var(--primary));letter-spacing:.04em;border-bottom:1px solid hsl(var(--primary)/.25)}
  body.nav-open{overflow:hidden}
  body.nav-open .sticky-check{display:none !important}
  body.nav-open{overflow:hidden}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 22px;border-radius:12px;border:1px solid transparent;font-weight:600;text-decoration:none;cursor:pointer;font-size:.95rem;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}
.btn:hover{transform:translateY(-1px)}
.btn-hero{position:relative;overflow:hidden;isolation:isolate;color:hsl(222 47% 11%) !important;background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--gradient-to)));box-shadow:var(--shadow-glow);font-weight:700}
.btn-hero:hover{box-shadow:var(--shadow-vibrant);color:hsl(222 47% 11%) !important}
.btn-hero svg{width:18px;height:18px;margin-right:8px;stroke:currentColor}
.btn-hero::after{content:"";position:absolute;top:0;left:0;width:40%;height:100%;background:linear-gradient(100deg,transparent 0%,hsl(0 0% 100% / 0) 35%,hsl(0 0% 100% / .5) 50%,hsl(0 0% 100% / 0) 65%,transparent 100%);transform:translateX(-120%) skewX(-20deg);animation:ctaShimmer 5s ease-in-out infinite;pointer-events:none;z-index:1}
@keyframes ctaShimmer{0%{transform:translateX(-120%) skewX(-20deg)}60%{transform:translateX(220%) skewX(-20deg)}100%{transform:translateX(220%) skewX(-20deg)}}
@media(prefers-reduced-motion:reduce){.btn-hero::after{animation:none;display:none}}
.btn-outline{border-color:hsl(var(--primary)/.5);background:transparent;color:hsl(var(--primary))}
.btn-outline:hover{background:hsl(var(--primary)/.1)}
.btn-lg{padding:16px 32px;font-size:1.05rem}
.wfull{display:flex;width:100%}

/* Hero */
.hero{position:relative;overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(800px 500px at 70% 20%,hsl(var(--primary)/.18),transparent 60%);pointer-events:none;will-change:transform;transform:translate3d(0,var(--parallax-y,0),0)}
.hero-inner{padding:80px 0 20px;text-align:center;position:relative}
.hero h1{margin:1rem 0}
.hero-collage{position:relative;margin:2.5rem auto 0;max-width:1024px;height:180px}
.hero-frame{position:absolute;top:24px;width:46%;aspect-ratio:4/3;overflow:hidden;border-radius:16px;box-shadow:var(--shadow-elegant);transition:transform .5s ease;line-height:0}
.hero-frame img{width:100%;height:100%;max-width:none;object-fit:cover;border-radius:0}
.hero-collage .hc-left{left:0;transform:rotate(-6deg);z-index:1}
.hero-collage .hc-right{right:0;transform:rotate(6deg);z-index:1}
.hero-collage .hc-center{left:50%;top:0;width:52%;transform:translateX(-50%);z-index:2}
.hero-collage .hc-left:hover,.hero-collage .hc-right:hover{transform:rotate(0) scale(1.05)}
.hero-collage .hc-center:hover{transform:translateX(-50%) scale(1.05)}
@media(min-width:640px){.hero-collage{height:340px}}
@media(min-width:900px){.hero-collage{height:420px}}
.cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:24px}
.hero-social{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:20px;flex-wrap:wrap;color:hsl(var(--muted-fg));font-size:.9rem}
.hero-social-link{display:inline-flex;align-items:center;gap:8px;color:inherit;text-decoration:none;font-family:"Cormorant Garamond",serif;letter-spacing:.03em;transition:color .2s}
.hero-social-link:hover{color:hsl(var(--primary))}
.hero-social-sep{color:hsl(var(--primary)/.4)}
.social-cta-section{padding:60px 0}
.social-cta{position:relative;max-width:820px;margin:0 auto;border:1px solid hsl(var(--primary)/.3);border-radius:24px;background:linear-gradient(135deg,hsl(var(--card)),hsl(var(--secondary)/.4));padding:48px 32px;text-align:center;overflow:hidden}
.social-cta::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(600px 300px at 50% 0%,hsl(var(--primary)/.12),transparent 70%);opacity:.7}
.social-cta > *{position:relative}
.social-cta-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:24px}

/* Cards / features */
.features{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:640px){.features{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.features{grid-template-columns:repeat(4,1fr)}}
.card{background:hsl(var(--card));border:1px solid hsl(var(--border)/.6);border-radius:16px;padding:22px;transition:transform .3s,border-color .3s,box-shadow .3s}
.card:hover{border-color:hsl(var(--primary)/.5);transform:translateY(-4px);box-shadow:var(--shadow-vibrant)}
.icon-wrap{width:48px;height:48px;border-radius:12px;background:hsl(var(--primary)/.12);display:flex;align-items:center;justify-content:center;color:hsl(var(--primary));font-size:1.4rem;margin-bottom:14px}
.icon-wrap svg{width:24px;height:24px}
.card p{color:hsl(var(--muted-fg));margin:.25rem 0 0;font-size:.92rem}

/* Steps */
.steps-wrap{position:relative;max-width:1100px;margin:0 auto}
.steps-line{display:none;position:absolute;top:32px;left:10%;right:10%;height:2px;background:linear-gradient(to right,transparent,hsl(var(--primary)/.4),transparent);z-index:0}
@media(min-width:1024px){.steps-line{display:block}}
.steps{display:grid;gap:28px;grid-template-columns:1fr;position:relative;z-index:1}
@media(min-width:640px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.steps{grid-template-columns:repeat(5,1fr)}}
.step{text-align:center;display:flex;flex-direction:column;align-items:center}
.step-circle{width:64px;height:64px;border-radius:50%;background:hsl(var(--card));border:2px solid hsl(var(--primary));display:flex;align-items:center;justify-content:center;color:hsl(var(--primary));box-shadow:var(--shadow-glow);margin-bottom:14px;position:relative;z-index:2}
.step-circle svg{width:28px;height:28px}
.step-num{font-family:"Cormorant Garamond",serif;font-size:.85rem;color:hsl(var(--primary)/.7);letter-spacing:.2em;margin-bottom:4px}
.step h3{margin:.4rem 0;font-size:1.2rem}
.step p{color:hsl(var(--muted-fg));font-size:.88rem;line-height:1.5}

/* Gallery */
.gallery{display:grid;gap:16px;grid-template-columns:repeat(2,1fr);max-width:1100px;margin:0 auto}
@media(min-width:900px){.gallery{grid-template-columns:repeat(3,1fr)}}
.gallery img{aspect-ratio:1/1;object-fit:cover;box-shadow:var(--shadow-elegant);transition:transform .4s}
.gallery img:hover{transform:scale(1.03)}

/* Clients */
.clients{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:56px 90px;max-width:1100px;margin:0 auto}
.clients img{height:48px;width:auto;opacity:.85;filter:brightness(0) invert(1);transition:opacity .2s}
.clients img.client-logo-color{filter:none}
.clients .client-bg{background:#fff;border-radius:10px;padding:10px 18px;display:inline-flex;align-items:center;opacity:.95;transition:opacity .2s}
.clients .client-bg img{filter:none;height:40px;opacity:1}
.clients .client-bg:hover{opacity:1}
.clients img:hover{opacity:1}
.client-text{font-family:"Cormorant Garamond",serif;font-size:1.2rem;color:hsl(var(--foreground)/.85);text-align:center;max-width:14rem;line-height:1.2}
.clients-label{text-align:center;font-size:.8rem;letter-spacing:.25em;text-transform:uppercase;color:hsl(var(--muted-fg));margin-bottom:28px}

/* Testimonials */
.testimonials{display:grid;gap:18px;grid-template-columns:1fr;max-width:1100px;margin:0 auto}
@media(min-width:700px){.testimonials{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.testimonials{grid-template-columns:repeat(3,1fr)}}
.testimonial--wide{grid-column:1 / -1}
@media(min-width:1024px){.testimonial--wide{grid-column:span 3}}
.testimonial p.quote{font-style:italic;color:hsl(var(--foreground)/.9);margin:0 0 12px}
.testimonial .author{font-family:"Cormorant Garamond",serif;color:hsl(var(--primary))}

/* Map */
.map-grid{display:grid;gap:40px;align-items:center;max-width:1100px;margin:0 auto;grid-template-columns:1fr}
@media(min-width:1024px){.map-grid{grid-template-columns:1fr 1fr}}
.map-svg{max-width:480px;margin:0 auto;display:block}
.map-wrap{position:relative;max-width:480px;margin:0 auto}
.map-img{display:block;width:100%;height:auto}
.map-pin{position:absolute;width:0;height:0}
.map-pin--bb{left:38%;top:52%;transform:translate(-50%,-50%)}
.map-pin .map-pulse,.map-pin .map-dot-outer,.map-pin .map-dot-inner{position:absolute;left:50%;top:50%;border-radius:9999px;transform:translate(-50%,-50%)}
.map-pin .map-pulse{width:60px;height:60px;border:2px solid hsl(var(--primary));opacity:.6;animation:mapPulse 3s infinite ease-out;transform-origin:center}
.map-pin .map-dot-outer{width:32px;height:32px;background:hsl(var(--primary)/0.4)}
.map-pin .map-dot-inner{width:14px;height:14px;background:hsl(var(--primary))}
@keyframes mapPulse{0%{transform:translate(-50%,-50%) scale(0.5);opacity:.7}100%{transform:translate(-50%,-50%) scale(8);opacity:0}}
.map-city{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:4px;pointer-events:none}
.map-city .city-dot{width:6px;height:6px;border-radius:9999px;background:hsl(var(--muted-fg))}
.map-city .city-label{font-size:11px;color:hsl(var(--muted-fg));white-space:nowrap;margin-top:2px}
.map-caption{text-align:center;margin-top:14px;font-style:italic;font-family:"Cormorant Garamond",serif;color:hsl(var(--primary));font-size:1.05rem}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:18px 0}
.stat{background:hsl(var(--card));border:1px solid hsl(var(--border)/.6);border-radius:12px;padding:16px;text-align:center}
.stat .num{font-size:1.8rem;font-weight:700;color:hsl(var(--primary))}
.stat .lbl{font-size:.85rem;color:hsl(var(--muted-fg))}

/* Pricing */
.pricing{display:grid;gap:18px;grid-template-columns:1fr;align-items:stretch;grid-auto-rows:1fr;max-width:1300px;margin:0 auto}
@media(min-width:700px){.pricing{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.pricing{grid-template-columns:repeat(4,1fr)}}
.price{display:flex;flex-direction:column;height:100%;position:relative}
.price.featured{border-color:hsl(var(--primary));box-shadow:var(--shadow-glow)}
.badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:hsl(var(--primary));color:hsl(var(--primary-contrast));font-size:.72rem;font-weight:700;padding:5px 14px;border-radius:999px;text-transform:uppercase;letter-spacing:.1em}
.price h3{color:hsl(var(--primary));font-size:1.6rem}
.price .subtitle{color:hsl(var(--muted-fg));font-size:.9rem;margin-bottom:14px}
.price .list{list-style:none;padding:0;margin:0 0 18px;flex-grow:1}
.price .list li{padding:5px 0;font-size:.92rem;display:flex;gap:8px}
.price .list li:before{content:"✓";color:hsl(var(--primary));font-weight:700}
.price .extras-label{margin:14px 0 6px;padding-top:12px;border-top:1px solid hsl(var(--primary)/.3);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:hsl(var(--primary));display:flex;align-items:center;gap:6px}
.price .extras-label:before{content:"✦";font-size:.85rem}
.price .list.extras{margin-bottom:18px}
.price .list.extras li{color:hsl(var(--primary));font-weight:600}
.price .list.extras li:before{content:none}
.price .value{font-size:1.9rem;font-weight:700;color:hsl(var(--primary));margin:auto 0 12px}

/* FAQ */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq details{background:hsl(var(--card));border:1px solid hsl(var(--border)/.6);border-radius:12px;padding:0 22px;transition:border-color .25s ease}
.faq details[open]{border-color:hsl(var(--primary)/.5)}
.faq summary{cursor:pointer;list-style:none;padding:18px 0;font-family:"Cormorant Garamond",serif;font-size:1.15rem;display:flex;justify-content:space-between;align-items:center;gap:12px;user-select:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";color:hsl(var(--primary));font-size:1.6rem;line-height:1;transition:transform .3s ease;display:inline-block}
.faq details[open] summary:after{transform:rotate(45deg)}
.faq .faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease,opacity .3s ease;opacity:0}
.faq details[open] .faq-body{grid-template-rows:1fr;opacity:1}
.faq .faq-body > .faq-body-inner{overflow:hidden}
.faq .faq-body p{color:hsl(var(--muted-fg));margin:0;padding-bottom:18px;line-height:1.6}

/* Contact */
.contact{position:relative;overflow:hidden;text-align:center;padding:90px 0}
.contact:before{content:"";position:absolute;inset:0;background:radial-gradient(600px 400px at 50% 50%,hsl(var(--primary)/.22),transparent 60%);pointer-events:none}
.contact-inner{position:relative;max-width:700px;margin:0 auto}
.contact-info{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;margin-top:30px;font-size:.95rem}
.contact-info a{color:hsl(var(--foreground));text-decoration:none;display:inline-flex;gap:8px;align-items:center}
.contact-info a svg{width:18px;height:18px;color:hsl(var(--primary));flex-shrink:0}
.contact-info a:hover{color:hsl(var(--primary))}
.need-icon{margin:0 auto 14px}
.brand-logo{height:64px;width:auto;display:block}
@media(max-width:899px){.brand-logo{height:60px}}
.footer-logo{height:120px;width:auto;display:block;margin-bottom:18px;object-fit:contain}
@media(max-width:699px){.footer-logo{margin-left:auto;margin-right:auto}.site-footer .footer-grid > *:first-child{text-align:center}}

/* Footer */
.site-footer{background:hsl(var(--secondary)/.5);padding:50px 0 24px;border-top:1px solid hsl(var(--border)/.6)}
.footer-grid{display:grid;gap:30px;grid-template-columns:1fr;align-items:start}
@media(min-width:700px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:repeat(4,1fr)}}
.site-footer h4{color:hsl(var(--primary));font-size:1.2rem;margin:0 0 14px}
.site-footer .footer-list{list-style:none;padding:0;margin:0}
.site-footer .footer-list li{display:flex;align-items:center;gap:10px;margin:8px 0;color:hsl(var(--muted-fg));font-size:.92rem}
.site-footer .footer-list li svg{width:16px;height:16px;color:hsl(var(--primary));flex-shrink:0}
.site-footer .footer-list a{color:hsl(var(--muted-fg));text-decoration:none;transition:color .2s}
.site-footer .footer-list a:hover{color:hsl(var(--foreground))}
.site-footer .footer-link-primary{color:hsl(var(--primary));text-decoration:none;font-size:.9rem}
.site-footer .footer-link-primary:hover{text-decoration:underline;text-underline-offset:4px}
.copy{margin-top:30px;padding-top:18px;border-top:1px solid hsl(var(--border)/.4);text-align:center;color:hsl(var(--muted-fg));font-size:.85rem}

/* Sticky date check */
.sticky-check{position:fixed;right:18px;bottom:18px;z-index:40}
.sticky-check > .btn{box-shadow:var(--shadow-glow);animation:softPulse 2.6s ease-in-out infinite}
@keyframes softPulse{0%,100%{box-shadow:0 18px 40px -12px hsl(42 75% 58% / .35),0 0 0 0 hsl(42 75% 58% / .5)}50%{box-shadow:0 18px 40px -12px hsl(42 75% 58% / .5),0 0 0 12px hsl(42 75% 58% / 0)}}
@media(prefers-reduced-motion:reduce){.sticky-check > .btn{animation:none}}
.sticky-check-form{background:hsl(var(--card));border:1px solid hsl(var(--primary)/.4);border-radius:16px;padding:18px;width:280px;box-shadow:var(--shadow-vibrant);display:none}
.sticky-check.open .sticky-check-form{display:block}
.sticky-check.open > .btn{display:none}
.sticky-check-form h4{color:hsl(var(--primary));margin:0 0 10px}
.sticky-check-form label{display:block;font-size:.8rem;color:hsl(var(--muted-fg));margin:8px 0 4px}
.sticky-check-form input{width:100%;padding:9px 11px;border-radius:8px;border:1px solid hsl(var(--border));background:hsl(var(--background));color:hsl(var(--foreground));font:inherit}
.sticky-check-form .row{display:flex;gap:8px;margin-top:12px}
.sticky-check-form .row .btn{flex:1;padding:9px 14px;font-size:.85rem}
.close-x{background:none;border:0;color:hsl(var(--muted-fg));cursor:pointer;float:right;font-size:1.2rem;line-height:1}

/* ============ GALÉRIA ============ */
.gallery-page{padding-top:60px}
.gallery-tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:32px 0 40px;padding:8px;background:hsl(var(--card));border-radius:60px;border:1px solid hsl(var(--border));max-width:fit-content;margin-left:auto;margin-right:auto}
.gallery-tab{padding:10px 22px;border-radius:50px;border:0;background:transparent;color:hsl(var(--foreground));font-family:inherit;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}
.gallery-tab:hover{color:hsl(var(--primary))}
.gallery-tab.is-active{background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--gradient-to)));color:hsl(var(--primary-contrast));box-shadow:var(--shadow-glow);font-weight:600}
.gallery-panel{display:none}
.gallery-panel.is-active{display:block;animation:fadeIn .4s ease}
.gallery-panel-desc{text-align:center;color:hsl(var(--muted-fg));max-width:42rem;margin:0 auto 24px}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:20px}
.gallery-item{display:block;overflow:hidden;border-radius:14px;aspect-ratio:1/1;cursor:zoom-in;border:1px solid hsl(var(--border));transition:transform .25s ease,box-shadow .25s ease}
.gallery-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-elegant)}
.gallery-item img{width:100%;height:100%;object-fit:cover;border-radius:0;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-empty,.gallery-empty-state{text-align:center;color:hsl(var(--muted-fg));padding:60px 20px}
.gallery-placeholder{aspect-ratio:1/1;border-radius:14px;background:hsl(var(--secondary)/.4);border:1px dashed hsl(var(--border));display:flex;align-items:center;justify-content:center}
.gallery-placeholder span{font-size:.8rem;color:hsl(var(--muted-fg))}
.gallery-empty-state .btn{margin-top:20px}
.gallery-item-hidden{display:none !important}
.gallery-item-more{position:relative}
.gallery-item-more .gallery-more-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:hsl(222 47% 5% / .72);color:hsl(var(--primary));backdrop-filter:blur(2px);border-radius:14px;text-align:center;gap:4px;transition:background .25s ease}
.gallery-item-more:hover .gallery-more-overlay{background:hsl(222 47% 5% / .82)}
.gallery-more-plus{font-family:var(--font-display,inherit);font-size:2.2rem;font-weight:600;line-height:1}
.gallery-more-label{font-size:.85rem;letter-spacing:.04em;color:hsl(var(--primary-contrast)/.85)}
.gallery-cta{text-align:center;margin-top:60px;padding-top:40px;border-top:1px solid hsl(var(--border)/.4)}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Lightbox */
.gallery-lightbox{position:fixed;inset:0;background:hsl(222 47% 5% / .95);display:none;align-items:center;justify-content:center;z-index:100;padding:40px}
.gallery-lightbox.is-open{display:flex}
.gallery-lightbox img{max-width:90vw;max-height:85vh;border-radius:12px;box-shadow:var(--shadow-elegant)}
.gallery-lightbox button{position:absolute;background:hsl(var(--card));color:hsl(var(--primary));border:1px solid hsl(var(--border));width:48px;height:48px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}
.gallery-lightbox button:hover{background:hsl(var(--primary));color:hsl(var(--primary-contrast))}
.gallery-lightbox-close{top:20px;right:20px}
.gallery-lightbox-prev{left:20px;top:50%;transform:translateY(-50%)}
.gallery-lightbox-next{right:20px;top:50%;transform:translateY(-50%)}
@media(max-width:600px){
  .gallery-tabs{border-radius:20px;padding:6px}
  .gallery-tab{padding:8px 14px;font-size:.85rem}
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
  .gallery-lightbox{padding:10px}
  .gallery-lightbox button{width:40px;height:40px}
}

/* Print hide */
@media print{.sticky-check,.booking-modal{display:none}}

/* ===== Booking modal ===== */
.booking-modal{position:fixed;inset:0;background:hsl(222 47% 5% / .85);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;z-index:100;padding:40px 20px;overflow-y:auto}
.booking-modal.is-open{display:flex}
.booking-modal-content{position:relative;background:hsl(var(--card));border:1px solid hsl(var(--primary)/.4);border-radius:18px;padding:32px;max-width:860px;width:100%;box-shadow:var(--shadow-vibrant);margin:auto}
.booking-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.booking-form label{display:flex;flex-direction:column;font-size:.85rem;color:hsl(var(--muted-fg));gap:6px}
.booking-form label.full,.booking-form .btn,.booking-form button[type="submit"],.booking-form .bf-recaptcha-inline{grid-column:1 / -1}
.booking-form input,.booking-form textarea,.booking-form select{font:inherit;padding:10px 12px;border-radius:10px;border:1px solid hsl(var(--border));background:hsl(var(--background));color:hsl(var(--foreground));width:100%}
.booking-form input:focus,.booking-form textarea:focus,.booking-form select:focus{outline:none;border-color:hsl(var(--primary));box-shadow:0 0 0 3px hsl(var(--primary)/.15)}
.booking-form select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:38px;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%23c9a84c' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 14px center;background-size:12px 8px;transition:border-color .2s ease,box-shadow .2s ease}
.booking-form select:hover{border-color:hsl(var(--primary)/.6)}
.booking-form select option{background:hsl(var(--background));color:hsl(var(--foreground));padding:8px}
.booking-form textarea{resize:vertical;min-height:80px}
.booking-form .btn{margin-top:6px}
.booking-form.is-sending button[type="submit"],.booking-form.is-sending input[type="submit"],.booking-form button[type="submit"]:disabled,.booking-form input[type="submit"]:disabled{background:hsl(var(--muted)) !important;background-image:none !important;color:hsl(var(--muted-fg)) !important;border-color:hsl(var(--border)) !important;box-shadow:none !important;opacity:1 !important;cursor:not-allowed;filter:none;transform:none}
.booking-form.is-sending button[type="submit"]::after,.booking-form button[type="submit"]:disabled::after{display:none !important}
.booking-form .bf-recaptcha-inline{justify-self:center !important;display:flex !important;justify-content:center !important;align-items:center !important;min-height:70px;margin:2px auto -2px !important;width:256px !important;max-width:100%;overflow:hidden;text-align:center}
.bf-recaptcha-inline > div[id^="g-recaptcha"]{display:flex !important;justify-content:center !important;width:256px !important;max-width:100%;margin:0 auto !important}
.bf-recaptcha-inline .grecaptcha-badge{position:static !important;display:block !important;margin:0 auto !important;box-shadow:none !important}
.bf-recaptcha-inline .grecaptcha-badge iframe[style*="display: none !important"],.bf-recaptcha-inline .grecaptcha-badge iframe[style*="display:none !important"]{display:none !important}
@media(max-width:700px){.booking-form{grid-template-columns:1fr}}
@media(max-width:600px){.booking-modal-content{padding:24px 20px}.booking-title{font-size:1.4rem}}
.booking-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:8px;background:transparent;border:0;color:hsl(var(--muted-fg));font-size:1.5rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .2s ease,background .2s ease;padding:0}
.booking-close:hover{color:hsl(var(--primary));background:hsl(var(--primary)/.1)}
.booking-title{font-family:"Cormorant Garamond",serif;color:hsl(var(--primary));font-size:1.8rem;margin:0 0 6px;text-transform:uppercase;letter-spacing:.04em}
.booking-sub{color:hsl(var(--muted-fg));margin:0 0 20px;font-size:.95rem}
.booking-pkg{color:hsl(var(--muted-fg));font-size:.9rem;margin:0 0 16px}
.booking-pkg strong{color:hsl(var(--primary));font-family:"Cormorant Garamond",serif;font-weight:700}
/* Testimonials – equal layout */
.testimonial{display:flex;flex-direction:column}
.testimonial p.quote{flex:1 1 auto}
.testimonial .author{margin-top:auto;padding-top:8px}
/* Kontakt background logo */
.contact{position:relative}
.contact .contact-bg-logo{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:.05;z-index:0}
.contact .contact-bg-logo img{width:80%;max-width:720px;height:auto}
.contact .contact-inner{position:relative;z-index:1}

/* ===== Contact Form Plugin (Martin Kapfhammer / contactformsimple) ===== */
.contact-form,
form.contact-form,
.contactform,
form.contactform,
.simple-contact-form,
form.simple-contact-form{
  display:flex;flex-direction:column;gap:14px;
  max-width:560px;margin:0 auto;
  background:hsl(var(--card));
  border:1px solid hsl(var(--primary)/.3);
  border-radius:18px;
  padding:28px;
  box-shadow:var(--shadow-vibrant);
}
.contact-form .form-group,
.contactform .form-group,
.simple-contact-form .form-group{
  display:flex;flex-direction:column;gap:6px;margin:0;
}
.contact-form label,
.contactform label,
.simple-contact-form label{
  font-size:.85rem;color:hsl(var(--muted-fg));font-weight:500;
}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form input[type="date"],
.contact-form input[data-datepicker],
.contact-form input[type="number"],
.contact-form input[type="url"],
.contact-form select,
.contact-form textarea,
.contactform input[type="text"],
.contactform input[type="email"],
.contactform input[type="tel"],
.contactform input[type="date"],
.contactform input[data-datepicker],
.contactform input[type="number"],
.contactform input[type="url"],
.contactform select,
.contactform textarea,
.simple-contact-form input[type="text"],
.simple-contact-form input[type="email"],
.simple-contact-form input[type="tel"],
.simple-contact-form input[type="date"],
.simple-contact-form input[data-datepicker],
.simple-contact-form input[type="number"],
.simple-contact-form input[type="url"],
.simple-contact-form select,
.simple-contact-form textarea,
.contact-form .form-control,
.contactform .form-control,
.simple-contact-form .form-control{
  font:inherit;
  font-family:inherit;
  padding:11px 14px;
  border-radius:10px;
  border:1px solid hsl(var(--border));
  background:hsl(var(--background));
  color:hsl(var(--foreground));
  width:100%;
  transition:border-color .2s,box-shadow .2s;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus,
.contactform input:focus,
.contactform select:focus,
.contactform textarea:focus,
.simple-contact-form input:focus,
.simple-contact-form select:focus,
.simple-contact-form textarea:focus,
.contact-form .form-control:focus,
.contactform .form-control:focus,
.simple-contact-form .form-control:focus{
  outline:none;
  border-color:hsl(var(--primary));
  box-shadow:0 0 0 3px hsl(var(--primary)/.18);
}
.contact-form textarea,
.contactform textarea,
.simple-contact-form textarea{
  resize:vertical;min-height:120px;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder,
.contactform input::placeholder,
.contactform textarea::placeholder,
.simple-contact-form input::placeholder,
.simple-contact-form textarea::placeholder{
  color:hsl(var(--muted-fg)/.7);
}
.contact-form button,
.contact-form input[type="submit"],
.contact-form .btn,
.contactform button,
.contactform input[type="submit"],
.contactform .btn,
.simple-contact-form button,
.simple-contact-form input[type="submit"],
.simple-contact-form .btn{
  margin-top:6px;
  align-self:stretch;
  background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--primary-glow)));
  color:hsl(var(--primary-foreground));
  border:0;
  padding:14px 22px;
  border-radius:12px;
  font-weight:600;
  font-size:1rem;
  cursor:pointer;
  letter-spacing:.02em;
  transition:transform .2s,box-shadow .2s,filter .2s;
  box-shadow:var(--shadow-vibrant);
}
.contact-form button:hover,
.contact-form input[type="submit"]:hover,
.contact-form .btn:hover,
.contactform button:hover,
.contactform input[type="submit"]:hover,
.contactform .btn:hover,
.simple-contact-form button:hover,
.simple-contact-form input[type="submit"]:hover,
.simple-contact-form .btn:hover{
  transform:translateY(-2px);
  filter:brightness(1.05);
}
/* Validation / alerts */
.contact-form .alert,
.contactform .alert,
.simple-contact-form .alert,
.contact-form .flash-message,
.contactform .flash-message{
  padding:12px 14px;border-radius:10px;font-size:.92rem;
  border:1px solid hsl(var(--border));
  background:hsl(var(--secondary));
  color:hsl(var(--foreground));
}
.contact-form .alert-success,
.contactform .alert-success,
.simple-contact-form .alert-success,
.contact-form .flash-message.success,
.contactform .flash-message.success{
  border-color:hsl(142 60% 45% /.5);
  background:hsl(142 60% 20% /.25);
  color:hsl(142 70% 75%);
}
.contact-form .alert-danger,
.contact-form .alert-error,
.contactform .alert-danger,
.contactform .alert-error,
.simple-contact-form .alert-danger,
.contact-form .flash-message.error,
.contactform .flash-message.error{
  border-color:hsl(var(--destructive)/.6);
  background:hsl(var(--destructive)/.15);
  color:hsl(var(--destructive));
}
.contact-form .help-block,
.contact-form .invalid-feedback,
.contactform .help-block,
.contactform .invalid-feedback{
  font-size:.82rem;color:hsl(var(--destructive));margin-top:4px;
}
.contact-form input.is-invalid,
.contact-form textarea.is-invalid,
.contactform input.is-invalid,
.contactform textarea.is-invalid{
  border-color:hsl(var(--destructive));
}
@media(max-width:600px){
  .contact-form,.contactform,.simple-contact-form{padding:22px 18px;border-radius:14px}
  .contact-form button,.contactform button,.simple-contact-form button{padding:13px 18px}
}

/* ===== Language switcher ===== */
.lang-switcher{position:relative;display:inline-block;margin-left:6px}
.lang-switcher .lang-trigger{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;cursor:pointer;color:hsl(var(--muted-fg));font:inherit;font-size:.95rem;letter-spacing:.05em;text-transform:uppercase;padding:6px 4px;transition:color .2s}
.lang-switcher .lang-trigger:hover,.lang-switcher.is-open .lang-trigger{color:hsl(var(--primary))}
.lang-switcher .lang-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:170px;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:10px;box-shadow:var(--shadow-vibrant);list-style:none;margin:0;padding:6px;display:none;z-index:60}
.lang-switcher.is-open .lang-menu{display:block}
.lang-switcher .lang-menu li{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:.92rem;color:hsl(var(--foreground));transition:background .15s}
.lang-switcher .lang-menu li:hover{background:hsl(var(--primary)/.1);color:hsl(var(--primary))}
.lang-switcher .lang-menu li.is-active{background:hsl(var(--primary)/.12);color:hsl(var(--primary));font-weight:600}
.lang-switcher .flag{font-size:1.05rem;line-height:1}

/* Flatpickr theme override – gold/navy */
.flatpickr-calendar{background:hsl(var(--card)) !important;border:1px solid hsl(var(--primary)/.4) !important;box-shadow:var(--shadow-vibrant) !important;border-radius:14px !important;color:hsl(var(--foreground)) !important;font-family:Inter,sans-serif !important;padding:14px 16px !important;width:auto !important}
.flatpickr-calendar .flatpickr-days,.flatpickr-calendar .dayContainer{width:auto !important;min-width:0 !important}
.flatpickr-calendar .flatpickr-rContainer{width:auto !important}
.flatpickr-calendar .flatpickr-innerContainer{overflow:visible !important}
.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{border-bottom-color:hsl(var(--primary)/.4) !important}
.flatpickr-months .flatpickr-month,.flatpickr-current-month,.flatpickr-weekdays,.flatpickr-weekday{background:transparent !important;color:hsl(var(--primary)) !important;fill:hsl(var(--primary)) !important;font-family:"Cormorant Garamond",serif !important;font-weight:600 !important}
.flatpickr-weekday{color:hsl(var(--muted-fg)) !important;font-family:Inter,sans-serif !important;font-size:.78rem !important;text-transform:uppercase;letter-spacing:.08em}
.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{color:hsl(var(--primary)) !important;fill:hsl(var(--primary)) !important}
.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:hsl(var(--primary-glow)) !important}
.flatpickr-day{color:hsl(var(--foreground)) !important;border-radius:8px !important}
.flatpickr-day.today{border-color:hsl(var(--primary)) !important;color:hsl(var(--primary)) !important}
.flatpickr-day:hover{background:hsl(var(--primary)/.15) !important;border-color:transparent !important}
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--gradient-to))) !important;border-color:transparent !important;color:hsl(var(--primary-contrast)) !important;font-weight:700}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:hsl(var(--muted-fg)/.4) !important}
.numInputWrapper:hover,.flatpickr-current-month input.cur-year{color:hsl(var(--primary)) !important}
.flatpickr-current-month .numInputWrapper span.arrowUp:after{border-bottom-color:hsl(var(--primary)) !important}
.flatpickr-current-month .numInputWrapper span.arrowDown:after{border-top-color:hsl(var(--primary)) !important}

/* Custom toast notifications */
.bf-toast{position:fixed;left:50%;bottom:32px;transform:translate(-50%,20px);background:hsl(var(--card));color:hsl(var(--foreground));border:1px solid hsl(var(--primary)/.4);border-radius:12px;padding:12px 18px;font-size:.95rem;font-weight:500;box-shadow:var(--shadow-vibrant);z-index:9999;opacity:0;transition:opacity .25s ease,transform .25s ease;max-width:90vw;text-align:center}
.bf-toast.is-show{opacity:1;transform:translate(-50%,0)}
.bf-toast-error{border-color:hsl(0 70% 55%/.6);color:hsl(0 80% 75%)}

/* Invalid input highlight */
.booking-form input.is-invalid,.booking-form textarea.is-invalid,.booking-form select.is-invalid{border-color:hsl(0 70% 55%) !important;box-shadow:0 0 0 2px hsl(0 70% 55%/.2) !important}

/* Disable text selection globally, allow only on meaningful content */
body{-webkit-user-select:none;user-select:none}
p,li,blockquote,pre,code,h1,h2,h3,h4,h5,h6,input,textarea,[contenteditable="true"],.selectable,a[href^="tel:"],a[href^="mailto:"]{-webkit-user-select:text;user-select:text}

/* ========== Cookie bar (OFFLINE.Cookies addon) ========== */
.cookie-bar{
  position:fixed; left:0; right:0; bottom:0; z-index:9999;
  background:hsl(var(--background)/.96);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-top:1px solid hsl(var(--primary)/.4);
  box-shadow:0 -10px 40px rgba(0,0,0,.5);
  color:hsl(var(--fg));
  padding:18px 22px;
  display:flex; align-items:center; justify-content:center; gap:22px;
  flex-wrap:wrap;
  font-family:'Inter',sans-serif;
  font-size:.92rem; line-height:1.5;
  animation:cookieSlideUp .5s ease-out;
}
@keyframes cookieSlideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-bar > *{margin:0}
.cookie-bar p{max-width:780px;margin:0;color:hsl(var(--fg)/.92)}
.cookie-bar a{color:hsl(var(--primary));text-decoration:underline;text-underline-offset:3px;font-weight:600}
.cookie-bar a:hover{color:hsl(var(--primary-glow,var(--primary)));text-decoration:none}

.cookie-bar .cookie-bar-buttons,
.cookie-bar > .buttons{display:flex;gap:10px;flex-wrap:wrap}

.cookie-bar[hidden],
.cookie-modal[hidden]{display:none !important}

.cookie-bar button,
.cookie-bar .btn,
.cookie-bar a.button{
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:.88rem;
  letter-spacing:.02em;
  padding:10px 22px;
  border-radius:999px;
  border:1px solid hsl(var(--primary)/.6);
  background:transparent;
  color:hsl(var(--primary));
  cursor:pointer;
  transition:all .25s ease;
  text-decoration:none;
  white-space:nowrap;
}
.cookie-bar button:hover,
.cookie-bar .btn:hover{
  background:hsl(var(--primary)/.12);
  border-color:hsl(var(--primary));
  transform:translateY(-1px);
}
/* primary "Súhlasím" button — usually the last button */
.cookie-bar button.btn-primary,
.cookie-bar button[data-cookie-accept],
.cookie-bar .buttons > *:last-child,
.cookie-bar .cookie-bar-buttons > *:last-child{
  background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--primary-glow,var(--primary))));
  color:hsl(var(--background));
  border-color:transparent;
  box-shadow:0 6px 20px hsl(var(--primary)/.35);
}
.cookie-bar button.btn-primary:hover,
.cookie-bar .buttons > *:last-child:hover,
.cookie-bar .cookie-bar-buttons > *:last-child:hover{
  filter:brightness(1.08);
  box-shadow:0 10px 28px hsl(var(--primary)/.5);
}

/* Settings modal (Manage cookies) — centered popup overlay, hidden by default */
.cookie-settings,
.cookie-modal,
#cookie-settings,
.initbiz-cookieconsent-settings,
.cc-settings-modal{
  display:none;
}
.cookie-settings.is-open,.cookie-settings.show,.cookie-settings.active,.cookie-settings[style*="display: block"],.cookie-settings[style*="display:block"],
.cookie-modal.is-open,.cookie-modal.show,.cookie-modal.active,.cookie-modal[style*="display: block"],.cookie-modal[style*="display:block"],
#cookie-settings.is-open,#cookie-settings.show,#cookie-settings.active,#cookie-settings[style*="display: block"],#cookie-settings[style*="display:block"],
.initbiz-cookieconsent-settings.is-open,.initbiz-cookieconsent-settings.show,.initbiz-cookieconsent-settings.active,.initbiz-cookieconsent-settings[style*="display: block"],.initbiz-cookieconsent-settings[style*="display:block"],
.cc-settings-modal.is-open,.cc-settings-modal.show,.cc-settings-modal.active,.cc-settings-modal[style*="display: block"],.cc-settings-modal[style*="display:block"]{
  display:flex !important;
  position:fixed !important;
  inset:0 !important;
  top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;
  width:auto !important;height:auto !important;
  z-index:10000 !important;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(5,10,20,.75);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  overflow-y:auto;
  animation:cookieFadeIn .25s ease-out;
}
@keyframes cookieFadeIn{from{opacity:0}to{opacity:1}}


.cookie-settings > *,
.cookie-modal > *,
#cookie-settings > *,
.initbiz-cookieconsent-settings > *,
.cc-settings-modal > *{
  background:hsl(var(--card));
  color:hsl(var(--fg));
  border:1px solid hsl(var(--primary)/.35);
  border-radius:18px;
  padding:28px;
  max-width:680px;
  width:100%;
  max-height:85vh;
  overflow-y:auto;
  box-shadow:0 30px 80px rgba(0,0,0,.7), 0 0 0 1px hsl(var(--primary)/.15);
  margin:auto;
}

.cookie-groups{
  background:hsl(var(--card));
  color:hsl(var(--fg));
  border:1px solid hsl(var(--primary)/.3);
  border-radius:16px;
  padding:20px;
  margin:14px 0;
}

.cookie-settings h1,.cookie-settings h2,.cookie-settings h3,
.cookie-modal h1,.cookie-modal h2,.cookie-modal h3,
.cookie-groups h2,.cookie-groups h3{
  font-family:'Cormorant Garamond',serif;
  color:hsl(var(--primary));
  margin-top:0;
}

.cookie-settings label,
.cookie-modal label{display:flex;align-items:center;gap:10px;margin:10px 0;font-weight:600}
.cookie-settings p,
.cookie-modal p{color:hsl(var(--fg)/.85);font-size:.95rem;line-height:1.55}

.cookie-settings button,
.cookie-modal button{
  background:transparent;color:hsl(var(--fg));
  border:1px solid hsl(var(--primary)/.55);
  padding:10px 18px;border-radius:999px;
  font-weight:600;cursor:pointer;transition:all .25s ease;
  margin:8px 8px 0 0;
}
.cookie-settings button:hover,
.cookie-modal button:hover{background:hsl(var(--primary)/.15);border-color:hsl(var(--primary))}
.cookie-settings button[type=submit],
.cookie-settings .btn-primary,
.cookie-modal button[type=submit],
.cookie-modal .btn-primary{
  background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--primary-glow,var(--primary))));
  color:hsl(var(--background));border:0;
  box-shadow:0 6px 20px hsl(var(--primary)/.35);
}

@media(max-width:640px){
  .cookie-bar{flex-direction:column;align-items:stretch;text-align:center;padding:16px}
  .cookie-bar .cookie-bar-buttons,
  .cookie-bar > .buttons{justify-content:center}
  .cookie-bar button,.cookie-bar .btn{width:100%}
}

/* ===== Success popup po odoslaní formulára ===== */
.bf-success-popup{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:20px}
.bf-success-popup.is-open{display:flex}
.bf-success-popup__backdrop{position:absolute;inset:0;background:rgba(7,12,28,.72);backdrop-filter:blur(6px)}
.bf-success-popup__card{position:relative;background:linear-gradient(180deg,hsl(var(--card)) 0%,hsl(var(--background)) 100%);border:1px solid hsl(var(--primary)/.45);border-radius:18px;padding:36px 32px 32px;max-width:440px;width:100%;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.45),0 0 0 1px hsl(var(--primary)/.15);animation:bfPopIn .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes bfPopIn{from{opacity:0;transform:translateY(12px) scale(.94)}to{opacity:1;transform:none}}
.bf-success-popup__icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--primary)/.7));color:hsl(var(--primary-foreground,0 0% 8%));display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:36px;font-weight:700;box-shadow:0 8px 24px hsl(var(--primary)/.45)}
.bf-success-popup__title{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:1.85rem;margin:0 0 12px;color:hsl(var(--primary))}
.bf-success-popup__text{margin:0;color:hsl(var(--foreground));font-size:1rem;line-height:1.55;opacity:.92}
.bf-success-popup__close{position:absolute;top:10px;right:14px;background:transparent;border:0;color:hsl(var(--foreground));font-size:28px;line-height:1;cursor:pointer;opacity:.65;transition:opacity .2s}
.bf-success-popup__close:hover{opacity:1}

/* Blog */
.blog-grid{display:flex;flex-direction:column;gap:24px;max-width:760px;margin:0 auto}
.blog-card{display:flex;flex-direction:column;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:18px;overflow:hidden;box-shadow:var(--shadow-elegant);transition:transform .25s ease, box-shadow .25s ease}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-vibrant)}
.blog-card-img{display:block;overflow:hidden;aspect-ratio:16/10;background:hsl(var(--muted))}
.blog-card-img img{width:100%;height:100%;object-fit:cover;border-radius:0;transition:transform .4s ease}
.blog-card:hover .blog-card-img img{transform:scale(1.04)}
.blog-card-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.blog-card-cats{display:flex;flex-wrap:wrap;gap:6px;margin:0}
.blog-tag{display:inline-block;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:999px;background:hsl(var(--primary)/.15);color:hsl(var(--primary));border:1px solid hsl(var(--primary)/.3)}
.blog-card-title{font-size:1.5rem;margin:0;line-height:1.2;text-transform:none}
.blog-card-title a{text-decoration:none;color:hsl(var(--foreground));transition:color .2s}
.blog-card-title a:hover{color:hsl(var(--primary))}
.blog-card-date{font-size:.85rem;color:hsl(var(--muted-fg));margin:0}
.blog-card-excerpt{color:hsl(var(--muted-fg));margin:0;flex:1}
.blog-card .btn{align-self:flex-start;margin-top:8px}
.blog-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:40px;flex-wrap:wrap}
.blog-pagination-info{color:hsl(var(--muted-fg));font-size:.9rem}
.blog-back{color:hsl(var(--primary));text-decoration:none;font-size:.95rem}
.blog-back:hover{text-decoration:underline}
.blog-hero-img{margin:0 0 28px;border-radius:18px;overflow:hidden;border:1px solid hsl(var(--border));box-shadow:var(--shadow-elegant)}
.blog-hero-img img{width:100%;height:auto;border-radius:0}
.blog-content{font-size:1.05rem;line-height:1.75;color:hsl(var(--foreground))}
.blog-content h2,.blog-content h3,.blog-content h4{text-align:left;text-transform:none;margin-top:1.8em;color:hsl(var(--primary))}
.blog-content h2{font-size:1.9rem}
.blog-content h3{font-size:1.5rem}
.blog-content p{margin:0 0 1em}
.blog-content a{color:hsl(var(--primary));text-decoration:underline;text-underline-offset:3px}
.blog-content img{margin:1.5em auto;border-radius:14px}
.blog-content ul,.blog-content ol{padding-left:1.4em;margin:0 0 1em}
.blog-content li{margin-bottom:.4em}
.blog-content blockquote{border-left:3px solid hsl(var(--primary));padding:.4em 1em;margin:1.4em 0;color:hsl(var(--muted-fg));font-style:italic}

/* Blog – video & embed support */
.blog-content iframe,
.blog-content video,
.blog-content embed,
.blog-content object{display:block;max-width:100%;width:100%;aspect-ratio:16/9;height:auto;border:0;border-radius:14px;margin:1.5em auto;background:#000;box-shadow:var(--shadow-elegant)}
.blog-content figure{margin:1.5em 0}
.blog-content figure iframe,.blog-content figure video{margin:0}
.blog-content .video-embed,
.blog-content .embed-responsive,
.blog-content .oembed{position:relative;width:100%;aspect-ratio:16/9;margin:1.5em auto;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-elegant);background:#000}
.blog-content .video-embed iframe,
.blog-content .embed-responsive iframe,
.blog-content .oembed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:0;margin:0}
