.mavacka__waiting{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:30px 20px;
  background:linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 50%, #f0f9ff 100%);
  border-radius:20px;
  border:1px solid rgba(14,165,233,.15);
  box-shadow:0 4px 24px rgba(14,165,233,.08);
  min-height:280px;
}

.mavacka__waitingTitle{
  font-size:22px;
  font-weight:700;
  color:#0369a1;
  margin-top:10px;
  letter-spacing:-0.02em;
}

.mavacka__waitingText{
  margin-top:10px;
  font-size:15px;
  color:#475569;
  max-width:320px;
  line-height:1.5;
}

.mavacka__waitingMeta{
  margin-top:16px;
  font-size:13px;
  color:#64748b;
  background:rgba(255,255,255,.7);
  padding:8px 16px;
  border-radius:20px;
  border:1px solid rgba(14,165,233,.1);
}

.mavacka__waitingMeta strong{
  color:#0284c7;
}

.is-hidden{
  display:none !important;
}

.mavacka__spinner{
  position:relative;
  width:80px;
  height:80px;
}

.mavacka__spinner::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:50%;
  border:4px solid rgba(14,165,233,.15);
  border-top-color:#0ea5e9;
  animation:mavackaSpin 1s linear infinite;
}

.mavacka__spinner::after{
  content:'';
  position:absolute;
  inset:8px;
  border-radius:50%;
  background:linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);
  animation:mavackaPulse 2s ease-in-out infinite;
}

@keyframes mavackaSpin{
  from{transform:rotate(0deg);}
  to{transform:rotate(360deg);}
}

@keyframes mavackaPulse{
  0%,100%{transform:scale(1);opacity:0.8;}
  50%{transform:scale(1.08);opacity:1;}
}

.mavacka__spinnerIcon{
  position:absolute;
  inset:16px;
  width:48px;
  height:48px;
  z-index:1;
}

.mavacka__dots::after{
  content:'';
  animation:mavackaDots 1.5s steps(4,end) infinite;
}

@keyframes mavackaDots{
  0%{content:'';}
  25%{content:'.';}
  50%{content:'..';}
  75%{content:'...';}
  100%{content:'';}
}

/* Stav: Přijato - odpočet */
.mavacka__waiting.is-accepted{
  background:linear-gradient(135deg, #ecfdf5 0%, #d1fae5 50%, #ecfdf5 100%);
  border-color:rgba(16,185,129,.2);
  box-shadow:0 4px 24px rgba(16,185,129,.1);
}

.mavacka__waiting.is-accepted .mavacka__spinner::before{
  border-color:rgba(16,185,129,.15);
  border-top-color:#10b981;
}

.mavacka__waiting.is-accepted .mavacka__spinner::after{
  background:linear-gradient(135deg, #10b981 0%, #059669 100%);
}

.mavacka__waiting.is-accepted .mavacka__waitingTitle{
  color:#059669;
}

.mavacka__waiting.is-accepted .mavacka__waitingMeta{
  border-color:rgba(16,185,129,.15);
}

.mavacka__waiting.is-accepted .mavacka__waitingMeta strong{
  color:#059669;
}

.mavacka__countdown{
  display:flex;
  flex-direction:column;
  align-items:center;
  margin-top:20px;
  gap:6px;
}

.mavacka__countdownLabel{
  font-size:13px;
  color:#64748b;
  text-transform:uppercase;
  letter-spacing:0.05em;
}

.mavacka__countdownTime{
  font-size:42px;
  font-weight:800;
  font-variant-numeric:tabular-nums;
  color:#059669;
  line-height:1;
  letter-spacing:-0.02em;
}

.mavacka__countdownTime.is-warning{
  color:#d97706;
}

.mavacka__countdownTime.is-overdue{
  color:#dc2626;
}

.mavacka__countdownHint{
  font-size:12px;
  color:#94a3b8;
  margin-top:4px;
}

/* Zpoždění řidiče */
.mavacka__delay{
  margin-top:24px;
  padding:20px 24px;
  background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  border:2px solid #f59e0b;
  border-radius:16px;
  max-width:320px;
  animation:mavackaDelayPulse 2s ease-in-out infinite;
}

@keyframes mavackaDelayPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.4);}
  50%{box-shadow:0 0 0 8px rgba(245,158,11,0);}
}

.mavacka__delayIcon{
  width:40px;
  height:40px;
  margin:0 auto 12px;
  color:#b45309;
}

.mavacka__delayIcon svg{
  width:100%;
  height:100%;
}

.mavacka__delayTitle{
  font-size:17px;
  font-weight:700;
  color:#92400e;
  margin-bottom:8px;
}

.mavacka__delayText{
  font-size:14px;
  color:#78350f;
  line-height:1.4;
}

.mavacka__delayText strong{
  font-size:18px;
  color:#b45309;
}

.mavacka__delayActions{
  display:flex;
  gap:10px;
  margin-top:16px;
}

.mavacka__delayBtn{
  flex:1;
  padding:12px 16px;
  border:none;
  border-radius:10px;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:transform 0.15s, box-shadow 0.15s;
}

.mavacka__delayBtn:hover{
  transform:translateY(-1px);
}

.mavacka__delayBtn:active{
  transform:translateY(0);
}

.mavacka__delayBtn--accept{
  background:#059669;
  color:#fff;
  box-shadow:0 2px 8px rgba(5,150,105,.3);
}

.mavacka__delayBtn--accept:hover{
  background:#047857;
  box-shadow:0 4px 12px rgba(5,150,105,.4);
}

.mavacka__delayBtn--reject{
  background:#fff;
  color:#dc2626;
  border:2px solid #dc2626;
}

.mavacka__delayBtn--reject:hover{
  background:#fef2f2;
}

/* Stav: Zpoždění aktivní */
.mavacka__waiting.is-delayed{
  background:linear-gradient(135deg, #fffbeb 0%, #fef3c7 50%, #fffbeb 100%);
  border-color:rgba(245,158,11,.25);
  box-shadow:0 4px 24px rgba(245,158,11,.12);
}

.mavacka__waiting.is-delayed .mavacka__spinner::before{
  border-color:rgba(245,158,11,.2);
  border-top-color:#f59e0b;
}

.mavacka__waiting.is-delayed .mavacka__spinner::after{
  background:linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.mavacka__waiting.is-delayed .mavacka__waitingTitle{
  color:#b45309;
}

.mavacka__waiting.is-delayed .mavacka__waitingMeta{
  border-color:rgba(245,158,11,.2);
}

.mavacka__waiting.is-delayed .mavacka__waitingMeta strong{
  color:#b45309;
}

/* Stav: Taxi na místě (čekám) */
.mavacka__waiting.is-arrived{
  background:linear-gradient(135deg, #ede9fe 0%, #ddd6fe 50%, #ede9fe 100%);
  border-color:rgba(139,92,246,.25);
  box-shadow:0 4px 24px rgba(139,92,246,.15);
  animation:mavackaArrivedPulse 1.5s ease-in-out infinite;
}

@keyframes mavackaArrivedPulse{
  0%,100%{box-shadow:0 4px 24px rgba(139,92,246,.15);}
  50%{box-shadow:0 4px 32px rgba(139,92,246,.3);}
}

.mavacka__waiting.is-arrived .mavacka__spinner{
  animation:mavackaArrivedBounce 0.6s ease-in-out infinite;
}

@keyframes mavackaArrivedBounce{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-6px);}
}

.mavacka__waiting.is-arrived .mavacka__spinner::before{
  border-color:rgba(139,92,246,.2);
  border-top-color:#8b5cf6;
  animation:none;
}

.mavacka__waiting.is-arrived .mavacka__spinner::after{
  background:linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
  animation:none;
}

.mavacka__waiting.is-arrived .mavacka__waitingTitle{
  color:#7c3aed;
}

.mavacka__waiting.is-arrived .mavacka__waitingMeta{
  border-color:rgba(139,92,246,.2);
}

.mavacka__waiting.is-arrived .mavacka__waitingMeta strong{
  color:#7c3aed;
}

.mavacka__arrived{
  margin-top:20px;
  padding:20px 24px;
  background:linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
  border-radius:16px;
  color:#fff;
  max-width:280px;
  animation:mavackaArrivedAlert 0.5s ease-out;
}

@keyframes mavackaArrivedAlert{
  0%{transform:scale(0.8);opacity:0;}
  50%{transform:scale(1.05);}
  100%{transform:scale(1);opacity:1;}
}

.mavacka__arrivedIcon{
  width:48px;
  height:48px;
  margin:0 auto 12px;
  background:rgba(255,255,255,.2);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  animation:mavackaArrivedIconPulse 1s ease-in-out infinite;
}

@keyframes mavackaArrivedIconPulse{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.1);}
}

.mavacka__arrivedIcon svg{
  width:28px;
  height:28px;
}

.mavacka__arrivedTitle{
  font-size:20px;
  font-weight:800;
  margin-bottom:8px;
}

.mavacka__arrivedText{
  font-size:15px;
  opacity:.95;
  line-height:1.4;
}

/* Stav: Nabráno - rekapitulace jízdy */
.mavacka__waiting.is-riding{
  background:linear-gradient(135deg, #fdf4ff 0%, #fae8ff 50%, #fdf4ff 100%);
  border-color:rgba(192,38,211,.2);
  box-shadow:0 4px 24px rgba(192,38,211,.1);
}

.mavacka__waiting.is-riding .mavacka__spinner::before{
  border-color:rgba(192,38,211,.15);
  border-top-color:#c026d3;
}

.mavacka__waiting.is-riding .mavacka__spinner::after{
  background:linear-gradient(135deg, #d946ef 0%, #c026d3 100%);
}

.mavacka__waiting.is-riding .mavacka__waitingTitle{
  color:#a21caf;
}

.mavacka__waiting.is-riding .mavacka__waitingMeta{
  border-color:rgba(192,38,211,.15);
}

.mavacka__waiting.is-riding .mavacka__waitingMeta strong{
  color:#a21caf;
}

.mavacka__recap{
  margin-top:20px;
  padding:20px;
  background:#fff;
  border-radius:16px;
  border:1px solid rgba(192,38,211,.15);
  width:100%;
  max-width:320px;
  text-align:left;
}

.mavacka__recapHeader{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
  padding-bottom:12px;
  border-bottom:1px solid #f3e8ff;
}

.mavacka__recapIcon{
  width:32px;
  height:32px;
  background:linear-gradient(135deg, #d946ef 0%, #c026d3 100%);
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
}

.mavacka__recapIcon svg{
  width:18px;
  height:18px;
}

.mavacka__recapTitle{
  font-size:16px;
  font-weight:700;
  color:#a21caf;
}

.mavacka__recapRoute{
  position:relative;
  padding-left:20px;
}

.mavacka__recapRoute::before{
  content:'';
  position:absolute;
  left:5px;
  top:8px;
  bottom:8px;
  width:2px;
  background:linear-gradient(to bottom, #22c55e, #c026d3, #ef4444);
  border-radius:1px;
}

.mavacka__recapStop{
  position:relative;
  padding:8px 0;
}

.mavacka__recapStopDot{
  position:absolute;
  left:-20px;
  top:12px;
  width:12px;
  height:12px;
  border-radius:50%;
  background:#c026d3;
  border:2px solid #fff;
  box-shadow:0 0 0 2px rgba(192,38,211,.2);
}

.mavacka__recapStop--start .mavacka__recapStopDot{
  background:#22c55e;
  box-shadow:0 0 0 2px rgba(34,197,94,.2);
}

.mavacka__recapStop--end .mavacka__recapStopDot{
  background:#ef4444;
  box-shadow:0 0 0 2px rgba(239,68,68,.2);
}

.mavacka__recapStopLabel{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:#94a3b8;
  margin-bottom:2px;
}

.mavacka__recapStopValue{
  font-size:14px;
  font-weight:500;
  color:#334155;
  line-height:1.3;
}

.mavacka__recapPrice{
  margin-top:16px;
  padding-top:12px;
  border-top:1px solid #f3e8ff;
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.mavacka__recapPriceLabel{
  font-size:13px;
  color:#64748b;
}

.mavacka__recapPriceValue{
  font-size:18px;
  font-weight:700;
  color:#a21caf;
}

.mavacka__recapChange{
  margin-top:12px;
  padding:10px 12px;
  background:#fef3c7;
  border:1px solid #f59e0b;
  border-radius:8px;
  display:flex;
  align-items:center;
  gap:8px;
  animation:mavackaRecapChangePulse 2s ease-in-out infinite;
}

@keyframes mavackaRecapChangePulse{
  0%,100%{opacity:1;}
  50%{opacity:0.7;}
}

.mavacka__recapChangeIcon{
  width:20px;
  height:20px;
  background:#f59e0b;
  border-radius:50%;
  color:#fff;
  font-size:14px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
}

.mavacka__recapChangeText{
  font-size:13px;
  font-weight:600;
  color:#92400e;
}

/* Stav: Dokončeno - poděkování */
.mavacka__waiting.is-finished{
  background:linear-gradient(135deg, #f0fdf4 0%, #dcfce7 50%, #f0fdf4 100%);
  border-color:rgba(34,197,94,.2);
  box-shadow:0 4px 24px rgba(34,197,94,.12);
}

.mavacka__waiting.is-finished .mavacka__spinner{
  display:none;
}

.mavacka__waiting.is-finished .mavacka__waitingTitle{
  color:#16a34a;
}

.mavacka__waiting.is-finished .mavacka__waitingMeta{
  border-color:rgba(34,197,94,.15);
}

.mavacka__waiting.is-finished .mavacka__waitingMeta strong{
  color:#16a34a;
}

.mavacka__finished{
  width:100%;
  max-width:340px;
  text-align:center;
}

.mavacka__finishedIcon{
  width:72px;
  height:72px;
  margin:0 auto 16px;
  background:linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  animation:mavackaFinishedPop 0.5s ease-out;
}

@keyframes mavackaFinishedPop{
  0%{transform:scale(0);opacity:0;}
  50%{transform:scale(1.2);}
  100%{transform:scale(1);opacity:1;}
}

.mavacka__finishedIcon svg{
  width:40px;
  height:40px;
}

.mavacka__finishedTitle{
  font-size:28px;
  font-weight:800;
  color:#16a34a;
  margin-bottom:8px;
}

.mavacka__finishedText{
  font-size:15px;
  color:#64748b;
  margin-bottom:20px;
}

.mavacka__finishedCard{
  background:#fff;
  border-radius:16px;
  border:1px solid rgba(34,197,94,.15);
  padding:16px;
  text-align:left;
  margin-bottom:16px;
}

.mavacka__finishedCardTitle{
  font-size:13px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:#64748b;
  margin-bottom:12px;
}

.mavacka__finishedRoute{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.mavacka__finishedRouteItem{
  display:flex;
  gap:8px;
}

.mavacka__finishedRouteLabel{
  font-size:13px;
  color:#94a3b8;
  min-width:50px;
}

.mavacka__finishedRouteValue{
  font-size:14px;
  font-weight:500;
  color:#334155;
  flex:1;
}

.mavacka__finishedDivider{
  height:1px;
  background:#e2e8f0;
  margin:12px 0;
}

.mavacka__finishedMeta{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.mavacka__finishedMetaItem{
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.mavacka__finishedMetaLabel{
  font-size:13px;
  color:#64748b;
}

.mavacka__finishedMetaValue{
  font-size:14px;
  font-weight:600;
  color:#334155;
}

.mavacka__finishedMetaItem--price .mavacka__finishedMetaValue{
  font-size:20px;
  font-weight:800;
  color:#16a34a;
}

.mavacka__finishedBtn{
  width:100%;
  padding:14px 20px;
  background:linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  color:#fff;
  border:none;
  border-radius:12px;
  font-size:16px;
  font-weight:700;
  cursor:pointer;
  transition:transform 0.15s, box-shadow 0.15s;
  box-shadow:0 4px 12px rgba(34,197,94,.3);
}

.mavacka__finishedBtn:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(34,197,94,.4);
}

.mavacka__finishedBtn:active{
  transform:translateY(0);
}

/* Base theme */
:root {
  --bg: #000000;
  --fg: #f8fafc;
  --muted: #64748b;
  --link: #2563eb;
  --border: #e2e8f0;
  --soft: #f8fafc;
  --ok: #16a34a;
  --warn: #f59e0b;
  --err: #dc2626;
}

html, body {
  margin: 0;
  padding: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif;
  color: #0f172a;
  background: #fff;
}

a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }

.container { max-width: 1920px; margin: 16px auto; padding: 0 10px; }

/* Top bars */
.top-header .wrap { max-width: 1920px; margin: 0 auto; padding: 8px 16px; display: flex; align-items: center; justify-content: space-between; }
.top-header { background: var(--bg); color: var(--fg); border-bottom: 1px solid rgba(255,255,255,.08); }
.logo a { color: var(--fg); font-weight: 700; letter-spacing: .2px; background: transparent url(../images/logo.png) center left no-repeat; padding:20px 0; padding-left: 45px; }
/* ===== HLAVNÍ NAVIGACE ===== */
.nav { display: flex; align-items: center; }
.nav__menu { display: flex; }
.nav__links { display: flex; gap: 16px; align-items: center; }
.nav__overlay { display: none; }
.nav__close { display: none; }
.nav__toggle { display: none; }
.nav a { color: var(--fg); padding: 8px 10px; border-radius: 6px; }
.nav a:hover { background: rgba(255,255,255,.08); text-decoration: none; }

.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;
}

/* ===== MOBILNÍ MENU (max 760px) ===== */
@media (max-width: 760px){
  .top-header .wrap { flex-wrap: wrap; gap: 10px; }
  .nav { width: 100%; justify-content: flex-end; }

  /* Hamburger tlačítko */
  .nav__toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    appearance: none;
    border: none;
    background: rgba(255,255,255,.1);
    color: var(--fg);
    border-radius: 8px;
    width: 44px;
    height: 44px;
    cursor: pointer;
    transition: background .2s ease;
  }
  .nav__toggle:hover { background: rgba(255,255,255,.18); }
  .nav__toggle:focus { outline: 2px solid rgba(37,99,235,.8); outline-offset: 2px; }

  /* Hamburger ikona - 3 čárky */
  .nav__toggleIcon {
    width: 22px;
    height: 2px;
    background: currentColor;
    display: block;
    position: relative;
    transition: background .15s ease;
  }
  .nav__toggleIcon::before,
  .nav__toggleIcon::after {
    content: "";
    position: absolute;
    left: 0;
    width: 22px;
    height: 2px;
    background: currentColor;
    transition: transform .25s ease, top .25s ease;
  }
  .nav__toggleIcon::before { top: -7px; }
  .nav__toggleIcon::after { top: 7px; }

  /* Hamburger animace na křížek při otevření */
  .nav.is-open .nav__toggleIcon { background: transparent; }
  .nav.is-open .nav__toggleIcon::before {
    top: 0;
    transform: rotate(45deg);
  }
  .nav.is-open .nav__toggleIcon::after {
    top: 0;
    transform: rotate(-45deg);
  }

  /* Overlay - tmavé pozadí za menu */
  .nav__overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .3s ease, visibility .3s ease;
  }
  .nav.is-open .nav__overlay {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .nav__overlay[hidden] { display: none !important; }

  /* Vysouvací panel zprava */
  .nav__menu {
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    height: 100dvh;
    width: min(320px, 85vw);
    background: var(--bg);
    color: var(--fg);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    padding: 16px;
    box-shadow: -8px 0 32px rgba(0,0,0,.4);
    transform: translateX(100%);
    transition: transform .3s cubic-bezier(.4, 0, .2, 1);
  }
  .nav.is-open .nav__menu { transform: translateX(0); }

  /* Křížek pro zavření */
  .nav__close {
    display: flex;
    align-self: flex-end;
    align-items: center;
    justify-content: center;
    appearance: none;
    border: none;
    background: rgba(255,255,255,.1);
    color: var(--fg);
    border-radius: 8px;
    width: 44px;
    height: 44px;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    transition: background .2s ease;
  }
  .nav__close:hover { background: rgba(255,255,255,.18); }
  .nav__close:focus { outline: 2px solid rgba(37,99,235,.8); outline-offset: 2px; }

  /* Navigační odkazy */
  .nav__links {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 20px;
    overflow-y: auto;
    flex: 1;
  }
  .nav__links a {
    display: block;
    padding: 14px 12px;
    border-radius: 8px;
    font-size: 1rem;
    transition: background .15s ease;
  }
  .nav__links a:hover,
  .nav__links a:focus { background: rgba(255,255,255,.1); }
}

/* Flashes */
.flash { max-width: 1920px; margin: 12px auto; padding: 10px 14px; border-radius: 8px; border: 1px solid transparent; box-shadow: 0 1px 2px rgba(0,0,0,.06); font-weight: 600; }
.flash.success { background: #ecfdf5; color: #065f46; border-color: #a7f3d0; }
.flash.info { background: #eff6ff; color: #1e3a8a; border-color: #bfdbfe; }
.flash.warn,
.flash.warning { background: #fff7ed; color: #9a3412; border-color: #fed7aa; }
.flash.error { background: #fef2f2; color: #991b1b; border-color: #fecaca; }

/* ===== Řidič – mobilní homepage (Moje zakázky) ===== */
.ridic-home{max-width:720px;margin:0 auto;}
.ridic-home__header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:4px 0 12px;}
.ridic-home__title{font-size:22px;font-weight:800;line-height:1.1;}
.ridic-home__subtitle{margin-top:4px;color:#6b7280;font-size:14px;}
.ridic-home__actions{display:flex;gap:10px;margin:0 0 10px;align-items:center;}
.ridic-home__actions-left{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.ridic-home__actions-right{margin-left:auto;display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.ridic-home__actions .btn{white-space:nowrap; font-size: 17px;}

.ridic-logout{
  width:100%;
  text-align:center;
  padding:14px 14px;
  font-size:16px;
  font-weight:800;
  border-radius:12px;
}

.ridic-zakazky{display:flex;flex-direction:column;gap:10px;}
.ridic-empty{padding:14px 12px;border:1px dashed #cbd5e1;border-radius:12px;color:#475569;background:#f8fafc;}

.ridic-card{border:1px solid #e5e7eb;border-radius:14px;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.05);overflow:hidden;}
.ridic-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:linear-gradient(180deg,#f8fafc, #ffffff);border-bottom:1px solid #eef2f7;}
.ridic-card__countdown{font-size:18px;font-weight:800;letter-spacing:.2px;}
.ridic-card__time{font-size:14px;color:#64748b;}

.ridic-card__route{padding:10px 12px;display:flex;flex-direction:column;gap:10px;}
.ridic-card__row{display:grid;grid-template-columns:92px 1fr;gap:10px;align-items:start;}
.ridic-card__label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;}
.ridic-card__value{font-size:15px;line-height:1.25;color:#0f172a;word-break:break-word;}
.ridic-card__value .ridic-card__navlink{color:inherit;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;}
.ridic-card__value .ridic-card__navlink:hover{text-decoration-thickness:2px;}

.ridic-card__actions{padding:10px 12px;border-top:1px solid #eef2f7;background:#fff;display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.ridic-card__actions .ridic-delay{flex:0 0 auto;}
.btn:disabled{opacity:.55;cursor:not-allowed;filter:saturate(.7);}
.ridic-delay{display:flex;align-items:center;gap:8px;}
.ridic-delay__label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;white-space:nowrap;}
.ridic-delay__controls{display:flex;align-items:center;gap:10px;}
.ridic-delay select{min-width:90px;padding:9px 10px;border:1px solid #cbd5e1;border-radius:10px;font-size:13px;background:#fff;}
.ridic-delay__status{font-size:12px;color:#64748b;min-width:0;text-align:left;}
.ridic-delay__status.ok{color:#065f46;}
.ridic-delay__status.err{color:#991b1b;}

.ridic-card.is-ok .ridic-card__countdown{color:#065f46;}
.ridic-card.is-soon .ridic-card__countdown{color:#9a3412;}
.ridic-card.is-overdue .ridic-card__countdown{color:#991b1b;}

.ridic-verify{padding:14px 12px;border:1px solid #e5e7eb;border-radius:14px;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.04);}
.ridic-verify__title{font-size:25px;font-weight:800;margin-bottom:6px;}
.ridic-verify__text{color:#334155;font-size:16px;line-height:1.35;margin-bottom:10px;}
.ridic-verify__form{display:flex;flex-direction:column;gap:10px;}
.ridic-verify__row label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:6px;}
.ridic-verify__row input[type="text"],
.ridic-verify__row input[type="number"]{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;font-size:16px; box-sizing: border-box; }
.ridic-verify__actions input[type="submit"],
.ridic-verify__actions button{width:100%;padding:10px 12px;border-radius:10px; font-size: 17px;}

@media (max-width: 480px){
  .ridic-home__title{font-size:20px;}
  .ridic-card__row{grid-template-columns:78px 1fr;}
  .ridic-card__countdown{font-size:17px;}
}

/* ===== Řidič – Mávačka ===== */
.mavacka{max-width:720px;margin:0 auto;}
.mavacka__top{text-align: right; margin-bottom: 10px;}
.mavacka__top a{color:#0369a1;font-weight:600;}
.mavacka .btn{padding: 12px 12px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 17px;}

.mavacka__form{margin:0;}
.mavacka__grid{display:flex;flex-direction:column;gap:10px;}

/* Formulář - wrapper s kartou */
.mavacka__formWrap{
  background:linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 50%, #f0f9ff 100%);
  border:1px solid rgba(14,165,233,.15);
  border-radius:24px;
  padding:24px;
  box-shadow:0 4px 24px rgba(14,165,233,.08);
}

.mavacka__formHeader{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:10px;
  padding-bottom:20px;
  border-bottom:1px solid rgba(14,165,233,.1);
}

.mavacka__formIcon{
  width:56px;
  height:56px;
  background:linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(14,165,233,.3);
}

.mavacka__formIcon svg{
  width:32px;
  height:32px;
}

.mavacka__formTitle{
  font-size:22px;
  font-weight:800;
  color:#0369a1;
  letter-spacing:-0.02em;
}

.mavacka__formSubtitle{
  font-size:14px;
  color:#64748b;
  margin-top:4px;
}

/* Route builder - vizuální trasa */
.mavacka__routeBuilder{
  position:relative;
  padding-left:28px;
}

.mavacka__routeLine{
  position:absolute;
  left:11px;
  top:24px;
  bottom:24px;
  width:2px;
  background:linear-gradient(to bottom, #22c55e 0%, #0ea5e9 50%, #ef4444 100%);
  border-radius:1px;
}

.mavacka__routeDot{
  position:absolute;
  left:-28px;
  top:20px;
  width:24px;
  height:24px;
  border-radius:50%;
  background:#0ea5e9;
  border:3px solid #fff;
  box-shadow:0 2px 8px rgba(14,165,233,.3);
  display:flex;
  align-items:center;
  justify-content:center;
}

.mavacka__routePoint--start .mavacka__routeDot{
  background:#22c55e;
  box-shadow:0 2px 8px rgba(34,197,94,.3);
}

.mavacka__routePoint--end .mavacka__routeDot{
  background:#ef4444;
  box-shadow:0 2px 8px rgba(239,68,68,.3);
}

.mavacka__routePoint--via .mavacka__routeDot{
  background:#f59e0b;
  box-shadow:0 2px 8px rgba(245,158,11,.3);
}

.mavacka__routeField{
  position: relative;
}

.mavacka__routeField > label{
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:#64748b;
}

/* Inputy */
.mavacka__input{
  width:100%;
  padding:14px 16px;
  border:2px solid #e2e8f0;
  border-radius:12px;
  font-size:16px;
  line-height:1.3;
  box-sizing:border-box;
  background:#fff;
  transition:border-color 0.2s, box-shadow 0.2s;
}

.mavacka__input::placeholder{
  color:#94a3b8;
}

.mavacka__input:focus{
  outline:none;
  border-color:#0ea5e9;
  box-shadow:0 0 0 4px rgba(14,165,233,.15);
}

.mavacka__hint{    
  font-size:12px;
  line-height:1.3;
  color:#64748b;
}

.mavacka__hint svg{
  flex-shrink:0;
  opacity:0.6;
}

/* Options - checkboxy */
.mavacka__options{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.mavacka__option{
  display:flex;
  align-items:center;
  gap:6px;
  padding:10px;
  background:#fff;
  border:2px solid #e2e8f0;
  border-radius:12px;
  cursor:pointer;
  transition:border-color 0.2s, background 0.2s;
  user-select:none;
}

.mavacka__option:hover{
  border-color:#cbd5e1;
  background:#f8fafc;
}

.mavacka__option:has(input:checked){
  border-color:#0ea5e9;
  background:#f0f9ff;
}

.mavacka__option:has(input:disabled){
  opacity:0.5;
  cursor:not-allowed;
}

.mavacka__option input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.mavacka__optionCheck{
  width:20px;
  height:20px;
  border:2px solid #cbd5e1;
  border-radius:6px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background 0.2s, border-color 0.2s;
  flex-shrink:0;
}

.mavacka__option:has(input:checked) .mavacka__optionCheck{
  background:#0ea5e9;
  border-color:#0ea5e9;
}

.mavacka__option:has(input:checked) .mavacka__optionCheck::after{
  content:'';
  width:6px;
  height:10px;
  border:2px solid #fff;
  border-top:none;
  border-left:none;
  transform:rotate(45deg) translateY(-1px);
}

.mavacka__optionText{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  font-weight:500;
  color:#334155;
}

.mavacka__optionText svg{
  color:#64748b;
}

/* Termín */
.mavacka__terminWrap{
  background:#fff;
  border:2px solid #e2e8f0;
  border-radius:12px;
  padding:16px;
}

.mavacka__terminLabel{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  font-weight:600;
  color:#334155;
  margin-bottom:12px;
}

.mavacka__terminLabel svg{
  color:#0ea5e9;
}

.mavacka__terminInput{
  border-color:#cbd5e1;
}

/* Summary karta */
.mavacka__summaryCard{
  background:#fff;
  border:2px solid #e2e8f0;
  border-radius:16px;
  padding:4px;
  display:flex;
  flex-direction:column;
}

.mavacka__summaryItem{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
}

.mavacka__summaryDivider{
  height:1px;
  background:#e2e8f0;
  margin:0 16px;
}

.mavacka__summaryIcon{
  width:40px;
  height:40px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.mavacka__summaryIcon--route{
  background:#eff6ff;
  color:#3b82f6;
}

.mavacka__summaryIcon--price{
  background:#f0fdf4;
  color:#22c55e;
}

.mavacka__summaryIcon--driver{
  background:#fef3c7;
  color:#f59e0b;
}

.mavacka__summaryIcon--driver.is-available{
  background:#f0fdf4;
  color:#22c55e;
}

.mavacka__summaryIcon--driver.is-unavailable{
  background:#fef2f2;
  color:#ef4444;
}

.mavacka__summaryContent{
  flex:1;
  min-width:0;
}

.mavacka__summaryLabel{
  font-size:12px;
  color:#64748b;
  margin-bottom:2px;
}

.mavacka__summaryValue{
  font-size:15px;
  font-weight:600;
  color:#334155;
  font-variant-numeric:tabular-nums;
}

.mavacka__summaryValue--price{
  color:#16a34a;
  font-size:17px;
}

.mavacka__summaryValue--driver{
  font-size:13px;
  font-weight:500;
}

/* Mapa - kontejner */
.mavacka__mapWrap{
  margin-top:12px;
  border-radius:16px;
  overflow:hidden;
  border:2px solid #e2e8f0;
  background:#f8fafc;
  animation:mavackaMapSlide 0.3s ease-out;
}

@keyframes mavackaMapSlide{
  from{
    opacity:0;
    max-height:0;
  }
  to{
    opacity:1;
    max-height:400px;
  }
}

.mavacka__mapContainer{
  width:100%;
  height:280px;
  background:#e2e8f0;
}

.mavacka__mapHint{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:10px 16px;
  background:#fff;
  border-top:1px solid #e2e8f0;
  font-size:12px;
  color:#64748b;
}

.mavacka__mapHint svg{
  flex-shrink:0;
  opacity:0.6;
}

/* Portal – historie objednávek */
.mavacka__historyWrap {
  background: linear-gradient(135deg, #f8f9fa 0%, #e8f4fd 50%, #f8f9fa 100%);
  border: 1px solid rgba(26, 115, 232, .12);
  border-radius: 24px;
  padding: 20px 24px 24px;
  box-shadow: 0 4px 24px rgba(26, 115, 232, .06);
}
@media (max-width: 480px) {
  .mavacka__historyWrap {
    padding: 16px 16px 20px;
    border-radius: 20px;
  }
}
.mavacka__historyHeader {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid rgba(26, 115, 232, .1);
}
.mavacka__historyHeaderText{
  flex:1;
  min-width:0;
}
.mavacka__historyIcon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(14, 165, 233, .3);
}
.mavacka__historyIcon svg {
  width: 32px;
  height: 32px;
  color: #fff;
}
@media (max-width: 480px) {
  .mavacka__historyIcon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
  }
  .mavacka__historyIcon svg {
    width: 28px;
    height: 28px;
  }
}
.mavacka__historyTitle {
  font-size: 22px;
  font-weight: 800;
  color: #0369a1;
  letter-spacing: -0.02em;
}
.mavacka__historySubtitle {
  font-size: 14px;
  color: #64748b;
  margin-top: 4px;
  display:flex;
  align-items:center;
  gap:6px;
}
.mavacka__historySubtitle svg{
  flex-shrink:0;
  vertical-align:-2px;
  opacity:.7;
}
@media (max-width: 480px) {
  .mavacka__historyTitle {
    font-size: 20px;
  }
}
.mavacka__historyEmpty {
  text-align: center;
  padding: 48px 20px;
  background: #f8f9fa;
  border-radius: 16px;
  margin-top: 8px;
}
.mavacka__historyEmptyIcon {
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  background: #e8eaed;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mavacka__historyActions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 10px;
}
@media (max-width: 480px) {
  .mavacka__historyActions{
    width:100%;
    justify-content:flex-start;
    margin-top:8px;
  }
}
.mavacka__historyActionBtn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  color: #fff;
  background: linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);
  border-color: rgba(2, 132, 199, .35);
  box-shadow: 0 2px 10px rgba(15, 23, 42, .06);
}
.mavacka__historyActionBtn:hover {
  filter: brightness(1.09);
  text-decoration: none;
}

.mavacka__historyActionBtn--primary:hover {
  filter: brightness(1.03);
}
.mavacka__historyEmptyIcon svg {
  width: 32px;
  height: 32px;
  color: #9aa0a6;
}
.mavacka__historyEmptyText {
  color: #5f6368;
  font-size: 14px;
}
.mavacka__historyList {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.mavacka__historyCard {
  background: #fff;
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 1px 3px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.04);
  border: 1px solid rgba(0,0,0,.06);
  transition: box-shadow .2s, transform .2s;
}
.mavacka__historyCard:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,.12), 0 4px 16px rgba(0,0,0,.06);
  transform: translateY(-1px);
}
.mavacka__historyCard.is-completed {
  border-left: 3px solid #34a853;
}
.mavacka__historyCard.is-cancelled {
  border-left: 3px solid #ea4335;
  opacity: .85;
}
.mavacka__historyCard.is-active {
  border-left: 3px solid #fbbc04;
}
.mavacka__historyCardHeader {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}
.mavacka__historyOrderId {
  font-size: 16px;
  font-weight: 700;
  color: #1a73e8;
}
.mavacka__historyOrderIdHash {
  opacity: .5;
  font-weight: 400;
}
.mavacka__historyDate {
  font-size: 12px;
  color: #5f6368;
  display: flex;
  align-items: center;
  gap: 4px;
}
.mavacka__historyDate svg {
  opacity: .6;
}
.mavacka__historyRoute {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 12px 0;
}
.mavacka__historyStop {
  display: flex;
  align-items: center;
  gap: 10px;
}
.mavacka__historyStopIcon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.mavacka__historyStop--start .mavacka__historyStopIcon {
  color: #34a853;
}
.mavacka__historyStop--end .mavacka__historyStopIcon {
  color: #ea4335;
}
.mavacka__historyStop--via .mavacka__historyStopIcon {
  color: #fbbc04;
}
.mavacka__historyStopContent {
  flex: 1;
  min-width: 0;
}
.mavacka__historyStopLabel {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: #9aa0a6;
  font-weight: 600;
}
.mavacka__historyStopValue {
  font-size: 13px;
  color: #202124;
  line-height: 1.3;
}
.mavacka__historyCardFooter {
  display: flex;
  align-items: center;
  gap: 10px 14px;
  flex-wrap: wrap;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid #f1f3f4;
}

.mavacka__historyStatus{
  display:flex;
  align-items:center;
}

.mavacka__historyMeta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mavacka__historyMetaItem {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: #f1f5f9;
  border-radius: 8px;
  font-size: 12px;
  color: #475569;
}
.mavacka__historyMetaItem--price {
  background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  color: #065f46;
}
.mavacka__historyMetaItem--price .mavacka__historyMetaIcon {
  color: #10b981;
}
.mavacka__historyMetaIcon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: #64748b;
}
.mavacka__historyMetaValue {
  font-weight: 600;
}
.mavacka__historyBadge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
  background: #f1f3f4;
  color: #5f6368;
}
.mavacka__historyBadge--pending {
  background: #fef7e0;
  color: #b36b00;
}
.mavacka__historyBadge--active {
  background: #e6f4ea;
  color: #137333;
}
.mavacka__historyBadge--completed {
  background: #34a853;
  color: #fff;
}
.mavacka__historyBadge--cancelled {
  background: #fce8e6;
  color: #c5221f;
}
.mavacka__historyBadge--cashback {
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  color: #92400e;
}
.mavacka__historyBadge--invoice {
  background: linear-gradient(135deg, #ede9fe 0%, #ddd6fe 100%);
  color: #5b21b6;
}
.mavacka__historyBadge--senior {
  background: linear-gradient(135deg, #fce7f3 0%, #fbcfe8 100%);
  color: #9d174d;
}
.mavacka__historySource {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: #9aa0a6;
  margin-left: auto;
}
.mavacka__historySource svg {
  opacity: .7;
}


.mavacka__mapHint.is-hidden{
  display:none;
}

/* Submit button */
.mavacka__actions{
  padding-top:8px;
}

.mavacka__submit{
  width:100%;
  padding:18px 24px;
  background:linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);
  color:#fff;
  border:none;
  border-radius:14px;
  font-size:16px;
  font-weight:700;
  cursor:pointer;
  transition:transform 0.15s, box-shadow 0.15s;
  box-shadow:0 4px 16px rgba(14,165,233,.35);
}

.mavacka__submit:hover:not(:disabled){
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(14,165,233,.45);
}

.mavacka__submit:active:not(:disabled){
  transform:translateY(0);
}

.mavacka__submit:disabled{
  opacity:0.6;
  cursor:not-allowed;
}

/* Legacy styly pro kompatibilitu */
.mavacka__row{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:14px 12px 12px;
  border:1px solid #e5e7eb;
  border-radius:14px;
  background:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.04);
}
.mavacka__row > label{
  position:absolute;
  top:-2px;
  left:12px;
  transform:translateY(-50%);
  padding:0 6px;
  background:#fff;
  font-size:14px;
  letter-spacing:.06em;
  color:#64748b;
}

.mavacka__toggles{display:flex;flex-wrap:wrap;gap:10px;}
.mavacka__check{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border:1px solid #e5e7eb;
  border-radius:999px;
  background:#f8fafc;
  font-size:14px;
  color:#0f172a;
  cursor:pointer;
  user-select:none;
}
.mavacka__check:has(input[disabled]){opacity:.55;cursor:not-allowed;}
.mavacka__check input{width:18px;height:18px;}

.mavacka__summary{
  padding:12px 12px;
  border:1px solid #e5e7eb;
  border-radius:14px;
  background:linear-gradient(180deg,#f8fafc,#ffffff);
  box-shadow:0 1px 2px rgba(0,0,0,.04);
  display:grid;
  gap:6px;
  font-size:14px;
}
.mavacka__summary strong{color:#334155;}
.mavacka__summary #mavackaDistance,
.mavacka__summary #mavackaPrice{font-variant-numeric:tabular-nums;}

/* Responsive */
@media (max-width: 600px){
  .mavacka__formWrap{
    padding:20px 16px;
    border-radius:20px;
  }

  .mavacka__formHeader{
    flex-direction:column;
    text-align:center;
    gap:12px;
  }

  .mavacka__formIcon{
    width:48px;
    height:48px;
    border-radius:14px;
  }

  .mavacka__formIcon svg{
    width:28px;
    height:28px;
  }

  .mavacka__formTitle{
    font-size:20px;
  }  

  .mavacka__summaryCard{
    border-radius:14px;
  }
}

/* ===== Mávačka – pomocné gridy (použito i pro Tankování) ===== */
.mavacka__rowset{display:grid;grid-template-columns:1fr;gap:12px;}
.mavacka__rowset--3{grid-template-columns:repeat(3, minmax(0, 1fr));}

@media (max-width: 720px){
  .mavacka__rowset--3{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .mavacka__row--span2{grid-column:1 / -1;}
}

@media (max-width: 480px){
  .mavacka__rowset--3{grid-template-columns:1fr;}
  .mavacka__row--span2{grid-column:auto;}
}

@media (max-width: 480px){  
  .mavacka__title{font-size:20px;}
}

@media (min-width: 860px){
  .mavacka{max-width:760px;padding:18px 16px 22px;}
  .mavacka__grid{gap:14px;}
}

/* Buttons */
.btn {
  display: inline-block;
  padding: 10px 15px;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #334155;
  cursor: pointer;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  box-sizing: border-box;
  transition: all 0.15s ease;
}
.btn:hover {
  text-decoration: none;
  background: #f8fafc;
  border-color: #cbd5e1;
}
.btn-primary {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  border: none;
  color: #fff;
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.25);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(37, 99, 235, 0.3);
}
.btn-success {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  border: none;
  color: #fff;
  box-shadow: 0 2px 4px rgba(22, 163, 74, 0.25);
}
.btn-success:hover {
  background: linear-gradient(135deg, #16a34a 0%, #15803d 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(22, 163, 74, 0.3);
}
.btn-danger { background: var(--err); border-color: var(--err); color: #fff; }
.btn-danger:hover { filter: brightness(0.9); color: #64748b; }
.btn-small { padding: 5px 5px; font-size: 12px; font-weight: 400; }
.btn-icon { padding: 5px 6px; display: inline-flex; align-items: center; justify-content: center; vertical-align: middle; }
.btn-icon svg { display: block; }

/* Disabled button state (used for locked pobočky) */
.btn-disabled { opacity: .55; cursor: not-allowed; pointer-events: none; }

/* Inactive toggle state (used for unchecked driver buttons) */
.btn-inactive { background: #ccc; }

/* Forms */

/* Filter bar - vylepšený design */
.filter-bar {
  margin: 16px 0;
  padding: 16px 20px;
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.filter-bar label {
  font-size: 13px;
  font-weight: 500;
  color: #64748b;
}

.filter-bar input[type="text"],
.filter-bar input[type="date"],
.filter-bar select {
  min-width: 180px;
  padding: 10px 14px;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #fff;
  font-size: 14px;
  color: #334155;
  transition: all 0.15s ease;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.filter-bar input[type="text"]:focus,
.filter-bar input[type="date"]:focus,
.filter-bar select:focus {
  outline: none;
  border-color: #7dd3fc;
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

.filter-bar input[type="text"]::placeholder {
  color: #94a3b8;
}

.filter-bar .btn {
  padding: 10px 18px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 8px;
  transition: all 0.15s ease;
}

.filter-bar .btn-primary {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  border: none;
  color: #fff;
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.25);
}

.filter-bar .btn-primary:hover {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(37, 99, 235, 0.3);
}

.inline-form { display: inline-block; }

/* Checkboxes - nicer defaults */
input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: #3b82f6; /* primary blue */
  vertical-align: middle;
}
input[type="checkbox"]:focus-visible {
  outline: 2px solid rgba(59,130,246,.55);
  outline-offset: 2px;
  border-radius: 3px;
}
input[type="checkbox"][disabled] {
  accent-color: #94a3b8;
  opacity: .6;
  cursor: not-allowed;
}

.form-grid { max-width: 720px; }
.form-row { display: flex; align-items: center; gap: 16px; margin: 10px 0; }
.form-row label { width: 220px; font-weight: 600; }
.form-row input[type="text"],
.form-row input[type="password"],
.form-row input[type="time"],
.form-row input[type="number"],
.form-row input[type="date"],
.form-row input[type="datetime-local"],
.form-row select { flex: 1; padding: 8px 10px; border: 1px solid var(--border); border-radius: 6px; background: #fff; }
.form-row textarea { flex: 1; padding: 8px 10px; border: 1px solid var(--border); border-radius: 6px; background: #fff; min-height: 100px; }
.form-row .form-value { flex: 1; padding: 8px 10px; }
.form-actions { margin-top: 16px; }
.form-actions input[type="submit"],
.form-actions .btn { padding: 10px 16px; }

/* Kompaktní formuláře s plovoucími labely */
.form-grid--compact {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
  max-width: 100%;
  margin: 0 auto;
}
.form-field { position: relative; }
.form-field__label {
  position: absolute;
  top: -8px;
  left: 10px;
  padding: 0 6px;
  font-size: 11px;
  line-height: 16px;
  background: #fff;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  z-index: 10;
}
.form-field input[type="text"],
.form-field input[type="password"],
.form-field input[type="time"],
.form-field input[type="number"],
.form-field input[type="date"],
.form-field input[type="datetime-local"],
.form-field input[type="email"],
.form-field select,
.form-field textarea {
  width: 100%;
  padding: 14px 12px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-sizing: border-box;
  font-size: 15px;
}
.form-field textarea { min-height: 100px; padding-top: 14px; }
.form-field__value {
  display: block;
  width: 100%;
  padding: 14px 12px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--soft);
  font-size: 15px;
  color: #334155;
}
.form-field:hover input,
.form-field:hover select,
.form-field:hover textarea {
  background: var(--soft);
  border-color: var(--link);
}
.form-field:focus-within input,
.form-field:focus-within select,
.form-field:focus-within textarea {
  background: var(--soft);
  border-color: var(--link);
  outline: none;
}
.form-field:hover .form-field__label,
.form-field:focus-within .form-field__label {
  color: var(--link);
}
.form-field { grid-column: span 4; }
.form-field--full { grid-column: 1 / -1; }
.form-field--half { grid-column: span 6; }
.form-field--third { grid-column: span 4; }
.form-field--quarter { grid-column: span 3; }

/* Subgrid pro řádky se 4 poli */
.form-row-group {
  grid-column: 1 / -1;
  display: grid;
  gap: 14px;
}
.form-row-group--4col {
  grid-template-columns: repeat(4, 1fr);
}
.form-row-group--3col {
  grid-template-columns: repeat(3, 1fr);
}
.form-row-group .form-field {
  grid-column: span 1;
}

/* ===== Auth (login / set password) ===== */
.auth-page{
  display:flex;
  justify-content:center;
  padding:24px 12px;
}
.auth-card{
  width:100%;
  max-width:420px;
  border:1px solid #e5e7eb;
  border-radius:14px;
  background:#fff;
  box-shadow:0 10px 24px rgba(15,23,42,.08);
  padding:16px 16px 14px;
}
.auth-title{margin:0 0 4px;font-size:22px;font-weight:800;line-height:1.15;}
.auth-subtitle{margin:0 0 14px;color:#64748b;font-size:16px;line-height:1.35;}
.auth-form{display:flex;flex-direction:column;gap:12px;}
.auth-field{position:relative;}
.auth-input{
  width:100%;
  padding:14px 12px 10px;
  border:1px solid #cbd5e1;
  border-radius:10px;
  font-size:16px;
  background:#fff;
  box-sizing:border-box;
}
.auth-label{
  position:absolute;
  top:-8px;
  left:10px;
  padding:0 6px;
  font-size:14px;
  line-height:16px;
  background:#fff;
  color:var(--muted);
  letter-spacing:.06em;  
}
.auth-field:focus-within .auth-input{
  background:var(--soft);
  border-color:var(--link);
  outline:none;
  box-shadow:0 0 0 3px rgba(37,99,235,.15);
}
.auth-field:focus-within .auth-label{color:var(--link);}
.auth-input.error{
  border-color:var(--err);
  background:#fff1f2;
}
.auth-field:focus-within .auth-input.error{box-shadow:0 0 0 3px rgba(220,38,38,.12);}
.auth-actions{margin-top:4px;}
.auth-submit{width:100%;padding:12px 12px;border-radius:10px;font-weight:700;font-size:16px;}
.auth-errors{
  border:1px solid #fecaca;
  background:#fef2f2;
  color:#991b1b;
  border-radius:10px;
  padding:10px 12px;
  font-size:13px;
}
.auth-error + .auth-error{margin-top:6px;}

@media (max-width: 480px){
  .auth-page{padding:14px 8px;}
  .auth-card{border-radius:12px;}
}

/* CheckboxList horizontal layout */
.form-row .checkboxlist { display: flex; flex-wrap: wrap; gap: 8px 12px; }
.form-row .checkboxlist label { display: inline-flex; align-items: center; gap: 6px; padding: 2px 8px; border: 1px solid #e5e7eb; border-radius: 6px; white-space: nowrap; }
.form-row .checkboxlist input[type="checkbox"] { margin: 0; }

/* Tables */
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: 1px; border-bottom: 1px solid var(--border); vertical-align: top; font-size: 14px; color:#475569; }
.table td input{ font-size: 14px; color:#475569; }
.table thead th { background: #f8fafc; text-align: left; position: sticky; top: 0; z-index: 1; font-size: 14px; }
.table tbody tr:hover { background: #f9fafb; }
.table tbody tr.status-hotove,
.table tbody tr.status-senior,
.table tbody tr.status-cashback,
.table tbody tr.status-storno { background: #cccccc; }
.table tbody tr.status-hotove:hover,
.table tbody tr.status-senior:hover,
.table tbody tr.status-cashback:hover,
.table tbody tr.status-storno:hover { background: #c2c2c2; }

/* Status coloring for Orders list */
.table tbody tr.status-neprijato { background: #71b73b; }
.table tbody tr.status-neprijato:hover { background: #71b73b; }
.table tbody tr.status-nabrano { background: #9dd474; }
.table tbody tr.status-nabrano:hover { background: #93ca69; }
.table tbody tr.status-prijato { background: #FF6347; }
.table tbody tr.status-prijato:hover { background: #ff583a; }

/* Zakázky – časové statusy (řádek má vždy jen jednu status-* třídu) */
#zakazky_current_table tbody tr.status-prihoriva { background: #ff8080; color: #fff; }
#zakazky_current_table tbody tr.status-prihoriva:hover { background: #ff8080; }
#zakazky_current_table tbody tr.status-hori { background: #f51515; color: #fff; }
#zakazky_current_table tbody tr.status-hori:hover { background: #f51515; }
#zakazky_current_table tbody tr.status-pozde { background: #8B0000; color: #fff; }
#zakazky_current_table tbody tr.status-pozde:hover { background: #8B0000; }

/* Zakázky – s upozorněním (zobrazit dříve): modré zvýraznění + vždy nahoře dle řazení na serveru */
#zakazky_current_table tbody tr.priority-upozorneni {
  background: #2563eb;
  color: #fff;
}
#zakazky_current_table tbody tr.priority-upozorneni:hover {
  background: #1d4ed8;
}

.table input[type="text"],
.table input[type="number"],
.table input[type="time"],
.table select { width: 100%; padding: 12px 8px; border: none; border-radius: 0; background: none; box-sizing: border-box;}

/* Zakázky – select pro výběr řidiče musí být čitelný i na tmavých řádcích */
#zakazky_current_table select.zakazky-ridic-select {
  /* Zavřený select: čitelný na tmavém řádku */
  background: rgba(0, 0, 0, .22);
  color: #fff;  
  padding: 6px 8px;  
}
#zakazky_current_table select.zakazky-ridic-select option,
#zakazky_current_table select.zakazky-ridic-select optgroup {
  /* Rozbalený seznam: většina prohlížečů tohle respektuje, aby položky nebyly bílé na bílém */
  background: #fff;
  color: #0f172a;
}
#zakazky_current_table select.zakazky-ridic-select:focus {
  outline: 2px solid rgba(59, 130, 246, .35);
  outline-offset: 1px;
}

/* Zakázky – jméno řidiče nesmí zabrat celý řádek (jinak křížek padá pod něj) */
#zakazky_current_table td.js-zakazky-ridic > span.zakazky-ridic-label {  
  width: auto;  
}

/* Zakázky – decentní křížek pro vynulování řidiče */
#zakazky_current_table .zakazky-ridic-clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  margin-left: 6px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid currentColor;
  background: rgba(255, 255, 255, .12);
  color: inherit;
  opacity: .55;
  cursor: pointer;
  line-height: 1;
  font-size: 16px;
}
#zakazky_current_table .zakazky-ridic-clear:hover {
  opacity: .95;
  background: rgba(255, 255, 255, .22);
}
#zakazky_current_table .zakazky-ridic-clear:focus {
  outline: 2px solid rgba(59, 130, 246, .35);
  outline-offset: 1px;
}
#zakazky_current_table .zakazky-ridic-clear.btn-disabled,
#zakazky_current_table .zakazky-ridic-clear:disabled {
  opacity: .35;
  cursor: not-allowed;
  pointer-events: none;
}
.table span {display: inline-block;  width: 100%; padding: 5px; border-radius: 0; box-sizing: border-box;}
.table span.mark {display: block;  width: auto; padding: 0; border: none; border-radius: 0; background: #fff; box-sizing: border-box;}
.table .switch {margin: 5px;}
.table .actions a { margin-left: 8px; }

/* Sorting */
.table thead th.sorted { background: #e2e8f0; }
.sort-arrow { color: #94a3b8; margin-left: 6px; font-size: 12px; text-decoration: none; }
.sort-arrow:hover { color: #334155; text-decoration: none; }
.sort-arrow.active { color: #0f172a; font-weight: 700; }

/* Tags */
.tag { display: inline-block; padding: 2px 8px; background: #e2e8f0; color: #0f172a; border-radius: 999px; font-size: 12px; margin-right: 4px; }
.tag.top { background: #dbeafe; color: #1e3a8a; }
.tag.important { background: #dbeafe; color: #1e3a8a; }
.tag.minor { background: #e2e8f0; color: #0f172a; }
.meter { width: 100px; height: 6px; background: #e5e7eb; border-radius: 4px; overflow: hidden; display: inline-block; vertical-align: middle; margin-left: 8px; }
.meter .meter-fill { height: 100%; background: #3b82f6; }

/* Alpha bar */
/* Alpha bar - abecední filtr */
.alpha {
  margin: 12px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.alpha a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  background: #fff;
  color: #64748b;
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.15s ease;
}

.alpha a:hover {
  background: #f1f5f9;
  border-color: #cbd5e1;
  color: #334155;
}

.alpha a.active {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  border-color: #2563eb;
  color: #fff;
  box-shadow: 0 2px 4px rgba(37, 99, 235, 0.25);
}

/* Pagination - vylepšený design */
.pagination {
  margin-top: 16px;
  padding: 12px 0;
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.pagination span {
  font-size: 14px;
  color: #64748b;
}

.pagination .btn {
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #e2e8f0;
  color: #334155;
  transition: all 0.15s ease;
}

.pagination .btn:hover {
  background: #f8fafc;
  border-color: #cbd5e1;
  transform: translateY(-1px);
}


/* Status badge - univerzální */
.status-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.status-badge--aktivni {
  background: #dcfce7;
  color: #166534;
}

.status-badge--neaktivni {
  background: #fee2e2;
  color: #991b1b;
}

.status-badge--cekajici {
  background: #fef3c7;
  color: #92400e;
}

/* Kontaktní údaje s ikonami */
.contact-cell {
  display: flex;
  align-items: center;
  gap: 6px;
}

.contact-icon {
  width: 16px;
  height: 16px;
  opacity: 0.5;
}

/* Zůstatek - barevné zvýraznění */
.balance-positive {
  color: #16a34a;
  font-weight: 600;
}

.balance-negative {
  color: #dc2626;
  font-weight: 600;
}

.balance-zero {
  color: #9ca3af;
}

/* Přepínač zobrazení tabulka/karty */
.view-toggle {
  display: flex;
  gap: 4px;
  margin: 12px 0;
}

.view-toggle__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  color: #64748b;
  cursor: pointer;
  transition: all 0.15s ease;
}

.view-toggle__btn:hover {
  background: #f8fafc;
  color: #334155;
}

.view-toggle__btn--active {
  background: #e0f2fe;
  border-color: #7dd3fc;
  color: #0369a1;
}

/* ========================================
   UNIVERZÁLNÍ .table-scroll
   Jediná třída pro všechny tabulky s horizontálním scrollem
   ======================================== */
.table-scroll {
  margin-top: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}

.table-scroll .table {
  border-collapse: separate;
  border-spacing: 0;
}

.table-scroll .table thead th {
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  border-bottom: 2px solid #e2e8f0;
  padding: 12px 10px;
  font-weight: 600;
  color: #475569;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.05em;
}

.table-scroll .table tbody td {
  padding: 5px;
  border-bottom: 1px solid #f1f5f9;
  transition: background-color 0.15s ease;
  vertical-align: middle;
}

.table-scroll .table tbody tr:nth-child(even) {
  background: #fafbfc;
}

.table-scroll .table tbody tr:hover {
  background: #f0f9ff;
}

.table-scroll .table td input[type="text"],
.table-scroll .table td input[type="number"],
.table-scroll .table td input[type="time"],
.table-scroll .table td select {
  font-size: inherit;
  padding: 4px 6px;
}

/* Menší tlačítka v tabulkách */
.table-scroll .table td .btn {
  padding: 5px 10px;
  font-size: 13px;
}

/* Univerzální přepínač tabulka/karty */
.table-cards {
  border: none !important;
  background: transparent !important;
  overflow: visible !important;
}

.table-cards .table {
  display: none !important;
}

/* Skrytí karet v tabulkovém zobrazení (výchozí stav) */
.cards-grid {
  display: none;
}

.table-cards .cards-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 16px;
}

/* ========================================
   UNIVERZÁLNÍ .card
   Jednotná třída pro všechny kartové pohledy
   ======================================== */
.card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0;
  transition: all 0.2s ease;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.card:hover {
  border-color: #93c5fd;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}

.card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
  border-bottom: 1px solid #f1f5f9;
}

.card__title h3 {
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 700;
  color: #1e293b;
}

.card__subtitle {
  font-size: 12px;
  color: #64748b;
  display: block;
}

/* Pobocky: inline edit v kartách */
.pobocka-card .pobocka-inline-input {
  width: 100%;
}

.pobocka-card .pobocka-card__subtitle-edit {
  margin-top: 6px;
}

/* Řidič: ruční zadání km_end (fallback při výpadku GPS) */
.bw-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 9998;
}

.bw-modal {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(520px, calc(100% - 32px));
  background: #fff;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
  z-index: 9999;
}

.bw-modal__title {
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 8px;
}

.bw-modal__text {
  color: #444;
  font-size: 14px;
  margin-bottom: 12px;
}

.bw-modal__row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.bw-modal__label {
  min-width: 80px;
  color: #222;
  font-size: 14px;
}

.bw-modal__input {
  flex: 1;
  padding: 8px 10px;
}

.bw-modal__error {
  color: #b00020;
  font-size: 13px;
  margin-bottom: 10px;
}

.bw-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.card__badge {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
  letter-spacing: 0.5px;
}

.card__badge--dark {
  background: #1e293b;
  color: #fff;
}

.card__badge--primary {
  background: #3b82f6;
  color: #fff;
}

.card__badge--success {
  background: #dcfce7;
  color: #166534;
}

.card__badge--muted {
  background: #f1f5f9;
  color: #94a3b8;
}

.card__id {
  font-size: 11px;
  color: #94a3b8;
  background: #f1f5f9;
  padding: 2px 6px;
  border-radius: 4px;
  white-space: nowrap;
}
.card__id--success {
  color: #166534;
  background: #dcfce7;
}
.card__id--muted {
  color: #64748b;
  background: #f1f5f9;
}

.card__body {
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}

.card__section {
  background: #fafbfc;
  border-radius: 8px;
  padding: 10px 12px;
}

.card__section-title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}

.card__section-title svg {
  color: #94a3b8;
}

.card__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 12px;
}

.card__grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

.card__grid--4 {
  grid-template-columns: repeat(4, 1fr);
}

.card__field {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.card__field-label {
  font-size: 10px;
  color: #94a3b8;
  font-weight: 500;
}

.card__field-value {
  font-size: 13px;
  color: #334155;
  word-break: break-all;
}

.card__field-value--highlight {
  font-weight: 600;
  color: #16a34a;
}

.card__field-value--ok {
  color: #166534;
  font-weight: 600;
}

.card__field-value--muted {
  color: #94a3b8;
}

.card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  background: #fafbfc;
  border-top: 1px solid #f1f5f9;
  gap: 8px;
  flex-wrap: wrap;
}

.card__footer--end {
  justify-content: flex-end;
}

.card__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.card__actions {
  display: flex;
  gap: 6px;
}

.card__actions--row {
  padding: 10px 16px;
  border-top: 1px solid #f1f5f9;
  background: #fff;
}

.card__actions .btn {
  flex: 1;
  text-align: center;
}

.card__tags {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.card__time {
  font-size: 12px;
  color: #64748b;
  background: #e2e8f0;
  padding: 2px 8px;
  border-radius: 4px;
}

.card__mono {
  font-size: 10px;
  color: #64748b;
  font-family: monospace;
  background: #e2e8f0;
  padding: 2px 6px;
  border-radius: 3px;
}

.card__stat {
  font-size: 13px;
  font-weight: 600;
  color: #334155;
}

/* Speciální zobrazení pro ceníky - prominent cena */
.card__price-main {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  border-radius: 8px;
}

.card__price {
  display: flex;
  align-items: baseline;
  gap: 4px;
}

.card__price-value {
  font-size: 24px;
  font-weight: 700;
  color: #166534;
}

.card__price-unit {
  font-size: 14px;
  color: #166534;
  font-weight: 500;
}

.card__price-distance {
  font-size: 14px;
  color: #64748b;
  font-weight: 500;
}

/* Speciální zobrazení pro adresy */
.card__address {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.card__address-street {
  font-size: 14px;
  color: #1e293b;
  font-weight: 500;
}

.card__address-district {
  font-size: 13px;
  color: #64748b;
}

.card__address-city {
  font-size: 13px;
  color: #334155;
}

.card__address-city strong {
  color: #1e293b;
}

.card__coords {
  font-size: 12px;
  color: #64748b;
  font-family: monospace;
}

/* Helpers */
.text-center { text-align: center; }
.hidden { display: none !important; }

/* Toggle switch (checkbox replacement) */
.switch { position: relative; display: inline-block; width: 56px; height: 28px; vertical-align: middle; }
.form-row .switch { width: 56px; flex: 0 0 auto; }
.switch input[type="hidden"] { display: none; }
.switch input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.switch .slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: #ccc; transition: .2s; border-radius: 28px; }
.switch .slider:before { position: absolute; content: ""; height: 22px; width: 22px; left: 3px; bottom: 3px; background-color: white; transition: .2s; border-radius: 50%; box-shadow: 0 1px 3px rgba(0,0,0,.3); }
.switch input[type="checkbox"]:checked ~ .slider { background-color: #3b82f6; }
.switch input[type="checkbox"]:checked ~ .slider:before { transform: translateX(28px); }

/* Map toggle layout helper */
.map-toggle { display:flex; align-items:center; gap:10px; margin: 8px 0 12px; }
.map-toggle label { margin: 0; font-weight: 500; }

/* Map container */
.map-container { width: 100%; height: 420px; margin: 12px 0; border: 1px solid #ddd; }
.suggestions { position: absolute; background: #fff; border: 1px solid #ddd; box-shadow: 0 2px 6px rgba(0,0,0,.08); border-radius: 4px; overflow-y: auto; max-height: 220px; z-index: 1000; }
.suggestions div { padding: 8px 10px; cursor: pointer; }
.suggestions div:hover { background: #f5f5f5; }

/* Narrow map wrapper for detail pages (e.g., Orders) */
.order-map-wrap { max-width: 960px; }
.order-map-wrap .map-container { height: 360px; }

/* Smeny (Shifts) */
.smeny-grid { width: 100%; border-collapse: collapse; margin-top: 10px; }
.smeny-grid th, .smeny-grid td { padding: 6px 10px; border-bottom: 1px solid var(--border); vertical-align: top; }
.shift-col { width: 50%; }
.group-header { background: #f8fafc; font-weight: 600; padding: 8px 10px; }
.group-header-inner { display: flex; align-items: center; justify-content: space-between; }
.group-actions .btn { padding: 4px 8px; font-size: 12px; }
.shift-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.shift-row input[type="text"] { min-width: 160px; }
.shift-card { background: #fff; padding: 6px 8px; border-radius: 6px; border: 1px solid var(--border); margin-bottom: 6px; }
.shift-card--active-started { border-color: var(--ok); box-shadow: inset 0 0 0 1px var(--ok); }
.shift-card--active-waiting { border-color: var(--err); box-shadow: inset 0 0 0 1px var(--err); }
.shift-title { font-weight: 600; }
.shift-meta { color: #64748b; font-size: 13px; }
.smeny-grid tbody tr.top-row { background: #fff7ed; box-shadow: inset 3px 0 0 #f59e0b; }
.tag.plan { background: #eef2ff; color: #3730a3; }
.tag.potvrzena { background: #ecfdf5; color: #065f46; }
.tag.dokoncena { background: #f0fdf4; color: #166534; }
.tag.zrusena { background: #fef2f2; color: #991b1b; }
.muted { color: #64748b; }
.copy-bar { margin: 10px 0; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.copy-bar label { font-weight: 600; white-space: nowrap; }
.copy-bar input[type="date"] { min-width: 160px; padding: 6px 10px; border: 1px solid var(--border); border-radius: 6px; }

/* Smeny - responzivní úpravy */
@media (max-width: 900px) {
  .shift-row input[type="text"] { min-width: 140px; }
  .shift-row select { min-width: 100px; font-size: 12px; }
  .shift-row .btn { padding: 5px 8px; font-size: 12px; }
}

@media (max-width: 768px) {
  /* Filter bar - responzivní layout */
  .filter-bar { gap: 6px; }
  .filter-bar input[type="text"],
  .filter-bar input[type="date"],
  .filter-bar select { min-width: 140px; font-size: 14px; }
  .filter-bar .btn { padding: 7px 10px; font-size: 13px; white-space: nowrap; }
  .filter-bar .muted { font-size: 13px; }

  /* Copy bar - responzivní layout */
  .copy-bar { gap: 6px; }
  .copy-bar label { font-size: 13px; }
  .copy-bar input[type="date"] { min-width: 140px; font-size: 14px; }
  .copy-bar .btn { padding: 7px 10px; font-size: 13px; }

  /* Tabulka směn - zachovat dvousloupcový layout, ale zmenšit padding */
  .smeny-grid th, .smeny-grid td { padding: 4px 6px; font-size: 13px; }
  .group-header { padding: 6px 8px; font-size: 13px; }
  .group-header-inner { gap: 6px; }
  .group-actions .btn { padding: 3px 6px; font-size: 11px; }

  /* Shift karty - kompaktnější */
  .shift-card { padding: 6px 6px; margin-bottom: 8px; }
  .shift-row { gap: 6px; }
  .shift-row input[type="text"] { min-width: 100px; font-size: 13px; padding: 6px 8px; }
  .shift-row select { min-width: 90px; font-size: 12px; padding: 5px 6px; }
  .shift-row .btn { padding: 5px 6px; font-size: 11px; white-space: nowrap; }
  .shift-row .tag { font-size: 10px; padding: 1px 6px; margin-right: 2px; }
}

@media (max-width: 640px) {
  /* Na menších mobilech - změnit tabulku na vertikální karty */
  .smeny-grid { border-collapse: separate; border-spacing: 0; }

  /* Skrýt hlavičku tabulky */
  .smeny-grid thead { display: none; }

  /* Změnit řádky na bloky */
  .smeny-grid tbody,
  .smeny-grid tr,
  .smeny-grid td { display: block; width: 100%; }

  .smeny-grid tbody tr.group-header-row { margin: 16px 0 8px; }

  /* Group header jako běžný blok */
  .smeny-grid td.group-header {
    background: #f8fafc;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 8px 10px;
    margin-bottom: 8px;
  }

  /* Shift karty - plná šířka */
  .shift-card { margin-bottom: 10px; }

  /* Shift row - hybridní layout: většina prvků vertikálně, ale tagy zůstanou vedle sebe */
  .shift-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  /* Inputy a selecty na celou šířku */
  .shift-row input[type="text"],
  .shift-row select {
    flex: 1 1 100%;
    min-width: 0;
    width: 100%;
  }

  /* Tlačítka - vedle sebe, přirozeně se zalomí, pokud se nevejdou */
  .shift-row .btn {
    flex: 0 1 auto;
    min-width: auto;
    padding: 8px 10px;
    font-size: 13px;
    white-space: nowrap;
  }
  .shift-row .btn-small {
    padding: 7px 8px;
    font-size: 12px;
  }

  /* Tagy zůstanou vedle sebe (inline, na stejném řádku) */
  .shift-row .tag {
    flex: 0 0 auto;
    display: inline-block;
    margin: 0;
  }

  /* Hidden inputs nechat skryté */
  .shift-row input[type="hidden"] {
    display: none;
  }

  /* Kompaktnější filter bar - flexibilní layout s přirozeným zalamováním */
  .filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }

  /* Všechna tlačítka - flexibilní, vedle sebe, dokud se vejdou */
  .filter-bar .btn {
    flex: 0 0 auto;
    min-width: auto;
    white-space: nowrap;
    padding: 7px 10px;
    font-size: 13px;
  }

  /* Date input - flexibilní šířka mezi tlačítky */
  .filter-bar input[type="date"] {
    flex: 1 1 auto;
    min-width: 110px;
    max-width: 180px;
  }

  /* Select pro pobočky - přizpůsobivá šířka */
  .filter-bar select {
    flex: 1 1 auto;
    min-width: 140px;
  }

  /* Muted text info - na celou šířku */
  .filter-bar .muted {
    flex: 1 1 100%;
    text-align: center;
    margin: 4px 0;
    font-size: 13px;
  }

  /* Copy bar - label nahoře, input a tlačítko vedle sebe */
  .copy-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
  }

  .copy-bar label {
    flex: 1 1 100%;
    white-space: nowrap;
  }

  .copy-bar input[type="date"] {
    flex: 1 1 auto;
    min-width: 140px;
  }

  .copy-bar .btn {
    flex: 0 0 auto;
    min-width: auto;
    white-space: nowrap;
  }
}

@media (max-width: 480px) {
  /* Ještě kompaktnější pro velmi malé displeje */
  h1 { font-size: 20px; }

  .smeny-grid td.group-header { padding: 6px 8px; font-size: 12px; }
  .group-header-inner { font-size: 13px; }

  .shift-card { padding: 8px; }
  .shift-row { gap: 10px; }
  .shift-row .tag { font-size: 11px; }
}

/* Zakaznici - responzivní úpravy */
@media (max-width: 768px) {
  /* Alpha bar - kompaktnější na tabletech */
  .alpha { gap: 4px; }
  .alpha a { padding: 3px 6px; font-size: 13px; }

  /* Pagination - kompaktnější */
  .pagination { gap: 6px; }
  .pagination .btn { padding: 7px 10px; font-size: 13px; }
  .pagination span { font-size: 13px; }

  /* Form grid - menší gap na tabletech */
  .form-row { gap: 12px; margin: 8px 0; }
  .form-row label { width: 180px; font-size: 14px; }
  .form-row input[type="text"],
  .form-row input[type="password"],
  .form-row input[type="time"],
  .form-row input[type="number"],
  .form-row input[type="date"],
  .form-row input[type="datetime-local"],
  .form-row select { font-size: 14px; padding: 7px 9px; }

  /* Kompaktní formuláře - na tabletech */
  .form-grid--compact { gap: 12px; }
  .form-field input[type="text"],
  .form-field input[type="password"],
  .form-field input[type="time"],
  .form-field input[type="number"],
  .form-field input[type="date"],
  .form-field input[type="datetime-local"],
  .form-field input[type="email"],
  .form-field select,
  .form-field textarea { font-size: 14px; padding: 13px 11px 9px; }
}

@media (max-width: 640px) {
  /* Filter bar s labelem - label nahoře */
  .filter-bar label {
    flex: 1 1 100%;
    margin-bottom: 2px;
    font-size: 13px;
  }

  /* Form grid - vertikální layout na mobilech */
  .form-row {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    margin: 12px 0;
  }

  .form-row label {
    width: auto;
    font-size: 13px;
    font-weight: 700;
  }

  .form-row input[type="text"],
  .form-row input[type="password"],
  .form-row input[type="time"],
  .form-row input[type="number"],
  .form-row input[type="date"],
  .form-row input[type="datetime-local"],
  .form-row select,
  .form-row textarea {
    width: 100%;
    font-size: 16px;
    padding: 10px 12px;
    box-sizing: border-box;
  }

  .form-row .form-value {
    padding: 10px 0;
    font-size: 15px;
  }

  .form-actions {
    margin-top: 20px;
  }

  .form-actions input[type="submit"],
  .form-actions .btn {
    width: 100%;
    padding: 12px 16px;
    font-size: 16px;
  }

  /* Kompaktní formuláře - jeden sloupec na mobilech */
  .form-grid--compact {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .form-field input[type="text"],
  .form-field input[type="password"],
  .form-field input[type="time"],
  .form-field input[type="number"],
  .form-field input[type="date"],
  .form-field input[type="datetime-local"],
  .form-field input[type="email"],
  .form-field select,
  .form-field textarea {
    font-size: 16px;
    padding: 14px 12px 10px;
  }

  /* ========================================
     UNIVERZÁLNÍ MOBILNÍ TABULKA NA KARTY
     ======================================== */
  .table-scroll {
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
  }

  .table-scroll > .table {
    border-collapse: separate;
    border-spacing: 0;
  }

  /* Schovej hlavičku vizuálně */
  .table-scroll .table thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .table-scroll .table tbody,
  .table-scroll .table tr,
  .table-scroll .table td {
    display: block;
    width: 100%;
  }

  .table-scroll .table tbody tr {
    margin: 0 0 12px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    box-sizing: border-box;
  }

  .table-scroll .table tbody tr:hover {
    background: #fff;
  }

  .table-scroll .table td {
    padding: 6px 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    display: flex;
    gap: 10px;
    align-items: flex-start;
  }

  .table-scroll .table td:last-child {
    border-bottom: 0;
    padding-top: 10px;
  }

  .table-scroll .table td::before {
    content: attr(data-label);
    flex: 0 0 92px;
    font-size: 11px;
    line-height: 1.3;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    font-weight: 600;
  }

  /* Skrýt label "Akce" u posledního sloupce */
  .table-scroll .table td:last-child::before {
    display: none;
  }

  .table-scroll .table td > * {
    flex: 1 1 auto;
    min-width: 0;
  }

  /* Tlačítka v akci */
  .table-scroll .table td:last-child {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .table-scroll .table td .btn {
    flex: 0 0 auto;
  }

  /* Inline formuláře v tabulce - sjednocená velikost textu */
  .table-scroll .table td input[type="text"],
  .table-scroll .table td input[type="number"],
  .table-scroll .table td input[type="time"],
  .table-scroll .table td select {
    width: 100%;
    font-size: inherit;
    padding: 6px 8px;
    box-sizing: border-box;
  }

  /* Alpha bar - menší tlačítka */
  .alpha { gap: 3px; }
  .alpha a { padding: 2px 5px; font-size: 12px; }

}

@media (max-width: 480px) {
  /* Pagination - vertikální na velmi malých displejích */
  .pagination {
    flex-direction: column;
    align-items: stretch;
  }

  .pagination .btn {
    width: 100%;
    text-align: center;
  }

  .pagination span {
    text-align: center;
    padding: 4px 0;
  }
}

.choices {  
  flex: 1;
}

.choices__inner {  
  box-sizing: border-box;
  padding: 5px!important;
  min-height: inherit!important;
}

.choices__list--multiple .choices__item {  
  margin-bottom: 0!important;  
}

/* Timeline (Orders detail) */
.timeline{display:flex;align-items:flex-start;gap:18px;list-style:none;margin:12px 0;padding:8px 0}
.timeline-item{position:relative;margin:0;padding-left:20px}
.timeline-item:last-of-type:after{display:none}
.timeline-item .marker{position:absolute;left:0;top:4px;width:12px;height:12px;border-radius:50%;background:#cbd5e1;border:2px solid #fff;box-shadow:0 0 0 2px #e5e7eb}
.timeline-item.done .marker{background:#10b981}
.timeline-item .content{display:flex;align-items:baseline;gap:8px}
.timeline-item .title{font-weight:600}
.timeline-item .meta{color:#64748b;font-size:12px}
.timeline-item .who{white-space:nowrap}
@media (prefers-color-scheme: dark){
  .timeline-item:after{background:#334155}
  .timeline-item .marker{background:#475569;box-shadow:0 0 0 2px #334155}
}
.timeline .pending .meta{opacity:.7}
.timeline .pending .marker{background:#e2e8f0}
.timeline .pending .title{opacity:.9}
.timeline .meta .sep{padding:0 6px;color:#cbd5e1}
.timeline .time{font-variant-numeric:tabular-nums}
.timeline .label-badge{display:inline-block;font-size:11px;line-height:1;border-radius:10px;padding:3px 6px;margin-left:6px;background:#f1f5f9;color:#0f172a}

/* Zakázky – zjednodušené zadání */
.zakazky-quick-entry { margin-top: 12px; }
.zakazky-quick-toggles { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; justify-content: center; margin: 6px 0 10px; }
.zakazky-quick-toggles label { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; }
.zakazky-quick-grid {
  display: flex;
  gap: 10px;
  flex-wrap: nowrap;
  align-items: stretch;
  /*overflow-x: auto;
  overflow-y: hidden;*/
  scrollbar-gutter: stable;
}
.zakazky-quick-field { position: relative; flex: 1 1 260px; min-width: 220px; }
.zakazky-quick-field.qe-phone { flex: 0 1 210px; min-width: 180px; }
.zakazky-quick-field.qe-driver { flex: 0 1 240px; min-width: 200px; }
.zakazky-quick-field.qe-dojezd { flex: 0 1 100px; min-width: 100px; }
.zakazky-quick-field.qe-termin { flex: 0 1 240px; min-width: 210px; }
.zakazky-quick-field.qe-submit { flex: 0 0 90px; min-width: 90px; display: flex; align-items: flex-end; }
.zakazky-quick-field.qe-addr { flex: 1 1 0; }
.zakazky-quick-field.qe-addr { transition: flex-basis .15s ease, flex-grow .15s ease; }
.zakazky-quick-field.qe-addr:focus-within { flex: 2 1 520px; }
.zakazky-quick-field input[type="text"],
.zakazky-quick-field input[type="number"],
.zakazky-quick-field input[type="datetime-local"],
.zakazky-quick-field select {
  width: 100%;
  padding: 14px 10px 10px; /* místo nahoře pro label */
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  box-sizing: border-box;
}
.zakazky-quick-label {
  position: absolute;
  top: -8px;
  left: 10px;
  padding: 0 6px;
  font-size: 11px;
  line-height: 16px;
  background: #fff;
  color: var(--muted);
}
.zakazky-quick-field:hover input[type="text"],
.zakazky-quick-field:focus-within input[type="text"],
.zakazky-quick-field:hover input[type="number"],
.zakazky-quick-field:focus-within input[type="number"],
.zakazky-quick-field:hover input[type="datetime-local"],
.zakazky-quick-field:focus-within input[type="datetime-local"],
.zakazky-quick-field:hover select,
.zakazky-quick-field:focus-within select {
  background: var(--soft);
  border-color: var(--link);
}
.zakazky-quick-field:hover .zakazky-quick-label,
.zakazky-quick-field:focus-within .zakazky-quick-label {
  color: var(--link);
}
.zakazky-quick-actions { margin-top: 10px; }

/* Zakázky – tabulka: na mobilu scroll do strany */
.zakazky-table-scroll {
  margin-top: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}
.zakazky-table-scroll > .table {
  min-width: 980px;
}
#zakazky_current_table td.actions,
#zakazky_current_table th:last-child {
  white-space: nowrap;
}

/* Zakázky – panel zákazníka (výjezd zleva) */
.zakazky-customer-panel {
  flex: 0 0 0;
  min-width: 0;
  width: 0;
  max-width: 0;
  margin-top: 0;
  background: #fff;
  border: 0;
  border-radius: 6px;
  transform: translateX(-24px);
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: transform .2s ease, opacity .2s ease, max-height .2s ease;
}
.zakazky-customer-panel.open {
  margin-top: 10px;
  flex: 1 1 0;
  min-width: 320px;
  width: auto;
  max-width: 50%;
  border: 1px solid var(--border);
  transform: translateX(0);
  opacity: 1;
  max-height: 70vh;
  overflow: auto;
}
.zakazky-customer-panel__inner { padding: 12px 14px; display: grid; gap: 10px; }
.zakazky-customer-panel__title { margin: 10px 0 8px; font-size: 14px; }
.zakazky-customer-row { display: flex; justify-content: space-between; gap: 10px; padding: 4px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
.zakazky-customer-row span:first-child { min-width: 90px; }
.zakazky-customer-row:last-child{border-bottom:0;}
.zakazky-customer-row span:last-child{font-weight:600;}
.zakazky-customer-note { position: relative; margin-top: 8px; }
.zakazky-customer-note__text { white-space: pre-wrap; padding: 8px 10px; border: 1px solid var(--border); border-radius: 6px; background: var(--soft); }

/* Zakázky – karty uvnitř panelů (Zákazník / Trasa / apod.) */
.zakazky-panel-card{
  position: relative;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 10px 10px;
}

/* Zakázky – souhrn trasy */
.zakazky-route-summary__row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding: 4px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.zakazky-route-summary__row:last-child{border-bottom:0;}
.zakazky-route-summary__row span:last-child{font-weight:600;}

.zakazky-customer-job { padding: 8px 10px; border: 1px solid var(--border); border-radius: 6px; margin-bottom: 8px; }
.zakazky-customer-job--open { border-left: 4px solid var(--ok); }
.zakazky-customer-job__head { font-weight: 600; font-size: 13px; }
.zakazky-customer-job__route { font-size: 13px; color: var(--muted); margin-top: 2px; }

/* Zakázky – boční panely (zákazník vlevo, mapa vpravo) */
.zakazky-side-panels {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

/* Zakázky – panel mapy (výjezd zprava) */
.zakazky-route-panel {
  flex: 0 0 0;
  min-width: 0;
  width: 0;
  max-width: 0;
  margin-top: 0;
  background: #fff;
  border: 0;
  border-radius: 6px;
  transform: translateX(24px);
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: transform .2s ease, opacity .2s ease, max-height .2s ease;
}
.zakazky-route-panel.open {
  margin-top: 10px;
  flex: 1 1 0;
  min-width: 320px;
  width: auto;
  max-width: 50%;
  border: 1px solid var(--border);
  transform: translateX(0);
  opacity: 1;
  max-height: 70vh;
  overflow: auto;
}
.zakazky-route-panel__inner { padding: 12px 14px; }
.zakazky-route-panel__title { margin: 10px 0 8px; font-size: 14px; }
.zakazky-route-panel .map-container { margin: 0; height: 360px; }

/* Zakázky – chat panel (dispečer ↔ řidič) */
.zakazky-chat-panel {
  flex: 0 0 0;
  min-width: 0;
  width: 0;
  max-width: 0;
  margin-top: 0;
  background: #fff;
  border: 0;
  border-radius: 6px;
  transform: translateX(-24px);
  opacity: 0;
  max-height: 0;  
  transition: transform .2s ease, opacity .2s ease, max-height .2s ease;
}
.zakazky-chat-panel.open {
  margin-top: 10px;
  flex: 1 1 0;
  min-width: 320px;
  width: auto;
  max-width: 50%;
  border: 1px solid var(--border);
  transform: translateX(0);
  opacity: 1;
  max-height: 70vh;  
}
.zakazky-chat-panel__inner { padding: 12px 14px; }
.zakazky-chat-panel__title { margin: 10px 0 8px; font-size: 14px; }

/* Zakázky – rychlý report panel (napravo, výjezd zprava) */
.zakazky-report-panel {
  flex: 0 0 0;
  min-width: 0;
  width: 0;
  max-width: 0;
  margin-top: 0;
  background: #fff;
  border: 0;
  border-radius: 6px;
  transform: translateX(24px);
  opacity: 0;
  max-height: 0;  
  transition: transform .2s ease, opacity .2s ease, max-height .2s ease;
}
.zakazky-report-panel.open {
  margin-top: 10px;
  flex: 1 1 0;
  min-width: 320px;
  width: auto;
  max-width: 50%;
  border: 1px solid var(--border);
  transform: translateX(0);
  opacity: 1;
  max-height: 70vh;  
}
.zakazky-report-panel__inner { padding: 12px 14px; }
.report-title {
  font-size: 11px;
  line-height: 1;
  font-weight: 600;
  letter-spacing: .2px;
  position: absolute;
  top: -8px;
  left: 10px;
  padding: 0 6px;
  font-size: 11px;
  line-height: 16px;
  background: #fff;
  color: var(--muted);
}

.report-meta { font-size: 12px; margin-bottom: 10px; }
.report-grid { display:flex; gap:10px; align-items:flex-end; flex-wrap:wrap; }
.report-field { flex: 1 1 0; min-width: 180px; }
.report-select, .report-input {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  box-sizing: border-box;
}
.report-text {
  width: 100%;
  resize: vertical;
  padding: 10px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-sizing: border-box;
}
.report-actions { display:flex; gap:10px; align-items:center; margin-top: 10px; }
.report-field--content { margin-top: 10px; }

/* Zakázky – responzivita */
@media (max-width: 900px) {
  .zakazky-quick-grid { flex-wrap: wrap; }
}

@media (max-width: 768px) {
  .zakazky-side-panels { flex-direction: column; }

  .zakazky-customer-panel.open,
  .zakazky-route-panel.open,
  .zakazky-chat-panel.open,
  .zakazky-report-panel.open {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .zakazky-route-panel .map-container { height: 260px; }

  .zakazky-table-scroll {
    border-left: 0;
    border-right: 0;
    border-radius: 0;
  }
}

@media (max-width: 640px) {
  .zakazky-quick-toggles { justify-content: flex-start; }

  .zakazky-quick-grid {
    flex-direction: column;
    flex-wrap: nowrap;
  }

  .zakazky-quick-field {
    flex: 1 1 auto;
    min-width: 0;
  }
  .zakazky-quick-field.qe-phone,
  .zakazky-quick-field.qe-driver,
  .zakazky-quick-field.qe-dojezd,
  .zakazky-quick-field.qe-termin,
  .zakazky-quick-field.qe-submit {
    flex: 1 1 auto;
    min-width: 0;
  }
  .zakazky-quick-field.qe-addr:focus-within { flex: 1 1 auto; }

  .chat-compose { flex-wrap: wrap; }
  .chat-compose .chat-select { flex: 1 1 100%; min-width: 0; }
  .chat-text { flex: 1 1 100%; }
  .chat-send { flex: 1 1 100%; }

  .report-grid { flex-direction: column; align-items: stretch; }
  .report-field { min-width: 0; }

  /* Zakázky – tabulka jako karty (mobil) */
  .zakazky-table-scroll {
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
  }
  .zakazky-table-scroll > .table { min-width: 0; }

  #zakazky_current_table {
    border-collapse: separate;
    border-spacing: 0;
  }

  /* schovej hlavičku vizuálně (karty mají vlastní labely) */
  #zakazky_current_table thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  #zakazky_current_table tbody,
  #zakazky_current_table tr,
  #zakazky_current_table td {
    display: block;
    width: 100%;
  }

  #zakazky_current_table tbody tr {
    margin: 0 0 10px;
    padding: 10px 12px;
    border: 1px solid rgba(0,0,0,.10);
    border-radius: 14px;
    box-shadow: 0 1px 2px rgba(0,0,0,.05);
    overflow: hidden;
    box-sizing: border-box;
  }

  #zakazky_current_table tbody tr:hover { background: inherit; }

  #zakazky_current_table td {
    padding: 6px 0;
    border-bottom: 1px solid rgba(0,0,0,.08);
    display: flex;
    gap: 10px;
    align-items: flex-start;
  }
  #zakazky_current_table td:last-child { border-bottom: 0; }

  #zakazky_current_table tbody tr.status-prihoriva td,
  #zakazky_current_table tbody tr.status-hori td,
  #zakazky_current_table tbody tr.status-pozde td,
  #zakazky_current_table tbody tr.priority-upozorneni td {
    border-bottom-color: rgba(255,255,255,.20);
  }

  #zakazky_current_table td::before {
    content: attr(data-label);
    flex: 0 0 92px;
    font-size: 11px;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: rgba(15,23,42,.65);
  }
  /* když je řádek tmavý (časové stavy / upozornění), labely zesvětli */
  #zakazky_current_table tbody tr.status-prihoriva td::before,
  #zakazky_current_table tbody tr.status-hori td::before,
  #zakazky_current_table tbody tr.status-pozde td::before,
  #zakazky_current_table tbody tr.priority-upozorneni td::before {
    color: rgba(255,255,255,.78);
  }

  #zakazky_current_table td > span {
    width: auto;
    padding: 0;
  }

  #zakazky_current_table td > span,
  #zakazky_current_table td > a,
  #zakazky_current_table td > select,
  #zakazky_current_table td > input,
  #zakazky_current_table td > form,
  #zakazky_current_table td > .zakazky-actions {
    flex: 1 1 auto;
    min-width: 0;
  }

  #zakazky_current_table td.actions {
    align-items: center;
  }
  #zakazky_current_table td.actions .zakazky-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
  }
  #zakazky_current_table td.actions .zakazky-actions a { margin-left: 0; }

  #zakazky_current_table td.js-zakazky-ridic {
    flex-wrap: wrap;
    align-items: center;
  }
  #zakazky_current_table td.js-zakazky-ridic .zakazky-ridic-clear {
    flex: 0 0 auto;
  }
}

/* Reporty stránka */
.report-entry { max-width: 720px; }
.report-entry .form-row label { display: block; margin: 0 0 0.25rem 0; }
.report-entry select,
.report-entry input[type="text"],
.report-entry textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.report-entry .tox-tinymce {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
}

/* Kompaktnější chat (šetří místo) */
.chat-title { font-size:11px; line-height:1; font-weight:600; letter-spacing:.2px; position: absolute;
  top: -8px;
  left: 10px;
  padding: 0 6px;
  font-size: 11px;
  line-height: 16px;
  background: #fff;
  color: var(--muted); }
.chat-select { min-width: 240px; max-width: 100%; height:28px; padding:4px 8px; border: 1px solid var(--border); border-radius: 6px; background: #fff; font-size:12px; }

.chat-messages {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--soft);
  padding: 6px;  
  height: 180px;
  overflow: auto;  
}

.chat-msg { display:grid; grid-template-columns: auto auto 1fr auto; gap:6px; align-items:center; background:#fff; border:1px solid var(--border); border-radius:8px; padding:6px 8px; margin: 0 0 6px; }
.chat-msg.me { margin-left: 10px; border-left: 4px solid var(--link); }
.chat-msg.from-driver { border-left: 4px solid var(--ok); }
.chat-msg__time { opacity: .8; font-size: 11px; line-height: 1.1; color: var(--muted); white-space: nowrap; }
.chat-msg__driver {
  display:inline-block;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 1px 6px;
  border-radius: 999px;
  font-size: 10px;
  line-height: 1.4;
  background: rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.08);
}
.chat-msg__hide { justify-self:end; border: 0; background: transparent; color: var(--muted); cursor: pointer; padding: 0 4px; text-decoration: underline; font-size: 11px; white-space: nowrap; }
.chat-msg__hide:hover { color: var(--link); }
.chat-msg__text {
  min-width: 0;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  color: #0f172a;
  font-size: 13px;
  line-height: 1.25;
}

.chat-compose { display:flex; gap:6px; align-items:stretch; margin-top: 10px; }
.chat-compose .chat-select { min-width: 140px; flex: 0 1 220px; }
.chat-text { flex: 1 1 auto; min-width: 0; width: 100%; resize: vertical; padding: 6px 8px; border: 1px solid var(--border); border-radius: 8px; background: #fff; box-sizing: border-box; font-size: 13px; line-height: 1.25; }
.chat-send { padding: 6px 10px; }

/* Řidič – chat nahoře */
.ridic-chat{margin:0 0 12px;padding:12px;border:1px solid #e5e7eb;border-radius:14px;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.04);margin-top: 20px;}
.ridic-chat__head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px; }
.ridic-chat__title{font-size:16px;font-weight:800;}
.ridic-chat .chat-messages{height:220px;}

@media (max-width: 1024px) {
  .zakazky-customer-panel,
  .zakazky-route-panel,
  .zakazky-chat-panel,
  .zakazky-report-panel {
    max-width: 100%;
  }
}

/* ========================================
   SMĚNY - VYLEPŠENÉ ZOBRAZENÍ
   ======================================== */

/* Page header */
.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 16px;
}
.page-header h1 {
  margin: 0;
}
.page-header__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Statistiky bar */
.stats-bar {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
  padding: 12px 16px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
}
.stats-bar__item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--soft);
  border-radius: 8px;
}
.stats-bar__item--ok {
  background: rgba(22, 163, 74, 0.1);
}
.stats-bar__item--ok .stats-bar__icon,
.stats-bar__item--ok .stats-bar__value {
  color: var(--ok);
}
.stats-bar__item--warn {
  background: rgba(245, 158, 11, 0.1);
}
.stats-bar__item--warn .stats-bar__icon,
.stats-bar__item--warn .stats-bar__value {
  color: var(--warn);
}
.stats-bar__icon {
  flex-shrink: 0;
  color: var(--muted);
}
.stats-bar__icon--sun {
  color: #f59e0b;
}
.stats-bar__icon--moon {
  color: #6366f1;
}
.stats-bar__value {
  font-size: 18px;
  font-weight: 700;
  color: #0f172a;
}
.stats-bar__label {
  font-size: 13px;
  color: var(--muted);
}

/* Směny view toggle logic */
#smeny-view .smeny-cards-grid {
  display: none;
}
#smeny-view.smeny-view--cards .smeny-grid {
  display: none;
}
#smeny-view.smeny-view--cards .smeny-cards-grid {
  display: block;
}

/* Směny cards grid */
.smeny-cards-grid {
  margin-top: 16px;
}
.smeny-cards-section {
  margin-bottom: 24px;
}
.smeny-cards-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  padding: 10px 14px;
  background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
  border: 1px solid var(--border);
  border-radius: 10px 10px 0 0;
}
.smeny-cards-section__header h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
}
.smeny-cards-section__actions {
  display: flex;
  gap: 6px;
}
.smeny-cards-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 12px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--border);
  border-top: 0;
  border-radius: 0 0 10px 10px;
}

/* Směny card */
.smeny-card {
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
}
.smeny-card--active {
  border-color: var(--ok);
  box-shadow: inset 0 0 0 1px var(--ok), 0 2px 8px rgba(22, 163, 74, 0.15);
}
.smeny-card--waiting {
  border-color: var(--warn);
  box-shadow: inset 0 0 0 1px var(--warn), 0 2px 8px rgba(245, 158, 11, 0.15);
}

/* Badge pro denní/noční */
.card__badge--sun {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(245, 158, 11, 0.12);
  color: #b45309;
}
.card__badge--moon {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(99, 102, 241, 0.12);
  color: #4f46e5;
}

/* Poznámka v kartě */
.card__note {
  font-size: 13px;
  color: var(--muted);
  white-space: pre-wrap;
  line-height: 1.4;
}

/* Responzivní úpravy */
@media (max-width: 768px) {
  .page-header {
    flex-direction: column;
    align-items: stretch;
  }
  .page-header__actions {
    justify-content: flex-start;
  }
  .stats-bar {
    gap: 8px;
    padding: 10px 12px;
  }
  .stats-bar__item {
    flex: 1 1 calc(50% - 8px);
    min-width: 120px;
    padding: 8px 10px;
  }
  .stats-bar__value {
    font-size: 16px;
  }
  .stats-bar__label {
    font-size: 12px;
  }
  .smeny-cards-list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .stats-bar__item {
    flex: 1 1 100%;
  }
  .smeny-cards-section__header {
    flex-direction: column;
    align-items: stretch;
  }
  .smeny-cards-section__actions {
    justify-content: stretch;
  }
  .smeny-cards-section__actions .btn {
    flex: 1;
    text-align: center;
  }
}

/* Karty - inline formuláře */
.card-form {
  display: contents;
}
.card__form-grid {
  display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5px;
}
.card__form-row--full {
  grid-column: 1 / -1;
}
.card__form-row--full select,
.card__form-row--full input {
  max-width: none;
}
.card__form-row {
  display: flex;
    align-items: center;
    gap: 2px;
    min-width: 0;
}
.card__form-row label {
  flex: 0 0;
  font-size: 11px;
  font-weight: 500;
  color: #64748b;
  line-height: 1.3;  
  white-space: nowrap;
}
.card__form-row select,
.card__form-row input[type="text"],
.card__form-row input[type="number"] {
  flex: 1;
  min-width: 0;  
  padding: 4px 6px;
  font-size: 12px;
  border: 1px solid #e2e8f0;
  border-radius: 4px;
  box-sizing: border-box;
  background: #fff;
}
.card__form-row select:focus,
.card__form-row input[type="text"]:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}
.card__form-row select:disabled,
.card__form-row input[type="text"]:disabled {
  background: #f8fafc;
  color: #64748b;
  cursor: not-allowed;
}
.card__form-row .card__field-value {
  flex: 1;
  font-size: 12px;
  color: #334155;
}
.card__form-row--time .card__time-inputs {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 6px;
}
.card__form-row--time .card__time-inputs select {
  flex: 1;
  min-width: 0;
}
.card__form-row--time .card__time-inputs span {
  color: #94a3b8;
  font-weight: 500;
}
.card__form-row--readonly .card__field-value {
  font-size: 13px;
  font-weight: 500;
}
.smeny-card .card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}
.smeny-card .card__actions {
  display: flex;
  gap: 4px;
}

/* ========================================
   SMS / LINKY STRÁNKA
   ======================================== */
.sms-section {
  margin-bottom: 32px;
}

.sms-section__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.sms-section__header h2 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1e293b;
}

/* Grid pro linky karty */
.linky-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}

.linka-card {
  min-width: 0;
}

.linka-card .card__header {
  padding: 12px 14px;
}

.linka-card .card__body {
  padding: 10px 14px;
}

.linka-card .card__footer {
  padding: 10px 14px;
  border-top: 1px solid #f1f5f9;
}

/* Editovatelné inputy v kartách */
.linka-input {
  border: 1px solid transparent;
  background: transparent;
  padding: 4px 6px;
  border-radius: 6px;
  font: inherit;
  color: inherit;
  transition: all .15s ease;
}

.linka-input:hover {
  background: rgba(0,0,0,.03);
}

.linka-input:focus {
  outline: none;
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(59,130,246,.15);
}

.linka-input--name {
  font-size: 16px;
  font-weight: 700;
  width: 100%;
  margin: -4px -6px;
}

.linka-input--id {
  width: 60px;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  background: transparent;
  color: #fff;
}

.linka-input--id:focus {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.4);
  color: #fff;
}

.linka-user {
  font-weight: 500;
  color: #1e293b;
}

/* Univerzální rozbalovací sekce v kartách */
.card__section--collapsible {
  padding: 0;
}

.card__section-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 10px 12px;
  background: none;
  border: none;
  font: inherit;
  font-size: 12px;
  font-weight: 600;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: .03em;
  cursor: pointer;
  transition: background .15s ease;
}

.card__section-toggle:hover {
  background: rgba(0,0,0,.02);
}

.card__section-toggle-icon {
  display: flex;
  color: #94a3b8;
}

.card__section-arrow {
  display: flex;
  margin-left: auto;
  transition: transform .2s ease;
}

.card__section--collapsible.is-open .card__section-arrow {
  transform: rotate(180deg);
}

.card__section-content {
  display: none;
  padding: 0 12px 12px;
}

.card__section--collapsible.is-open .card__section-content {
  display: block;
}

/* Univerzální info řádky v kartách */
.card__info {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.card__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2px 0;
}

.card__row-label {
  color: #64748b;
  font-size: 13px;
}

.card__row-value {
  font-size: 13px;
  color: #1e293b;
}

/* Checkbox switches v kartách */
.card__switches {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.card__switch-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #64748b;
  cursor: pointer;
}

.card__switch-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* Univerzální editovatelné inputy v kartách */
.card-input {
  font-size: 14px;
  padding: 4px 6px;
  border: 1px solid #e2e8f0;
  border-radius: 4px;
  background: #fff;
  color: #1e293b;
  width: 100%;
  transition: all .15s ease;
}

.card-input:hover {
  background: rgba(0,0,0,.03);
}

.card-input:focus {
  outline: none;
  border-color: #3b82f6;
  background: #fff;
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.card-input--name {
  font-size: 16px;
  font-weight: 600;
  border: none;
  background: transparent;
  padding: 5px;
  width: 100%;
  display: inline;
}

.card-input--name:focus {
  box-shadow: none;
}

.card-input--subtitle {
  font-size: 15px;
  color: #64748b;
  margin-top: 2px;
  border: none;
  background: transparent;
  padding: 5px;
  width: 100%;
}

.card-input--subtitle:focus {
  box-shadow: none;
}

.card-input--small {
  width: 120px;
  font-size: 13px;
}

.card h3 {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.card__color-field {
  display: flex;
  align-items: center;
  gap: 6px;
}

.card__color-preview {
  width: 16px;
  height: 16px;
  border-radius: 3px;
  flex-shrink: 0;
}

/* Empty state */
.empty-state {
  text-align: center;
  padding: 48px 24px;
  background: #f8fafc;
  border-radius: 12px;
  border: 2px dashed #e2e8f0;
}

.empty-state__icon {
  color: #94a3b8;
  margin-bottom: 12px;
}

.empty-state p {
  margin: 0;
  color: #64748b;
  font-size: 14px;
}

/* Filter karta */
.filter-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 20px;
}

.sms-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-end;
}

.sms-filter__group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sms-filter__label {
  font-size: 11px;
  font-weight: 600;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sms-filter__row {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.sms-filter__input {
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
  background: #fff;
}

.sms-filter__input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(59,130,246,.12);
}

.sms-filter__sep {
  color: #94a3b8;
  font-size: 14px;
}

.sms-filter__divider {
  width: 1px;
  height: 40px;
  background: #e2e8f0;
  align-self: flex-end;
  margin-bottom: 4px;
}

.sms-filter__presets {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.sms-filter__group--submit {
  align-self: flex-end;
}

/* Inline inputy v tabulce */
.input-inline {
  border: 1px solid transparent;
  background: transparent;
  padding: 4px 8px;
  border-radius: 4px;
  font: inherit;
  color: inherit;
  transition: all .15s ease;
  width: 80px;
}

.input-inline:hover {
  background: rgba(0,0,0,.03);
  border-color: var(--border);
}

.input-inline:focus {
  outline: none;
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(59,130,246,.12);
}

.input-inline--wide {
  width: 160px;
}

.actions-cell {
  white-space: nowrap;
}

.actions-cell .inline-form {
  display: inline;
}

.sms-stat-card {
  min-width: 0;
}

.sms-stat-card--active {
  border-color: #86efac;
}

.sms-stat-card--active .card__header {
  background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%);
}

.sms-stat-card__info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 12px;
  border-bottom: 1px solid #f1f5f9;
  margin-bottom: 12px;
}

.sms-stat-card__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
}

.sms-stat-card__label {
  color: #64748b;
}

.sms-stat-card__value {
  font-weight: 500;
  color: #1e293b;
  font-family: ui-monospace, monospace;
  font-size: 12px;
}

.sms-stat-card__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.sms-stat-card__stats--range {
  grid-template-columns: repeat(4, 1fr);
}

.sms-stat-card__stat {
  text-align: center;
  padding: 10px 4px;
  background: #f8fafc;
  border-radius: 8px;
}

.sms-stat-card__stat-label {
  display: block;
  font-size: 10px;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 4px;
}

.sms-stat-card__stat-value {
  display: block;
  font-size: 18px;
  font-weight: 700;
  color: #1e293b;
}

.sms-stat-card__stat-detail {
  display: block;
  font-size: 11px;
  margin-top: 2px;
}

.sms-stat-card__totals {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #f1f5f9;
}

.sms-stat-card__total {
  text-align: center;
}

.sms-stat-card__total-label {
  display: block;
  font-size: 10px;
  color: #64748b;
  margin-bottom: 2px;
}

.sms-stat-card__total-value {
  font-size: 16px;
  font-weight: 700;
}

.sms-stat-card__range {
  margin-top: 12px;
}

.sms-stat-card__range-title {
  font-size: 11px;
  font-weight: 600;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
  text-align: center;
}

/* Barevné utility třídy */
.text-success { color: #16a34a; }
.text-danger { color: #dc2626; }
.text-muted { color: #94a3b8; }

/* Badge styly */
.badge {
  display: inline-block;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 4px;
}

.bg-success {
  background: #dcfce7;
  color: #166534;
}

.bg-secondary {
  background: #f1f5f9;
  color: #64748b;
}

/* Responzivní úpravy pro SMS stránku */
@media (max-width: 640px) {
  .sms-section__header {
    flex-direction: column;
    align-items: stretch;
  }

  .sms-section__header h2 {
    margin-bottom: 8px;
  }

  .sms-filter {
    flex-direction: column;
    align-items: stretch;
  }

  .sms-filter__group {
    width: 100%;
  }

  .sms-filter__row {
    width: 100%;
  }

  .sms-filter__input {
    flex: 1;
    min-width: 0;
  }

  .sms-filter__divider {
    width: 100%;
    height: 1px;
    margin: 4px 0;
  }

  .sms-filter__presets {
    width: 100%;
  }

  .sms-filter__presets .btn {
    flex: 1;
    text-align: center;
  }

  .sms-stat-card__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .sms-stat-card__stats--range {
    grid-template-columns: repeat(2, 1fr);
  }
}