/* ============ Tokens ============ */
:root{
  --orange:#FF5A1F;
  --black:#111111;
  --white:#FFFFFF;
  --muted:#9B9B9B;
  --light:#F5F4F2;
  --maxw:1180px;
  --display:"Fraunces", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --soft-shadow:0 28px 80px rgba(17,17,17,.10);
  --deep-shadow:0 44px 110px rgba(0,0,0,.22);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:110px}
body{
  font-family:var(--sans);
  color:var(--black);
  background:var(--white);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button,input,select,summary,a{font:inherit}
button:focus-visible,a:focus-visible,summary:focus-visible,input:focus-visible,select:focus-visible{
  outline:2px solid var(--orange);outline-offset:4px;
}
h1,h2,h3,h4{font-family:var(--display);font-weight:900;line-height:1;letter-spacing:-.01em}

/* ============ Loading screen ============ */
.loader{
  position:fixed;inset:0;z-index:5000;
  display:flex;align-items:center;justify-content:center;
  background:var(--white);color:var(--black);
  overflow:hidden;transition:transform 1.15s var(--ease), visibility 1.15s;
}
.loader::before{
  content:"";position:absolute;inset:0;background:var(--orange);
  transform:translateY(100%);
  animation:loaderReveal 2.35s var(--ease) forwards;
}
.loader__inner{position:relative;z-index:1;width:min(420px,calc(100vw - 48px));text-align:center}
.loader__logo{
  font-family:var(--display);font-weight:900;font-size:clamp(1.7rem,5vw,3rem);
  display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:26px;
}
.loader__bar{height:8px;border-radius:999px;background:rgba(17,17,17,.12);overflow:hidden}
.loader__bar i{
  display:block;height:100%;width:0;background:var(--black);border-radius:999px;
  animation:loaderBar 2.45s var(--ease) forwards;
}
.loader.is-done{transform:translateY(-100%);visibility:hidden}
@keyframes loaderReveal{0%{transform:translateY(100%)}72%,100%{transform:translateY(0)}}
@keyframes loaderBar{0%{width:0}78%{width:88%}100%{width:100%}}

/* ============ Custom cursor ============ */
.cursor{
  position:fixed;top:0;left:0;width:34px;height:34px;
  border-radius:50%;background:rgba(255,90,31,.25);
  border:1.5px solid var(--orange);
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .2s, height .2s, background .2s;
  mix-blend-mode:normal;
}
.cursor.is-hover{width:54px;height:54px;background:rgba(255,90,31,.15)}
@media (hover:none),(max-width:768px){.cursor{display:none}}

/* ============ Navbar ============ */
.nav{
  position:fixed;top:22px;left:50%;transform:translateX(-50%);
  z-index:1000;display:flex;align-items:center;gap:24px;
  background:rgba(255,255,255,.76);backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.55);
  border-radius:999px;padding:12px 14px 12px 24px;
  box-shadow:0 18px 55px rgba(0,0,0,.09);
  max-width:calc(100vw - 32px);
}
.nav__logo{font-family:var(--display);font-weight:900;font-size:1.15rem;display:flex;align-items:center;gap:6px;white-space:nowrap}
.nav__mark{color:var(--orange);transform:rotate(8deg)}
.nav__links{display:flex;gap:20px;font-weight:600;font-size:.95rem}
.nav__links a{position:relative;color:#555;transition:color .28s var(--ease)}
.nav__links a:hover{color:var(--black)}
.nav__links a.is-active{color:var(--orange)}
.nav__links a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-5px;height:2px;border-radius:2px;background:var(--orange)}
.nav__links a[hidden]{display:none}
/* dynamické tečky (sekce s načítáním zprava) */
.nav__progress{display:flex;align-items:center;gap:8px;padding:0 8px}
.nav__progress[hidden]{display:none}
.nav__progress i{width:8px;height:8px;border-radius:50%;background:#cdcbc7;transition:width .45s var(--ease), background .35s var(--ease)}
.nav__progress i.passed{background:var(--orange)}
.nav__progress i.active{width:26px;border-radius:5px;background:var(--orange)}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;font-weight:600;font-size:.95rem;font-family:inherit;
  padding:12px 22px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .32s var(--ease), background .32s var(--ease), color .32s var(--ease), box-shadow .32s var(--ease);white-space:nowrap;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(0,0,0,.12)}
.btn--dark{background:var(--black);color:var(--white)}
.btn--outline{background:transparent;color:var(--black);border-color:var(--black)}
.btn--outline:hover{background:var(--black);color:var(--white)}
.btn--ghost{background:transparent;color:var(--black)}
.btn--lg{padding:17px 38px;font-size:1.05rem}
.btn:active{transform:translateY(0) scale(.98)}

/* ============ Hero ============ */
.hero{
  background:var(--orange);color:var(--black);
  min-height:108svh;padding:170px 20px 92px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.hero__title{font-size:clamp(2.8rem,9vw,7.5rem);margin-bottom:.24em}
.hero__claim{font-size:clamp(1rem,2.2vw,1.5rem);font-weight:500;max-width:660px;line-height:1.45}
.rotator{
  display:inline-block;background:var(--black);color:var(--orange);
  padding:0 .35em;border-radius:8px;min-width:5.5em;text-align:center;
  transition:opacity .25s;
}

/* ---- Telefon ---- */
.phone{
  margin-top:70px;width:300px;height:610px;background:#000;
  max-width:calc(100vw - 56px);
  border-radius:46px;padding:12px;position:relative;
  box-shadow:0 54px 120px rgba(0,0,0,.30);
  animation:phoneFloat 7s var(--ease) infinite alternate;
}
@keyframes phoneFloat{from{transform:translateY(0)}to{transform:translateY(-12px)}}
.phone__notch{position:absolute;top:20px;left:50%;transform:translateX(-50%);
  width:110px;height:26px;background:#000;border-radius:0 0 16px 16px;z-index:3}
.phone__screen{width:100%;height:100%;background:var(--white);border-radius:36px;overflow:hidden;position:relative}

.demo{position:absolute;inset:0;display:flex;flex-direction:column;font-size:.82rem}
.demo__statusbar{display:flex;justify-content:space-between;padding:14px 20px 8px;font-weight:600;font-size:.72rem;color:#666}
.demo__screens{flex:1;position:relative}
.demo__screen{position:absolute;inset:0;padding:8px 18px;opacity:0;transform:translateY(12px);transition:opacity .72s var(--ease), transform .72s var(--ease);display:flex;flex-direction:column;gap:9px}
.demo__screen.is-active{opacity:1;transform:none}
.demo__label{font-family:var(--display);font-weight:900;font-size:1.05rem;margin-bottom:4px}
.demo__card,.demo__row,.demo__ticket{background:var(--light);border-radius:12px;padding:11px 13px;display:flex;flex-direction:column}
.demo__card span{color:var(--muted);font-size:.74rem}
.demo__card--ghost{opacity:.5;border:1.5px dashed #ccc;background:transparent}
.demo__row{flex-direction:row;justify-content:space-between;align-items:center;padding:10px 13px}
.demo__total{display:flex;justify-content:space-between;border-top:1.5px solid #eee;padding-top:10px;margin-top:2px}
.demo__total strong{color:var(--orange)}
.demo__ticket{background:#fff4ef;border-left:3px solid var(--orange)}
.demo__ticket--done{background:var(--light);border-left-color:#bbb;color:var(--muted)}
.demo__pill{display:inline-block;background:#fff;border-radius:8px;padding:3px 8px;margin:5px 5px 0 0;font-size:.72rem}
.demo__big{font-family:var(--display);font-weight:900;font-size:2rem;color:var(--orange)}
.demo__bars{display:flex;align-items:flex-end;gap:7px;height:70px;margin:6px 0}
.demo__bars i{flex:1;background:var(--orange);border-radius:4px 4px 0 0;opacity:.85}
.demo__bars i:nth-child(1){height:40%}.demo__bars i:nth-child(2){height:65%}
.demo__bars i:nth-child(3){height:50%}.demo__bars i:nth-child(4){height:85%}
.demo__bars i:nth-child(5){height:70%}.demo__bars i:nth-child(6){height:95%}
.demo__bars i:nth-child(7){height:60%}
.demo__dots{display:flex;gap:6px;justify-content:center;padding:12px 0 18px}
.demo__dots i{width:6px;height:6px;border-radius:50%;background:#ddd;transition:background .3s,width .3s}
.demo__dots i.is-active{background:var(--orange);width:18px;border-radius:3px}

/* ============ Logos ============ */
.logos{min-height:66vh;display:flex;flex-direction:column;justify-content:center;padding:120px 20px}
.logos__title{text-align:center;color:#3a3a3a;font-weight:600;font-size:1.25rem;margin-bottom:48px}
.marquee{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee__track{display:flex;gap:64px;width:max-content;animation:scroll 28s linear infinite}
.marquee__track span{font-family:var(--display);font-weight:900;font-size:1.4rem;color:#cfcdc9;white-space:nowrap}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ Statement (pinned, pomalé odhalování) ============ */
.statement{background:var(--white)}
.statement__inner{min-height:104vh;display:flex;align-items:center;justify-content:center;padding:120px 24px}
.statement__text{max-width:980px;font-family:var(--display);font-weight:900;font-size:clamp(1.7rem,3.6vw,3rem);line-height:1.22}
.statement__text .word{color:#e2e0db}
.statement__text .word.is-on{color:var(--black)}

/* ============ Sections shared ============ */
.section-title{font-size:clamp(2rem,5vw,3.4rem);text-align:center}
.section-sub{text-align:center;color:var(--muted);margin-top:18px;font-size:1.05rem;line-height:1.7}

/* ============ Features (velké karty, pinned reveal + zoom) ============ */
.features{width:100%;padding:120px 28px;min-height:112vh;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;background:var(--white)}
.features__head{max-width:1480px;width:100%;margin-left:auto;margin-right:auto}
.features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:42px;margin:82px auto 0;max-width:1480px;width:100%}
.card{display:flex;flex-direction:column}
.card__visual{
  background:#F0EDE7;border-radius:34px;aspect-ratio:3/5;min-height:560px;
  display:flex;align-items:center;justify-content:center;padding:30px;overflow:hidden;margin-bottom:26px;position:relative;
  box-shadow:inset 0 0 0 1px rgba(17,17,17,.035);
}
.card h3{font-size:1.65rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.card p{color:#555;font-size:1.05rem;line-height:1.68}
.card--last{transform-origin:center center;will-change:transform}

/* visual: app mock */
.vis-app{background:#15151a;color:#fff;border-radius:18px;padding:20px;width:100%;font-size:.78rem;box-shadow:var(--soft-shadow)}
.vis-app__top{font-family:var(--display);font-weight:900;font-size:1.05rem;margin-bottom:4px}
.vis-app__sub{color:#9a9aa5;margin-bottom:14px}
.vis-app__row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-top:1px solid #2a2a33;color:#cfcfd6}
.vis-app__tag{background:var(--orange);color:#fff;border-radius:999px;padding:2px 10px;font-size:.68rem;font-weight:600}
.vis-app__bar{height:5px;background:#2a2a33;border-radius:3px;margin-top:14px;overflow:hidden}
.vis-app__bar i{display:block;height:100%;width:72%;background:var(--orange);border-radius:3px;animation:fill 2.6s ease-in-out infinite alternate}
@keyframes fill{from{width:35%}to{width:88%}}

/* visual: import progress */
.vis-import{width:100%;text-align:center;color:#3a3a3a}
.vis-import__label{font-family:var(--display);font-weight:900;font-size:1.1rem;margin-bottom:16px}
.vis-import__track{height:8px;background:#dad6cd;border-radius:6px;overflow:hidden}
.vis-import__fill{display:block;height:100%;background:var(--orange);border-radius:6px;width:30%;animation:imp 3s ease-in-out infinite}
@keyframes imp{0%{width:8%}70%{width:96%}100%{width:96%}}
.vis-import__steps{display:flex;gap:8px;justify-content:center;margin:16px 0 10px}
.vis-import__steps i{width:9px;height:9px;border-radius:50%;background:#cfc9bd}
.vis-import__steps i.is-on{background:var(--orange)}
.vis-import__note{font-size:.8rem;color:#7a756a}

/* visual: surfaces (zařízení / kde systém běží) */
.vis-surfaces{display:flex;flex-direction:column;gap:12px;width:100%}
.surf{display:flex;align-items:center;gap:12px;background:#fff;border-radius:16px;padding:15px 17px;font-size:.92rem;font-weight:600;color:#15151a;box-shadow:0 14px 34px rgba(0,0,0,.055);transition:background .45s var(--ease), color .45s var(--ease), transform .45s var(--ease)}
.surf__ico{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;background:#f0ede6;font-size:1rem;flex:0 0 30px;transition:background .3s}
.surf.is-on{background:var(--orange);color:#fff;transform:translateX(4px)}
.surf.is-on .surf__ico{background:rgba(255,255,255,.25)}

/* visual: integrations */
.vis-int{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%}
.vis-int__tile{
  background:#fff;border-radius:16px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;box-shadow:0 14px 32px rgba(0,0,0,.07);
}
.vis-int__tile--brand{background:var(--orange);color:#fff;font-family:var(--display);font-weight:900;font-size:1.6rem}

/* ============ Zoom do poslední karty → černá ============ */
.features__zoom{position:absolute;inset:0;z-index:6;pointer-events:none}
.features__black{position:absolute;inset:-2px;background:#0d0d0f;opacity:0}

/* ============ Stories (tmavá sekce, rozprostřené karty) ============ */
.stories{background:#0d0d0f;color:#fff;padding:130px 24px;overflow:hidden;min-height:108vh;display:flex;flex-direction:column;justify-content:center}
.stories__stage{position:relative;max-width:1100px;width:100%;margin:0 auto;min-height:680px}
.stories__head{text-align:center;position:relative;z-index:1}
.stories__title{font-size:clamp(2.8rem,8vw,6rem);line-height:.96;color:#e4e4e7}
.stories__intro{color:#aaaab3;max-width:560px;margin:30px auto 0;font-size:1.1rem;line-height:1.75}
.stories__intro strong{color:#fff}

.scard{
  position:absolute;z-index:3;width:300px;padding:30px;border-radius:28px;cursor:pointer;
  background:#15151f;border:1px solid #25252f;color:#fff;
  box-shadow:0 34px 84px rgba(0,0,0,.42);transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
  will-change:transform;
}
.scard--left{left:0;top:150px;transform:rotate(-6deg)}
.scard--right{right:0;top:110px;transform:rotate(6deg)}
.scard--center{left:calc(50% - 165px);top:250px;width:330px;background:#101018}
.scard:hover{transform:scale(1.045) rotate(0)!important;box-shadow:0 54px 120px rgba(255,90,31,.22);border-color:var(--orange)}
.scard:focus-visible{outline:2px solid var(--orange);outline-offset:3px}
.scard__brand{font-family:var(--display);font-weight:900;font-size:.92rem;color:var(--orange);letter-spacing:.04em;margin-bottom:14px}
.scard__lead{font-family:var(--display);font-weight:900;font-size:1.45rem;line-height:1.12;margin-bottom:16px}
.scard__hover{max-height:0;overflow:hidden;opacity:0;color:#b6b6c0;font-size:.92rem;line-height:1.62;transition:max-height .45s var(--ease), opacity .45s var(--ease), margin .45s var(--ease)}
.scard:hover .scard__hover,.scard:focus-visible .scard__hover{max-height:140px;opacity:1;margin-bottom:16px}
.scard__cta{display:inline-block;background:var(--orange);color:#fff;font-weight:700;font-size:.9rem;padding:11px 20px;border-radius:999px}
.scard__chips{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.chip{background:#fff;border-radius:13px;padding:11px 15px;font-size:.62rem;letter-spacing:.06em;font-weight:700;color:#8a8a8a;display:flex;flex-direction:column;line-height:1.15;box-shadow:0 14px 30px rgba(0,0,0,.5)}
.chip strong{font-family:var(--display);font-size:1.7rem;color:#111;margin-bottom:3px}
.chip--note{flex-direction:row;align-items:center;gap:9px;color:#111;font-weight:600;letter-spacing:0;text-transform:none;font-size:.86rem}
.chip--note i{width:9px;height:9px;border-radius:50%;background:var(--orange);flex:0 0 9px}

/* ============ Pricing ============ */
.pricing{
  width:100%;max-width:none;margin:0;padding:145px 24px;
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  background:#0d0d0f;position:relative;overflow:hidden;isolation:isolate;
}
.pricing__curtain{
  position:absolute;inset:0;z-index:0;width:auto!important;margin:0!important;
  background:var(--white);transform-origin:bottom center;will-change:transform,border-radius;
}
.pricing::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  z-index:2;background:linear-gradient(90deg,transparent,rgba(17,17,17,.12),transparent);
}
.pricing > :not(.pricing__curtain){width:min(var(--maxw),100%);margin-left:auto;margin-right:auto;position:relative;z-index:1}
.pricing__grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;
  margin-top:72px;margin-bottom:118px;align-items:stretch;
}
.plan{border:1.5px solid #ececec;border-radius:30px;padding:42px 34px;display:flex;flex-direction:column;gap:10px;position:relative;background:var(--white);min-height:100%;box-shadow:0 18px 48px rgba(0,0,0,.035);transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease)}
.plan--featured{border-color:var(--orange);border-width:2px;box-shadow:0 34px 85px rgba(255,90,31,.15);transform:translateY(-12px)}
.plan:hover{transform:translateY(-6px);box-shadow:0 30px 75px rgba(0,0,0,.07);border-color:#dedbd5}
.plan--featured:hover{transform:translateY(-18px);box-shadow:0 42px 100px rgba(255,90,31,.18);border-color:var(--orange)}
.plan__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--orange);color:#fff;font-size:.72rem;font-weight:700;padding:5px 14px;border-radius:999px;letter-spacing:.03em}
.plan__name{font-size:1.6rem}
.plan__for{color:var(--muted);font-size:.92rem;margin-bottom:10px;line-height:1.6}
.plan__price{margin:6px 0 14px;display:flex;align-items:baseline;gap:6px}
.plan__price strong{font-family:var(--display);font-weight:900;font-size:2.4rem}
.plan__price span{color:var(--muted)}
.plan__list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:30px}
.plan__list li{padding-left:26px;position:relative;font-size:.95rem}
.plan__list li::before{content:"✓";position:absolute;left:0;color:var(--orange);font-weight:700}
.plan .btn{width:100%;margin-top:auto}
.pricing__note{
  text-align:center;color:var(--muted);font-size:.88rem;line-height:1.6;
  margin-top:0;padding-top:8px;clear:both;
}
.pricing__cta{margin-top:70px;text-align:center;background:var(--light);border-radius:32px;padding:58px 34px}
.pricing__cta h3{font-family:var(--display);font-weight:900;font-size:clamp(1.6rem,3.4vw,2.4rem);margin-bottom:10px}
.pricing__cta p{color:#555;max-width:480px;margin:0 auto 24px}

/* ============ FAQ (tmavá sekce) ============ */
.faq{background:#0d0d0f;color:#fff;padding:145px 24px;min-height:100vh;display:flex;flex-direction:column;justify-content:center}
.faq__title{font-family:var(--display);font-weight:900;font-size:clamp(2rem,5vw,3.4rem);text-align:center;color:#fff}
.faq__sub{text-align:center;color:#8a8a93;margin-top:14px;font-size:1.05rem}
.faq__list{max-width:880px;margin:66px auto 0;display:flex;flex-direction:column;gap:18px}
.faq__item{border-radius:22px;padding:0 30px;transition:background .42s var(--ease)}
.faq__item[open]{background:#17171e}
.faq__item summary{list-style:none;cursor:pointer;font-weight:700;font-size:1.1rem;color:#fff;padding:24px 0;display:flex;align-items:center;gap:16px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item[open] summary{color:var(--orange)}
.faq__icon{position:relative;width:26px;height:26px;flex:0 0 26px;border:1.5px solid #44444e;border-radius:50%}
.faq__item[open] .faq__icon{border-color:var(--orange)}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--orange);top:50%;left:50%;transform:translate(-50%,-50%)}
.faq__icon::before{width:11px;height:2px}
.faq__icon::after{width:2px;height:11px;transition:transform .25s}
.faq__item[open] .faq__icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq__item p{padding:0 0 26px 42px;color:#a7a7b0;max-width:90%;line-height:1.6}

/* ============ Footer (dvě karty + obří e-mail) ============ */
.footer{background:var(--light);padding:42px 24px 0;position:relative;overflow:hidden}
.footer__cards{display:grid;grid-template-columns:1fr 1.6fr;gap:26px;max-width:1180px;margin:0 auto;position:relative;z-index:2}
.footer__brandcard{background:var(--orange);color:#fff;border-radius:32px;padding:42px;display:flex;flex-direction:column;justify-content:space-between;min-height:320px}
.footer__logo{font-family:var(--display);font-weight:900;font-size:1.35rem;display:flex;align-items:center;gap:7px}
.footer__claim{font-family:var(--display);font-weight:900;font-size:1.7rem;line-height:1.1}
.footer__linkscard{background:#fff;border-radius:32px;padding:46px 48px;position:relative;display:flex;flex-direction:column;overflow:hidden}
.footer__mark{position:absolute;top:-30px;right:24px;font-family:var(--display);font-weight:900;font-size:8rem;color:var(--orange);transform:rotate(12deg);line-height:1;opacity:1}
.footer__cols{display:flex;gap:80px;flex:1}
.footer__cols h4{font-family:var(--sans);font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#9b9b9b;margin-bottom:16px}
.footer__cols a{display:block;color:#222;padding:6px 0;font-size:1rem;font-weight:600;transition:color .28s var(--ease), transform .28s var(--ease)}
.footer__cols a:hover{color:var(--orange);transform:translateX(3px)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;margin-top:34px;gap:16px}
.footer__copy{color:#9b9b9b;font-size:.85rem}
.footer__email{font-family:var(--display);font-weight:900;text-align:center;color:#e7e5e0;font-size:clamp(2.2rem,9vw,8rem);line-height:1;letter-spacing:-.02em;margin-top:-10px;white-space:nowrap;position:relative;z-index:1}

/* ============ Cookie ============ */
.cookie{
  position:fixed;left:18px;bottom:18px;z-index:1200;max-width:330px;
  background:var(--white);border-radius:22px;padding:22px;
  box-shadow:var(--deep-shadow);
  transform:translateY(150%);transition:transform .55s var(--ease);
}
.cookie.is-shown{transform:none}
.cookie strong{font-family:var(--display);font-weight:900;font-size:1.05rem;display:block;margin-bottom:6px}
.cookie p{font-size:.86rem;color:#555;margin-bottom:16px}
.cookie__btns{display:flex;gap:10px}
.cookie__btns .btn{flex:1;padding:10px}

/* ============ Reveal animation ============ */
.reveal-up{opacity:0;transform:translateY(42px);filter:blur(8px);transition:opacity .95s var(--ease), transform .95s var(--ease), filter .95s var(--ease)}
.reveal-up.is-in{opacity:1;transform:none;filter:blur(0)}

/* ============ Modal (case study na celou šířku) ============ */
.modal{position:fixed;inset:0;z-index:2000;display:none}
.modal.is-open{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(8,8,10,.7);backdrop-filter:blur(6px);animation:fade .45s var(--ease)}
.modal__panel{position:absolute;inset:0;background:#0d0d0f;color:#fff;overflow-y:auto;animation:slideUp .58s var(--ease)}
.modal__close{position:fixed;top:22px;right:26px;z-index:3;width:46px;height:46px;border-radius:50%;border:none;background:#fff;color:#111;font-size:1.1rem;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.modal__content{max-width:900px;margin:0 auto;padding:110px 28px 100px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.cs__brand{font-family:var(--display);font-weight:900;color:var(--orange);font-size:1rem;letter-spacing:.04em}
.cs__title{font-family:var(--display);font-weight:900;font-size:clamp(2.2rem,5.5vw,4rem);line-height:1.02;margin:14px 0 10px}
.cs__sub{color:#9a9aa5;font-size:1.15rem;max-width:640px}
.cs__stats{display:flex;flex-wrap:wrap;gap:40px;margin:48px 0;padding:36px 0;border-top:1px solid #25252f;border-bottom:1px solid #25252f}
.cs__stat strong{font-family:var(--display);font-weight:900;font-size:3rem;color:var(--orange);display:block;line-height:1}
.cs__stat span{font-size:.72rem;letter-spacing:.06em;color:#8a8a93;font-weight:700}
.cs__block{margin:34px 0}
.cs__block h4{font-family:var(--display);font-weight:900;font-size:1.4rem;margin-bottom:12px}
.cs__block p{color:#bdbdc6;line-height:1.7;font-size:1.05rem}
.cs__quote{font-family:var(--display);font-weight:900;font-size:1.6rem;line-height:1.3;border-left:3px solid var(--orange);padding-left:24px;margin:44px 0;color:#fff}
.cs__cta{display:inline-block;background:var(--orange);color:#fff;font-weight:700;padding:15px 30px;border-radius:999px;margin-top:10px}

/* ============ Demo modal (poptávkový formulář) ============ */
.dmodal{position:fixed;inset:0;z-index:2100;display:none}
.dmodal.is-open{display:block}
.dmodal__backdrop{position:absolute;inset:0;background:rgba(8,8,10,.6);backdrop-filter:blur(6px);animation:fade .45s var(--ease)}
.dmodal__panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(500px,calc(100vw - 32px));max-height:calc(100vh - 40px);overflow-y:auto;background:#fff;color:var(--black);border-radius:32px;padding:44px;box-shadow:0 40px 100px rgba(0,0,0,.38);animation:popIn .52s var(--ease)}
@keyframes popIn{from{opacity:0;transform:translate(-50%,-45%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.dmodal__close{position:absolute;top:18px;right:18px;width:40px;height:40px;border:none;border-radius:50%;background:var(--light);color:#111;font-size:1rem;cursor:pointer;transition:background .2s}
.dmodal__close:hover{background:#e7e4dd}
.dmodal__brand{font-family:var(--display);font-weight:900;color:var(--orange);font-size:.95rem;display:flex;align-items:center;gap:6px}
.dmodal__title{font-family:var(--display);font-weight:900;font-size:2rem;margin:10px 0 8px}
.dmodal__sub{color:#555;margin-bottom:26px;font-size:.98rem;line-height:1.5}
.dform{display:flex;flex-direction:column;gap:15px}
.dform[hidden]{display:none}
.dform label{display:flex;flex-direction:column;gap:7px;font-weight:600;font-size:.88rem;color:#333}
.dform input,.dform select{border:1.5px solid #e2e0db;border-radius:13px;padding:13px 15px;font:inherit;font-weight:500;transition:border-color .28s var(--ease), box-shadow .28s var(--ease);background:#fff;color:var(--black)}
.dform select{appearance:auto;cursor:pointer}
.dform input::placeholder{color:#b3b0a8;font-weight:400}
.dform input:focus,.dform select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 4px rgba(255,90,31,.12)}
.dform input:user-invalid,.dform select:user-invalid{border-color:#e23b2e}
.dform__submit{margin-top:8px;width:100%}
.dform__note{font-size:.76rem;color:#9b9b9b;text-align:center;margin-top:2px}
.dform__done{text-align:center;padding:14px 0 6px}
.dform__check{width:66px;height:66px;border-radius:50%;background:var(--orange);color:#fff;font-size:1.9rem;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.dform__done h3{font-family:var(--display);font-weight:900;font-size:1.7rem;margin-bottom:8px}
.dform__done p{color:#555;margin-bottom:22px;line-height:1.5}

/* ============ Responsive ============ */
@media(max-width:1180px){
  .features__grid{grid-template-columns:repeat(2,1fr);max-width:920px}
  .card__visual{min-height:460px}
}
@media(max-width:980px){
  .features__grid{grid-template-columns:repeat(2,1fr)}
  .footer__cols{gap:56px}
}
@media(max-width:768px){
  .nav{gap:12px;padding:8px 8px 8px 16px}
  .nav__links{display:none}
  .nav__logo{font-size:1rem}
  .nav .btn{padding:10px 16px;font-size:.88rem}
  .hero{min-height:100svh;padding:126px 16px 70px}
  .phone{width:min(292px,calc(100vw - 48px));height:auto;aspect-ratio:300/610}
  /* Funkce: na mobilu bez pinu/zoomu a bez clippingu */
  .features{min-height:auto;overflow:visible;display:block;padding:96px 24px}
  .features__grid{grid-template-columns:1fr;max-width:420px;margin:56px auto 0;gap:42px}
  .card__visual{aspect-ratio:16/11;min-height:280px}
  .features__zoom{display:none}
  /* Stories: z rozprostřených karet uděláme svislý stack */
  .stories__stage{min-height:0}
  .stories__head{padding-top:0;margin-bottom:36px}
  .scard{position:static;width:auto;transform:none;margin:0 auto 18px;max-width:420px}
  .scard--center{left:auto;width:auto}
  .scard:hover{transform:translateY(-4px)}
  /* Footer: karty pod sebou */
  .footer__cards{grid-template-columns:1fr}
  .footer__cols{gap:48px}
  .footer__brandcard{min-height:200px}
  .footer__mark{font-size:5rem}
  .plan--featured{transform:none}
  .plan--featured:hover,.plan:hover{transform:translateY(-4px)}
  .pricing{padding:110px 20px}
  .pricing__grid{gap:22px;margin-top:56px;margin-bottom:82px}
  .pricing__cta{margin-top:52px;padding:42px 24px}
  .faq{padding:110px 20px}
  .faq__item{padding:0 20px}
  .faq__item p{max-width:100%;padding-left:42px}
  .dmodal__panel{padding:34px 24px;border-radius:26px}
}

@media(max-width:420px){
  .nav{max-width:calc(100vw - 20px);width:calc(100vw - 20px);justify-content:space-between}
  .nav__logo{font-size:.92rem}
  .nav .btn{padding:9px 13px;font-size:.82rem}
  .hero__title{font-size:clamp(2.45rem,16vw,4rem)}
  .footer__cols{flex-direction:column;gap:28px}
  .footer__bottom{flex-direction:column;align-items:flex-start}
  .cookie{left:12px;right:12px;bottom:12px;max-width:none}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal-up{opacity:1;transform:none}
  .features{min-height:auto;overflow:visible}
  .features__zoom{display:none}
  .statement__text .word{color:var(--black)}
}
