:root{--pink:#ef858c;--pink-soft:#fbe2e2;--green:#688f64;--green-dark:#4f754d;--green-soft:#edf3e9;--ink:#171919;--muted:#626963;--cream:#fffdf9;--line:#e9e4dc;--shadow:0 14px 38px rgba(65,54,45,.10);--radius:24px;--serif:Georgia,'Times New Roman',serif;--sans:Inter,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--cream);color:var(--ink);font-family:var(--sans);line-height:1.58}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.container{width:min(1180px,calc(100% - 40px));margin:0 auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border-bottom:1px solid rgba(0,0,0,.05)}.header-inner{height:92px;display:flex;align-items:center;gap:28px}.brand{display:flex;align-items:center;margin-right:auto;min-width:178px;height:100%}.brand-logo{display:block;width:auto;height:70px;max-height:calc(100% - 16px);object-fit:contain;object-position:left center}.main-nav{display:flex;align-items:center;gap:34px;font-weight:600}.main-nav a{position:relative;padding:10px 0}.main-nav a:after{content:'';position:absolute;left:0;right:100%;bottom:2px;height:3px;border-radius:10px;background:var(--pink);transition:.2s}.main-nav a:hover:after{right:0}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 24px;border:1px solid transparent;border-radius:13px;font-weight:750;cursor:pointer;transition:.2s;font:inherit}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--pink);color:#fff;box-shadow:0 10px 24px rgba(239,133,140,.28)}.btn-outline{border-color:var(--green);color:var(--green-dark);background:rgba(255,255,255,.75)}.header-cta{white-space:nowrap;background:var(--green);color:#fff;box-shadow:0 10px 24px rgba(104,143,100,.28)}.header-cta:hover{background:var(--green-dark)}.nav-toggle{display:none;border:0;background:none;padding:10px}.nav-toggle span:not(.sr-only){display:block;width:24px;height:2px;background:var(--ink);margin:5px}.hero{position:relative;overflow:hidden;background:linear-gradient(90deg,#fffaf8 0%,#fff 70%)}.hero-grid{display:grid;grid-template-columns:43% 57%;min-height:570px}.hero-copy{display:flex;flex-direction:column;justify-content:center;padding:70px 20px 70px 0;position:relative;z-index:2}.eyebrow{margin:0 0 8px;color:var(--green);font-size:.82rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.hero h1,.section-heading h2,.about h2,.dental h2,.contact h2{font-family:var(--serif);line-height:1.04;margin:0}.hero h1{font-size:clamp(3rem,5.1vw,5.4rem);letter-spacing:-.04em}.hero h1 span{color:var(--pink)}.hero-lead{font-size:1.14rem;max-width:500px;color:#303534;margin:24px 0 0}.hero-actions{display:flex;gap:16px;margin-top:30px}.benefits{display:flex;gap:34px;margin-top:40px;color:var(--green-dark)}.benefits>div{display:flex;align-items:center;gap:10px}.benefits .icon-img{width:30px;height:30px;flex:0 0 30px}.benefits small{font-weight:650;line-height:1.35}.hero-photo{position:relative;min-width:0}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center}.photo-fade{position:absolute;inset:0;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.05) 28%,transparent 55%)}.doodle{position:absolute;right:35px;bottom:15px;color:var(--green);font-size:62px;transform:rotate(-10deg);opacity:.85}.hero-art-left{position:absolute;width:260px;height:220px;border-radius:50%;background:var(--pink-soft);filter:blur(1px);left:-120px;top:-100px}.section-pad{padding:88px 0}.about{background:#fff}.about-grid{display:grid;grid-template-columns:43% 1fr;gap:66px;align-items:center}.about-photo{border-radius:26px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:1.26}.about-photo img{width:100%;height:100%;object-fit:cover}.about-copy h2,.section-heading h2,.dental h2,.contact h2{font-size:clamp(2.3rem,4vw,3.8rem);color:var(--green-dark);letter-spacing:-.03em}.about-copy>p:not(.eyebrow){font-size:1.05rem;color:var(--muted);max-width:650px}.about-points{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}.about-points>div{padding:18px 10px;border-right:1px solid var(--line);text-align:center}.about-points>div:last-child{border-right:0}.about-points img{display:block;width:42px;height:42px;margin:0 auto 7px}.about-points strong,.about-points small{display:block}.about-points small{color:var(--muted)}.pricing{background:linear-gradient(180deg,#fffaf8,#fff)}.row-heading{display:flex;justify-content:space-between;align-items:end;gap:20px}.admin-badge{padding:9px 14px;border:1px solid #cfdcc9;border-radius:10px;background:var(--green-soft);font-size:.85rem;color:var(--green-dark)}.price-cards{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:28px}.price-card{min-height:230px;padding:24px 16px;border:1px solid #eee7df;border-radius:22px;background:#fff;box-shadow:0 8px 22px rgba(60,50,43,.06);text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:space-between}.price-card h3{font-size:1.05rem;line-height:1.25;margin:0}.price-card .dog-icon{width:92px;height:62px;display:flex;align-items:center;justify-content:center}.price-card .dog-icon img{width:100%;height:100%;object-fit:contain}.price-card strong{font-family:var(--serif);font-size:1.55rem;color:var(--green-dark)}.price-card.special{background:linear-gradient(180deg,#fff7f7,var(--pink-soft));border-color:#f4b9bc}.price-card.special p{font-size:.88rem}.paw img{width:27px;height:27px;filter:none}.price-actions{text-align:center;margin-top:28px}.full-price{margin-top:42px;scroll-margin-top:120px}.notes-card{background:var(--green-soft);border:1px solid #d6e3d1;border-radius:18px;padding:22px 28px;color:#40543d;margin-bottom:32px}.notes-card p{margin:6px 0}.notes-card.rules{background:#fff6f4;border-color:#f0d6d2;margin-top:28px;color:#604b46}.price-group{padding:30px 0;border-top:1px solid var(--line)}.price-group-head h3{font-family:var(--serif);font-size:2rem;color:var(--green-dark);margin:0}.price-group-head p{color:var(--muted);margin:6px 0 20px}.price-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.price-row{background:#fff;border:1px solid #ede7df;border-radius:16px;padding:18px 20px;display:flex;justify-content:space-between;gap:25px;align-items:flex-start}.price-row h4{margin:0 0 5px;font-size:1rem}.price-row p{margin:0;color:var(--muted);font-size:.9rem}.price-row strong{color:var(--green-dark);white-space:nowrap;text-align:right}.dental{background:#fff}.dental-panel{display:grid;grid-template-columns:100px 1.2fr 1.3fr 130px;gap:26px;align-items:center;padding:34px;border:1px solid #dce4d8;border-radius:28px;background:linear-gradient(105deg,#f5f8f2,#fff);box-shadow:var(--shadow)}.tooth-icon{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;background:var(--green)}.tooth-icon img{width:48px;height:48px}.dental-copy h2{font-size:2.5rem}.dental-copy p:last-child{color:var(--muted);margin-bottom:0}.dental-prices{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.dental-price{background:#fff;border-radius:16px;padding:20px;text-align:center;box-shadow:0 8px 20px rgba(59,74,55,.08)}.dental-price span,.dental-price strong{display:block}.dental-price span{font-size:.88rem;line-height:1.3}.dental-price strong{font-family:var(--serif);font-size:1.65rem;color:var(--green-dark);margin-top:8px}.dental-doodle{text-align:center}.dental-doodle img{width:92px;height:92px;margin:auto}.contact{background:linear-gradient(145deg,#fff7f5 0%,#fff 45%,#f7faf5 100%)}.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:70px;align-items:center}.contact-intro img{width:220px;height:120px;object-fit:contain;margin-bottom:18px}.contact-intro h2{color:var(--ink)}.contact-intro p{color:var(--muted);max-width:550px}.contact-actions{display:flex;gap:12px;margin-top:26px}.contact-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.contact-card{min-height:128px;padding:22px;border:1px solid #eee4dc;background:rgba(255,255,255,.9);border-radius:18px;display:flex;gap:14px;align-items:flex-start;transition:.2s}.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.contact-card>img{width:29px;height:29px;flex:0 0 29px}.contact-card small,.contact-card strong{display:block}.contact-card small{text-transform:uppercase;letter-spacing:.12em;color:var(--green);font-size:.7rem;font-weight:800}.contact-card strong{font-size:.95rem;margin-top:4px}.site-footer{background:var(--green);color:#fff}.footer-inner{min-height:62px;display:flex;align-items:center;gap:26px}.footer-inner span{margin-right:auto}.footer-inner a{font-weight:700}.admin-link{opacity:.66;font-size:.84rem}@media(max-width:1020px){.main-nav{gap:20px}.header-cta{display:none}.hero-grid{grid-template-columns:1fr;min-height:auto}.hero-copy{padding:58px 0 40px}.hero-photo{height:520px}.photo-fade{background:linear-gradient(180deg,#fff 0%,transparent 24%)}.about-grid{grid-template-columns:1fr;gap:38px}.price-cards{grid-template-columns:repeat(3,1fr)}.dental-panel{grid-template-columns:90px 1fr}.dental-prices{grid-column:1/-1}.dental-doodle{display:none}}@media(max-width:760px){.container{width:min(100% - 28px,1180px)}.header-inner{height:76px}.brand{min-width:86px}.brand-logo{height:54px}.nav-toggle{display:block}.main-nav{position:absolute;left:14px;right:14px;top:76px;display:none;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-radius:16px;padding:12px;box-shadow:var(--shadow)}.main-nav.open{display:flex}.main-nav a{padding:14px}.hero h1{font-size:3rem}.hero-actions,.benefits,.contact-actions{flex-wrap:wrap}.benefits{gap:18px}.hero-photo{height:390px}.section-pad{padding:64px 0}.about-points{grid-template-columns:1fr}.about-points>div{border-right:0;border-bottom:1px solid var(--line)}.price-cards{grid-template-columns:repeat(2,1fr)}.price-card{min-height:210px}.price-list{grid-template-columns:1fr}.price-row{flex-direction:column;gap:10px}.price-row strong{text-align:left}.row-heading{align-items:flex-start;flex-direction:column}.dental-panel{grid-template-columns:1fr;text-align:center;padding:28px 20px}.tooth-icon{margin:auto}.dental-prices{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr;gap:40px}.contact-cards{grid-template-columns:1fr}.footer-inner{padding:18px 0;flex-wrap:wrap}.footer-inner span{width:100%;margin:0}}@media(max-width:440px){.price-cards{grid-template-columns:1fr}.hero h1{font-size:2.55rem}.benefits{display:grid;grid-template-columns:1fr 1fr}.hero-photo{height:320px}}

/* Hero slider – celé původní fotografie bez nechtěného ořezu */
.hero-slider{position:relative;overflow:hidden;background:#eee9e3;isolation:isolate}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;display:grid;place-items:center;opacity:0;visibility:hidden;transition:opacity .7s ease,visibility .7s ease;background:#eee9e3}
.hero-slide.is-active{opacity:1;visibility:visible;z-index:1}
.hero-slide::before{content:"";position:absolute;inset:-28px;background-image:var(--slide-bg);background-size:cover;background-position:center;filter:blur(22px);transform:scale(1.08);opacity:.38}
.hero-photo .hero-slide img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;object-position:center;filter:none}
.hero-slider .photo-fade{z-index:2;pointer-events:none;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.64) 11%,rgba(255,255,255,.08) 28%,transparent 48%)}
.hero-slider .doodle{z-index:3;pointer-events:none}
.hero-slider-arrow{position:absolute;z-index:5;top:50%;width:46px;height:46px;margin-top:-23px;border:1px solid rgba(255,255,255,.78);border-radius:50%;background:rgba(255,255,255,.88);color:var(--green-dark);box-shadow:0 8px 24px rgba(28,34,27,.18);font:500 2rem/1 var(--sans);display:grid;place-items:center;cursor:pointer;transition:transform .2s ease,background .2s ease}
.hero-slider-arrow:hover{transform:scale(1.07);background:#fff}
.hero-slider-prev{left:24px}
.hero-slider-next{right:24px}
.hero-slider-dots{position:absolute;z-index:5;left:50%;bottom:22px;transform:translateX(-50%);display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:999px;background:rgba(255,255,255,.76);box-shadow:0 5px 18px rgba(28,34,27,.12);backdrop-filter:blur(8px)}
.hero-slider-dot{width:9px;height:9px;padding:0;border:0;border-radius:50%;background:rgba(79,117,77,.35);cursor:pointer;transition:width .2s ease,background .2s ease}
.hero-slider-dot.is-active{width:25px;border-radius:999px;background:var(--pink)}
.hero-slider:focus-within .hero-slider-arrow{background:#fff}
@media(max-width:1020px){.hero-slider .photo-fade{background:linear-gradient(180deg,#fff 0%,rgba(255,255,255,.28) 13%,transparent 30%)}.hero-slider-prev{left:16px}.hero-slider-next{right:16px}}
@media(max-width:760px){.hero-slider-arrow{width:40px;height:40px;margin-top:-20px}.hero-slider-prev{left:10px}.hero-slider-next{right:10px}.hero-slider-dots{bottom:14px}.hero-slider .doodle{display:none}}
@media(prefers-reduced-motion:reduce){.hero-slide{transition:none}.hero-slider-arrow,.hero-slider-dot{transition:none}}

/* Varianta B – portrétní fotografie patří do sekce O salonu */
@media (min-width:1021px){
  .about-grid{grid-template-columns:minmax(320px,400px) 1fr;gap:72px}
}
.about-photo{aspect-ratio:2/3;background:#f4efe9}
.about-photo img{width:100%;height:100%;object-fit:cover;object-position:center}
@media(max-width:1020px){
  .about-photo{width:min(100%,460px);margin-inline:auto;aspect-ratio:2/3}
}

/* Fotogalerie salonu */
.gallery{background:linear-gradient(180deg,#fff 0%,#fffaf8 100%);scroll-margin-top:110px}
.gallery-heading{display:flex;justify-content:space-between;align-items:end;gap:40px;margin-bottom:30px}
.gallery-heading>p{max-width:460px;margin:0;color:var(--muted);font-size:1.02rem}
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:350px 350px;gap:18px}
.gallery-item{position:relative;overflow:hidden;border:0;border-radius:24px;padding:0;background:#eee9e3;box-shadow:var(--shadow);cursor:zoom-in;isolation:isolate;text-align:left}
.gallery-item-featured{grid-row:1/3}
.gallery-item::before{content:"";position:absolute;inset:-28px;background-image:var(--gallery-bg);background-size:cover;background-position:center;filter:blur(24px);transform:scale(1.08);opacity:.5;z-index:0}
.gallery-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(18,24,18,.62) 100%);z-index:2;transition:background .25s ease}
.gallery-item img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;transition:transform .35s ease}
.gallery-item span{position:absolute;left:22px;right:22px;bottom:18px;z-index:3;color:#fff;font-weight:800;font-size:1rem;text-shadow:0 2px 10px rgba(0,0,0,.35)}
.gallery-item:hover img,.gallery-item:focus-visible img{transform:scale(1.025)}
.gallery-item:hover::after,.gallery-item:focus-visible::after{background:linear-gradient(180deg,transparent 38%,rgba(18,24,18,.72) 100%)}
.gallery-item:focus-visible{outline:4px solid rgba(239,133,140,.45);outline-offset:3px}

.gallery-lightbox{width:min(1180px,calc(100vw - 34px));max-width:none;padding:0;border:0;border-radius:24px;background:transparent;overflow:visible}
.gallery-lightbox::backdrop{background:rgba(16,18,16,.86);backdrop-filter:blur(8px)}
.gallery-lightbox-inner{position:relative;display:grid;place-items:center;min-height:min(84vh,900px);padding:44px 74px 52px;border-radius:24px;background:#111511;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.gallery-lightbox figure{margin:0;display:grid;place-items:center;gap:14px;max-width:100%}
.gallery-lightbox figure img{max-width:100%;max-height:75vh;width:auto;height:auto;object-fit:contain;border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.35)}
.gallery-lightbox figcaption{color:#fff;font-weight:700;text-align:center}
.gallery-lightbox-close,.gallery-lightbox-arrow{position:absolute;z-index:2;border:0;border-radius:50%;background:rgba(255,255,255,.9);color:var(--green-dark);display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 28px rgba(0,0,0,.25)}
.gallery-lightbox-close{top:16px;right:16px;width:44px;height:44px;font:500 2rem/1 var(--sans)}
.gallery-lightbox-arrow{top:50%;width:48px;height:48px;margin-top:-24px;font:500 2.2rem/1 var(--sans)}
.gallery-lightbox-prev{left:16px}.gallery-lightbox-next{right:16px}
.gallery-lightbox-close:hover,.gallery-lightbox-arrow:hover{background:#fff;transform:scale(1.05)}

@media(max-width:1020px){
  .gallery-grid{grid-template-rows:300px 300px}
  .gallery-heading{align-items:flex-start}
}
@media(max-width:760px){
  .gallery-heading{display:block}
  .gallery-heading>p{margin-top:14px}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:14px}
  .gallery-item,.gallery-item-featured{grid-row:auto;aspect-ratio:1/1}
  .gallery-item:last-child{aspect-ratio:3/2}
  .gallery-lightbox-inner{min-height:72vh;padding:58px 18px 64px}
  .gallery-lightbox-arrow{top:auto;bottom:12px}
  .gallery-lightbox-prev{left:calc(50% - 62px)}
  .gallery-lightbox-next{right:calc(50% - 62px)}
  .gallery-lightbox figure img{max-height:66vh}
}
@media(prefers-reduced-motion:reduce){.gallery-item img{transition:none}}

/* Mobilní oprava kompletního ceníku a fotografie v sekci O salonu */
.full-price,
.price-group,
.price-list,
.price-row,
.price-row > div {
  min-width: 0;
  max-width: 100%;
}

@media (max-width: 760px) {
  /* Portrétní fotografie na mobilu nezabírá místo. */
  .about-photo {
    display: none;
  }

  .about-grid {
    display: block;
  }

  /* Kompletní ceník se nesmí roztáhnout mimo displej. */
  .full-price {
    width: 100%;
    max-width: 100%;
    margin-top: 32px;
    overflow: hidden;
  }

  .price-group {
    width: 100%;
    max-width: 100%;
    padding: 24px 0;
  }

  .price-group-head h3 {
    font-size: 1.65rem;
    overflow-wrap: anywhere;
  }

  .price-list {
    width: 100%;
    max-width: 100%;
    grid-template-columns: minmax(0, 1fr);
  }

  .price-row {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 16px;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
  }

  .price-row > div,
  .price-row h4,
  .price-row p,
  .price-row strong,
  .notes-card,
  .notes-card p {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: normal;
  }

  .price-row strong {
    white-space: normal;
    text-align: left;
  }

  .notes-card {
    width: 100%;
    padding: 18px 16px;
  }
}

@media (max-width: 560px) {
  .price-cards {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* Oprava nežádoucího rámečku kolem loga v desktopové hlavičce */
.brand,
.brand:hover,
.brand:active,
.brand:focus,
.brand:focus-visible,
.brand-logo {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  text-decoration: none !important;
}

.brand-logo {
  border-radius: 0 !important;
}

/* =========================================================
   Jemné animace při scrollování
   ========================================================= */
.site-header {
  transition: background-color .28s ease, box-shadow .28s ease, border-color .28s ease;
}

@media (min-width: 761px) {
  .site-header .header-inner,
  .site-header .brand-logo {
    transition: height .28s ease, max-height .28s ease;
  }

  .site-header.is-scrolled {
    background: rgba(255, 255, 255, .985);
    border-bottom-color: rgba(79, 117, 77, .13);
    box-shadow: 0 10px 30px rgba(55, 64, 51, .09);
  }

  .site-header.is-scrolled .header-inner {
    height: 76px;
  }

  .site-header.is-scrolled .brand-logo {
    height: 57px;
    max-height: 60px;
  }
}

.scroll-progress {
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  pointer-events: none;
  transform: scaleX(0);
  transform-origin: left center;
  background: linear-gradient(90deg, var(--green), var(--pink));
  box-shadow: 0 1px 8px rgba(104, 143, 100, .22);
  will-change: transform;
}

.main-nav a.is-active::after {
  right: 0;
}

/* Třídy přidává JavaScript až po načtení stránky, takže obsah zůstává
   dostupný i při vypnutém JavaScriptu. */
.reveal-on-scroll {
  opacity: 0;
  transform: translate3d(0, 28px, 0);
  transition:
    opacity .72s cubic-bezier(.2, .7, .2, 1),
    transform .72s cubic-bezier(.2, .7, .2, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}

.reveal-on-scroll.reveal-left {
  transform: translate3d(-34px, 0, 0);
}

.reveal-on-scroll.reveal-right {
  transform: translate3d(34px, 0, 0);
}

.reveal-on-scroll.reveal-scale {
  transform: translate3d(0, 22px, 0) scale(.965);
}

.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

/* Jemný živý efekt u fotografií bez změny rozvržení. */
.about-photo,
.gallery-item,
.hero-photo {
  transform: translateZ(0);
}

.about-photo img,
.gallery-item img {
  will-change: transform;
}

.about-photo.is-visible img {
  animation: salon-photo-settle 1.15s cubic-bezier(.2, .7, .2, 1) both;
}

@keyframes salon-photo-settle {
  from { transform: scale(1.035); }
  to { transform: scale(1); }
}

@media (max-width: 760px) {
  .scroll-progress {
    height: 2px;
  }

  .reveal-on-scroll,
  .reveal-on-scroll.reveal-left,
  .reveal-on-scroll.reveal-right,
  .reveal-on-scroll.reveal-scale {
    transform: translate3d(0, 20px, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-header,
  .site-header .header-inner,
  .site-header .brand-logo,
  .reveal-on-scroll,
  .about-photo img {
    transition: none !important;
    animation: none !important;
  }

  .reveal-on-scroll {
    opacity: 1 !important;
    transform: none !important;
  }

  .scroll-progress {
    display: none;
  }
}


/* =========================================================
   Desktopová dynamika V2 – viditelnější pohyb při scrollování
   Aktivuje se na obrazovkách od 900 px, bez závislosti na typu myši.
   ========================================================= */
@media (min-width: 900px) {
  body.desktop-motion-v2 {
    --motion-ease: cubic-bezier(.2, .72, .22, 1);
  }

  body.desktop-motion-v2 .hero-copy {
    transform: translate3d(
      var(--hero-copy-x, 0px),
      var(--hero-copy-y, 0px),
      0
    );
    transition: transform .16s linear;
    will-change: transform;
  }

  body.desktop-motion-v2 .hero-photo {
    --hero-pointer-x: 0px;
    --hero-pointer-y: 0px;
    --hero-rotate-x: 0deg;
    --hero-rotate-y: 0deg;
    --hero-scroll-y: 0px;
    transform:
      perspective(1100px)
      translate3d(
        var(--hero-pointer-x),
        calc(var(--hero-pointer-y) + var(--hero-scroll-y)),
        0
      )
      rotateX(var(--hero-rotate-x))
      rotateY(var(--hero-rotate-y));
    transform-style: preserve-3d;
    transition: transform .18s ease-out, box-shadow .35s ease;
    box-shadow: 0 22px 52px rgba(55, 64, 51, .12);
    will-change: transform;
  }

  body.desktop-motion-v2 .hero-photo:hover {
    box-shadow: 0 34px 82px rgba(55, 64, 51, .22);
  }

  body.desktop-motion-v2 .hero-slides {
    animation: hejny-hero-breathe 7s ease-in-out infinite;
    transform-origin: center;
  }

  body.desktop-motion-v2 .hero-art-left {
    transform: translate3d(var(--art-x, 0px), var(--art-y, 0px), 0);
    transition: transform .2s ease-out;
    animation: hejny-art-float 8s ease-in-out infinite;
    will-change: transform;
  }

  body.desktop-motion-v2 .doodle {
    animation: hejny-doodle-float 4.8s ease-in-out infinite;
  }

  body.desktop-motion-v2 .benefits > div {
    transition: transform .28s var(--motion-ease);
  }

  body.desktop-motion-v2 .benefits > div:hover {
    transform: translateY(-7px);
  }

  body.desktop-motion-v2 .benefits > div:nth-child(1) .icon-img {
    animation: hejny-small-float 3.8s ease-in-out infinite;
  }

  body.desktop-motion-v2 .benefits > div:nth-child(2) .icon-img {
    animation: hejny-small-float 3.8s .45s ease-in-out infinite;
  }

  body.desktop-motion-v2 .benefits > div:nth-child(3) .icon-img {
    animation: hejny-small-float 3.8s .9s ease-in-out infinite;
  }

  body.desktop-motion-v2 .about-photo.reveal-on-scroll.is-visible,
  body.desktop-motion-v2 .gallery-item.reveal-on-scroll.is-visible,
  body.desktop-motion-v2 .price-card.reveal-on-scroll.is-visible,
  body.desktop-motion-v2 .dental-panel,
  body.desktop-motion-v2 .contact-card {
    --motion-scroll-y: 0px;
    transform: translate3d(0, var(--motion-scroll-y), 0);
    transition:
      transform .2s linear,
      box-shadow .32s ease,
      border-color .32s ease;
    will-change: transform;
  }

  body.desktop-motion-v2 .about-photo.reveal-on-scroll.is-visible:hover {
    transform: translate3d(0, calc(var(--motion-scroll-y) - 10px), 0) rotate(-.55deg);
    box-shadow: 0 28px 64px rgba(65, 54, 45, .19);
  }

  body.desktop-motion-v2 .about-photo img {
    transition: transform .7s var(--motion-ease);
  }

  body.desktop-motion-v2 .about-photo:hover img {
    transform: scale(1.035);
  }

  body.desktop-motion-v2 .gallery-item.reveal-on-scroll.is-visible:hover {
    transform: translate3d(0, calc(var(--motion-scroll-y) - 12px), 0) scale(1.012);
    box-shadow: 0 28px 66px rgba(55, 64, 51, .2);
  }

  body.desktop-motion-v2 .gallery-item img {
    transition: transform .75s var(--motion-ease);
  }

  body.desktop-motion-v2 .gallery-item:hover img {
    transform: scale(1.065);
  }

  body.desktop-motion-v2 .price-card.reveal-on-scroll.is-visible {
    --card-rx: 0deg;
    --card-ry: 0deg;
    --card-hover-y: 0px;
    transform:
      perspective(820px)
      translate3d(
        0,
        calc(var(--motion-scroll-y) + var(--card-hover-y)),
        0
      )
      rotateX(var(--card-rx))
      rotateY(var(--card-ry));
    transform-style: preserve-3d;
    transition:
      transform .18s ease-out,
      box-shadow .3s ease,
      border-color .3s ease;
  }

  body.desktop-motion-v2 .price-card.reveal-on-scroll.is-visible:hover {
    --card-hover-y: -14px;
    border-color: rgba(239, 133, 140, .5);
    box-shadow: 0 28px 62px rgba(60, 50, 43, .17);
  }

  body.desktop-motion-v2 .price-card .dog-icon {
    transform: translateZ(22px);
    animation: hejny-dog-float 4.3s ease-in-out infinite;
    transition: transform .28s ease;
  }

  body.desktop-motion-v2 .price-card:nth-child(2) .dog-icon { animation-delay: .35s; }
  body.desktop-motion-v2 .price-card:nth-child(3) .dog-icon { animation-delay: .7s; }
  body.desktop-motion-v2 .price-card:nth-child(4) .dog-icon { animation-delay: 1.05s; }
  body.desktop-motion-v2 .price-card:nth-child(5) .dog-icon { animation-delay: 1.4s; }

  body.desktop-motion-v2 .price-card:hover .dog-icon {
    transform: translateZ(38px) scale(1.09);
  }

  body.desktop-motion-v2 .price-card h3,
  body.desktop-motion-v2 .price-card strong,
  body.desktop-motion-v2 .price-card p,
  body.desktop-motion-v2 .price-card .paw {
    position: relative;
    transform: translateZ(12px);
  }

  body.desktop-motion-v2 .dental-panel:hover {
    transform: translate3d(0, calc(var(--motion-scroll-y) - 9px), 0);
    box-shadow: 0 28px 66px rgba(65, 75, 58, .17);
  }

  body.desktop-motion-v2 .tooth-icon img,
  body.desktop-motion-v2 .dental-doodle img {
    animation: hejny-tooth-float 4.2s ease-in-out infinite;
    transform-origin: center;
  }

  body.desktop-motion-v2 .dental-doodle img {
    animation-delay: .55s;
  }

  body.desktop-motion-v2 .contact-card:hover {
    transform: translate3d(0, calc(var(--motion-scroll-y) - 10px), 0);
    border-color: rgba(104, 143, 100, .38);
    box-shadow: 0 22px 48px rgba(65, 54, 45, .14);
  }

  body.desktop-motion-v2 .about-points > div {
    transition: transform .28s var(--motion-ease);
  }

  body.desktop-motion-v2 .about-points > div:hover {
    transform: translateY(-7px);
  }

  body.desktop-motion-v2 .about-points img {
    transition: transform .35s var(--motion-ease);
  }

  body.desktop-motion-v2 .about-points > div:hover img {
    transform: rotate(-7deg) scale(1.08);
  }

  body.desktop-motion-v2 .btn {
    --magnetic-x: 0px;
    --magnetic-y: 0px;
    transform: translate3d(var(--magnetic-x), var(--magnetic-y), 0);
    transition:
      transform .16s ease-out,
      background-color .2s ease,
      border-color .2s ease,
      box-shadow .2s ease;
    will-change: transform;
  }

  body.desktop-motion-v2 .btn:hover {
    box-shadow: 0 16px 34px rgba(65, 54, 45, .17);
  }

  @keyframes hejny-hero-breathe {
    0%, 100% { transform: scale(1) translateY(0); }
    50% { transform: scale(1.018) translateY(-5px); }
  }

  @keyframes hejny-art-float {
    0%, 100% { margin-top: 0; }
    50% { margin-top: -12px; }
  }

  @keyframes hejny-doodle-float {
    0%, 100% { translate: 0 0; rotate: 0deg; }
    50% { translate: 0 -12px; rotate: 4deg; }
  }

  @keyframes hejny-small-float {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-6px) rotate(3deg); }
  }

  @keyframes hejny-dog-float {
    0%, 100% { translate: 0 0; }
    50% { translate: 0 -7px; }
  }

  @keyframes hejny-tooth-float {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-8px) rotate(3deg); }
  }
}

@media (prefers-reduced-motion: reduce) {
  body.desktop-motion-v2 .hero-slides,
  body.desktop-motion-v2 .hero-art-left,
  body.desktop-motion-v2 .doodle,
  body.desktop-motion-v2 .icon-img,
  body.desktop-motion-v2 .dog-icon,
  body.desktop-motion-v2 .tooth-icon img,
  body.desktop-motion-v2 .dental-doodle img {
    animation: none !important;
  }
}
