:root{
  --accent:#1f6fff;
  --accent2:#47a0ff;
  --ink:#f2f6ff;
  --nav-bg:rgba(15,18,25,0.92);
  --calc-bg:rgba(15,18,25,0.9);
  --t:240ms cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box}
html,body{
  margin:0;
  height:100%;
  font-family:Inter,system-ui,sans-serif;
  color:var(--ink);
  background:#0b111a;
  scroll-behavior:smooth;
  overflow-x: hidden;
}
a{text-decoration:none;color:inherit}

/* ===== PRELOADER (okamžitý výskyt loga) ===== */
#preloader {
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at 50% 40%, #111827 0%, #0b0f18 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.6s ease, visibility 0.6s ease;
}

/* fade-out při dokončení */
#preloader.fade-out {
  opacity: 0;
  visibility: hidden;
}

.loader-content {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  opacity: 1;               /* hned viditelné */
  animation: preloader-pulse 2s ease-in-out infinite;
}

.loader-logo {
  width: 280px;
  height: 280px;
  object-fit: contain;
  opacity: 1;               /* hned viditelné */
  filter: drop-shadow(0 0 24px rgba(47,122,255,0.6));
  animation: preloader-glow 2.5s ease-in-out infinite;
}

@keyframes preloader-pulse {
  0%,100% { transform: scale(1); }
  50% { transform: scale(1.12); }
}

@keyframes preloader-glow {
  0%,100% { filter: drop-shadow(0 0 24px rgba(47,122,255,0.6)); }
  50% { filter: drop-shadow(0 0 40px rgba(47,122,255,1)); }
}

/* malé detaily */
body.loading {
  overflow: hidden;
}

/* ===== Navbar ===== */
header {
  position: sticky;
  top: 0;
  z-index: 800;
  backdrop-filter: blur(14px);
  background: var(--nav-bg);
  box-shadow: 0 4px 14px rgba(0,0,0,.45);
  height: 80px;
}

.nav {
  max-width: 1600px;
  margin: 0 auto;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 40px;
  position: relative;
}

/* levá strana - telefon + badge */
.nav-left {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-weight: 800;
  color: #dbe8ff;
  text-shadow: 0 2px 10px rgba(31,111,255,.45);
  flex: 0 0 auto;
}

.phone {
  font-size: 15px;
}

.open-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  padding: 3px 10px;
  backdrop-filter: blur(8px);
  color: #bcd2ff;
  transition: all .3s ease;
  box-shadow: inset 0 0 10px rgba(255,255,255,0.04), 0 0 10px rgba(0,0,0,0.35);
}


/* otevřeno / zavřeno stav */
.open-badge.open {
  background: linear-gradient(90deg,var(--accent),var(--accent2));
  color: #fff;
  box-shadow: 0 0 14px rgba(31,111,255,.5);
  animation: glowPulse 3s ease-in-out infinite;
}
.open-badge.closed {
  background: rgba(255,255,255,0.05);
  color: #ff9b9b;
  border: 1px solid rgba(255,80,80,0.3);
  box-shadow: 0 0 12px rgba(255,80,80,0.25);
}

@keyframes glowPulse {
  0%,100% { box-shadow: 0 0 10px rgba(31,111,255,.25); }
  50% { box-shadow: 0 0 22px rgba(31,111,255,.7); }
}

/* střední část - odkazy */
.nav-center {
  display: flex;
  gap: 18px;
  padding: 10px 24px;
  border-radius: 40px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  margin: 0 auto;
}

.nav-center a {
  font-weight: 600;
  padding: 8px 16px;
  border-radius: 20px;
  transition: all var(--t);
  color: #f2f6ff;
}
.nav-center a:hover,
.nav-center a.active {
  background: linear-gradient(90deg,var(--accent),var(--accent2));
  color: #fff;
  box-shadow: 0 6px 22px rgba(31,111,255,.35);
}

/* pravá část - tlačítko */
.nav-right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex: 0 0 auto;
  gap: 14px;
}

.btn-primary {
  background: linear-gradient(90deg,var(--accent),var(--accent2));
  color: #fff;
  font-weight: 800;
  padding: 12px 26px;
  border-radius: 999px;
  box-shadow: 0 8px 28px rgba(31,111,255,.35);
  transition: transform var(--t);
  flex-shrink: 0;
}
.btn-primary:hover {
  transform: translateY(-2px);
}

/* zarovnání celé navigace do krajů okna */
.nav-left { margin-right: auto; }
.nav-right { margin-left: auto; }
/* ===== HERO ===== */
.hero{
  position:relative;
  height:calc(100vh - 80px);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  padding:0 20px;
  isolation:auto;
  z-index:1;
}
.hero img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(0.92) saturate(1.05);
  opacity:0;
  transition:opacity 2s ease;
  z-index:1;
}
.hero img.active{opacity:1}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.35) 60%,rgba(0,0,0,.45) 100%);
  z-index:2;
  pointer-events:none;
}
.hero-inner{
  position:relative;
  z-index:3;
  width:min(1000px,92vw);
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:22px;
  opacity:1!important;
  transform:none!important;
}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.14em;
  font-weight:700;
  color:#e3edff;
  text-shadow:0 2px 8px rgba(0,0,0,.35);
}
h1{
  font-size:clamp(40px,5vw,72px);
  font-weight:800;
  line-height:1.05;
  color:#fff;
  text-shadow:0 3px 12px rgba(0,0,0,.55),0 0 24px rgba(0,0,0,.3);
  margin:0 0 20px;
}
h1 small{
  display:block;
  font-size:.55em;
  font-weight:600;
  opacity:.95;
  color:#f1f5ff;
  text-shadow:0 2px 8px rgba(0,0,0,.4);
}
.calc,.hero-call{position:relative;z-index:3}

/* ===== Kalkulačka ===== */
.calc{
  position:relative;
  width:min(1100px,96%);
  background:rgba(255,255,255,0.15);
  border:1px solid rgba(255,255,255,0.25);
  border-radius:18px;
  box-shadow:0 0 25px rgba(0,0,0,0.2),inset 0 1px 0 rgba(255,255,255,0.3);
  padding:28px clamp(24px,3vw,40px);
  margin:0 auto;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  backdrop-filter:blur(16px);
  z-index:3;
}
.calc h2{
  flex:1 1 100%;
  text-align:center;
  margin:0 0 12px;
  font-size:22px;
  font-weight:800;
  color:#f7faff;
  text-shadow:0 2px 12px rgba(0,0,0,0.35);
}
.field{flex:1 1 180px;display:flex;flex-direction:column}
.field label{font-size:13px;color:rgba(255,255,255,0.75);margin-bottom:5px}
.field select,.field input{
  width:100%;height:40px;border-radius:10px;
  border:1px solid rgba(255,255,255,0.25);
  background:rgba(255,255,255,0.9);
  color:#111;font-size:14px;padding:0 12px;
  transition:all 0.25s ease;
}
.field select:focus,.field input:focus{
  outline:none;
  background:#fff;
  border-color:rgba(31,111,255,0.6);
  box-shadow:0 0 0 2px rgba(31,111,255,0.25);
}
.field input::placeholder{color:rgba(0,0,0,0.5)}
.field select option{background:#fff;color:#111}
.slider-wrap{
  flex:2 1 320px;
  text-align:center;
  padding-top:6px;
}
.slider-wrap label{font-size:13px;color:rgba(255,255,255,0.75)}
.slider-wrap input[type=range]{
  width:100%;height:6px;appearance:none;
  background:rgba(255,255,255,0.3);
  border-radius:999px;outline:none;margin:10px 0;
  cursor:pointer;transition:background 0.25s ease;
}
.slider-wrap input[type=range]:hover{background:rgba(255,255,255,0.45)}
.slider-wrap input[type=range]::-webkit-slider-thumb{
  appearance:none;width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,#1f6fff,#47a0ff);
  box-shadow:0 0 10px rgba(31,111,255,0.5),inset 0 1px 1px rgba(255,255,255,0.3);
  transition:all 0.25s ease;
}
.slider-wrap input[type=range]::-webkit-slider-thumb:hover{
  transform:scale(1.08);
  box-shadow:0 0 16px rgba(31,111,255,0.7),inset 0 1px 1px rgba(255,255,255,0.4);
}
.slider-wrap output{
  display:block;
  font-weight:700;
  color:#FFFFFF;
  text-shadow:0 0 12px rgba(47,122,255,0.45);
}
.center-cta{
  flex:1 1 100%;
  display:flex;align-items:center;justify-content:center;
  gap:20px;margin-top:12px;
}
.price{
  font-size:22px;font-weight:800;color:#fff;
  white-space:nowrap;text-shadow:0 2px 10px rgba(0,0,0,0.35);
}
.btn-secondary{
  padding:12px 26px;border-radius:999px;
  background:linear-gradient(90deg,#fff,#eaf2ff);
  color:#1f6fff;font-weight:700;border:none;
  box-shadow:0 6px 20px rgba(31,111,255,0.35),inset 0 1px 0 rgba(255,255,255,0.5);
  transition:all 0.25s ease;
}
.btn-secondary:hover{
  background:linear-gradient(90deg,#1f6fff,#47a0ff);
  color:#fff;
  box-shadow:0 8px 26px rgba(31,111,255,0.5),inset 0 1px 0 rgba(255,255,255,0.2);
  transform:translateY(-2px);
}

/* ===== Telefon (CTA) ===== */
.hero-call {
  position: absolute;
  left: 26px;      /* <-- místo right */
  bottom: 26px;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  background: rgba(15,20,32,.9);
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 8px 22px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(8px);
  transition: transform .2s ease, box-shadow .2s ease;
  z-index: 3;
}
.hero-call:hover{
  transform:translateY(-2px);
  background:linear-gradient(90deg,#1f6fff,#47a0ff);
  border-color:transparent;
  box-shadow:0 14px 36px rgba(31,111,255,.45);
}
.hero-call::after{
  content:"";position:absolute;inset:-6px;border-radius:inherit;
  box-shadow:0 0 0 0 rgba(31,111,255,.45);
  animation:hero-pulse 1.8s ease-out infinite;
}
@keyframes hero-pulse{
  0%{box-shadow:0 0 0 0 rgba(31,111,255,.45)}
  70%{box-shadow:0 0 0 18px rgba(31,111,255,0)}
  100%{box-shadow:0 0 0 0 rgba(31,111,255,0)}
}

/* ===== VÝHODY ===== */
.features-rows{
  position:relative;
  z-index:10;
  --bg:#f7f9fe;
  --ink:#0e1b2e;
  --muted:#4b5c79;
  --stripe:#dbe5ff;
  background:var(--bg);
  padding:clamp(56px,7vw,112px) 0;
}
.fr__wrap{
  --padX:clamp(16px,4vw,28px);
  --mediaW:520px;
  --gap:clamp(28px,5vw,64px);
  --iconSize:64px;
  width:min(1200px,92vw);
  margin-inline:auto;
  padding:0 var(--padX);
  display:grid;
  grid-template-columns:minmax(0,1.05fr) var(--mediaW);
  gap:var(--gap);
  align-items:center;
}
.fr__list h2{
  margin:0 0 18px;
  font-size:clamp(24px,3vw,34px);
  color:var(--ink);
}
.fr__list ul{margin:0;padding:0;list-style:none}
.fr__list li{
  position:relative;
  display:grid;
  grid-template-columns:var(--iconSize) 1fr;
  gap:14px;
  align-items:center;
  padding:18px 0;
}
.fr__list li::before,
.fr__list li:first-child::after{
  content:"";
  position:absolute;
  left:calc(-1 * var(--padX));
  right:calc(var(--mediaW) + var(--gap) + var(--padX));
  height:1px;
  background:var(--stripe);
}
.fr__list li::before{bottom:0}
.fr__list li:first-child::after{top:0}
.ico-img{
  width:var(--iconSize);
  height:var(--iconSize);
  display:block;
  object-fit:contain;
}
.fr__list .txt strong{display:block;color:#0e1b2e}
.fr__list .txt p{margin:.25rem 0 0;color:#4b5c79;font-size:14px}

/* === FOTO + BADGE === */
.fr__media{position:relative;min-height:420px}

/* MODRÉ POZADÍ BADGE */
.fr__media .badge{
  position:absolute;
  inset:auto 0 18% 18%;
  aspect-ratio:1/1;
  border-radius:28px;
  background:linear-gradient(135deg,#1f6fff 0%,#47a0ff 50%,#5abaff 100%);
  box-shadow:0 24px 70px rgba(47,122,255,.28);
}

/* TEXTURY UVNITŘ BADGE */
.fr__media .badge::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(
    90deg,
    transparent 0 26%,
    #0b1a3d 26% 49%,
    transparent 49% 51%,
    #0b1a3d 51% 74%,
    transparent 74% 100%
  );
  mix-blend-mode:multiply;
  opacity:.65;
}

/* FOTKA */
.fr__media .photo{
  position:absolute;
  left:0;
  right:12%;
  bottom:0;
  height:64%;
  border-radius:22px;
  overflow:hidden;
  background:#000;
  box-shadow:0 24px 60px rgba(10,30,60,.22);
  transform:translate(0,0);
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.fr__media .photo img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* HOVER INTERAKCE */
.fr__media:hover .photo{
  transform:translate(-6px,-6px);
}

/* bezpečná verze bez ztracení obsahu */
.reveal {
  opacity: 1;
  transform: none;
}
.reveal[data-animate="true"] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal[data-animate="true"].in {
  opacity: 1;
  transform: none;
}

/* ===== PROMO TICKER – modré pozadí, plynulý loop ===== */
.promo-ticker {
  --bg1:#10306b;
  --bg2:#155BDB;
  --ink:#ffffff;
  --ink-dim:#cfe1ff;
  color:var(--ink);
  background:linear-gradient(90deg,var(--bg1),var(--bg2));
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(0,0,0,.25);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  overflow:hidden;
  user-select:none;
}

.ticker-mask {
  position:relative;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
          mask-image:linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
}

.ticker-track {
  display:flex;
  width:max-content;
  gap:4rem;
  padding:12px 0;
  animation:ticker-scroll 28s linear infinite;
}
.promo-ticker:hover .ticker-track { animation-play-state:paused; }

.ticker-segment {
  display:flex;
  align-items:center;
  gap:1.25rem;
  padding-inline:2rem;
  white-space:nowrap;
  font-weight:700;
  letter-spacing:.2px;
}

.ticker-segment .dot {
  opacity:.55;
  color:var(--ink-dim);
  font-size:14px;
}

.ticker-segment .msg { color:var(--ink-dim); font-weight:700; }

.ticker-segment .tel {
  color:#fff;
  font-weight:900;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2);
}

.ticker-segment .cta {
  color:#0b1f42;
  font-weight:900;
  padding:6px 14px;
  border-radius:999px;
  background:linear-gradient(90deg,#ffffff,#e6f0ff);
  border:1px solid #cfe0ff;
  box-shadow:0 6px 18px rgba(31,111,255,.28), inset 0 1px 0 rgba(255,255,255,.6);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
}
.ticker-segment .cta:hover {
  transform:translateY(-1px) scale(1.02);
  background:linear-gradient(90deg,#1f6fff,#47a0ff);
  color:#fff;
  border-color:transparent;
  box-shadow:0 10px 26px rgba(31,111,255,.38);
}

/* animace (zprava → doleva) */
@keyframes ticker-scroll {
  from { transform:translateX(0); }
  to { transform:translateX(-50%); }
}

/* ===== LIVE TRACKING ===== */
.live-tracking {
  --bg:#f3f6fb;
  --ink:#0e1b2e;
  --muted:#4b5c79;
  --accent:#1f6fff;
  --accent2:#47a0ff;
  background:
    radial-gradient(900px 600px at 85% -10%, #eaf2ff 0%, transparent 70%),
    linear-gradient(180deg,#f7faff,#eef4ff 60%, #f3f6fb);
  padding: clamp(56px,7vw,96px) 0;
}

.lt-wrap {
  width:min(1200px,92vw);
  margin-inline:auto;
  display:grid;
  grid-template-columns: 520px 1fr;
  gap: clamp(28px,5vw,64px);
  align-items:center;
}

/* Telefon */
.lt-phone { margin:0; display:flex; justify-content:center; }
.phone-body {
  width:min(360px,80vw);
  aspect-ratio:9/18;
  border-radius:36px;
  background:#0f1420;
  padding:10px;
  box-shadow:0 24px 64px rgba(10,30,60,.22), inset 0 0 0 1px #1b2742;
  position:relative;
}
.phone-notch {
  position:absolute; top:10px; left:50%; transform:translateX(-50%);
  width:40%; height:16px; background:#0f1420;
  border-bottom-left-radius:12px; border-bottom-right-radius:12px;
}
.phone-screen {
  width:100%; height:100%;
  border-radius:28px;
  overflow:hidden;
  background:linear-gradient(180deg,#0e1b2e,#162848);
  display:grid; place-items:center;
}

/* „Mapa“ uvnitř telefonu */
.map {
  position:relative; inset:0; width:100%; height:100%;
  background:
    radial-gradient(600px 300px at 30% 10%, #17305e 0%, transparent 60%),
    linear-gradient(180deg,#0f2a56,#163b73);
}
.road {
  position:absolute;
  background:#bcd3ff55;
  box-shadow:0 0 0 1px #cfe0ff33 inset;
}
.road.r1 { left:10%; right:10%; top:28%; height:6px; border-radius:4px; }
.road.r2 { left:64%; top:10%; bottom:10%; width:6px; border-radius:4px; }
.road.r3 { left:26%; right:26%; top:58%; height:6px; border-radius:4px; }

/* Marker + ping animace */
.marker {
  position:absolute;
  left:64%;
  top:28%;
  transform:translate(-50%,-50%);
}
.marker .car {
  width:16px; height:16px; display:block; border-radius:50%;
  background:linear-gradient(180deg,#ffffff,#e6f0ff);
  border:1px solid #cfe0ff;
  box-shadow:0 4px 10px rgba(0,0,0,.35);
}
.marker .ping {
  position:absolute; inset:0; border-radius:50%;
  box-shadow:0 0 0 0 rgba(71,160,255,.55);
  animation:ping 1.8s ease-out infinite;
}
@keyframes ping {
  0%   { box-shadow:0 0 0 0 rgba(71,160,255,.55); }
  70%  { box-shadow:0 0 0 16px rgba(71,160,255,0); }
  100% { box-shadow:0 0 0 0 rgba(71,160,255,0); }
}

/* Stavové štítky */
.chips {
  position:absolute;
  left:12px;
  bottom:12px;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.chip {
  font-size:12px; font-weight:800; color:#0e2a56;
  padding:6px 10px;
  border-radius:999px;
  background:linear-gradient(180deg,#ffffff,#f0f6ff);
  border:1px solid #cfe0ff;
  box-shadow:inset 0 1px 0 #fff8;
}

/* Pravá strana – text */
.lt-copy h2 {
  margin:0 0 10px;
  font-size:clamp(26px,3.2vw,36px);
  line-height:1.1;
  font-weight:900;
  color:var(--ink);
}
.lt-copy .lead {
  margin:0 0 12px;
  color:var(--muted);
  font-size:clamp(16px,1.4vw,18px);
}
.benefits { margin:12px 0 18px; padding-left:18px; color:#2a3e63; }
.benefits li { margin:.3rem 0; }

.actions {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin:6px 0 6px;
}
.btn-secondary {
  padding:11px 18px;
  border-radius:999px;
  border:1px solid #cfe0ff;
  background:linear-gradient(180deg,#fff,#f6f9ff);
  color:#0e2a56;
  font-weight:800;
  transition:all .25s ease;
}
.btn-secondary:hover {
  background:linear-gradient(90deg,#1f6fff,#47a0ff);
  color:#fff;
  border-color:transparent;
}
.note { margin:10px 0 0; color:#5a6f93; font-size:13px; }

/* Reveal efekt (scroll in) */
.live-tracking .reveal {
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s ease, transform .6s ease;
  transition-delay:calc(var(--d,0)*100ms);
}
.live-tracking .reveal.in {
  opacity:1;
  transform:none;
}

.live-tracking .reveal { opacity:1 !important; transform:none !important; }

/* ===== Pricing 2026 (světlé modré, ladí s brandem) ===== */
.pricing2026 {
  --ink:#0e1b2e;
  --muted:#4b5c79;
  --line:#e6ecf8;
  --bg:#f7f9fe;
  --accent:#1f6fff;
  --accent2:#47a0ff;
  background:var(--bg);
  padding:clamp(56px,7vw,96px) 0;
}

.pr-wrap {
  width:min(1200px,92vw);
  margin-inline:auto;
}

/* Nadpis */
.pr-head {
  text-align:center;
  margin-bottom:clamp(24px,4vw,40px);
  background:none!important;
  box-shadow:none!important;
  border:0!important;
  padding:0!important;
}
.pr-head h2 {
  margin:0 0 6px;
  font-size:clamp(28px,3vw,40px);
  font-weight:900;
  color:var(--ink);
}
.pr-head p {
  margin:8px 0 0;
  color:#4b5c79;
  font-weight:500;
}

/* Grid */
.pr-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2.4vw,22px);
}
@media(max-width:980px){
  .pr-grid{grid-template-columns:1fr;}
}

/* Karta */
.pr-card {
  text-align:center;
  border-radius:22px;
  overflow:hidden;
  position:relative;
  background:linear-gradient(180deg,#fff,#f4f8ff);
  border:1px solid var(--line);
  box-shadow:0 10px 26px rgba(20,40,80,.08);
  padding:16px 16px 18px;
  transition:transform .4s cubic-bezier(.2,.8,.2,1),
             box-shadow .3s ease,
             border-color .3s ease,
             background .3s ease;
  -webkit-tap-highlight-color:transparent;
}
.pr-card .car-img {
  aspect-ratio:16/9;
  border-radius:16px;
  overflow:hidden;
  background:#eef3ff;
}
.pr-card .car-img img {
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .5s ease;
}
.pr-card h3 {
  margin:12px 0 6px;
  font-size:18px;
  font-weight:900;
  color:var(--ink);
}
.pr-card .desc {
  margin:0 0 10px;
  color:var(--muted);
  font-size:14px;
  min-height:40px;
}
.pr-card .price {
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:6px;
  margin-bottom:10px;
}
.pr-card .price .big {
  font-size:28px;
  font-weight:900;
  color:#113366;
}
.pr-card .price .unit {
  color:#345;
  opacity:.8;
  font-weight:700;
}
.pr-card .perks {
  list-style:none;
  padding:0;
  margin:0 0 14px;
  color:#355;
  font-size:14px;
}
.pr-card .perks li {
  margin:.25rem 0;
}

/* CTA Button */
.pr-card .cta {
  display:inline-block;
  font-weight:900;
  letter-spacing:.2px;
  padding:10px 16px;
  border-radius:999px;
  background:linear-gradient(180deg,#fff,#f4f8ff);
  border:1px solid var(--line);
  color:#0e2a56;
  transition:all .25s ease;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
  -moz-tap-highlight-color:transparent;
  -ms-touch-action:manipulation;
  touch-action:manipulation;
}

/* Hover & Active States */
.pr-card:hover {
  transform:translateY(-4px);
  box-shadow:0 18px 42px rgba(20,40,80,.16);
}
.pr-card:hover .car-img img {
  transform:scale(1.06);
}
.pr-card.active {
  border-color:#9bb8ff;
  transform:translateY(-6px);
  box-shadow:0 20px 48px rgba(31,111,255,.18);
}
.pr-card.active::before {
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(180deg,rgba(10,18,33,.14),rgba(10,18,33,.22));
  mix-blend-mode:multiply;
  pointer-events:none;
}
.pr-card.active .price .big {
  color:var(--accent);
}
.pr-card.active .cta {
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  border-color:transparent;
  color:#fff;
  box-shadow:0 10px 26px rgba(31,111,255,.35);
}

/* CTA Hover */
.pr-card .cta:hover {
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  border-color:transparent;
  color:#fff;
  box-shadow:0 10px 28px rgba(31,111,255,.35);
  transform:translateY(-2px) scale(1.05);
}
.pr-card .cta:active {
  transform:scale(0.98);
  filter:brightness(1.05);
}
.pr-card .cta:focus {
  outline:none;
}

/* Platby – ikonky platebních metod */
.payment-methods {
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  margin-top:18px;
  flex-wrap:wrap;
  opacity:0.9;
  -webkit-tap-highlight-color:transparent;
}
.payment-methods img {
  height:22px;
  filter:grayscale(1);
  transition:filter .3s ease, transform .3s ease;
  user-select:none;
  pointer-events:none;
}
.payment-methods img:hover {
  filter:none;
  transform:scale(1.05);
}

/* Reveal efekt */
.pricing2026 .reveal {
  opacity:0;
  transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease;
}
.pricing2026 .reveal.in {
  opacity:1;
  transform:none;
}

/* Poznámky pod ceníkem */
.pricing-notes {
  padding:8px 0 24px;
  background:#f7f9fe;
}
.pricing-notes .notes-wrap {
  width:min(1200px,92vw);
  margin-inline:auto;
  text-align:center;
}
.pricing-notes .disclaimer {
  margin:0 0 8px;
  font-size:12.5px;
  color:#5f6f8e;
}
.pricing-notes .note-list {
  margin:10px auto 0;
  display:inline-block;
  text-align:left;
  list-style-position:inside;
  color:#4b5c79;
  font-size:13.5px;
  line-height:1.55;
}

/* Globální vypnutí šedého kliku na mobilech */
a, button, .cta, .pr-card, .payment-methods img {
  -webkit-tap-highlight-color:transparent !important;
  -moz-tap-highlight-color:transparent !important;
  tap-highlight-color:transparent !important;
}

/* ===== Floating Action Buttons (FAB) ===== */
.fab{
  position:fixed; z-index:900;
  bottom:22px; /* výchozí – přepíšeme u variant */
  width:52px; height:52px; border-radius:999px;
  display:grid; place-items:center;
  color:#e8f0ff;
  background:rgba(12,17,27,.8);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  box-shadow:0 10px 24px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.06);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, opacity .2s ease;
  opacity:0; pointer-events:none; /* zobrazí JS po scrollu (u .fab-up) */
}
.fab:hover{ transform:translateY(-2px); box-shadow:0 16px 34px rgba(0,0,0,.45) }

/* umístění */
.fab-up{ right:22px }
.fab-call{ left:22px; opacity:1; pointer-events:auto }  /* call je vidět ihned */

/* pulsující prstenec kolem telefonu */
.fab-call::after{
  content:""; position:absolute; inset:-6px; border-radius:inherit;
  box-shadow:0 0 0 0 rgba(31,111,255,.45);
  animation:fabc-pulse 1.8s ease-out infinite;
}
@keyframes fabc-pulse{
  0%   { box-shadow:0 0 0 0 rgba(31,111,255,.45) }
  70%  { box-shadow:0 0 0 18px rgba(31,111,255,0) }
  100% { box-shadow:0 0 0 0 rgba(31,111,255,0) }
}

/* skryté/viditelné stavy tlačítka nahoru */
.fab-up.is-visible{ opacity:1; pointer-events:auto }




/* === Karty === */
.car-card {
  flex: 1 1 580px;
  max-width: 640px;
  background: linear-gradient(180deg, #ffffff, #f3f6ff);
  border: 1px solid #e6ecf8;
  border-radius: 26px;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(20, 40, 80, 0.1);
  transition: all .35s ease;
  position: relative;
}
.car-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 48px rgba(31, 111, 255, 0.18);
}

/* === Obrázky === */
.car-card .car-media {
  aspect-ratio: 16/9;
  background: #e9f0ff;
  display: grid;
  place-items: center;
}
.car-card .car-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.04);
  transition: transform .6s ease;
}
.car-card:hover .car-media img {
  transform: scale(1.1);
}

/* === Meta === */
.car-meta {
  padding: 20px 24px 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.car-meta h3 {
  margin: 0;
  font-size: 22px;
  font-weight: 900;
  color: #0e1b2e;
}
.car-meta .pill {
  font-size: 14px;
  font-weight: 700;
  color: #18468f;
  background: #eaf2ff;
  border: 1px solid #d3e4ff;
  padding: 6px 14px;
  border-radius: 999px;
}

/* === Overlay (hover) === */
.car-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: radial-gradient(120% 120% at 50% 50%, rgba(0,0,0,.55) 0%, rgba(0,0,0,.85) 100%);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.car-card:hover .car-overlay {
  opacity: 1;
  pointer-events: auto;
}
.overlay-inner {
  color: #fff;
  padding: 24px;
  max-width: 440px;
  text-align: left;
  transform: translateY(12px);
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
}
.car-card:hover .overlay-inner {
  transform: translateY(0);
}
.overlay-inner h4 {
  margin: 0 0 10px;
  font-size: 22px;
  font-weight: 800;
}
.overlay-inner .bullets {
  margin: 0;
  padding-left: 20px;
  font-size: 15px;
  line-height: 1.55;
  color: #e7eeff;
}

/* === Responzivní fix === */
@media (max-width: 980px) {
  .fleet-grid,
  .fleet-grid--wide {
    flex-direction: column;
    align-items: center;
  }
  .car-card {
    max-width: 90%;
  }
}

/* Card */
.car-card{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  background:linear-gradient(180deg,#fff,#f5f8ff);
  border:1px solid #e6ecf8;
  box-shadow:0 10px 26px rgba(20,40,80,.06);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s ease,border-color .35s ease;
  isolation:isolate;
}
.car-card:hover{transform:translateY(-4px);box-shadow:0 18px 42px rgba(20,40,80,.12),0 0 0 1px #cfe0ff inset}

/* Image */
.car-media{
  aspect-ratio:4/3;
  display:grid;
  place-items:end center;
  background:linear-gradient(180deg,#fbfdff,#eef4ff);
}
.car-media img{
  width:88%;object-fit:contain;
  transform:translateY(4%);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),filter .35s ease;
}

/* Meta */
.car-meta{
  padding:10px 12px 14px;
  display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;
}
.car-meta h3{margin:0;font-size:15px;font-weight:800;color:#0e1b2e}
.pill{
  font-size:11px;font-weight:700;color:#18468f;
  background:#eaf2ff;border:1px solid #d3e4ff;
  padding:4px 8px;border-radius:999px;
}

/* Overlay */
.car-overlay{
  position:absolute;inset:0;display:grid;place-items:center;padding:14px;
  background:radial-gradient(140% 100% at 50% 60%,rgba(0,0,0,.62) 0%,rgba(0,0,0,.82) 100%);
  opacity:0;pointer-events:none;transition:opacity .28s ease;
}
.overlay-inner{
  width:min(260px,88%);
  text-align:left;color:#fff;
  transform:translateY(8px);
  transition:transform .32s cubic-bezier(.2,.8,.2,1);
}
.overlay-inner h4{margin:0 0 6px;font-size:18px;font-weight:800}
.bullets{margin:0 0 12px;padding-left:16px;font-size:14px;line-height:1.45;color:#e7eeff}
.bullets li{margin:.2rem 0}

/* CTA */
.btn-ghost{
  display:inline-block;padding:10px 16px;border-radius:999px;
  border:1px solid rgba(255,255,255,.65);color:#fff;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  backdrop-filter:blur(4px);
  font-weight:800;letter-spacing:.2px;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease;
  cursor:pointer;
}
.btn-ghost:hover{
  background:linear-gradient(90deg,#1f6fff,#47a0ff);
  border-color:transparent;
  box-shadow:0 8px 22px rgba(31,111,255,.35);
  transform:translateY(-1px) scale(1.02);
}

/* Hover interakce */
.car-card:hover .car-overlay{opacity:1;pointer-events:auto}
.car-card:hover .overlay-inner{transform:translateY(0)}
.car-card:hover img{transform:translateY(2%) scale(1.04);filter:saturate(1.05) contrast(1.05)}

/* Keyboard toggle */
.sr-only-toggle{
  position:absolute;inset:0;opacity:0;pointer-events:auto;border:0;background:transparent;
}
.sr-only-toggle:focus{outline:2px solid #1f6fff;outline-offset:-6px}


/* ===== MAPA ===== */
.map-wrap{ position:relative; width:100%; height: clamp(280px, 36vw, 420px); }
.map-wrap iframe{
  position:absolute; inset:0; width:100%; height:100%; border:0; filter: grayscale(.2) saturate(1.1) contrast(1.05);
}
.map-wrap .map-gradient{
  position:absolute; inset:auto 0 0 0; height:120px;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(7,12,20,.75) 70%, rgba(7,12,20,1) 100%);
  pointer-events:none;
}

/* ===== FOOTER ===== */
:root{
  --footer-bg: #0b111a;
  --footer-bg-2:#0f141f;
  --footer-ink:#e8f0ff;
  --footer-dim:#a9b6cf;
  --footer-line:#1c2535;
  --accent:#1f6fff; --accent2:#47a0ff;
}

.site-footer{
  background: linear-gradient(180deg,var(--footer-bg-2),var(--footer-bg));
  color: var(--footer-ink);
  padding: 26px 0 24px;
  border-top: 1px solid var(--footer-line);
}
.footer-container{ width:min(1200px,92vw); margin-inline:auto }

/* Top bar */
.footer-top{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding: 8px 0 14px;
}
.phone-pill{
  display:inline-flex; align-items:center; gap:10px;
  color:#dbe8ff; font-weight:900; letter-spacing:.2px;
  background: linear-gradient(180deg,#12203a,#0e1830);
  border:1px solid #233553; padding:10px 16px; border-radius:999px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 8px 20px rgba(0,0,0,.25);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.phone-pill:hover{
  transform: translateY(-1px);
  border-color:#335a9e;
  box-shadow: 0 10px 26px rgba(31,111,255,.25);
}
.socials{ display:flex; align-items:center; gap:10px }
.soc{
  width:38px; height:38px; display:grid; place-items:center; border-radius:12px;
  color:#cfe0ff; background: #121a2a; border:1px solid #223350;
  transition: transform .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.soc:hover{ color:#fff; border-color:#3a62b0; transform: translateY(-1px); box-shadow:0 8px 18px rgba(31,111,255,.25) }

/* lines */
.footer-line{ border:0; height:1px; background: var(--footer-line); margin: 10px 0 16px }

/* middle grid */
.footer-grid{
  display:grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 24px;
}

@media (max-width: 980px){ .footer-grid{ grid-template-columns: 1fr 1fr } }
@media (max-width: 560px){ .footer-grid{ grid-template-columns: 1fr } }

.f-col h4{ margin:0 0 10px; font-size:16px; color:#e7efff; letter-spacing:.3px }
.f-col .list{ list-style:none; padding:0; margin:0; color:var(--footer-dim) }
.f-col .list li{ display:flex; align-items:flex-start; gap:8px; margin: .35rem 0 }
.f-col .list a{ color:#cfe0ff; text-decoration:none }
.f-col .list a:hover{ color:#fff; text-decoration:underline }

.brand{ display:flex; align-items:center; gap:10px; font-weight:900; color:#eaf2ff; margin-bottom:8px }
.brand .mark{
  width:40px; height:40px; border-radius:12px;
  background: radial-gradient(90% 90% at 30% 15%, #7fb0ff 0%, #1f6fff 55%, #1348b6 100%);
  box-shadow: inset 0 0 22px rgba(31,111,255,.28);
  border:1px solid #cfe1ff44;
}
.muted{ color: var(--footer-dim); margin:0 }

/* bottom */
.footer-bottom{
  display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
  padding-top: 8px;
}

/* ===== Rozšířený azure glow kolem sekce ===== */
.azure-glow {
  position: relative;
  z-index: 1;
}

.azure-glow::before {
  content: "";
  position: absolute;
  inset: -200px -25vw; /* větší roztažení – víc do stran i nahoru/dolů */
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(ellipse at center,
      rgba(47, 122, 255, 0.45) 0%,
      rgba(47, 122, 255, 0.15) 25%,
      rgba(47, 122, 255, 0.05) 50%,
      transparent 90%);
  filter: blur(100px);
  opacity: 0.9;
  transition: opacity 0.4s ease, filter 0.4s ease;
}

.azure-glow:hover::before {
  filter: blur(120px);
  opacity: 1;
}

@media(prefers-reduced-motion:reduce){
  .hero img{transition:none}
  .reveal{opacity:1;transform:none;transition:none}
  .ticker-track{ animation:none; }
  .marker .ping { animation:none; }
  .live-tracking .reveal { opacity:1; transform:none; transition:none; }
  .fab, .fab:hover{ transition:none }
  .fab-call::after{ animation:none }
}
@media (max-width:980px){
  .fr__wrap{grid-template-columns:1fr;--mediaW:0px}
  .fr__media{min-height:360px}
  .fr__media .photo{right:10%}
  .lt-wrap { grid-template-columns:1fr; gap:26px; }
  .lt-phone { order:1; }
  .lt-copy { order:2; text-align:center; }
}
@media (max-height:780px){
  .hero-logo{width:260px;height:260px}
  h1{font-size:clamp(32px,5vw,54px)}
  .ticker-track{ padding:10px 0; }
  .ticker-segment{ gap:.9rem; padding-inline:1.2rem; font-weight:800; }
  .ticker-segment .cta{ padding:6px 12px; }
  .ticker-segment .tel{ padding:4px 8px; }
}
@media (max-width:640px){
  .hero-logo{width:240px;height:240px}
  .calc{flex-direction:column;gap:12px}
}
#flotila .car-card:hover {
  transform: perspective(1000px) rotateY(6deg) rotateX(3deg) scale(1.02);
  box-shadow: 0 20px 50px rgba(31,111,255,0.18);
}
#flotila .car-card:hover img {
  transform: scale(1.1);
}
#flotila .fleet-head h2 {
  background: none !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
}

/* Globálně už máš overflow-x hidden, to necháme být */
/* Hamburger defaultně schovaný na desktopu */
.nav-toggle {
  display: none;
  position: relative;
  width: 34px;
  height: 26px;
  margin-left: 16px;
  border: 0;
  background: transparent;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.nav-toggle span {
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: 999px;
  background: #f2f6ff;
  transition: transform .22s ease, opacity .22s ease, top .22s ease;
}
.nav-toggle span:nth-child(1) { top: 4px; }
.nav-toggle span:nth-child(2) { top: 11px; }
.nav-toggle span:nth-child(3) { top: 18px; }

/* Stav otevřený */
.nav.nav-open .nav-toggle span:nth-child(1) {
  top: 11px;
  transform: rotate(45deg);
}
.nav.nav-open .nav-toggle span:nth-child(2) {
  opacity: 0;
}
.nav.nav-open .nav-toggle span:nth-child(3) {
  top: 11px;
  transform: rotate(-45deg);
}

/* =========================
   MOBILNÍ VERZE ≤ 768 px
   ========================= */
@media (max-width: 768px) {

  body {
    font-size: 15px;
    line-height: 1.5;
  }

  /* HEADER / NAVBAR */
  header {
    height: auto;
  }

  .nav {
    max-width: 100%;
    padding: 10px 14px;
    height: auto;
    gap: 10px;
  }

  .nav-left {
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
  }

  .nav-left .phone {
    font-size: 13px;
    font-weight: 600;
  }

  .open-badge {
    font-size: 11px;
    padding: 2px 8px;
  }

  .nav-right {
    gap: 10px;
    margin-left: auto;
  }

  .btn-primary {
    padding: 8px 14px;
    font-size: 13px;
  }

  /* ZOBRAZENÍ HAMBURGERU */
  .nav-toggle {
    display: block;
  }

  /* DESKTOPOVÝ PILL-MENU BAR → DROPDOWN */
  .nav-center {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    margin: 0;
    padding: 8px 14px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: rgba(10, 14, 24, 0.97);
    border-top: 1px solid rgba(255,255,255,0.06);
    box-shadow: 0 18px 40px rgba(0,0,0,0.6);
    max-height: 0;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
    transform: translateY(-6px);
    transition: max-height .25s ease, opacity .22s ease, transform .22s ease;
  }

  .nav-center a {
    border-radius: 999px;
    padding: 9px 12px;
    font-size: 14px;
    text-align: left;
  }

  /* otevřený stav (přidává JS třídou .nav-open na .nav) */
  .nav.nav-open .nav-center {
    max-height: 280px;
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  /* HERO */
  .hero {
    height: auto;
    padding: 90px 16px 40px;
    align-items: stretch;
    justify-content: flex-start;
  }

  .hero-inner {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 18px 14px 16px;
    background: rgba(7, 12, 20, 0.9);
    border-radius: 18px;
    backdrop-filter: blur(10px);
  }

  .hero-inner h1 {
    font-size: 26px;
    margin-bottom: 14px;
  }

  .hero-inner h1 small {
    font-size: 0.7em;
  }

  .eyebrow {
    font-size: 11px;
    letter-spacing: 0.14em;
  }

  .calc {
    width: 100%;
    margin-top: 14px;
    padding: 14px 12px 16px;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .calc h2 {
    font-size: 18px;
    margin-bottom: 8px;
  }

  .calc .field,
  .calc .slider-wrap {
    flex: 1 1 auto;
    width: 100%;
  }

  .field label,
  .slider-wrap label {
    font-size: 13px;
  }

  .field select,
  .field input {
    height: 40px;
    font-size: 14px;
  }

  .center-cta {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-top: 8px;
  }

  .price {
    font-size: 22px;
  }

  .calc .btn-secondary {
    width: 100%;
    text-align: center;
  }

  .hero-call {
    left: auto;
    right: 16px;
    bottom: 16px;
    width: 50px;
    height: 50px;
  }

  /* VÝHODY ("Prečo ísť s nami") */
  .features-rows {
    padding: 40px 0 32px;
  }

  .fr__wrap {
    width: 100%;
    padding: 0 16px;
    display: flex;
    flex-direction: column;
    gap: 28px;
  }

  .fr__list h2 {
    font-size: 22px;
  }

  .fr__list li {
    grid-template-columns: 48px 1fr;
    padding: 14px 0;
  }

  .ico-img {
    width: 40px;
    height: 40px;
  }

  .fr__list .txt strong {
    font-size: 15px;
  }

  .fr__list .txt p {
    font-size: 13px;
  }

  /* šrafované čáry zleva – zkrátit, ať nedělají divnosti */
  .fr__list li::before,
  .fr__list li:first-child::after {
    left: 0;
    right: 0;
  }

  .fr__media {
    min-height: 260px;
  }

  .fr__media .photo {
    left: 0;
    right: 0;
  }

  /* TICKER */
  .promo-ticker .ticker-track {
    font-size: 12px;
    padding: 10px 0;
  }

  .ticker-segment {
    padding-inline: 1.4rem;
    gap: 0.8rem;
  }

  .ticker-segment .cta,
  .ticker-segment .tel {
    padding-inline: 8px;
  }

  /* FLOTILA */
  .fleet-section {
    padding: 52px 0 44px !important;
  }

  .fleet-container {
    width: 100% !important;
    padding-inline: 16px;
  }

  .fleet-head {
    margin-bottom: 26px !important;
  }

  .fleet-head h2 {
    font-size: 24px !important;
  }

  .fleet-head p {
    font-size: 14px !important;
  }

  .fleet-grid,
  .fleet-grid--wide {
    flex-direction: column;
    align-items: stretch;
    gap: 22px !important;
  }

  .car-card,
  .car-card.car-card--xl {
    max-width: 100% !important;
  }

  /* vypnout hover 3D / tilt na mobilech */
  #flotila .car-card,
  #flotila .car-card:hover {
    transform: none !important;
    box-shadow: 0 10px 24px rgba(20, 40, 80, 0.1) !important;
  }

  .car-meta {
    padding: 16px 16px 18px;
  }

  .car-meta h3 {
    font-size: 17px;
  }

  .pill {
    font-size: 12px;
    padding: 4px 10px;
  }

  .overlay-inner {
    width: 90%;
    max-width: 320px;
    font-size: 14px;
  }

  /* LIVE TRACKING */
  .live-tracking {
    padding: 46px 16px 50px;
  }

  .lt-wrap {
    width: 100%;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 24px;
  }

  .lt-phone .phone-body {
    width: 260px;
  }

  .lt-copy {
    text-align: center;
  }

  .lt-copy h2 {
    font-size: 24px;
  }

  .lt-copy .lead {
    font-size: 14px;
  }

  .benefits {
    font-size: 14px;
    max-width: 420px;
    margin: 14px auto 16px;
    text-align: left;
  }

  .actions {
    justify-content: center;
  }

  .note {
    font-size: 12px;
  }

  /* CENNÍK */
  .pricing2026 {
    padding: 52px 0 48px;
  }

  .pr-wrap {
    width: 100%;
    padding-inline: 16px;
  }

  .pr-head h2 {
    font-size: 24px;
  }

  .pr-head p {
    font-size: 14px;
  }

  .pr-grid {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  .pr-card {
    padding: 14px 14px 16px;
  }

  .pr-card h3 {
    font-size: 18px;
  }

  .pr-card .desc,
  .pr-card .perks {
    font-size: 14px;
  }

  .payment-methods img {
    height: 20px;
  }

  .pr-card .cta {
    width: 100%;
    text-align: center;
  }

  /* AZURE GLOW – zmenšit, ať se nebere šířka mimo viewport */
  .azure-glow::before {
    inset: -80px -10vw;
    filter: blur(80px);
  }

  /* MAPA */
  .map-wrap {
    height: 260px;
  }

  .map-wrap iframe {
    height: 260px;
  }

@media (max-width: 768px) {

  /* Footer – text a obsah uprostřed */
  .site-footer {
    padding: 36px 0 26px;
    text-align: center;
  }

  .footer-container {
    width: 100%;
    margin-inline: auto;
    padding-inline: 16px;
  }

  .footer-top {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }

  .phone-pill {
    width: 100%;
    justify-content: center;
  }

  .socials {
    justify-content: center;
  }

  /* GRID → pořád grid, ale centrovaný obsah */
  .footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    text-align: center;
    justify-items: center;      /* děti gridu doprostřed */
  }

  .f-col {
    text-align: center;
  }

  .f-col .list {
    align-items: center;
  }

  .f-col .list li {
    justify-content: center;
  }

  .brand {
    justify-content: center;
  }

  .footer-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-align: center;
  }

  .footer-bottom .legal {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
  }

  .footer-bottom .copy,
  .footer-bottom .legal a {
    font-size: 12px;
  }

  /* Sekce CENÍK – základ */
  #cenik.pricing2026 {
    padding: 48px 0 40px !important;
    text-align: center;
  }

  #cenik .pr-wrap {
    width: 100% !important;
    padding: 0 16px;
    margin: 0 auto;
  }

  /* Nadpis + podnadpis */
  #cenik .pr-head {
    margin-bottom: 24px !important;
  }

  #cenik .pr-head h2 {
    font-size: 24px !important;
    margin-bottom: 8px !important;
  }

  #cenik .pr-head p {
    font-size: 14px !important;
    line-height: 1.5;
    max-width: 420px;
    margin: 0 auto;
  }

  /* Grid → pěkný sloupec karet */
  #cenik .pr-grid {
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 20px;
  }

  /* KARTA – ať se nic neusekává */
  #cenik .pr-card {
    flex: 0 0 auto;
    max-width: 100% !important;
    text-align: left;
    padding: 0 !important;
    overflow: visible !important;   /* tady řešíme ufiknutý obsah */
    display: flex;
    flex-direction: column;
  }

  #cenik .pr-card figure.car-img {
    aspect-ratio: 16 / 9;
  }

  #cenik .pr-card > div {
    padding: 18px 16px 16px !important;
  }

  #cenik .pr-card h3 {
    font-size: 18px !important;
    margin-bottom: 6px !important;
  }

  #cenik .pr-card p {
    font-size: 14px !important;
    margin-bottom: 10px !important;
  }

  #cenik .pr-card ul {
    font-size: 14px !important;
    line-height: 1.5;
  }

  /* Platby – Visa / Mastercard / Apple Pay vždy viditelné */
  #cenik .payment-methods {
    display: flex !important;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 14px;
  }

  #cenik .payment-methods img {
    width: 60px !important;
    height: auto;
    filter: none !important;
    opacity: 1 !important;
  }

  /* Tlačítko dole přes celou šířku */
  #cenik .cta-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 10px 16px;
    margin-top: 10px;
    border-radius: 999px;
  }

  /* Vypnout poskakující reveal animace v ceníku na mobilu */
  #cenik .reveal {
    opacity: 1 !important;
    transform: none !important;
  }
}


