
/* ══════════════════════════════════════
   BOOKING PAGE
══════════════════════════════════════ */
.booking-hero {
  background: var(--bg2);
  border-bottom: 1px solid var(--line);
  padding: 52px 0 44px;
}

.booking-layout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 32px;
  align-items: start;
}

/* Step indicator */
.booking-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 36px;
  overflow-x: auto;
  scrollbar-width: none;
  padding-bottom: 2px;
}
.booking-steps::-webkit-scrollbar { display: none; }

.bstep {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.bstep-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--surface2);
  border: 1px solid var(--line);
  color: var(--text3);
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  transition: .25s var(--ease);
  flex-shrink: 0;
}
.bstep-label {
  font-size: 12px;
  color: var(--text3);
  font-weight: 600;
  white-space: nowrap;
  transition: .25s var(--ease);
}
.bstep.active .bstep-num { background: var(--orange); border-color: var(--orange); color: #fff; }
.bstep.active .bstep-label { color: var(--orange); }
.bstep.done .bstep-num { background: var(--green); border-color: var(--green); color: #fff; }
.bstep.done .bstep-label { color: var(--text2); }
.bstep-line {
  flex: 1;
  min-width: 24px;
  height: 1px;
  background: var(--line);
  margin: 0 6px;
}
.bstep.done + .bstep-line { background: var(--green); }

/* Booking form card */
.bform-card {
  padding: 28px;
}

.bform-section { margin-bottom: 28px; }
.bform-section:last-child { margin-bottom: 0; }
.bform-section-title {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text2);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.bform-section-title::before {
  content: '';
  width: 3px; height: 14px;
  background: var(--orange);
  border-radius: 2px;
  flex-shrink: 0;
}

/* Service selector chips */
.service-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.svc-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 99px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: .2s var(--ease);
  user-select: none;
}
.svc-chip:hover { border-color: var(--orange-brd); color: var(--text); }
.svc-chip.selected {
  background: var(--orange-dim);
  border-color: var(--orange);
  color: var(--orange);
  font-weight: 600;
}
.svc-chip-ico { font-size: 14px; }

/* Date/time grid */
.date-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 16px;
}
.date-btn {
  padding: 10px 8px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text2);
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: .2s var(--ease);
  line-height: 1.3;
}
.date-btn:hover { border-color: var(--orange-brd); color: var(--text); }
.date-btn.selected { background: var(--orange-dim); border-color: var(--orange); color: var(--orange); }
.date-btn.disabled { opacity: .35; cursor: not-allowed; pointer-events: none; }
.date-day { font-size: 10px; color: inherit; opacity: .7; }

.time-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.time-btn {
  padding: 9px 6px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text2);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: .2s var(--ease);
  text-align: center;
}
.time-btn:hover { border-color: var(--orange-brd); color: var(--text); }
.time-btn.selected { background: var(--orange-dim); border-color: var(--orange); color: var(--orange); }
.time-btn.busy { opacity: .3; cursor: not-allowed; pointer-events: none; text-decoration: line-through; }

/* Form inputs */
.bform-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.bform-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.bform-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text3);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.bform-input, .bform-select, .bform-textarea {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 11px 14px;
  font-size: 14px;
  color: var(--text);
  outline: none;
  font-family: 'Mulish', sans-serif;
  transition: .2s var(--ease);
}
.bform-input:focus, .bform-select:focus, .bform-textarea:focus {
  border-color: var(--orange);
  box-shadow: 0 0 0 3px rgba(255,107,0,.1);
}
.bform-input::placeholder, .bform-textarea::placeholder { color: var(--text3); }
.bform-select { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.bform-textarea { resize: vertical; min-height: 80px; }

.bform-input[readonly] {
  background: rgba(255,255,255,.04);
  color: var(--text2);
  cursor: not-allowed;
}
.bform-note {
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.45;
  color: var(--text3);
}

/* Nav buttons */
.bform-nav {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}

/* Booking sidebar summary */
.booking-summary {
  position: static;
  top: 80px;
}
.bsummary-card { padding: 24px; }
.bsummary-title {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text2);
  margin-bottom: 18px;
}
.bsum-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  font-size: 13px;
}
.bsum-row:last-of-type { border-bottom: none; }
.bsum-row .k { color: var(--text3); }
.bsum-row .v { color: var(--text); font-weight: 600; text-align: right; }
.bsum-row .v.orange { color: var(--orange); }
.bsum-empty { color: var(--text3); font-size: 13px; font-style: italic; }

/* Booking success */
.booking-success {
  text-align: center;
  padding: 48px 20px;
}
.bs-icon {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(34,197,94,.1);
  border: 2px solid var(--green);
  display: flex; align-items: center; justify-content: center;
  font-size: 36px;
  margin: 0 auto 24px;
  animation: popIn .4s var(--ease) both;
}
.bs-title { font-family: 'Oswald', sans-serif; font-size: 28px; font-weight: 700; margin-bottom: 10px; }
.bs-sub { font-size: 15px; color: var(--text2); margin-bottom: 28px; line-height: 1.6; }
.bs-detail {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 18px 22px;
  max-width: 360px;
  margin: 0 auto 28px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.bs-detail-row { display: flex; justify-content: space-between; font-size: 13px; }
.bs-detail-row .k { color: var(--text3); }
.bs-detail-row .v { font-weight: 600; color: var(--orange); }

/* ══════════════════════════════════════
   CHAT — BOTTOM SHEET (no FAB)
══════════════════════════════════════ */

/* Overlay behind chat/notifs */
#chat-overlay, #notifs-overlay {
  display: none;
  position: fixed; inset: 0;
  z-index: 498;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  opacity: 0;
  transition: opacity .3s ease;
}
#chat-overlay.vis, #notifs-overlay.vis {
  display: block;
  opacity: 1;
}

.chat-window {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 499;
  max-height: 80dvh;
  min-height: 320px;
  background: var(--bg2);
  border-top: 1px solid var(--line);
  border-radius: 20px 20px 0 0;
  display: flex;
  flex-direction: column;
  box-shadow: 0 -8px 40px rgba(0,0,0,.5);
  transform: translateY(100%);
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.chat-window.open {
  transform: translateY(0);
}

/* Desktop: positioned window */
@media (min-width: 901px) {
  .chat-window {
    left: auto; right: 28px;
    bottom: 28px;
    width: 360px; max-height: 520px;
    border-radius: 16px;
    border: 1px solid var(--line);
    transform: scale(.92) translateY(16px);
    transform-origin: bottom right;
    opacity: 0; pointer-events: none;
  }
  .chat-window.open {
    transform: scale(1) translateY(0);
    opacity: 1; pointer-events: all;
  }
  #chat-overlay { display: none !important; }
}

/* Drag handle */
.chat-handle {
  width: 36px; height: 4px;
  background: rgba(255,255,255,.18);
  border-radius: 99px;
  margin: 12px auto 0;
  flex-shrink: 0;
}
@media (min-width: 901px) { .chat-handle { display: none; } }

.chat-head { flex-shrink: 0; }
.chat-head-inner {
  padding: 14px 16px 14px;
  background: var(--orange);
  border-radius: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}
@media (min-width: 901px) {
  .chat-head-inner { border-radius: 15px 15px 0 0; }
}

.chat-head-av {
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.chat-head-name { font-family: 'Oswald', sans-serif; font-size: 15px; font-weight: 600; color: #fff; }
.chat-head-status { font-size: 11px; color: rgba(255,255,255,.8); display: flex; align-items: center; gap: 5px; }
.chat-online-dot {
  width: 7px; height: 7px; background: #4ade80; border-radius: 50%;
  animation: blink 2s infinite;
  display: inline-block;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.4} }

.chat-head-close {
  margin-left: auto;
  color: rgba(255,255,255,.75);
  font-size: 22px; line-height: 1;
  width: 32px; height: 32px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: .2s; cursor: pointer;
  flex-shrink: 0;
}
.chat-head-close:hover { color: #fff; background: rgba(255,255,255,.15); }

.chat-messages {
  flex: 1; overflow-y: auto;
  padding: 14px 14px 6px;
  display: flex; flex-direction: column; gap: 10px;
  scrollbar-width: thin;
  scrollbar-color: var(--surface2) transparent;
}
.chat-msg { max-width: 80%; display: flex; flex-direction: column; gap: 2px; }
.chat-msg.bot  { align-self: flex-start; }
.chat-msg.user { align-self: flex-end; }
.chat-bubble {
  padding: 9px 13px; border-radius: 12px;
  font-size: 13px; line-height: 1.55;
}
.chat-msg.bot .chat-bubble  { background: var(--surface2); color: var(--text); border-bottom-left-radius: 4px; }
.chat-msg.user .chat-bubble { background: var(--orange); color: #fff; border-bottom-right-radius: 4px; }
.chat-time { font-size: 10px; color: var(--text3); padding: 0 4px; }
.chat-msg.user .chat-time { text-align: right; }

.chat-typing {
  display: flex; gap: 4px; align-items: center;
  padding: 10px 14px;
  background: var(--surface2);
  border-radius: 12px; border-bottom-left-radius: 4px;
  width: fit-content;
}
.chat-typing span {
  width: 6px; height: 6px; background: var(--text3); border-radius: 50%;
  animation: typingDot 1.2s infinite;
}
.chat-typing span:nth-child(2) { animation-delay: .2s; }
.chat-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes typingDot { 0%,80%,100%{transform:scale(1);opacity:.4} 40%{transform:scale(1.3);opacity:1} }

.chat-quick-replies {
  padding: 8px 14px; display: flex; gap: 6px; flex-wrap: wrap;
  flex-shrink: 0; border-top: 1px solid var(--line);
}
.qr-btn {
  font-size: 12px; color: var(--orange);
  border: 1px solid var(--orange-brd); background: var(--orange-dim);
  padding: 5px 10px; border-radius: 99px; cursor: pointer;
  transition: .2s var(--ease); white-space: nowrap;
}
.qr-btn:active { background: rgba(255,107,0,.22); transform: scale(.96); }

.chat-input-row {
  padding: 10px 12px;
  padding-bottom: max(10px, env(safe-area-inset-bottom, 10px));
  display: flex; gap: 8px; align-items: center;
  border-top: 1px solid var(--line); flex-shrink: 0;
}
.chat-input {
  flex: 1; background: var(--surface); border: 1px solid var(--line);
  border-radius: 20px; padding: 10px 14px;
  font-size: 16px; color: var(--text); outline: none;
  font-family: 'Mulish', sans-serif; transition: .2s var(--ease);
}
.chat-input:focus { border-color: var(--orange-brd); }
.chat-input::placeholder { color: var(--text3); font-size: 14px; }
.chat-send {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--orange); color: #fff;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: .2s var(--ease);
}
.chat-send:hover  { background: var(--orange-l); transform: scale(1.07); }
.chat-send:active { transform: scale(.93); }


/* ══════════════════════════════════════
   NOTIFICATIONS PANEL — BOTTOM SHEET
══════════════════════════════════════ */
#notifs-panel {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 499;
  max-height: 85dvh;
  background: var(--bg2);
  border-top: 1px solid var(--line);
  border-radius: 20px 20px 0 0;
  display: flex; flex-direction: column;
  box-shadow: 0 -8px 40px rgba(0,0,0,.5);
  transform: translateY(100%);
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
#notifs-panel.open { transform: translateY(0); }

@media (min-width: 901px) {
  #notifs-panel {
    left: auto; right: 28px; bottom: 28px;
    width: 380px; max-height: 560px;
    border-radius: 16px;
    border: 1px solid var(--line);
    transform: scale(.92) translateY(16px);
    transform-origin: bottom right;
    opacity: 0; pointer-events: none;
  }
  #notifs-panel.open { transform: scale(1) translateY(0); opacity: 1; pointer-events: all; }
  #notifs-overlay { display: none !important; }
}

.notifs-handle {
  width: 36px; height: 4px;
  background: rgba(255,255,255,.18); border-radius: 99px;
  margin: 12px auto 0; flex-shrink: 0;
}
@media (min-width: 901px) { .notifs-handle { display: none; } }

.notifs-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px 12px; border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.notifs-title {
  font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .5px;
}
.notifs-close {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--surface); color: var(--text3);
  font-size: 20px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: .2s;
}
.notifs-close:hover { background: var(--surface2); color: var(--text); }

.notifs-body {
  flex: 1; overflow-y: auto;
  padding: 10px 14px 8px;
  display: flex; flex-direction: column; gap: 8px;
}

.notif-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px; border-radius: 10px;
  cursor: pointer; transition: .2s var(--ease);
  position: relative;
}
.notif-item.unread { border-left: 3px solid var(--orange); }
.notif-item:active { transform: scale(.99); opacity: .85; }
.notif-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--orange); flex-shrink: 0; margin-top: 5px;
}
.notif-ico {
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
}
.notif-ico.success { background: rgba(34,197,94,.12); }
.notif-ico.info    { background: rgba(96,165,250,.12); }
.notif-ico.warning { background: rgba(245,158,11,.12); }
.notif-ico.promo   { background: rgba(255,107,0,.12);  }
.notif-content { flex: 1; min-width: 0; }
.notif-title  { font-weight: 700; font-size: 13px; margin-bottom: 3px; }
.notif-text   { font-size: 12px; color: var(--text2); line-height: 1.45; }
.notif-time   { font-size: 11px; color: var(--text3); margin-top: 4px; }

.notifs-footer {
  padding: 12px 16px;
  padding-bottom: max(12px, env(safe-area-inset-bottom, 12px));
  border-top: 1px solid var(--line); flex-shrink: 0;
}
.notifs-clear-btn {
  width: 100%; padding: 10px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 8px; font-size: 13px; font-weight: 600;
  color: var(--text2); cursor: pointer; transition: .2s;
  font-family: 'Mulish', sans-serif;
}
.notifs-clear-btn:hover { background: var(--surface2); color: var(--text); }
.notifs-clear-btn:active { transform: scale(.98); }

/* ══════════════════════════════════════
   ADMIN PANEL
══════════════════════════════════════ */
.admin-layout {
  display: flex;
  min-height: calc(100vh - var(--nav-h));
}

/* Admin sidebar */
.admin-sidebar {
  width: 220px;
  flex-shrink: 0;
  background: var(--bg2);
  border-right: 1px solid var(--line);
  padding: 24px 0;
  position: static;
  top: var(--nav-h);
  height: calc(100vh - var(--nav-h));
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.admin-nav-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--text3);
  padding: 0 18px;
  margin-bottom: 8px;
  margin-top: 20px;
}
.admin-nav-label:first-child { margin-top: 0; }
.admin-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  color: var(--text2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: .2s var(--ease);
  border-left: 2px solid transparent;
  position: relative;
}
.admin-nav-item:hover { background: rgba(255,255,255,.04); color: var(--text); }
.admin-nav-item.active { color: var(--orange); background: var(--orange-dim); border-left-color: var(--orange); }
.admin-nav-icon { font-size: 15px; flex-shrink: 0; }
.admin-nav-badge {
  margin-left: auto;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--orange);
  color: #fff; font-size: 10px; font-weight: 700;
  border-radius: 99px;
  display: flex; align-items: center; justify-content: center;
}

/* Admin content */
.admin-content {
  flex: 1;
  overflow: hidden;
  padding: 28px;
  min-width: 0;
}
.admin-pane { display: none; animation: pageIn .25s var(--ease) both; }
.admin-pane.active { display: block; }

.admin-page-title {
  font-family: 'Oswald', sans-serif;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Stats row */
.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 28px;
}
.astat-card {
  padding: 18px 20px;
  border-radius: 8px;
}
.astat-label { font-size: 11px; color: var(--text3); font-weight: 600; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 6px; }
.astat-num { font-family: 'Oswald', sans-serif; font-size: 28px; font-weight: 700; color: var(--text); line-height: 1; }
.astat-change { font-size: 11px; margin-top: 4px; }
.astat-change.up { color: var(--green); }
.astat-change.down { color: var(--red); }

/* Orders table */
.admin-table-wrap {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  overflow-x: auto;
}
.admin-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 640px;
}
.admin-table thead { background: var(--surface2); }
.admin-table th {
  padding: 12px 16px;
  text-align: left;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text3);
  white-space: nowrap;
}
.admin-table td {
  padding: 14px 16px;
  font-size: 13px;
  border-top: 1px solid var(--line);
  vertical-align: middle;
}
.admin-table tbody tr:hover td { background: rgba(255,255,255,.02); }

.order-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .5px;
  white-space: nowrap;
}
.order-status.new { background: rgba(99,179,237,.12); color: #63b3ed; }
.order-status.process { background: var(--orange-dim); color: var(--orange); }
.order-status.done { background: rgba(34,197,94,.1); color: var(--green); }
.order-status.cancelled { background: rgba(239,68,68,.1); color: var(--red); }
.order-status::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.order-status.process::before { animation: blink 1.5s infinite; }

.order-actions { display: flex; gap: 6px; }
.act-btn {
  padding: 5px 11px;
  border-radius: 5px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .5px;
  transition: .2s var(--ease);
}
.act-btn.view { background: rgba(255,255,255,.06); color: var(--text2); border: 1px solid var(--line); }
.act-btn.view:hover { color: var(--text); background: rgba(255,255,255,.1); }
.act-btn.edit { background: var(--orange-dim); color: var(--orange); border: 1px solid var(--orange-brd); }
.act-btn.edit:hover { background: rgba(255,107,0,.2); }

/* Admin filter bar */
.admin-filters {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
  align-items: center;
}
.admin-filter-btn {
  padding: 7px 14px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text2);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: .2s var(--ease);
}
.admin-filter-btn:hover, .admin-filter-btn.active { color: var(--orange); border-color: var(--orange); background: var(--orange-dim); }
.admin-search {
  margin-left: auto;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 7px 14px;
  font-size: 13px;
  color: var(--text);
  outline: none;
  width: 200px;
  transition: .2s var(--ease);
  font-family: 'Mulish', sans-serif;
}
.admin-search:focus { border-color: var(--orange-brd); }

/* Admin calendar */
.admin-calendar {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 20px;
  align-items: start;
}
.cal-grid-wrap { }
.cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.cal-month { font-family: 'Oswald', sans-serif; font-size: 18px; font-weight: 600; }
.cal-nav { display: flex; gap: 6px; }
.cal-nav-btn {
  width: 32px; height: 32px;
  border-radius: 6px;
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--text2);
  font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: .2s var(--ease);
}
.cal-nav-btn:hover { border-color: var(--orange-brd); color: var(--orange); }
.cal-days-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: 6px;
}
.cal-day-name { text-align: center; font-size: 11px; color: var(--text3); font-weight: 600; padding: 6px; }
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.cal-cell {
  aspect-ratio: 1;
  border-radius: 8px;
  border: 1px solid transparent;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: .2s var(--ease);
  position: relative;
  gap: 3px;
}
.cal-cell:hover { background: var(--surface2); border-color: var(--line); }
.cal-cell.today { border-color: var(--orange-brd); background: var(--orange-dim); }
.cal-cell.selected { background: var(--orange); border-color: var(--orange); }
.cal-cell.other-month .cal-cell-num { opacity: .3; }
.cal-cell.has-orders .cal-cell-dot { display: block; }
.cal-cell-num { font-size: 13px; font-weight: 600; line-height: 1; }
.cal-cell.selected .cal-cell-num { color: #fff; }
.cal-cell-dot {
  display: none;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--orange);
}
.cal-cell.selected .cal-cell-dot { background: rgba(255,255,255,.6); }

.cal-day-orders { }
.cal-day-title {
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 14px;
  color: var(--orange);
}
.cal-order-item {
  padding: 12px 14px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface);
  margin-bottom: 8px;
  cursor: pointer;
  transition: .2s var(--ease);
}
.cal-order-item:hover { border-color: var(--orange-brd); }
.cal-order-time { font-size: 12px; color: var(--orange); font-weight: 700; margin-bottom: 3px; }
.cal-order-name { font-size: 13px; font-weight: 600; }
.cal-order-svc { font-size: 12px; color: var(--text3); margin-top: 2px; }

/* Admin messages */
.admin-msg-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  height: 560px;
}
.msg-list { border-right: 1px solid var(--line); overflow-y: auto; }
.msg-list-item {
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: .2s var(--ease);
  display: flex;
  gap: 11px;
  align-items: flex-start;
}
.msg-list-item:hover { background: rgba(255,255,255,.03); }
.msg-list-item.active { background: var(--orange-dim); border-left: 2px solid var(--orange); }
.msg-av {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--surface2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--orange);
  flex-shrink: 0;
}
.msg-info { min-width: 0; flex: 1; }
.msg-name { font-size: 13px; font-weight: 700; margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.msg-preview { font-size: 12px; color: var(--text3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.msg-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
.msg-time { font-size: 10px; color: var(--text3); white-space: nowrap; }
.msg-unread-badge { width: 16px; height: 16px; background: var(--orange); border-radius: 50%; font-size: 9px; font-weight: 700; color: #fff; display: flex; align-items: center; justify-content: center; }

.msg-chat-area {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.msg-chat-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bg2);
  flex-shrink: 0;
}
.msg-chat-name { font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 600; }
.msg-chat-phone { font-size: 12px; color: var(--text3); }
.msg-chat-actions { margin-left: auto; display: flex; gap: 8px; }
.msg-action-btn {
  padding: 6px 12px;
  border-radius: 5px;
  font-size: 11px;
  font-weight: 600;
  background: var(--orange-dim);
  border: 1px solid var(--orange-brd);
  color: var(--orange);
  cursor: pointer;
  transition: .2s var(--ease);
}
.msg-action-btn:hover { background: rgba(255,107,0,.2); }
.msg-chat-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.msg-chat-input-row {
  padding: 12px 16px;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 10px;
  align-items: flex-end;
  flex-shrink: 0;
}
.msg-chat-input {
  flex: 1;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 13px;
  color: var(--text);
  outline: none;
  resize: none;
  font-family: 'Mulish', sans-serif;
  transition: .2s var(--ease);
  max-height: 100px;
}
.msg-chat-input:focus { border-color: var(--orange-brd); }
.msg-send-btn {
  padding: 10px 18px;
  background: var(--orange);
  color: #fff;
  border-radius: 8px;
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  flex-shrink: 0;
  transition: .2s var(--ease);
}
.msg-send-btn:hover { background: var(--orange-l); }

/* Admin quick stats panel  */
.admin-quick-actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}
.aqa-card {
  padding: 16px;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: .2s var(--ease);
}
.aqa-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.25); }
.aqa-ico { font-size: 20px; }
.aqa-t { font-weight: 700; font-size: 13px; }
.aqa-d { font-size: 11px; color: var(--text2); margin-top: 2px; }

/* Mobile admin */
@media(max-width:900px) {
  .admin-layout { flex-direction: column; }
  .admin-sidebar {
    width: 100%;
    height: auto;
    position: static;
    flex-direction: row;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 12px 0;
    border-right: none;
    border-bottom: 1px solid var(--line);
    scrollbar-width: none;
    gap: 0;
  }
  .admin-sidebar::-webkit-scrollbar { display: none; }
  .admin-nav-label { display: none; }
  .admin-nav-item {
    flex-direction: column;
    gap: 4px;
    padding: 8px 14px;
    border-left: none;
    border-bottom: 2px solid transparent;
    white-space: nowrap;
    font-size: 11px;
  }
  .admin-nav-item.active { border-bottom-color: var(--orange); border-left-color: transparent; }
  .admin-nav-badge { position: absolute; top: 4px; right: 6px; }
  .admin-content { padding: 20px 16px; }
  .admin-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .admin-calendar { grid-template-columns: 1fr; }
  .admin-msg-layout { grid-template-columns: 1fr; height: auto; }
  .msg-list { max-height: 200px; }
  .msg-chat-area { height: 400px; }
  .admin-quick-actions { grid-template-columns: 1fr 1fr; }
}
@media(max-width:560px) {
  .admin-stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .astat-num { font-size: 22px; }
  .booking-layout { grid-template-columns: 1fr; }
  .booking-summary { display: none; } /* скрыто — заменено кнопкой корзины */
  .bform-row { grid-template-columns: 1fr; }
  .date-grid { grid-template-columns: repeat(3, 1fr); }
  .time-grid { grid-template-columns: repeat(3, 1fr); }
  .admin-quick-actions { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   CONFIRM MODAL / GENERIC MODAL
══════════════════════════════════════ */
.cmodal-overlay {
  display: none;
  position: fixed; inset: 0;
  z-index: 900;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  align-items: center; justify-content: center;
}
.cmodal-overlay.open { display: flex; }
.cmodal-box {
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 28px 24px 24px;
  width: 92vw;
  max-width: 380px;
  box-shadow: 0 24px 64px rgba(0,0,0,.6);
  animation: modalIn .22s cubic-bezier(.16,1,.3,1);
}
@keyframes modalIn { from{transform:scale(.92) translateY(12px);opacity:0} to{transform:none;opacity:1} }
.cmodal-title { font-family:'Oswald',sans-serif; font-size:18px; font-weight:700; margin-bottom:8px; }
.cmodal-sub   { font-size:13px; color:var(--text2); line-height:1.5; margin-bottom:20px; }
.cmodal-actions { display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap; }


/* ══════════════════════════════════════
   MODAL UI KIT / DETAIL SURFACES
══════════════════════════════════════ */
.cmodal-overlay,
.owiz-overlay,
.odet-overlay{
  background: radial-gradient(circle at top, rgba(255,107,0,.10), transparent 34%), rgba(6,10,16,.78);
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
}

.cmodal-box,
.cmodal-card{
  position: relative;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)),
    linear-gradient(180deg, rgba(255,107,0,.035), transparent 28%),
    var(--bg2);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow:
    0 28px 90px rgba(0,0,0,.46),
    0 12px 30px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.05);
}
.cmodal-box::before,
.cmodal-card::before,
.owiz-box::before,
.odet-panel::before{
  content:"";
  position:absolute; inset:0; pointer-events:none;
  border-radius:inherit;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.cmodal-box{ border-radius:22px; padding:28px 24px 24px; max-width:420px; }
.cmodal-card{ width:min(92vw, 920px); border-radius:24px; overflow:hidden; animation: modalIn .22s cubic-bezier(.16,1,.3,1); }
.cmodal-head{
  display:flex; align-items:flex-start; justify-content:space-between; gap:14px;
  padding:22px 24px 16px;
  border-bottom:1px solid rgba(255,255,255,.07);
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,0));
}
.cmodal-head h3{
  margin:0; font-family:'Oswald',sans-serif; font-size:20px; line-height:1.2; letter-spacing:.3px;
}
.cmodal-body{ padding:20px 24px 24px; }
.cmodal-close{
  width:38px; height:38px; border-radius:12px; flex:0 0 auto;
  border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.04); color:var(--text2);
  display:flex; align-items:center; justify-content:center; cursor:pointer; transition:.2s;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
.cmodal-close:hover{ color:var(--text); border-color:rgba(255,107,0,.32); background:rgba(255,107,0,.10); transform:translateY(-1px); }
.cmodal-sub{ color:var(--text2); }
.cmodal-actions .btn{ min-height:42px; }

.modal-surface,
.detail-surface,
.schedule-surface{
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.07);
  border-radius:18px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

@media (max-width: 700px){
  .cmodal-box{ width:min(100vw - 20px, 440px); border-radius:22px; padding:22px 18px 18px; }
  .cmodal-card{ width:min(100vw - 14px, 920px); border-radius:22px; }
  .cmodal-head{ padding:18px 18px 14px; }
  .cmodal-body{ padding:16px 18px 18px; }
}

/* ══════════════════════════════════════
   GLOBAL TOAST
══════════════════════════════════════ */
.g-toast {
  position: fixed;
  bottom: calc(var(--bnav-h, 72px) + 16px);
  left: 50%; transform: translateX(-50%) translateY(20px);
  z-index: 1000;
  background: var(--surface2);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 99px;
  padding: 10px 20px;
  font-size: 13px; font-weight: 600;
  white-space: nowrap;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  opacity: 0; pointer-events: none;
  transition: opacity .25s, transform .3s cubic-bezier(.16,1,.3,1);
}
.g-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }
.g-toast.error { background: rgba(239,68,68,.15); border-color: rgba(239,68,68,.35); color: #f87171; }

/* ══════════════════════════════════════
   ORDER STATUS SELECT (inline)
══════════════════════════════════════ */
.order-status-sel {
  border-radius: 99px;
  padding: 3px 8px;
  font-size: 11px; font-weight: 700;
  cursor: pointer;
  border: 1px solid transparent;
}
.order-status-sel.new       { background:rgba(96,165,250,.15); color:#60a5fa; border-color:rgba(96,165,250,.3); }
.order-status-sel.process   { background:rgba(245,158,11,.12); color:#f59e0b; border-color:rgba(245,158,11,.3); }
.order-status-sel.done      { background:rgba(34,197,94,.12);  color:#22c55e; border-color:rgba(34,197,94,.3); }
.order-status-sel.cancelled { background:rgba(239,68,68,.1);   color:#ef4444; border-color:rgba(239,68,68,.25); }

/* ══════════════════════════════════════
   SCHED BUTTON — finish state
══════════════════════════════════════ */
.sched-btn.finish {
  background: rgba(245,158,11,.15);
  color: #f59e0b;
  border: 1px solid rgba(245,158,11,.3);
  font-size: 11px; font-weight: 700;
  border-radius: 6px; padding: 6px 10px;
  cursor: pointer; transition: .2s;
}
.sched-btn.finish:hover { background: rgba(245,158,11,.25); }


/* PATCH 2026-03-11 — parts order modal */
.parts-order-modal-box .pof-fields{margin-top:12px;}
.parts-order-modal-box .pof-group{margin-bottom:12px;}
.parts-order-modal-box .pof-input{width:100%;}
.parts-order-modal-box .cmodal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;}
@media (max-width:640px){
  .parts-order-modal-box{width:min(100vw - 24px,520px)!important;padding:18px!important;border-radius:18px!important;}
  .parts-order-modal-box .cmodal-actions .btn{width:100%;}
}

.client-card-hero{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));margin-bottom:14px}.client-card-ico,.car-card-ico{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;background:rgba(255,255,255,.05);border:1px solid var(--line);flex-shrink:0}.client-card-title{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700}.client-card-sub{font-size:13px;color:var(--text2);margin-top:3px}.cars-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.car-card{padding:16px;border:1px solid var(--line);border-radius:20px;background:var(--card)}.car-card.is-default{border-color:rgba(251,146,60,.35);box-shadow:0 0 0 1px rgba(251,146,60,.12) inset}.car-card-head{display:flex;align-items:flex-start;gap:12px}.car-card-main{min-width:0;flex:1}.car-card-title{font-weight:800;font-size:15px}.car-card-sub,.car-card-meta{font-size:12px;color:var(--text2);margin-top:4px;line-height:1.5}.car-default-chip{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;padding:5px 8px;border-radius:999px;background:rgba(251,146,60,.14);color:var(--orange);border:1px solid rgba(251,146,60,.22)}.car-card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.car-empty{padding:24px;text-align:center;border-style:dashed}.car-empty-ico{font-size:32px;margin-bottom:8px}.car-empty-t{font-weight:800;margin-bottom:6px}.car-empty-d{font-size:13px;color:var(--text2)}.vehicle-editor{padding:18px;border-radius:20px}.vehicle-editor .profile-form{display:grid;gap:12px}@media (max-width:720px){.vehicle-editor .profile-form{grid-template-columns:1fr!important}.cars-grid{grid-template-columns:1fr}}


.booking-vehicles-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:8px}
.booking-vehicle-card{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:var(--card);border-radius:14px;padding:12px 14px;text-align:left;cursor:pointer;color:inherit}
.booking-vehicle-card.selected{border-color:var(--orange);box-shadow:0 0 0 2px rgba(245,158,11,.12)}
.booking-vehicle-card .ico{width:34px;height:34px;border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.booking-vehicle-card .main{display:flex;flex-direction:column;min-width:0;flex:1}
.booking-vehicle-card .title{font-weight:700;font-size:13px}
.booking-vehicle-card .sub{font-size:11px;color:var(--text3);white-space:normal}
.booking-vehicle-card .chip{font-size:10px;color:var(--orange);border:1px solid var(--orange-brd);background:var(--orange-dim);padding:4px 8px;border-radius:999px}
.garage-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:12px}
.garage-stats>div{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:10px 8px;text-align:center}
.garage-stats b{display:block;font-family:'Oswald',sans-serif;font-size:16px;color:var(--text)}
.garage-stats span{display:block;font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px}
.garage-km{font-family:'Oswald',sans-serif;font-size:14px;color:var(--orange);margin-left:auto;white-space:nowrap}
.garage-history-list{display:grid;gap:8px;margin-top:12px}
.garage-history-item{display:flex;align-items:center;gap:10px;width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:10px 12px;text-align:left;cursor:pointer}
.garage-history-item .badge{font-size:10px;padding:4px 8px;border-radius:999px;background:var(--green-dim);border:1px solid rgba(16,185,129,.16);color:#10b981;flex-shrink:0}
.garage-history-item .badge.parts{background:var(--orange-dim);border-color:var(--orange-brd);color:var(--orange)}
.garage-history-item .name{font-weight:600;font-size:12px;flex:1;min-width:0}
.garage-history-item .meta{font-size:11px;color:var(--text3);white-space:nowrap}
.garage-empty-mini{font-size:12px;color:var(--text3);padding:10px 0}
.vehicle-detail-card{padding:18px}
.vehicle-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}
.vehicle-detail-grid>div{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px}
.vehicle-detail-grid span{display:block;font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.vehicle-detail-grid b{font-family:'Oswald',sans-serif;font-size:16px}
.vehicle-maint-row,.vehicle-last-order .ttl,.vehicle-detail-card .ttl{font-size:12px;color:var(--text2);margin-top:10px}
@media (max-width: 720px){.garage-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.vehicle-detail-grid{grid-template-columns:1fr}}


/* === v9.4.60 unified card system === */
:root{
  --card-radius-sm:12px;
  --card-radius-md:18px;
  --card-radius-lg:22px;
  --card-border:rgba(255,255,255,.08);
  --card-border-strong:rgba(255,255,255,.13);
  --card-shadow-soft:0 10px 30px rgba(0,0,0,.18);
  --card-shadow-hover:0 18px 46px rgba(0,0,0,.28);
  --card-shadow-accent:0 0 0 1px rgba(255,107,0,.14) inset, 0 20px 50px rgba(255,107,0,.10);
}
.card,
.hv-card,
.st-card,
.team-card,
.rv-card,
.faq-item,
.part-card,
.parts-why-card,
.val-card,
.client-card-hero,
.car-card,
.vehicle-detail-card,
.master-card,
.schedule-card,
.notif-card{
  border-radius:var(--card-radius-md);
  border:1px solid var(--card-border);
  box-shadow:var(--card-shadow-soft);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
  background:linear-gradient(180deg, rgba(255,255,255,.038), rgba(255,255,255,.018));
  backdrop-filter:blur(10px);
}
.card:hover,
.hv-card:hover,
.st-card:hover,
.team-card:hover,
.rv-card:hover,
.faq-item:hover,
.part-card:hover,
.parts-why-card:hover,
.val-card:hover,
.car-card:hover{
  transform:translateY(-2px);
  border-color:var(--card-border-strong);
  box-shadow:var(--card-shadow-hover);
}
.card.is-selected,
.car-card.is-default,
.hv-card.is-active,
.st-card.is-active,
.vehicle-detail-card{
  border-color:rgba(255,107,0,.30);
  box-shadow:var(--card-shadow-accent);
}
.hero-visual{
  position:relative;
  padding:8px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 24px 70px rgba(0,0,0,.28);
}
.hero-visual::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(135deg, rgba(255,107,0,.12), transparent 30%, transparent 70%, rgba(255,255,255,.03));
}
.hv-card{
  position:relative;
  overflow:hidden;
  min-height:88px;
}
.hv-card::after,
.st-card::after,
.car-card::after{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(135deg, rgba(255,255,255,.04), transparent 35%, transparent 65%, rgba(255,255,255,.02));
}
.client-card-hero,
.vehicle-detail-card{
  border-radius:var(--card-radius-lg);
}
.st-card,
.part-card,
.team-card,
.rv-card,
.faq-item,
.val-card{
  border-radius:20px;
}
.hero-stats,
.parts-hero-stats,
.mo-hero,
.cab-hero,
.owner-hero{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 14px 40px rgba(0,0,0,.16);
}
.reveal{ will-change:transform, opacity; }
.reveal:not(.in){ opacity:0; transform:translateY(18px) scale(.985); }
.reveal.in{ opacity:1; transform:none; }
@media (max-width:720px){
  .card,
  .hv-card,
  .st-card,
  .team-card,
  .rv-card,
  .faq-item,
  .part-card,
  .parts-why-card,
  .val-card,
  .client-card-hero,
  .car-card,
  .vehicle-detail-card{ border-radius:16px; }
  .hero-visual{ border-radius:20px; padding:6px; }
}


/* === v9.4.61 internal panels visual-system === */
.admin-pane,
.owner-pane,
.master-pane,
.admin-table-wrap,
.admin-msg-layout,
.owner-block,
.a-stat-card,
.astat-card,
.cal-day-orders,
.msg-chat-area,
.msg-list,
.msg-composer,
.price-view,
.admin-quick-actions .aqa-card,
.aqa-card{
  border-radius:22px;
}

.admin-pane{
  padding:18px;
  border:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.012));
  box-shadow:0 18px 48px rgba(0,0,0,.18);
}
.admin-pane.active{ display:block; }
.admin-page-title{
  font-size:26px;
  letter-spacing:.2px;
  margin-bottom:18px;
}
.admin-page-title + div[style*="display:flex"],
.admin-pane > div[style*="display:flex"]:has(.admin-page-title){
  padding:2px 0 14px;
}
.admin-stats-grid{ gap:16px; }
.astat-card{
  padding:20px 22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.018));
  box-shadow:0 14px 38px rgba(0,0,0,.18);
  position:relative;
  overflow:hidden;
}
.astat-card::after,
.owner-block::after,
.admin-table-wrap::after,
.admin-msg-layout::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(135deg, rgba(255,255,255,.04), transparent 35%, transparent 70%, rgba(255,255,255,.02));
}
.astat-num{ font-size:30px; }
.astat-label{ color:var(--text2); }
.admin-filters{ gap:10px; margin-bottom:18px; }
.admin-filter-btn{
  min-height:40px;
  padding:9px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.admin-search{
  height:42px;
  border-radius:14px;
  min-width:220px;
  background:rgba(255,255,255,.028);
  border-color:rgba(255,255,255,.08);
}
.admin-table-wrap{
  position:relative;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012));
  box-shadow:0 18px 50px rgba(0,0,0,.18);
}
.admin-table thead{ background:rgba(255,255,255,.03); }
.admin-table th{ color:var(--text2); }
.admin-table td{ border-top:1px solid rgba(255,255,255,.06); }
.admin-table tbody tr{ transition:background .18s ease, transform .18s ease; }
.admin-table tbody tr:hover td{ background:rgba(255,255,255,.03); }

.admin-msg-layout{
  position:relative;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012));
  box-shadow:0 18px 50px rgba(0,0,0,.2);
}
.msg-list-item{ transition:background .18s ease, border-color .18s ease, transform .18s ease; }
.msg-list-item:hover{ background:rgba(255,255,255,.03); }
.msg-list-item.active{ background:rgba(255,107,0,.10); border-left:2px solid var(--orange); }

.admin-calendar{ gap:22px; }
.cal-grid-wrap, .cal-day-orders{
  position:relative;
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.014));
  box-shadow:0 18px 48px rgba(0,0,0,.18);
}
.cal-grid{ gap:8px; }
.cal-cell{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.05);
  background:rgba(255,255,255,.015);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
.cal-cell:hover{ border-color:rgba(255,255,255,.12); box-shadow:0 10px 24px rgba(0,0,0,.16); }
.cal-order-item{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.025);
  box-shadow:0 10px 24px rgba(0,0,0,.14);
}

.owner-block{
  position:relative;
  border-radius:24px!important;
  border:1px solid rgba(255,255,255,.07)!important;
  background:linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012))!important;
  box-shadow:0 18px 50px rgba(0,0,0,.18)!important;
}
.owner-block-elevated{
  box-shadow:0 24px 60px rgba(0,0,0,.22)!important;
}
.owner-block-title{ font-size:15px; letter-spacing:.3px; }
.owner-hero{
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 24px 64px rgba(0,0,0,.22);
}
.owner-tab{
  min-height:44px;
  padding:0 16px;
  border-bottom-width:2px;
}
.owner-tab.active{ box-shadow:inset 0 -1px 0 rgba(255,107,0,.25); }

.admin-master-grid{ gap:14px; }
.admin-master-card{
  position:relative;
  min-height:168px;
  padding:18px;
  border-radius:22px;
}
.admin-master-card .car-title{ font-size:16px; font-weight:800; }
.admin-master-card .car-sub{ color:var(--text2); }
.admin-master-card-actions{ display:flex; gap:8px; flex-wrap:wrap; margin-top:12px; }
.master-card, .schedule-card{
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.014));
  box-shadow:0 18px 46px rgba(0,0,0,.18);
}

.price-view{
  position:relative;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.02);
  box-shadow:0 10px 24px rgba(0,0,0,.14);
}

@media (max-width:900px){
  .admin-pane{ padding:14px; }
  .admin-page-title{ font-size:22px; }
  .admin-table-wrap, .admin-msg-layout, .owner-block, .cal-grid-wrap, .cal-day-orders{ border-radius:18px; }
}
@media (max-width:560px){
  .admin-pane{ padding:12px; }
  .admin-search{ width:100%; min-width:0; margin-left:0; }
  .admin-filters{ flex-direction:column; align-items:stretch; }
  .admin-filter-btn{ width:100%; justify-content:center; }
  .admin-master-card{ min-height:auto; }
}

/* ══════════════════════════════════════════
   QUICK SEARCH OVERLAY
══════════════════════════════════════════ */
.qs-item:hover {
  background: var(--orange-dim, rgba(255,107,0,.12)) !important;
}

/* ══════════════════════════════════════════
   MASTER NAV TABS — IMPROVED
══════════════════════════════════════════ */
.cab-tab {
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
  font-weight: 600;
  letter-spacing: .2px;
}
.cab-tab.active {
  color: var(--orange) !important;
  border-bottom-color: var(--orange) !important;
}
.cab-tab:hover:not(.active) {
  color: var(--text2);
}

/* ══════════════════════════════════════════
   OWNER ANALYTICS CARDS
══════════════════════════════════════════ */
.analytics-kpi {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

/* ══════════════════════════════════════════
   MASTER STATS GRID
══════════════════════════════════════════ */
.master-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}

/* ══════════════════════════════════════════
   MO-STATS IMPROVEMENT
══════════════════════════════════════════ */
.mo-stats {
  grid-template-columns: repeat(4, 1fr) !important;
}
@media (max-width: 480px) {
  .mo-stats { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ══════════════════════════════════════════
   ADMIN SIDEBAR SEARCH BTN
══════════════════════════════════════════ */
.admin-sidebar kbd {
  font-family: monospace;
  opacity: .6;
  transition: opacity .2s;
}
.admin-sidebar button:hover kbd { opacity: 1; }

/* ══════════════════════════════════════════
   OWNER TABS SCROLLABLE
══════════════════════════════════════════ */
.owner-tabs {
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.owner-tabs::-webkit-scrollbar { display: none; }
.owner-tab {
  white-space: nowrap;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════
   REVIEWS STARS ANIMATION
══════════════════════════════════════════ */
@keyframes starPop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.3); }
  100% { transform: scale(1); }
}

/* ══════════════════════════════════════════
   BAR CHART HOVER
══════════════════════════════════════════ */
.bar-fill { transition: width .5s cubic-bezier(.4,0,.2,1); }

/* ══════════════════════════════════════════
   WEEK CELL HOVER
══════════════════════════════════════════ */
.week-cell { cursor: pointer; transition: box-shadow .15s, transform .15s; }
.week-cell:hover { transform: translateY(-2px); }

/* ══════════════════════════════════════════
   CMODAL CARD HOVER LIFT
══════════════════════════════════════════ */
.master-schedule-shell {
  transition: box-shadow .2s;
}
.master-schedule-shell:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
}

/* ══════════════════════════════════════════
   ADMIN MASTERS LIST SEARCH HIGHLIGHT
══════════════════════════════════════════ */
#admin-masters-list .cmodal-card {
  transition: opacity .2s, transform .2s;
}
#admin-masters-list .cmodal-card[style*="display: none"] {
  opacity: 0;
  transform: scale(.97);
}

/* ══════════════════════════════════════════
   CLIENT ORDER DETAIL MODAL
══════════════════════════════════════════ */
#client-order-modal.cmodal-overlay {
  z-index: 8000;
}
#client-order-modal .cmodal-box {
  animation: slideUpFade .28s cubic-bezier(.22,1,.36,1);
}
@keyframes slideUpFade {
  from { opacity:0; transform:translateY(28px) scale(.97); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}

/* Clickable mo-card */
.mo-card {
  transition: box-shadow .15s, transform .12s;
}
.mo-card:hover {
  box-shadow: 0 0 0 2px var(--orange), 0 8px 24px rgba(0,0,0,.15);
  transform: translateY(-1px);
}
.mo-card:active {
  transform: translateY(0);
  box-shadow: 0 0 0 2px var(--orange);
}

/* Photo lightbox */
#photo-viewer-overlay {
  animation: fadeIn .18s ease;
}
#photo-viewer-overlay img {
  animation: scaleIn .22s cubic-bezier(.22,1,.36,1);
}
@keyframes scaleIn {
  from { opacity:0; transform:scale(.88); }
  to   { opacity:1; transform:scale(1); }
}

/* Report form in Detail panel */
#odet-report-form-section textarea {
  transition: border-color .2s;
}
#odet-report-form-section textarea:focus {
  outline: none;
  border-color: var(--orange) !important;
}



.car-card{cursor:pointer}
.car-card-media{margin:-16px -16px 12px}
.car-card-photo-wrap{height:172px;border-radius:20px 20px 14px 14px;overflow:hidden;background:var(--bg2);border-bottom:1px solid var(--line)}
.car-card-photo{width:100%;height:172px;object-fit:cover;display:block}
.car-card-photo--placeholder{height:172px;display:flex;align-items:center;justify-content:center;font-size:48px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));border-radius:20px 20px 14px 14px;border-bottom:1px solid var(--line)}
.vehicle-quick-create-note{font-size:13px;color:var(--text2);margin-bottom:14px}
.vehicle-quick-create-grid{display:grid;grid-template-columns:148px 1fr;gap:14px;align-items:start}
.vehicle-quick-photo-box{display:flex;align-items:flex-start;justify-content:center}
.vehicle-quick-photo-label{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;cursor:pointer}
.vehicle-quick-photo-preview{width:132px;height:132px;border-radius:18px;border:1px dashed var(--line);background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:42px;overflow:hidden}
.vehicle-quick-photo-preview.has-image{padding:0;border-style:solid}
.vehicle-quick-photo-preview img{width:100%;height:100%;object-fit:cover;display:block}
.vehicle-quick-photo-text{font-size:12px;color:var(--text3)}
.vehicle-detail-photo-wrap{margin:-18px -18px 14px;border-radius:18px 18px 14px 14px;overflow:hidden;background:var(--bg2);border-bottom:1px solid var(--line)}
.vehicle-detail-photo{width:100%;height:220px;object-fit:cover;display:block}
@media (max-width:720px){.vehicle-quick-create-grid{grid-template-columns:1fr}.vehicle-quick-photo-box{justify-content:flex-start}.car-card-photo-wrap,.car-card-photo,.car-card-photo--placeholder{height:148px}.vehicle-detail-photo{height:180px}}

.vehicle-editor-sections{display:grid;gap:14px}
.vehicle-editor-section{border:1px solid var(--line);border-radius:16px;padding:14px;background:var(--bg2)}
.vehicle-editor-section-title{font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;margin-bottom:12px}
.vehicle-fill-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:var(--bg2);margin-top:14px}
.vehicle-fill-card.good{border-color:rgba(16,185,129,.25)}
.vehicle-fill-card.mid{border-color:rgba(245,158,11,.25)}
.vehicle-fill-card.low{border-color:rgba(239,68,68,.22)}
.vehicle-fill-title{font-weight:800}
.vehicle-fill-sub{font-size:12px;color:var(--text3);margin-top:4px}
.vehicle-fill-value{font-family:'Oswald',sans-serif;font-size:28px;color:var(--orange);white-space:nowrap}
.vehicle-fill-bar{height:8px;border-radius:999px;background:var(--bg2);border:1px solid var(--line);overflow:hidden;margin:10px 0 4px}
.vehicle-fill-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#f59e0b,#f97316)}
.vehicle-detail-section{margin-top:16px}
.vehicle-detail-section-title{font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;margin-bottom:10px}
.vehicle-note-box{margin-top:10px;padding:12px 14px;border-radius:14px;background:var(--bg2);border:1px solid var(--line)}
.vehicle-note-box span{display:block;font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.vehicle-note-box b{display:block;font-size:13px;line-height:1.5;font-weight:600}


/* Services unified page */
.services-hero-shell { position: relative; overflow: hidden; }
.services-hero-content { position: relative; z-index: 1; }
.service-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 18px;
}
.service-toolbar-chips { flex: 1 1 640px; }
.service-pricing-trigger { min-height: 44px; white-space: nowrap; }
.services-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
  margin-top: 22px;
}
.services-overview-card { padding: 20px; }
.services-overview-kicker {
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 10px;
}
.services-overview-title {
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 8px;
}
.services-overview-text { color: var(--text2); line-height: 1.7; }
.services-featured-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}
.services-featured-card { padding: 20px; display: grid; gap: 14px; }
.services-featured-top { display: flex; gap: 12px; align-items: center; }
.services-featured-name { font-size: 18px; font-weight: 800; color: var(--text); }
.services-featured-meta { font-size: 13px; color: var(--text3); margin-top: 4px; }
.services-featured-desc { color: var(--text2); line-height: 1.7; min-height: 48px; }
.services-featured-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.services-featured-price { font-size: 16px; font-weight: 800; color: var(--orange); }
.services-grid--unified {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
}
.services-inline-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.services-inline-tag {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--bg2);
  border: 1px solid var(--line);
  color: var(--text2);
  font-size: 12px;
  font-weight: 600;
}
@media (max-width: 1100px){
  .services-overview-grid,
  .services-featured-grid,
  .services-grid--unified { grid-template-columns: 1fr; }
}
@media (max-width: 760px){
  .service-toolbar { align-items: stretch; }
  .service-pricing-trigger { width: 100%; justify-content: center; }
  .services-overview-card,
  .services-featured-card { padding: 16px; }
  .services-featured-foot { flex-direction: column; align-items: stretch; }
  .services-featured-foot .btn { width: 100%; justify-content: center; }
}

/* ═══════════════════════════════════════════════════════════
   УЛУЧШЕННЫЕ СТРАНИЦЫ: УСЛУГИ / ЗАПЧАСТИ / О НАС  v9.4.72
   ═══════════════════════════════════════════════════════════ */

/* ── HERO universal upgrade ─────────────────────────────── */
.page-hero-v2 {
  position: relative;
  background: var(--bg2);
  border-bottom: 1px solid var(--line);
  padding: 60px 0 52px;
  overflow: hidden;
}
.page-hero-v2-bg {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 90% at 92% 50%, rgba(255,107,0,.07) 0%, transparent 60%),
    radial-gradient(ellipse 30% 60% at 10% 80%, rgba(255,107,0,.04) 0%, transparent 55%),
    repeating-linear-gradient(-45deg, transparent 0, transparent 28px, rgba(255,107,0,.018) 28px, rgba(255,107,0,.018) 29px);
}
.page-hero-v2-label {
  font-size: 11px; font-weight: 700; letter-spacing: 4px;
  text-transform: uppercase; color: var(--orange); margin-bottom: 14px;
}
.page-hero-v2-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(34px, 5vw, 62px);
  font-weight: 700; line-height: 1.05;
  margin-bottom: 14px;
}
.page-hero-v2-sub {
  font-size: 15px; color: var(--text2);
  max-width: 560px; line-height: 1.8; margin-bottom: 28px;
}
.page-hero-v2-statsrow {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 0;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px 24px;
  max-width: 620px;
  margin-bottom: 28px;
}
.hero-stat { flex: 1; min-width: 90px; text-align: center; }
.hero-stat-num {
  font-family: 'Oswald', sans-serif;
  font-size: 26px; font-weight: 700; line-height: 1; color: var(--orange);
}
.hero-stat-lbl { font-size: 10px; color: var(--text3); font-weight: 600; text-transform: uppercase; letter-spacing: .5px; margin-top: 5px; }
.hero-stat-sep { width: 1px; height: 40px; background: var(--line); flex-shrink: 0; }

/* ── SERVICES PAGE v2 ────────────────────────────────────── */
.svc-filter-bar {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap; margin-top: 6px;
}
.svc-chip-v2 {
  display: flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: 10px;
  background: var(--surface); border: 1.5px solid var(--line);
  font-size: 13px; font-weight: 600; color: var(--text2);
  cursor: pointer; transition: .18s var(--ease);
  white-space: nowrap;
}
.svc-chip-v2:hover { border-color: var(--orange-brd); color: var(--text); }
.svc-chip-v2.active, .svc-chip-v2.selected {
  background: var(--orange-dim); border-color: var(--orange-brd);
  color: var(--orange);
}
.svc-chip-v2 .chip-cnt {
  background: var(--surface2); color: var(--text3);
  font-size: 10px; font-weight: 700; border-radius: 99px;
  padding: 2px 7px; min-width: 20px; text-align: center;
}
.svc-chip-v2.active .chip-cnt, .svc-chip-v2.selected .chip-cnt {
  background: var(--orange); color: #fff;
}

.svc-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 18px;
}
@media(max-width: 720px) { .svc-cards-grid { grid-template-columns: 1fr; } }

.svc-card-v2 {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 22px 22px 18px;
  display: flex; flex-direction: column; gap: 0;
  transition: .2s var(--ease);
}
.svc-card-v2:hover { border-color: var(--orange-brd); transform: translateY(-3px); box-shadow: 0 14px 36px rgba(0,0,0,.35); }

.svc-card-v2-head {
  display: flex; align-items: flex-start; gap: 14px;
  margin-bottom: 12px;
}
.svc-card-v2-ico {
  width: 52px; height: 52px; border-radius: 12px;
  background: var(--orange-dim); border: 1px solid var(--orange-brd);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
}
.svc-card-v2-info { flex: 1; min-width: 0; }
.svc-card-v2-name {
  font-family: 'Oswald', sans-serif;
  font-size: 18px; font-weight: 600; line-height: 1.15;
  margin-bottom: 5px;
}
.svc-card-v2-cat {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--orange);
  background: var(--orange-dim); border: 1px solid var(--orange-brd);
  border-radius: 6px; padding: 3px 8px;
}
.svc-card-v2-price {
  font-family: 'Oswald', sans-serif; font-size: 17px; font-weight: 700;
  color: var(--orange); white-space: nowrap; margin-top: 4px;
}
.svc-card-v2-time { font-size: 11px; color: var(--text3); margin-top: 2px; }

.svc-card-v2-desc {
  font-size: 13px; color: var(--text2); line-height: 1.65;
  margin-bottom: 14px; border-bottom: 1px solid var(--line); padding-bottom: 14px;
}
.svc-card-v2-body {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
  margin-bottom: 16px;
}
@media(max-width: 480px) { .svc-card-v2-body { grid-template-columns: 1fr; } }

.svc-col-title {
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text3); margin-bottom: 8px;
}
.svc-steps-v2 { list-style: none; display: flex; flex-direction: column; gap: 5px; }
.svc-steps-v2 li {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 12px; color: var(--text2); line-height: 1.4;
}
.svc-step-n {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--surface2); border: 1px solid var(--line);
  font-size: 10px; font-weight: 700; color: var(--orange);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 1px;
}
.svc-checklist-v2 { list-style: none; display: flex; flex-direction: column; gap: 5px; }
.svc-checklist-v2 li {
  display: flex; align-items: flex-start; gap: 7px;
  font-size: 12px; color: var(--text2); line-height: 1.4;
}
.svc-check-v2 {
  color: var(--green); font-weight: 700; font-size: 12px;
  flex-shrink: 0; margin-top: 1px;
}
.svc-card-v2-why {
  font-size: 12px; color: var(--text3); line-height: 1.55;
  background: var(--bg2); border-radius: 8px; padding: 9px 12px;
  margin-bottom: 14px; border-left: 3px solid var(--orange-brd);
}
.svc-card-v2-foot {
  display: flex; gap: 8px; flex-wrap: wrap;
  border-top: 1px solid var(--line); padding-top: 14px;
}
.svc-card-v2-foot .btn { flex: 1; justify-content: center; font-size: 13px; }

/* ── PARTS PAGE v2 ───────────────────────────────────────── */
.parts-v2-layout {
  display: grid;
  grid-template-columns: 1fr 310px;
  gap: 24px; padding-top: 28px; align-items: start;
}
@media(max-width: 960px) {
  .parts-v2-layout { grid-template-columns: 1fr; }
  .parts-v2-sidebar { order: -1; }
}
.parts-search-v2 {
  position: relative; display: flex; align-items: center;
  margin-bottom: 12px;
}
.parts-search-v2 .psi { position: absolute; left: 14px; color: var(--text3); font-size: 16px; pointer-events: none; }
.parts-search-v2 input {
  width: 100%; background: var(--surface);
  border: 1.5px solid var(--line); border-radius: 12px;
  padding: 13px 44px 13px 44px; font-size: 14px; color: var(--text);
  font-family: 'Mulish', sans-serif; outline: none;
  transition: .2s var(--ease);
}
.parts-search-v2 input:focus { border-color: var(--orange-brd); }
.parts-search-v2 .psc {
  position: absolute; right: 12px; background: none; border: none;
  color: var(--text3); font-size: 18px; cursor: pointer; padding: 4px;
}
.parts-cats-v2 {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px;
}
.parts-cat-v2 {
  padding: 8px 14px; border-radius: 9px;
  background: var(--surface); border: 1.5px solid var(--line);
  font-size: 12px; font-weight: 600; color: var(--text2);
  cursor: pointer; transition: .18s var(--ease);
}
.parts-cat-v2:hover { border-color: var(--orange-brd); color: var(--text); }
.parts-cat-v2.active { background: var(--orange-dim); border-color: var(--orange-brd); color: var(--orange); }

.parts-grid-v2 {
  display: flex;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
  justify-content: space-evenly;
  align-content: center;
  align-items: start;
  justify-items: start;
  flex-wrap: wrap;
  flex-direction: row;
}
@media(max-width: 520px) { .parts-grid-v2 { grid-template-columns: 1fr 1fr; } }
@media(max-width: 360px) { .parts-grid-v2 { grid-template-columns: 1fr; } }

.part-card-v2 {
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 16px;
  padding: 14px;
  display: flex;
  width: min(100%, 320px);
  min-width: 260px;
  gap: 10px;
  transition: .2s var(--ease);
  flex-wrap: nowrap;
  align-content: stretch;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: column;
  overflow: hidden;
}
.part-card-v2:hover { border-color: var(--orange-brd); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0,0,0,.3); }
.part-card-v2-media-wrap {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.06);
}
.part-card-v2-media {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.part-card-v2-cat {
  position: absolute;
  left: 10px;
  bottom: 10px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(15,23,42,.72);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  backdrop-filter: blur(6px);
}
.part-card-v2-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.part-card-v2-name { font-weight: 700; font-size: 15px; line-height: 1.35; }
.part-stock-badge {
  font-size: 10px; font-weight: 700; border-radius: 6px; padding: 3px 8px;
  white-space: nowrap; flex-shrink: 0;
}
.part-stock-badge.in { background: rgba(34,197,94,.15); color: var(--green); border: 1px solid rgba(34,197,94,.3); }
.part-stock-badge.order { background: rgba(245,158,11,.12); color: #f59e0b; border: 1px solid rgba(245,158,11,.3); }
.part-sku-v2 { font-size: 11px; color: var(--text3); }
.part-price-v2 {
  font-family: 'Oswald', sans-serif; font-size: 20px; font-weight: 700; color: var(--orange);
}
.part-note-v2 { font-size: 11px; color: var(--text3); line-height: 1.4; }
.part-shop-v2 {
  font-size: 11px; color: var(--text3);
  display: flex; align-items: center; gap: 5px;
}
.part-card-v2-actions { margin-top: auto; display: flex; gap: 6px; }
.part-card-v2-actions--stacked { align-items: stretch; }
.part-card-v2-actions .btn { flex: 1; justify-content: center; font-size: 12px; padding: 9px 10px; }
.part-rating-btn { flex: 0 0 48px !important; max-width: 48px; }

.part-details-layout {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.05fr);
  gap: 18px;
  align-items: start;
}
.part-details-media-wrap {
  background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
}
.part-details-media {
  width: 100%;
  display: block;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.part-details-main { display:flex; flex-direction:column; gap:14px; }
.part-details-topline { display:flex; justify-content:space-between; gap:10px; align-items:flex-start; flex-wrap:wrap; }
.part-details-chip {
  display:inline-flex; align-items:center; gap:6px; padding:7px 12px; border-radius:999px;
  background:rgba(251,146,60,.12); border:1px solid rgba(251,146,60,.22); color:var(--orange); font-size:12px; font-weight:700;
}
.part-details-price { font-family:'Oswald', sans-serif; font-size:32px; line-height:1; color:var(--orange); }
.part-details-meta-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; }
.part-details-meta-card {
  border:1px solid var(--line); border-radius:14px; padding:12px 14px; background:var(--bg2);
  display:flex; flex-direction:column; gap:6px;
}
.part-details-meta-card span { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:.04em; }
.part-details-meta-card strong { font-size:14px; color:var(--text); line-height:1.35; }
.part-details-rating { font-size:13px; color:var(--text2); }
.part-details-section { border-top:1px solid var(--line); padding-top:12px; }
.part-details-section-title { font-size:12px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.04em; margin-bottom:8px; }
.part-details-text { font-size:14px; line-height:1.6; color:var(--text); }
.part-details-actions { display:flex; gap:8px; flex-wrap:wrap; margin-top:4px; }
.part-details-actions .btn { min-width:160px; }
@media (max-width: 860px) {
  .part-details-layout { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .part-card-v2 { width: 100%; min-width: 0; }
  .part-details-meta-grid { grid-template-columns: 1fr; }
  .part-details-actions .btn { width: 100%; }
}

/* sidebar */
.parts-v2-sidebar-card {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 20px; margin-bottom: 14px;
}
.parts-v2-sidebar-title {
  font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 700;
  margin-bottom: 4px;
}
.parts-v2-sidebar-sub { font-size: 12px; color: var(--text2); line-height: 1.55; margin-bottom: 14px; }
.parts-why-row-v2 {
  display: flex; align-items: flex-start; gap: 12px;
  margin-bottom: 12px;
}
.parts-why-ico-v2 {
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--orange-dim); border: 1px solid var(--orange-brd);
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; flex-shrink: 0;
}
.parts-why-t-v2 { font-weight: 700; font-size: 13px; }
.parts-why-s-v2 { font-size: 12px; color: var(--text2); margin-top: 2px; }

/* parts empty */
.parts-empty-v2 {
  display: none; flex-direction: column; align-items: center;
  justify-content: center; padding: 40px 20px; text-align: center;
  grid-column: 1/-1;
}
.parts-empty-v2-ico { font-size: 40px; margin-bottom: 10px; }
.parts-empty-v2-t { font-weight: 700; font-size: 16px; margin-bottom: 6px; }
.parts-empty-v2-d { font-size: 13px; color: var(--text3); }

/* ── ABOUT PAGE v2 ───────────────────────────────────────── */
.about-nav-v2 {
  display: flex; gap: 4px; flex-wrap: wrap; margin-top: 24px;
}
.about-nav-btn {
  padding: 9px 18px; border-radius: 10px;
  background: var(--surface); border: 1.5px solid var(--line);
  font-size: 13px; font-weight: 600; color: var(--text2);
  cursor: pointer; transition: .18s var(--ease);
}
.about-nav-btn:hover { border-color: var(--orange-brd); color: var(--text); }
.about-nav-btn.active, .about-nav-btn.selected {
  background: var(--orange-dim); border-color: var(--orange-brd); color: var(--orange);
}

/* overview */
.about-grid-v2 {
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 36px;
  align-items: start;
}
@media(max-width: 860px) { .about-grid-v2 { grid-template-columns: 1fr; } }

.about-facts-v2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.about-fact-v2 {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 12px; padding: 18px 16px; text-align: center;
  transition: .2s var(--ease);
}
.about-fact-v2:hover { border-color: var(--orange-brd); }
.about-fact-v2-num {
  font-family: 'Oswald', sans-serif; font-size: 30px; font-weight: 700;
  color: var(--orange); line-height: 1;
}
.about-fact-v2-lbl { font-size: 12px; color: var(--text2); margin-top: 6px; line-height: 1.3; }

/* values */
.vals-v2 {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
@media(max-width: 860px) { .vals-v2 { grid-template-columns: 1fr 1fr; } }
@media(max-width: 520px) { .vals-v2 { grid-template-columns: 1fr; } }

.val-v2 {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 22px 20px;
  display: flex; flex-direction: column; gap: 10px;
  transition: .2s var(--ease);
}
.val-v2:hover { border-color: var(--orange-brd); transform: translateY(-2px); }
.val-v2-ico { font-size: 28px; }
.val-v2-t { font-family: 'Oswald', sans-serif; font-size: 17px; font-weight: 600; }
.val-v2-d { font-size: 13px; color: var(--text2); line-height: 1.6; }

/* team */
.team-v2 {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px;
}
.team-card-v2 {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 24px 18px;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 10px; transition: .2s var(--ease);
}
.team-card-v2:hover { border-color: var(--orange-brd); transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,.3); }
.team-av-v2 {
  width: 62px; height: 62px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif; font-size: 22px; font-weight: 700;
  border: 2px solid; flex-shrink: 0;
}
.team-name-v2 { font-weight: 700; font-size: 15px; line-height: 1.2; }
.team-role-v2 { font-size: 12px; color: var(--text2); line-height: 1.4; }
.team-exp-v2 { font-size: 11px; color: var(--text3); }
.team-vacancy-v2 {
  border-style: dashed !important;
  justify-content: center; gap: 8px; padding: 28px 18px;
}
.team-vacancy-v2 .vac-plus { font-size: 32px; opacity: .25; }
.team-vacancy-v2 .vac-t { font-size: 13px; font-weight: 700; color: var(--text2); }
.team-vacancy-v2 .vac-d { font-size: 11px; color: var(--text3); }

/* reviews */
.rv-grid-v2 {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px;
  margin-bottom: 24px;
}
.rv-card-v2 {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 20px;
  display: flex; flex-direction: column; gap: 10px;
  transition: .2s var(--ease);
}
.rv-card-v2:hover { border-color: var(--orange-brd); }
.rv-q-v2 {
  font-family: 'Oswald', sans-serif; font-size: 42px; font-weight: 700;
  color: var(--orange); line-height: 1; opacity: .35; margin-bottom: -6px;
}
.rv-stars-v2 { color: var(--orange); font-size: 14px; letter-spacing: 2px; }
.rv-text-v2 { font-size: 13px; color: var(--text2); line-height: 1.7; flex: 1; }
.rv-author-v2 { display: flex; align-items: center; gap: 10px; border-top: 1px solid var(--line); padding-top: 12px; }
.rv-av-v2 {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--orange-dim); border: 1px solid var(--orange-brd);
  color: var(--orange); font-weight: 700; font-size: 14px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.rv-name-v2 { font-weight: 700; font-size: 13px; }
.rv-date-v2 { font-size: 11px; color: var(--text3); margin-top: 2px; }
.rv-score-bar {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 20px 22px;
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
  margin-bottom: 20px;
}
.rv-score-big {
  font-family: 'Oswald', sans-serif; font-size: 56px; font-weight: 700;
  color: var(--orange); line-height: 1; flex-shrink: 0;
}
.rv-score-stars { color: var(--orange); font-size: 20px; letter-spacing: 3px; }
.rv-score-count { font-size: 12px; color: var(--text3); margin-top: 4px; }
.rv-score-actions { margin-left: auto; display: flex; gap: 10px; flex-wrap: wrap; }

/* contacts v2 */
.ct-v2-grid {
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 24px; align-items: start;
}
@media(max-width: 860px) { .ct-v2-grid { grid-template-columns: 1fr; } }

.ci-v2-card {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 12px; padding: 16px 18px;
  display: flex; align-items: flex-start; gap: 14px;
  transition: .2s var(--ease); margin-bottom: 10px;
}
.ci-v2-card:hover { border-color: var(--orange-brd); }
.ci-v2-ico {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--orange-dim); border: 1px solid var(--orange-brd);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.ci-v2-lbl { font-size: 10px; color: var(--text3); text-transform: uppercase; letter-spacing: 1px; font-weight: 700; margin-bottom: 3px; }
.ci-v2-val { font-size: 14px; font-weight: 600; }
.ci-v2-val a { color: var(--text); text-decoration: none; }
.ci-v2-val a:hover { color: var(--orange); }
.ci-v2-hint { font-size: 11px; color: var(--text3); margin-top: 3px; line-height: 1.4; }

.ct-hours-v2 {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 12px; padding: 16px 18px; margin-bottom: 14px;
}
.ct-hours-title { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--text3); margin-bottom: 10px; }
.hr-row-v2 {
  display: flex; justify-content: space-between;
  font-size: 13px; padding: 5px 0; border-bottom: 1px solid var(--line);
}
.hr-row-v2:last-child { border-bottom: none; }
.hr-row-v2.today { color: var(--orange); font-weight: 700; }
.hr-row-v2 .off { color: var(--text3); }

.ct-map-v2 {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 14px; overflow: hidden;
  min-height: 300px; position: relative;
}
.ct-map-placeholder {
  min-height: 300px; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px;
  text-align: center; padding: 24px;
}
.ct-open-badge-v2 {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; margin-bottom: 16px;
}
.ct-open-dot-v2 {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  animation: pulseGreen 2s infinite;
}
@keyframes pulseGreen { 0%,100%{opacity:1} 50%{opacity:.4} }

/* FAQ accordion v2 */
.faq-v2-list { display: flex; flex-direction: column; gap: 8px; }
.faq-v2-item {
  background: var(--surface); border: 1.5px solid var(--line);
  border-radius: 12px; overflow: hidden; cursor: pointer;
  transition: border-color .18s var(--ease);
}
.faq-v2-item:hover, .faq-v2-item.open { border-color: var(--orange-brd); }
.faq-v2-q {
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px; padding: 16px 18px; font-weight: 600; font-size: 14px;
  user-select: none;
}
.faq-v2-arr {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--surface2); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--orange); flex-shrink: 0;
  transition: transform .25s var(--ease);
}
.faq-v2-item.open .faq-v2-arr { transform: rotate(180deg); }
.faq-v2-a {
  max-height: 0; overflow: hidden;
  font-size: 13px; color: var(--text2); line-height: 1.7;
  transition: max-height .3s var(--ease), padding .3s var(--ease);
  padding: 0 18px;
}
.faq-v2-item.open .faq-v2-a { max-height: 400px; padding: 0 18px 16px; }

/* ── УНИФИКАЦИЯ ШАПОК (v9.4.73) ─────────────────────────────
   Все публичные страницы: page-hero-v2
   Кабинет (.cab-hero) и заявки (.mo-hero) — выравниваем
   визуально под тот же стиль (bg, border, overlay)
   ──────────────────────────────────────────────────────── */

/* Override cab-hero to match page-hero-v2 palette */
.cab-hero {
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--line) !important;
  position: relative;
  overflow: hidden;
}
.cab-hero::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 90% at 92% 50%, rgba(255,107,0,.06) 0%, transparent 60%),
    repeating-linear-gradient(-45deg, transparent 0, transparent 28px, rgba(255,107,0,.015) 28px, rgba(255,107,0,.015) 29px);
}

/* Override mo-hero — now replaced by page-hero-v2 in JS,
   keep these as fallback for any cached renders */
.mo-hero {
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--line) !important;
  position: relative;
  overflow: hidden;
}

/* news-hero-section fallback (now page-hero-v2 in JS) */
.news-hero-section {
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--line) !important;
  padding: 60px 0 52px !important;
}

/* ═══════════════════════════════════════════════════════════
   SPA LAYOUT SYSTEM  v9.4.74
   Страницы — не лендинги. Компактная шапка + липкий фильтр
   ═══════════════════════════════════════════════════════════ */

/* ── SPA страница ─────────────────────────────────────────── */
.spa-page {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - var(--nav-h));
}

/* ── Компактная шапка страницы ────────────────────────────── */
.spa-page-header {
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  padding: 16px 0 14px;
  flex-shrink: 0;
}
.spa-page-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.spa-page-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  min-width: 0;
}
.spa-page-header-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.spa-page-title {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}
.spa-page-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--surface2);
  color: var(--text3);
  border: 1px solid var(--line);
  border-radius: 99px;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  min-width: 24px;
}
.spa-page-badge {
  font-size: 11px; font-weight: 700;
  border-radius: 99px; padding: 2px 9px;
  border: 1px solid;
}
.spa-badge-green { background: rgba(34,197,94,.12); color: var(--green); border-color: rgba(34,197,94,.28); }
.spa-badge-amber { background: rgba(245,158,11,.12); color: #f59e0b; border-color: rgba(245,158,11,.28); }
.spa-page-meta-text { font-size: 12px; color: var(--text3); }
.spa-page-meta { display: flex; align-items: center; gap: 8px; }
.spa-cta { font-size: 13px; padding: 9px 16px; }

/* ── Липкий фильтр-бар ────────────────────────────────────── */
.spa-filter-bar {
  position: static;
  top: var(--nav-h);
  z-index: 40;
  background: var(--bg2);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  flex-shrink: 0;
}
.spa-filter-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 10px;
  padding-bottom: 10px;
  flex-wrap: wrap;
  min-height: 50px;
}

/* ── Чипы-фильтры ─────────────────────────────────────────── */
.spa-chips {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1;
}
.spa-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: 8px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  font-size: 12px;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  transition: .15s var(--ease);
  white-space: nowrap;
  line-height: 1;
}
.spa-chip:hover {
  border-color: var(--orange-brd);
  color: var(--text);
}
.spa-chip.active, .spa-chip.selected {
  background: var(--orange-dim);
  border-color: var(--orange-brd);
  color: var(--orange);
}
.spa-chip-e { font-size: 13px; }
.spa-chip-cnt {
  background: var(--surface2);
  color: var(--text3);
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  min-width: 18px;
  text-align: center;
}
.spa-chip.active .spa-chip-cnt,
.spa-chip.selected .spa-chip-cnt {
  background: var(--orange);
  color: #fff;
}
.spa-info-btn {
  font-size: 12px;
  color: var(--text3);
  background: none;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  padding: 4px 6px;
  border-radius: 6px;
  transition: .15s;
}
.spa-info-btn:hover { color: var(--text); background: var(--surface); }

/* ── Контент-зона ─────────────────────────────────────────── */
.spa-content {
  flex: 1;
  padding: 24px 0 40px;
}

/* ── Разделитель внутри секции ────────────────────────────── */
.spa-section-sep {
  height: 1px;
  background: var(--line);
  margin: 28px 0 22px;
}
.spa-section-title {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .5px;
  margin-bottom: 14px;
  color: var(--text);
}

/* ── О нас: applyAboutFilterState обновляет чипы и секции ─── */
[data-about-section] { transition: none; }

/* ── Мобайл ───────────────────────────────────────────────── */
@media (max-width: 520px) {
  .spa-page-title { font-size: 18px; }
  .spa-filter-inner { gap: 8px; padding-top: 8px; padding-bottom: 8px; }
  .spa-chip { font-size: 11px; padding: 5px 10px; }
  .spa-content { padding: 16px 0 32px; }
}

/* ── Убираем старые hero-классы от мешающего стиля ───────── */
.news-hero-section,
.mo-hero { padding: 0 !important; background: transparent !important; border: none !important; }

/* ═══════════════════════════════════════════════════════════
   УСЛУГИ v9.4.75 — категорийные группы + модалка
   ═══════════════════════════════════════════════════════════ */

/* ── Группа категории ─────────────────────────────────────── */
.svc-cat-group {
  margin-bottom: 36px;
}
.svc-cat-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.svc-cat-header-ico {
  width: 46px; height: 46px;
  border-radius: 12px;
  border: 1.5px solid;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; flex-shrink: 0;
}
.svc-cat-header-name {
  font-family: 'Oswald', sans-serif;
  font-size: 20px; font-weight: 700; line-height: 1;
}
.svc-cat-header-count {
  font-size: 12px; color: var(--text3); margin-top: 4px;
}

/* ── spa-chip с CSS-переменными цвета ─────────────────────── */
.spa-chip {
  --chip-active-bg:  var(--orange-dim);
  --chip-active-brd: var(--orange-brd);
  --chip-active-clr: var(--orange);
}
.spa-chip.active, .spa-chip.selected {
  background:    var(--chip-active-bg)  !important;
  border-color:  var(--chip-active-brd) !important;
  color:         var(--chip-active-clr) !important;
}
.spa-chip.active .spa-chip-cnt,
.spa-chip.selected .spa-chip-cnt {
  background: var(--chip-active-clr) !important;
  color: #fff !important;
}

/* ── Модалка услуги ───────────────────────────────────────── */
.svc-modal-box {
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 18px;
  width: min(92vw, 700px);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  margin: auto;
  position: relative;
}

/* Hero */
.svc-modal-hero {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 22px 22px 18px;
  flex-shrink: 0;
}
.svc-modal-hero-ico {
  width: 60px; height: 60px;
  border-radius: 14px; border: 1.5px solid;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; flex-shrink: 0;
}
.svc-modal-hero-info { flex: 1; min-width: 0; }
.svc-modal-hero-cat {
  font-size: 11px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 6px;
}
.svc-modal-hero-name {
  font-family: 'Oswald', sans-serif;
  font-size: 22px; font-weight: 700; line-height: 1.1;
  margin-bottom: 10px;
}
.svc-modal-hero-meta {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.svc-modal-badge {
  font-size: 11px; font-weight: 700;
  border-radius: 8px; padding: 4px 10px;
  background: var(--surface2);
  border: 1px solid var(--line);
  color: var(--text2);
}
.svc-modal-close {
  background: var(--surface2);
  border: 1px solid var(--line);
  color: var(--text2);
  border-radius: 8px;
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  font-size: 14px; font-weight: 700;
  transition: .15s var(--ease);
}
.svc-modal-close:hover { background: var(--orange-dim); border-color: var(--orange-brd); color: var(--orange); }

/* Tabs */
.svc-modal-tabs {
  display: flex;
  border-bottom: 1px solid var(--line);
  background: var(--bg2);
  flex-shrink: 0;
}
.svc-modal-tab {
  flex: 1; padding: 11px 8px;
  font-size: 13px; font-weight: 600;
  color: var(--text3);
  background: none; border: none; border-bottom: 2px solid transparent;
  cursor: pointer; transition: .15s var(--ease);
}
.svc-modal-tab:hover { color: var(--text); }
.svc-modal-tab.active { color: var(--orange); border-bottom-color: var(--orange); }

/* Panes */
.svc-modal-pane {
  display: none;
  padding: 22px;
  overflow-y: auto;
  flex: 1;
}
.svc-modal-pane.active { display: block; }

/* Описание pane */
.svc-modal-desc {
  font-size: 14px; color: var(--text2); line-height: 1.75;
  margin-bottom: 16px;
}
.svc-modal-why {
  display: flex; gap: 12px; align-items: flex-start;
  background: var(--bg2); border-radius: 10px;
  padding: 12px 14px; margin-bottom: 18px;
  border-left: 3px solid var(--orange-brd);
  font-size: 13px; color: var(--text2); line-height: 1.6;
}
.svc-modal-why-ico { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.svc-modal-two-col {
  display: grid; grid-template-columns: 1fr 200px; gap: 18px;
  align-items: start;
}
@media (max-width: 560px) { .svc-modal-two-col { grid-template-columns: 1fr; } }

.svc-modal-col-title {
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text3); margin-bottom: 10px;
}
.svc-modal-list {
  list-style: none; display: flex; flex-direction: column; gap: 6px;
}
.svc-modal-list li {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 13px; color: var(--text2); line-height: 1.4;
}
.svc-modal-book-aside {
  background: var(--bg2); border-radius: 12px;
  padding: 16px; text-align: center;
  border: 1px solid var(--line);
}
.svc-modal-price-big {
  font-family: 'Oswald', sans-serif;
  font-size: 24px; font-weight: 700; color: var(--orange);
  line-height: 1; margin-bottom: 6px;
}
.svc-modal-time-hint { font-size: 12px; color: var(--text3); }

/* Этапы pane */
.svc-modal-steps-list { display: flex; flex-direction: column; gap: 10px; }
.svc-modal-step {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 12px 14px;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 10px;
}
.svc-modal-step-n {
  width: 28px; height: 28px; border-radius: 50%;
  border: 1.5px solid;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; flex-shrink: 0;
}
.svc-modal-step-text { font-size: 14px; color: var(--text2); line-height: 1.5; padding-top: 3px; }

/* Стоимость pane */
.svc-modal-price-table { display: flex; flex-direction: column; gap: 0; }
.svc-modal-price-row {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 16px; padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.svc-modal-price-row:last-child { border-bottom: none; }
.svc-modal-price-key { font-size: 13px; color: var(--text3); flex-shrink: 0; }
.svc-modal-price-val { font-size: 13px; font-weight: 600; text-align: right; }

/* ── Мобайл ───────────────────────────────────────────────── */
@media (max-width: 520px) {
  .svc-modal-hero { padding: 16px; gap: 12px; }
  .svc-modal-hero-ico { width: 48px; height: 48px; font-size: 22px; }
  .svc-modal-hero-name { font-size: 18px; }
  .svc-modal-pane { padding: 16px; }
  .svc-cat-header-name { font-size: 17px; }
}

/* ═══════════════════════════════════════════════════════════
   SPA-PAGE-HERO  v9.4.76
   Полноценная шапка страницы: название + описание + статистика
   Единый стиль для всех SPA-страниц (Услуги, Запчасти, Новости,
   О нас, Правовые, Мои заявки и т.д.)
   ═══════════════════════════════════════════════════════════ */
.spa-page-hero {
  position: relative;
  background: var(--bg2);
  border-bottom: 1px solid var(--line);
  padding: 44px 0 36px;
  overflow: hidden;
  flex-shrink: 0;
}
.spa-hero-bg {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 90% at 92% 50%, rgba(255,107,0,.07) 0%, transparent 60%),
    radial-gradient(ellipse 25% 60% at 8% 80%,  rgba(255,107,0,.04) 0%, transparent 55%),
    repeating-linear-gradient(
      -45deg,
      transparent 0, transparent 28px,
      rgba(255,107,0,.018) 28px, rgba(255,107,0,.018) 29px
    );
}
.spa-hero-label {
  font-size: 11px; font-weight: 700;
  letter-spacing: 4px; text-transform: uppercase;
  color: var(--orange); margin-bottom: 12px;
}
.spa-hero-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(28px, 4.5vw, 52px);
  font-weight: 700; line-height: 1.05;
  margin-bottom: 12px;
}
.spa-hero-sub {
  font-size: 14px; color: var(--text2);
  max-width: 540px; line-height: 1.8;
  margin-bottom: 24px;
}
.spa-hero-stats {
  display: flex; align-items: center; flex-wrap: wrap; gap: 0;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 14px 22px;
  max-width: 580px;
  margin-bottom: 22px;
}
.spa-hero-stat { flex: 1; min-width: 80px; text-align: center; }
.spa-hero-stat-num {
  font-family: 'Oswald', sans-serif;
  font-size: 22px; font-weight: 700; line-height: 1; color: var(--orange);
}
.spa-hero-stat-lbl {
  font-size: 10px; color: var(--text3);
  font-weight: 600; text-transform: uppercase;
  letter-spacing: .5px; margin-top: 4px;
}
.spa-hero-stat-sep {
  width: 1px; height: 34px;
  background: var(--line); flex-shrink: 0;
}

/* Мобайл */
@media (max-width: 640px) {
  .spa-page-hero { padding: 28px 0 24px; }
  .spa-hero-title { font-size: 26px; }
  .spa-hero-stats { padding: 10px 14px; max-width: 100%; }
  .spa-hero-stat-num { font-size: 18px; }
}
@media (max-width: 420px) {
  .spa-hero-stats { flex-direction: column; gap: 8px; }
  .spa-hero-stat-sep { width: 100%; height: 1px; }
  .spa-hero-stat { text-align: left; }
}

/* ═══════════════════════════════════════════════════════════
   SVC-FILTER-STICKY  v9.4.78 — улучшенные кнопки фильтра
   ═══════════════════════════════════════════════════════════ */

.svc-filter-sticky {
  position: static;
  top: var(--nav-h);
  z-index: 40;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  flex-shrink: 0;
}

.svc-filter-track {
  display: flex;
  align-items: stretch;
  gap: 6px;
  padding: 10px 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.svc-filter-track::-webkit-scrollbar { display: none; }

/* ── Одна кнопка ─────────────────────────────────────────── */
.svc-filter-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 9px 16px;
  border-radius: 10px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  color: var(--text2);
  font-family: 'Mulish', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition:
    background .18s var(--ease),
    border-color .18s var(--ease),
    color .18s var(--ease),
    transform .15s var(--ease),
    box-shadow .18s var(--ease);
  --fc: var(--orange);
  position: relative;
  overflow: hidden;
}

/* shimmer-подсветка при наведении */
.svc-filter-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(255,255,255,.06) 0%, transparent 70%);
  opacity: 0;
  transition: opacity .2s;
}
.svc-filter-btn:hover::before { opacity: 1; }

.svc-filter-btn:hover {
  border-color: rgba(var(--fc-r, 255), var(--fc-g, 107), var(--fc-b, 0), .35);
  color: var(--text);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(0,0,0,.2);
}

/* Иконка */
.svc-filter-btn-ico {
  font-size: 16px;
  line-height: 1;
  flex-shrink: 0;
}

/* Счётчик */
.svc-filter-btn-cnt {
  background: var(--surface2);
  color: var(--text3);
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  min-width: 20px;
  text-align: center;
  transition: background .18s, color .18s;
}

/* ── Активное состояние ──────────────────────────────────── */
.svc-filter-btn.active {
  background: color-mix(in srgb, var(--fc) 12%, transparent);
  border-color: color-mix(in srgb, var(--fc) 40%, transparent);
  color: var(--fc);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--fc) 20%, transparent),
              0 4px 16px color-mix(in srgb, var(--fc) 15%, transparent);
  transform: translateY(-1px);
}
.svc-filter-btn.active .svc-filter-btn-cnt {
  background: var(--fc);
  color: #fff;
}

/* ── Fallback для браузеров без color-mix ────────────────── */
@supports not (background: color-mix(in srgb, red 10%, blue)) {
  .svc-filter-btn.active {
    background: var(--orange-dim);
    border-color: var(--orange-brd);
    color: var(--orange);
    box-shadow: none;
  }
  .svc-filter-btn.active .svc-filter-btn-cnt {
    background: var(--orange);
    color: #fff;
  }
}

/* ── Кнопка «Прайс» — всегда нейтральная ────────────────── */
.svc-filter-price {
  margin-left: auto;
  color: var(--text3);
  border-style: dashed;
}
.svc-filter-price:hover {
  color: var(--orange);
  border-color: var(--orange-brd);
  border-style: solid;
}

/* ── Мобайл ───────────────────────────────────────────────── */
@media (max-width: 600px) {
  .svc-filter-btn {
    padding: 8px 12px;
    font-size: 12px;
    gap: 5px;
    border-radius: 9px;
  }
  .svc-filter-btn-ico { font-size: 14px; }
  .svc-filter-price { margin-left: 0; }
}

/* ═══════════════════════════════════════════════════════════
   SPA-PAGE-HERO — мобильный режим  v9.4.79
   На десктопе: полный hero как обычно
   На телефоне: компактная 1-строчная шапка + кнопка ℹ
                Весь контент — в bottom sheet
   ═══════════════════════════════════════════════════════════ */

/* ── Мобильная компактная строка (скрыта на десктопе) ────── */
.spa-hero-mobile-bar {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.spa-hero-mobile-title {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.spa-hero-mobile-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 99px;
  background: var(--surface2);
  color: var(--text3);
  border: 1px solid var(--line);
  font-family: 'Mulish', sans-serif;
  letter-spacing: 0;
}
.spa-hero-mobile-badge.green { background: rgba(34,197,94,.15); color: var(--green); border-color: rgba(34,197,94,.3); }
.spa-hero-mobile-badge.amber { background: rgba(245,158,11,.13); color: #f59e0b; border-color: rgba(245,158,11,.3); }

.spa-hero-mobile-info {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--surface2);
  border: 1.5px solid var(--line);
  color: var(--text3);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: .15s var(--ease);
  font-family: serif;
}
.spa-hero-mobile-info:hover,
.spa-hero-mobile-info:active {
  background: var(--orange-dim);
  border-color: var(--orange-brd);
  color: var(--orange);
}

/* ── На мобиле: весь hero скрыт, только кнопка ℹ в фильтр-баре ── */
@media (max-width: 640px) {
  .spa-page-hero { display: none !important; }
}
@media (min-width: 641px) {
  .spa-hero-mobile-bar { display: none !important; }
  .spa-hero-body { display: block !important; }
  /* Кнопка ℹ в фильтр-баре не нужна на десктопе */
  .svc-filter-hero-btn { display: none !important; }
}

/* ═══════════════════════════════════════════════════════════
   BOTTOM SHEET
   ═══════════════════════════════════════════════════════════ */
.spa-hero-sheet {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  align-items: flex-end;
}
.spa-hero-sheet.open {
  display: flex;
}

.spa-hero-sheet-box {
  width: 100%;
  background: var(--bg2);
  border-top: 1px solid var(--line);
  border-radius: 20px 20px 0 0;
  padding: 16px 20px 32px;
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.32,1,.5,1);
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
}
.spa-hero-sheet-box.up {
  transform: translateY(0);
}

/* Ручка */
.spa-hero-sheet-handle {
  width: 40px; height: 4px;
  border-radius: 99px;
  background: var(--surface2);
  margin: 0 auto 18px;
}

/* Контент внутри sheet */
.spa-hero-sheet-label {
  font-size: 10px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase;
  color: var(--orange); margin-bottom: 8px;
}
.spa-hero-sheet-title {
  font-family: 'Oswald', sans-serif;
  font-size: 24px; font-weight: 700;
  line-height: 1.1; margin-bottom: 4px;
}
.spa-hero-sheet-sub {
  font-size: 13px; color: var(--text2);
  line-height: 1.7; margin-bottom: 18px;
}
.spa-hero-sheet-stats {
  max-width: 100% !important;
  margin-bottom: 18px !important;
}
.spa-hero-sheet-actions {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-bottom: 16px;
}
.spa-hero-sheet-close {
  width: 100%;
  padding: 11px;
  border-radius: 10px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  color: var(--text2);
  font-size: 13px; font-weight: 600;
  cursor: pointer;
  transition: .15s;
  font-family: 'Mulish', sans-serif;
}
.spa-hero-sheet-close:hover { border-color: var(--orange-brd); color: var(--orange); }

/* На десктопе sheet вообще не показывается */
@media (min-width: 641px) {
  .spa-hero-sheet { display: none !important; }
}

/* ── Кнопка ℹ в фильтр-баре (только мобиле ≤640px) ─────── */
.svc-filter-hero-btn {
  display: none; /* скрыта на десктопе */
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: 10px;
  background: var(--surface2);
  border: 1.5px solid var(--line);
  color: var(--text2);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  font-family: 'Mulish', sans-serif;
  transition: .15s var(--ease);
}
.svc-filter-hero-btn:hover,
.svc-filter-hero-btn:active {
  background: var(--orange-dim);
  border-color: var(--orange-brd);
  color: var(--orange);
}
.svc-filter-hero-info {
  font-family: serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--orange);
  opacity: .8;
}
.svc-filter-sep {
  width: 1px;
  height: 24px;
  background: var(--line);
  flex-shrink: 0;
  align-self: center;
}

@media (max-width: 640px) {
  .svc-filter-hero-btn { display: flex !important; }
  .svc-filter-sep { display: flex; }
}

/* ═══════════════════════════════════════════════════════════
   PARTS FILTER STICKY  v9.4.82
   Двухрядный адаптивный фильтр-бар для страницы Запчасти
   ═══════════════════════════════════════════════════════════ */

.parts-filter-sticky {
  position: static;
  top: var(--nav-h);
  z-index: 40;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  flex-shrink: 0;
}

/* ── Строки внутри ───────────────────────────────────────── */
.pf-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pf-row-search {
  padding: 10px 0 8px;
  border-bottom: 1px solid var(--line);
}
.pf-row-cats {
  padding: 8px 0;
  overflow: hidden;
}

/* ── Строка поиска ───────────────────────────────────────── */
.pf-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
}
.pf-search-ico {
  position: absolute;
  left: 13px;
  font-size: 15px;
  color: var(--text3);
  pointer-events: none;
  line-height: 1;
}
.pf-search-input {
  width: 100%;
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 10px;
  padding: 10px 40px 10px 40px;
  font-size: 14px;
  color: var(--text);
  font-family: 'Mulish', sans-serif;
  outline: none;
  transition: border-color .15s var(--ease);
  min-width: 0;
}
.pf-search-input:focus {
  border-color: var(--orange-brd);
  background: var(--surface2);
}
.pf-search-input::placeholder { color: var(--text3); }
.pf-search-clear {
  position: absolute;
  right: 10px;
  background: var(--surface2);
  border: none;
  color: var(--text3);
  font-size: 16px;
  font-weight: 700;
  width: 24px; height: 24px;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: .15s;
  line-height: 1;
}
.pf-search-clear:hover { color: var(--text); background: var(--line); }

/* Кнопка инфо в строке поиска — только мобиле */
.pf-info-btn {
  flex-shrink: 0;
}

/* ── Строка категорий (горизонтальный скролл) ────────────── */
.pf-cats-track {
  display: flex;
  align-items: center;
  gap: 6px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 2px;
}
.pf-cats-track::-webkit-scrollbar { display: none; }

/* ── Кнопка категории ────────────────────────────────────── */
.pf-cat-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 9px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  color: var(--text2);
  font-family: 'Mulish', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background .15s, border-color .15s, color .15s, transform .12s;
  line-height: 1;
}
.pf-cat-btn:hover {
  border-color: var(--orange-brd);
  color: var(--text);
  transform: translateY(-1px);
}
.pf-cat-btn.active {
  background: var(--orange-dim);
  border-color: var(--orange-brd);
  color: var(--orange);
  transform: translateY(-1px);
}
.pf-cat-ico { font-size: 15px; line-height: 1; }
.pf-cat-label { line-height: 1; }

/* ── Адаптив ─────────────────────────────────────────────── */
@media (max-width: 640px) {
  .pf-row-search { padding: 8px 0 7px; }
  .pf-row-cats   { padding: 6px 0; }
  .pf-search-input { font-size: 16px; /* prevent iOS zoom */ padding: 9px 38px 9px 38px; }
  .pf-cat-btn { font-size: 12px; padding: 7px 12px; gap: 5px; }
  .pf-cat-ico { font-size: 14px; }
  /* Инфо-кнопка показывается только на мобиле */
  .pf-info-btn.svc-filter-hero-btn { display: inline-flex !important; }
}
@media (min-width: 641px) {
  .pf-info-btn.svc-filter-hero-btn { display: none !important; }
  .pf-search-input { font-size: 14px; }
}

/* ── Сетка карточек запчастей ─────────────────────────────── */
/* Переопределяем grid для мобиле */
@media (max-width: 640px) {
  .parts-grid-v2 {
    flex-template-columns: 0fr 0fr !important;
    gap: 10px !important;
  }
}
@media (max-width: 360px) {
  .parts-grid-v2 {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   MY ORDERS v9.4.83 — filter tabs + type cards
   ═══════════════════════════════════════════════════════════ */

/* ── Фильтр-бар со вкладками ─────────────────────────────── */
.mo-filter-bar {
  margin-bottom: 16px;
}
.mo-filter-tabs {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 2px;
}
.mo-filter-tabs::-webkit-scrollbar { display: none; }

.mo-filter-tab {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 13px;
  border-radius: 9px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  font-family: 'Mulish', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: .15s var(--ease);
  line-height: 1;
}
.mo-filter-tab:hover { border-color: var(--orange-brd); color: var(--text); }
.mo-filter-tab.active {
  background: var(--orange-dim);
  border-color: var(--orange-brd);
  color: var(--orange);
}
.mo-filter-tab[data-filter="parts_request"].active {
  background: rgba(96,165,250,.12);
  border-color: rgba(96,165,250,.35);
  color: #60a5fa;
}
.mo-filter-tab[data-filter="service_order"].active {
  background: rgba(34,197,94,.11);
  border-color: rgba(34,197,94,.3);
  color: var(--green);
}
.mo-filter-tab-ico { font-size: 13px; }
.mo-filter-cnt {
  background: var(--surface2);
  color: var(--text3);
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  min-width: 18px;
  text-align: center;
}
.mo-filter-tab.active .mo-filter-cnt {
  background: currentColor;
  color: var(--bg);
}

/* ── Тип-бейдж на карточке ───────────────────────────────── */
.mo-type-badge {
  font-size: 10px;
  font-weight: 700;
  border-radius: 6px;
  padding: 3px 8px;
  border: 1px solid;
  white-space: nowrap;
}
.mo-type-badge.parts {
  background: rgba(96,165,250,.12);
  border-color: rgba(96,165,250,.3);
  color: #60a5fa;
}
.mo-type-badge.service {
  background: rgba(34,197,94,.1);
  border-color: rgba(34,197,94,.25);
  color: var(--green);
}

/* ── Карточка запчасти — левый акцент ────────────────────── */
.mo-card-parts {
  border-left: 3px solid #60a5fa !important;
}

/* ── Чат-кнопка ─────────────────────────────────────────── */
.mo-chat-btn {
  position: relative;
  font-size: 12px;
  padding: 8px 14px;
}
.mo-chat-badge {
  position: absolute;
  top: -6px; right: -6px;
  background: var(--orange);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: 99px;
  min-width: 18px; height: 18px;
  display: flex; align-items: center; justify-content: center;
  padding: 0 4px;
}

/* ── Мобайл ─────────────────────────────────────────────── */
@media (max-width: 520px) {
  .mo-filter-tab { font-size: 11px; padding: 6px 10px; }
  .mo-filter-tab-ico { font-size: 12px; }
}


.parts-categories-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
.parts-category-card{width:100%;text-align:left;border:1px solid color-mix(in srgb,var(--pc) 24%,var(--line));background:linear-gradient(180deg,color-mix(in srgb,var(--pc) 10%,var(--surface)) 0%,var(--surface) 100%);border-radius:22px;padding:22px;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;color:inherit;box-shadow:0 8px 28px rgba(0,0,0,.10)}
.parts-category-card:hover{transform:translateY(-4px);border-color:var(--pc);box-shadow:0 16px 36px rgba(0,0,0,.16)}
.parts-category-card__top{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;margin-bottom:14px}
.parts-category-card__icon{width:60px;height:60px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;background:color-mix(in srgb,var(--pc) 16%,transparent)}
.parts-category-card__label{font-size:12px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.parts-category-card__title{font-family:'Oswald',sans-serif;font-size:28px;line-height:1}
.parts-category-card__count{min-width:58px;height:58px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:var(--pc);color:#fff;font-size:22px;font-weight:800}
.parts-category-card__desc{color:var(--text2);line-height:1.75;min-height:56px;margin-bottom:14px}
.parts-category-card__stats{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.parts-category-card__stats span{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--line);font-size:12px;color:var(--text2)}
.parts-category-card__cta{margin-top:14px;color:var(--pc);font-weight:700}
.parts-category-focus{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:stretch;border:1px solid color-mix(in srgb,var(--pc) 26%,var(--line));background:linear-gradient(135deg,color-mix(in srgb,var(--pc) 12%,var(--surface)) 0%,var(--surface) 72%);border-radius:24px;padding:22px;margin-bottom:24px}
.parts-category-focus__badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:color-mix(in srgb,var(--pc) 16%,transparent);border:1px solid color-mix(in srgb,var(--pc) 28%,transparent);color:var(--pc);font-weight:700;margin-bottom:12px}
.parts-category-focus__title{font-family:'Oswald',sans-serif;font-size:clamp(30px,4vw,44px);line-height:1;margin:0 0 10px}
.parts-category-focus__sub{margin:0;color:var(--text2);max-width:760px;line-height:1.8}
.parts-category-focus__stats{display:grid;grid-template-columns:repeat(3,minmax(110px,1fr));gap:12px}.parts-category-focus__stat{min-width:118px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid var(--line);padding:16px 18px}.parts-category-focus__stat strong{font-size:28px;line-height:1;margin-bottom:6px}.parts-category-focus__stat span{color:var(--text3);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.parts-inline-tools{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;margin-bottom:18px}
.part-desc-v2{font-size:13px;color:var(--text2);line-height:1.65;min-height:42px}
@media(max-width:980px){.parts-categories-grid{grid-template-columns:1fr}.parts-category-focus{grid-template-columns:1fr}.parts-category-focus__stats{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:640px){.parts-category-card{padding:18px;border-radius:18px}.parts-category-card__top{grid-template-columns:auto 1fr}.parts-category-card__count{grid-column:1/-1;width:100%;height:44px;border-radius:14px;justify-content:flex-start;padding:0 14px}.parts-category-card__title{font-size:24px}.parts-category-focus{padding:12px 14px;border-radius:16px;gap:12px;margin-bottom:16px}.parts-category-focus__badge{padding:6px 10px;font-size:12px;margin-bottom:8px}.parts-category-focus__title{font-size:24px;margin:0 0 6px}.parts-category-focus__sub{font-size:13px;line-height:1.55}.parts-category-focus__stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.parts-category-focus__stat{min-width:0;padding:10px 10px;border-radius:14px}.parts-category-focus__stat strong{font-size:18px;margin-bottom:4px}.parts-category-focus__stat span{font-size:10px;letter-spacing:.04em}.parts-inline-tools{grid-template-columns:1fr}.part-desc-v2{min-height:0}}
@media(max-width:420px){.parts-category-focus{padding:10px 12px}.parts-category-focus__title{font-size:21px}.parts-category-focus__sub{font-size:12px;line-height:1.45}.parts-category-focus__stats{grid-template-columns:repeat(2,minmax(0,1fr))}.parts-category-focus__stat:last-child{grid-column:1/-1}.parts-category-focus__stat strong{font-size:16px}.parts-category-focus__stat span{font-size:9px}}


/* part detail mobile compact fix */
@media (max-width: 640px){
  #hero-part{display:none !important}
  .parts-detail-tools{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:10px}
  .parts-breadcrumb{font-size:11px;gap:5px;line-height:1.35}
  .parts-breadcrumb__current{display:block;width:100%}
  .parts-share-btn{width:100%;justify-content:center;min-height:40px;padding:9px 12px;font-size:12px}
  .parts-section-group{margin-bottom:16px}
  .parts-category-focus{padding:10px 12px;border-radius:14px;gap:10px;margin-bottom:12px}
  .parts-category-focus__badge{padding:5px 9px;font-size:11px;margin-bottom:6px}
  .parts-category-focus__title{font-size:20px;line-height:1.05;margin:0 0 4px}
  .parts-category-focus__sub{display:none}
  .news-back-btn{min-height:38px;padding:8px 12px;font-size:12px;margin-bottom:8px}
  .parts-category-focus__stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
  .parts-category-focus__stat{padding:8px 8px;border-radius:12px;min-width:0}
  .parts-category-focus__stat strong{font-size:14px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .parts-category-focus__stat span{font-size:9px;letter-spacing:.02em}
  .part-details-layout{gap:10px}
  .part-details-media-wrap{border-radius:14px}
  .part-details-media{aspect-ratio:16 / 11}
  .part-details-main{gap:10px}
  .part-details-topline{gap:8px}
  .part-details-chip{padding:6px 10px;font-size:11px}
  .part-stock-badge{font-size:11px;padding:6px 10px}
  .part-details-price{font-size:24px}
  .part-details-meta-grid{gap:8px}
  .part-details-meta-card{padding:10px 12px;border-radius:12px}
  .part-details-meta-card span{font-size:10px}
  .part-details-meta-card strong{font-size:13px}
  .part-details-rating{font-size:12px}
  .part-details-section{padding-top:10px}
  .part-details-section-title{font-size:11px;margin-bottom:6px}
  .part-details-text{font-size:13px;line-height:1.5}
  .part-details-actions{gap:6px}
  .part-details-actions .btn{min-width:0;width:100%;min-height:42px;padding:10px 12px;font-size:13px}
  .news-section-head{margin:4px 0 10px}
  .news-section-title{font-size:22px}
  .news-section-sub{font-size:13px;line-height:1.5}
  .parts-grid-v2{gap:12px}
}
@media (max-width: 420px){
  .parts-detail-tools{gap:6px}
  .parts-breadcrumb{font-size:10px}
  .parts-category-focus{padding:8px 10px;border-radius:12px}
  .parts-category-focus__title{font-size:18px}
  .parts-category-focus__stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .parts-category-focus__stat:last-child{grid-column:1/-1}
  .parts-category-focus__stat strong{font-size:13px}
  .part-details-price{font-size:22px}
  .part-details-meta-card{padding:9px 10px}
  .part-details-text{font-size:12px}
}


.part-card-v2--shoplike{gap:12px}
.part-card-v2-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.part-card-v2-info{flex:1;min-width:0;display:grid;gap:4px}
.part-card-v2-sku{font-size:11px;color:var(--text3);line-height:1.35}
.part-card-v2-desc{font-size:12px;color:var(--text2);line-height:1.6;min-height:38px}
.part-card-v2-meta{display:flex;align-items:flex-end;justify-content:space-between;gap:10px}
.part-card-v2-meta-side{display:grid;gap:4px;justify-items:end}
.part-card-v2-rating,.part-card-v2-shop{font-size:11px;color:var(--text3);line-height:1.35;text-align:right}
.part-card-v2-bottomline{display:flex;align-items:center;min-height:26px}
.part-card-v2-chip{display:inline-flex;align-items:center;max-width:100%;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--line);font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.part-card-v2-foot{margin-top:auto;display:flex;gap:6px;align-items:stretch}
.part-card-v2-foot .btn{flex:1;justify-content:center;font-size:12px;padding:9px 10px}
.part-card-v2-foot .part-rating-btn{flex:0 0 48px;max-width:48px}
@media (max-width: 640px){
  .part-card-v2--shoplike{gap:10px}
  .part-card-v2-desc{font-size:11px;line-height:1.5;min-height:0}
  .part-card-v2-meta{align-items:flex-start;flex-direction:column;gap:6px}
  .part-card-v2-meta-side{justify-items:start}
  .part-card-v2-price{font-size:18px}
  .part-card-v2-foot .btn{font-size:11px;padding:8px 8px}
}


.parts-level__head{display:flex;align-items:center;justify-content:flex-start;gap:12px;margin:0 0 14px}
.parts-summary-card{grid-template-columns:minmax(0,1fr) repeat(3,minmax(120px,1fr));gap:14px;align-items:stretch;margin-bottom:18px}
.parts-summary-card__badge{background:color-mix(in srgb,var(--pc) 16%,transparent);border-color:color-mix(in srgb,var(--pc) 28%,transparent);color:var(--pc)}
.parts-summary-card__count strong{color:var(--text)}
.parts-grid-v2--catalog{align-items:stretch}
.parts-grid-v2--catalog .part-card-v2{height:100%}
.part-card-v2--shoplike{padding:14px;display:flex;flex-direction:column;justify-content:flex-start}
.part-card-v2-media-wrap{aspect-ratio:16/10}
.part-card-v2-name{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.7em}
.part-card-v2-desc{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:4.8em}
.part-card-v2-meta{margin-top:auto;padding-top:2px}
.part-card-v2-bottomline{margin-top:2px;min-height:34px}
.part-card-v2-chip{width:100%;justify-content:flex-start}
.part-card-v2-foot{margin-top:8px}
@media (max-width:980px){
  .parts-summary-card{grid-template-columns:1fr repeat(3,minmax(0,1fr))}
}
@media (max-width:640px){
  .parts-level__head{margin:0 0 10px}
  .parts-summary-card{grid-template-columns:1fr 1fr;gap:10px;padding:12px 14px !important;border-radius:16px !important}
  .parts-summary-card .svc-active-category__main{grid-column:1/-1;gap:8px}
  .parts-summary-card__count{min-width:0;padding:10px 12px !important;border-radius:14px !important}
  .parts-summary-card__count strong{font-size:18px !important}
  .parts-summary-card__count span{font-size:10px !important}
  .part-card-v2--shoplike{padding:12px}
  .part-card-v2-name{min-height:2.55em}
  .part-card-v2-desc{min-height:3.9em;-webkit-line-clamp:3}
}
@media (max-width:420px){
  .parts-summary-card{grid-template-columns:1fr;gap:8px;padding:10px 12px !important;border-radius:14px !important}
  .parts-summary-card .svc-active-category__main,.parts-summary-card__count{grid-column:auto}
  .parts-summary-card__count strong{font-size:16px !important}
  .part-card-v2--shoplike{padding:10px}
  .part-card-v2-desc{min-height:3.6em}
}

.booking-categories-grid{margin-top:12px}
.booking-subcat-chips{display:flex;flex-wrap:wrap;gap:10px}
.booking-subcat-chip{border:1px solid var(--line);background:var(--surface-2,#151515);color:var(--text);padding:10px 14px;border-radius:999px;font-weight:700;cursor:pointer;transition:.18s ease}
.booking-subcat-chip:hover{border-color:var(--orange-brd);transform:translateY(-1px)}
.booking-subcat-chip.selected{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.35);color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.18)}
.booking-step-price .svc-card-v2.selected{border-color:var(--orange-brd);box-shadow:0 16px 36px rgba(0,0,0,.35),0 0 0 1px rgba(245,158,11,.24) inset}
.booking-step-price .svc-card-v2.selected .svc-card-v2-price{color:#fff}
.booking-empty-services{padding:16px 18px;border-radius:14px;border:1px dashed rgba(255,255,255,.14);background:rgba(255,255,255,.03);color:var(--text2);font-size:13px;line-height:1.6}
.booking-price-grid{margin-top:4px}


.booking-service-grid{
  grid-template-columns:1fr;
  gap:12px;
}
.booking-service-card{
  width:100%;
  text-align:left;
}
.booking-service-card.active{
  border-color:var(--fc);
  box-shadow:0 16px 36px rgba(0,0,0,.35),0 0 0 1px color-mix(in srgb, var(--fc) 35%, transparent) inset;
}
.booking-service-card .svc-cat-nav-card__count{
  min-width:72px;
  text-align:center;
}
.booking-service-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
  font-size:11px;
  color:var(--text3);
}
.booking-service-card__meta span{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}
.booking-service-actions{
  display:flex;
  gap:10px;
  margin:-2px 0 2px;
}
.booking-service-actions .btn{
  flex:1;
  justify-content:center;
}
@media(max-width:640px){
  .booking-service-actions{flex-direction:column;}
  .booking-service-card .svc-cat-nav-card__count{min-width:64px;font-size:12px;}
}


.booking-vehicle-empty{border:1px solid var(--line);border-radius:16px;padding:14px;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01))}
.booking-vehicle-empty__title{font-weight:800;color:#fff;font-size:14px}
.booking-vehicle-empty__desc{font-size:12px;color:var(--text3);margin-top:4px;line-height:1.45}
.booking-vehicle-card{position:relative;min-height:68px;transition:border-color .16s ease,transform .16s ease,box-shadow .16s ease}
.booking-vehicle-card:hover{border-color:var(--orange-brd);transform:translateY(-1px)}
.booking-vehicle-card.selected{background:linear-gradient(180deg,rgba(245,158,11,.12),rgba(245,158,11,.05))}
.booking-vehicle-card .sub-soft{opacity:.92}
.booking-vehicle-side{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0;min-width:44px}
.booking-vehicle-check{width:28px;height:28px;border-radius:999px;background:var(--orange);color:#111;display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 10px 24px rgba(245,158,11,.22)}
.booking-vehicle-arrow{color:var(--text3);font-weight:800;flex-shrink:0}
.booking-vehicle-card--action .ico,.booking-vehicle-card--manual .ico{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.2)}

/* ── Кнопка корзины бронирования (мобиль) ─────────────────────── */
#booking-cart-fab {
  display: none;
  position: fixed;
  bottom: calc(72px + env(safe-area-inset-bottom, 0px) + 12px);
  right: 18px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--orange);
  color: #fff;
  border: none;
  font-size: 22px;
  cursor: pointer;
  z-index: 900;
  box-shadow: 0 4px 16px rgba(255,107,0,.45);
  align-items: center;
  justify-content: center;
  transition: transform .15s, box-shadow .15s;
}
#booking-cart-fab:active { transform: scale(.93); }
#booking-cart-fab .booking-cart-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: #fff;
  color: var(--orange);
  font-size: 11px;
  font-weight: 800;
  border-radius: 99px;
  min-width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 2px solid var(--orange);
  line-height: 1;
}
@media(max-width:560px) {
  #booking-cart-fab { display: flex; }
}


/* ╔══════════════════════════════════════════════════════════════════
   MOBILE APP UPGRADE — комплексный апгрейд под мобильное приложение
   ══════════════════════════════════════════════════════════════════╝ */

/* ── 1. Базовые улучшения для touch-устройств ────────────────────── */
:root {
  --bnav-h: 68px;
  --topbar-h: 56px;
  --radius-modal: 24px;
  --tap-target: 44px;   /* минимальный tap-target по Apple HIG */
}

/* Убираем tap-highlight на всех интерактивных элементах */
a, button, [role="button"], [data-booking-action], .bnav-item,
.booking-vehicle-card, .mo-card, .card[onclick], .act-btn,
.svc-cat-nav-card, .cab-tab, .admin-nav-item, .drawer-link {
  -webkit-tap-highlight-color: transparent;
}

/* Плавный скролл везде */
* { -webkit-overflow-scrolling: touch; }
html { scroll-behavior: smooth; }

/* Запрет случайного выделения текста при свайпах */
.bnav-item, .booking-steps, .mo-card, .act-btn,
.sched-btn, .cab-tab, .admin-nav-item {
  -webkit-user-select: none;
  user-select: none;
}

/* ── 2. Нижний навбар — нативный вид ────────────────────────────── */
#bottom-nav {
  height: calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  background: rgba(13,13,15,.88);
  border-top: 1px solid rgba(255,255,255,.08);
}
.bnav-inner {
  height: var(--bnav-h);
  display: flex;
  align-items: stretch;
}
.bnav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 6px 4px;
  min-height: var(--tap-target);
  border-radius: 12px;
  margin: 4px 2px;
  transition: background .15s, transform .1s;
  position: relative;
}
.bnav-item:active { transform: scale(.91); background: rgba(255,255,255,.06); }
.bnav-item.active { background: rgba(255,107,0,.12); }
.bnav-icon { font-size: 22px; line-height: 1; }
.bnav-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .2px;
  color: var(--text3);
  transition: color .15s;
}
.bnav-item.active .bnav-label { color: var(--orange); }
.bnav-icon-wrap { position: relative; }

/* ── 3. Верхний навбар — компактнее на мобиле ───────────────────── */
@media (max-width: 640px) {
  #nav {
    height: var(--topbar-h);
    padding: 0 14px;
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
  }
  #nav.scrolled { box-shadow: 0 1px 0 rgba(255,255,255,.06); }
  .nav-logo { font-size: 17px; letter-spacing: .5px; }
  .nav-links { display: none; } /* скрыт на мобиле — есть bottom nav */
  #navLinks { display: none; }
}

/* ── 4. Отступ от нижнего навбара ───────────────────────────────── */
@media (max-width: 900px) {
  #app {
    padding-bottom: calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px) + 8px);
  }
}

/* ── 5. Карточки — увеличенные tap-зоны ─────────────────────────── */
@media (max-width: 640px) {
  .card {
    border-radius: 18px;
  }

  /* Кнопки — минимум 44px высота */
  .btn {
    min-height: var(--tap-target);
    border-radius: 12px;
    font-size: 14px;
    padding: 11px 18px;
  }
  .btn-primary { font-weight: 700; }

  /* Инпуты — крупнее и удобнее */
  .pf-input, .bform-input, .bform-textarea {
    font-size: 16px !important; /* предотвращает зум на iOS */
    min-height: 48px;
    border-radius: 12px;
    padding: 12px 14px;
  }
  textarea.pf-input, .bform-textarea {
    min-height: 96px;
  }

  /* Селект */
  select.pf-input {
    min-height: 48px;
    background-image: none;
    -webkit-appearance: none;
  }
}

/* ── 6. Модалки — bottom sheet на мобиле ───────────────────────── */
@media (max-width: 640px) {
  .cmodal-overlay {
    align-items: flex-end;
    padding: 0;
    background: rgba(0,0,0,.6);
  }
  .cmodal-card, .cmodal-box {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: var(--radius-modal) var(--radius-modal) 0 0 !important;
    max-height: 92vh !important;
    margin: 0;
    padding-bottom: env(safe-area-inset-bottom, 16px);
    /* Drag handle индикатор */
    background: var(--bg2);
  }
  /* Handle — полоска сверху */
  .cmodal-card::before, .cmodal-box::before {
    content: '';
    display: block;
    width: 40px;
    height: 4px;
    border-radius: 2px;
    background: rgba(255,255,255,.18);
    margin: 10px auto -6px;
    flex-shrink: 0;
  }
  .cmodal-head {
    padding: 16px 20px 12px;
    border-bottom: 1px solid var(--line);
  }
  .cmodal-head h3 { font-size: 17px; }
  .cmodal-body { padding: 16px 20px; }
  /* Confirm modal — тоже bottom sheet */
  #confirm-modal .cmodal-box {
    padding: 0 0 env(safe-area-inset-bottom, 20px);
  }
}

/* ── 7. Карточки заявок (мастер, клиент) ───────────────────────── */
@media (max-width: 640px) {
  .mo-card {
    border-radius: 18px;
    padding: 16px;
    margin-bottom: 10px;
  }
  .mo-card-title { font-size: 15px; font-weight: 700; }
  .mo-card-actions {
    gap: 8px;
    margin-top: 12px;
    flex-wrap: wrap;
  }
  .mo-card-actions .btn { flex: 1; min-width: 0; justify-content: center; }

  /* Мастер — карточка заявки */
  .sched-card {
    border-radius: 18px;
    padding: 14px 16px;
  }
  .sched-card .btn { min-height: 42px; }

  /* Бирж‑карточка */
  .queue-card {
    border-radius: 18px;
    padding: 14px 16px;
  }
}

/* ── 8. Страница «Мои заявки» ───────────────────────────────────── */
@media (max-width: 640px) {
  .mo-filter-bar {
    margin: 0 -16px;
    padding: 0 12px;
  }
  .mo-filter-tabs {
    padding: 0 4px 8px;
    gap: 6px;
  }
  .mo-filter-tab {
    flex-shrink: 0;
    padding: 8px 14px;
    border-radius: 99px;
    font-size: 13px;
    min-height: 38px;
  }
  .mo-timeline {
    padding: 10px 0 0;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .mo-timeline::-webkit-scrollbar { display: none; }
}

/* ── 9. Booking wizard ──────────────────────────────────────────── */
@media (max-width: 640px) {
  .booking-hero { padding: 28px 0 20px; }
  .bform-card { padding: 16px; border-radius: 18px; }
  .bform-section-title { font-size: 13px; }

  /* Шаги — горизонтальный скролл без обрезания */
  .booking-steps {
    padding: 0 4px 6px;
    margin-bottom: 20px;
    gap: 0;
  }
  .bstep-label { font-size: 10px; }
  .bstep-num { width: 24px; height: 24px; font-size: 10px; }
  .bstep-line { min-width: 16px; }

  /* Карточки услуг */
  .booking-service-card {
    padding: 12px;
    border-radius: 14px;
  }

  /* Выбор авто */
  .booking-vehicle-card {
    padding: 12px 14px;
    border-radius: 14px;
    min-height: var(--tap-target);
  }

  /* Дата и время */
  .date-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .time-grid { grid-template-columns: repeat(4, 1fr); gap: 6px; }
  .date-btn, .time-btn {
    padding: 10px 6px;
    border-radius: 12px;
    font-size: 12px;
    min-height: 52px;
  }

  /* Навигация wizard */
  .bform-nav {
    gap: 8px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--line);
  }
  .bform-nav .btn { flex: 1; justify-content: center; }
}

/* ── 10. Нотиф FAB и корзина — правильное позиционирование ────── */
#notifs-fab {
  bottom: calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px) + 14px);
  right: 18px;
}
#booking-cart-fab {
  bottom: calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px) + 76px);
  right: 18px;
}

/* ── 11. Формы профиля ──────────────────────────────────────────── */
@media (max-width: 640px) {
  .profile-form {
    grid-template-columns: 1fr !important;
    gap: 12px;
  }
  .pf-group { margin-bottom: 0; }
  .pf-label { font-size: 12px; margin-bottom: 5px; }
}

/* ── 12. Toast — снизу, над навбаром ────────────────────────────── */
@media (max-width: 640px) {
  .g-toast {
    bottom: calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px) + 16px) !important;
    left: 16px !important;
    right: 16px !important;
    width: auto !important;
    max-width: none !important;
    transform: translateY(20px) !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    padding: 14px 18px !important;
    text-align: center;
    white-space: normal;
  }
  .g-toast.show {
    transform: translateY(0) !important;
  }
}

/* ── 13. Spa hero — компактнее на мобиле ────────────────────────── */
@media (max-width: 640px) {
  .spa-page-hero { padding: 28px 0 20px; }
  .spa-hero-title { font-size: 26px; }
  .spa-hero-sub { font-size: 14px; }
  .spa-hero-stats {
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-start;
  }
  .spa-hero-stat { min-width: 60px; }
  .spa-hero-stat-num { font-size: 22px; }
  .section { padding: 28px 0; }
}

/* ── 14. Чат — оптимизация под мобиль ──────────────────────────── */
@media (max-width: 640px) {
  .chat-overlay.open {
    border-radius: var(--radius-modal) var(--radius-modal) 0 0;
    top: auto !important;
    bottom: 0;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-height: 92vh;
    height: 92vh;
  }
  .chat-head {
    padding: 14px 16px;
    border-radius: var(--radius-modal) var(--radius-modal) 0 0;
  }
  .chat-messages {
    padding: 12px 14px;
  }
  .chat-footer {
    padding: 10px 14px;
    padding-bottom: max(14px, env(safe-area-inset-bottom, 14px));
  }
  .chat-input {
    font-size: 16px !important; /* no zoom on iOS */
    border-radius: 12px;
    min-height: 42px;
  }
  .chat-send-btn {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    flex-shrink: 0;
  }
}

/* ── 15. Контейнер — паддинги на мобиле ─────────────────────────── */
@media (max-width: 640px) {
  .container { padding: 0 14px; }
}

/* ── 16. Таблицы — скролл по горизонтали ────────────────────────── */
@media (max-width: 640px) {
  .admin-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 14px;
  }
  table { min-width: 480px; }
  th, td { padding: 10px 12px; font-size: 12px; }
}

/* ── 17. Pull-to-refresh индикатор (визуальный) ─────────────────── */
@keyframes spin-ptr {
  to { transform: rotate(360deg); }
}
.ptr-indicator {
  position: fixed;
  top: calc(var(--topbar-h) + env(safe-area-inset-top, 0px) + 8px);
  left: 50%;
  transform: translateX(-50%);
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--surface);
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  opacity: 0;
  transition: opacity .2s;
  z-index: 500;
  box-shadow: 0 4px 12px rgba(0,0,0,.3);
}
.ptr-indicator.visible { opacity: 1; animation: spin-ptr .7s linear infinite; }

/* ── 18. Скелетон-загрузка ──────────────────────────────────────── */
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
.skeleton {
  background: linear-gradient(90deg,
    var(--surface) 25%,
    rgba(255,255,255,.06) 50%,
    var(--surface) 75%
  );
  background-size: 800px 100%;
  animation: shimmer 1.4s infinite;
  border-radius: 8px;
}
.skeleton-text  { height: 14px; border-radius: 4px; }
.skeleton-title { height: 22px; border-radius: 6px; }
.skeleton-card  { height: 80px; border-radius: 16px; }

/* ── 19. Переходы страниц ────────────────────────────────────────── */
@media (max-width: 900px) {
  .page {
    animation: page-enter .22s cubic-bezier(.25,.46,.45,.94) both;
  }
  @keyframes page-enter {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
  }
}

/* ── 20. Активные состояния кнопок ──────────────────────────────── */
@media (hover: none) {
  .btn:active         { transform: scale(.95); opacity: .88; }
  .act-btn:active     { transform: scale(.93); }
  .bnav-item:active   { transform: scale(.88); }
  .mo-card:active     { transform: scale(.99); }
  .sched-card:active  { transform: scale(.99); box-shadow: none; }
  .booking-vehicle-card:active { transform: scale(.97); }
  .date-btn:active, .time-btn:active { transform: scale(.93); }
}


@media (max-width: 768px){
  #svc-active-category,
  .svc-active-category#svc-active-category{
    display:none !important;
  }
}


.svc-card-v2-cart-btn{
  gap:8px;
  transition:background .15s, color .15s, border-color .15s;
}
.svc-card-v2-cart-btn::before{
  content:'';
}
.svc-card-v2-cart-btn--active{
  border-color:#ef4444 !important;
  color:#ef4444 !important;
}
.svc-card-v2-cart-btn--active:hover{
  background:rgba(239,68,68,.08) !important;
}

@media (max-width:768px){
  .news-category-focus__stats{
    display:none !important;
  }
}


@media (max-width:768px){
  .svc-active-category.svc-active-category--page.parts-summary-card{
    display:none !important;
  }
}



/* ── Общая корзина услуг (категории services:*) ─────────────────── */
#services-cart-fab{
  display:none;
  position:fixed;
  right:18px;
  bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom, 0px) + 12px);
  width:56px;
  height:56px;
  border:none;
  border-radius:50%;
  background:linear-gradient(180deg, #ff8b3d 0%, #ff6b00 100%);
  color:#fff;
  font-size:24px;
  cursor:pointer;
  z-index: 898;
  box-shadow:0 10px 28px rgba(255,107,0,.38);
  align-items:center;
  justify-content:center;
}
#services-cart-fab:active{ transform:scale(.95); }
#services-cart-fab .services-cart-badge{
  position:absolute;
  top:-4px;
  right:-4px;
  min-width:22px;
  height:22px;
  border-radius:999px;
  background:#fff;
  color:var(--orange);
  border:2px solid var(--orange);
  font-size:11px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 5px;
  line-height:1;
}
.services-cart-modal-card{
  max-width:430px;
  width:min(94vw,430px);
  border-radius:20px;
  padding-bottom:env(safe-area-inset-bottom,0);
}
.services-cart-modal__count{
  font-size:12px;
  color:var(--text3);
  font-weight:500;
}
.services-cart-modal__list{
  display:flex;
  flex-direction:column;
  gap:0;
}
.services-cart-modal__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 0;
  border-bottom:1px solid var(--line);
}
.services-cart-modal__meta{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.services-cart-modal__ico{
  width:32px;
  height:32px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,107,0,.08);
  flex:0 0 32px;
}
.services-cart-modal__name{
  font-size:14px;
  font-weight:700;
}
.services-cart-modal__sub{
  font-size:12px;
  color:var(--text3);
  margin-top:2px;
}
.services-cart-modal__remove{
  width:30px;
  height:30px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--text3);
  font-size:18px;
  cursor:pointer;
  flex:0 0 30px;
}
.services-cart-modal__footer{
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid var(--line);
}
.services-cart-modal__total{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:14px;
}
.services-cart-modal__total span{
  font-size:13px;
  color:var(--text);
  font-weight:700;
}
.services-cart-modal__total strong{
  color:var(--orange);
  font-size:20px;
  font-weight:800;
}
.services-cart-modal__actions{
  display:flex;
  gap:8px;
}
.services-cart-modal__actions .btn{
  flex:1;
}
.services-cart-modal__actions--single .btn{
  width:100%;
}
.services-cart-modal__empty{
  color:var(--text3);
  font-size:13px;
  text-align:center;
  padding:18px 0;
}
@media (min-width: 769px){
  #services-cart-fab{ display:none !important; }
  #services-cart-gonext{ display:none !important; }
}

/* ── Кнопка «Далее» рядом с FAB корзины ───────────────────────── */
#services-cart-gonext{
  display:none;
  position:fixed;
  right:calc(18px + 56px + 10px);
  bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom, 0px) + 12px);
  height:56px;
  padding:0 22px;
  border:none;
  border-radius:28px;
  background:linear-gradient(135deg, #ff8b3d 0%, #ff6b00 100%);
  color:#fff;
  font-size:15px;
  font-weight:700;
  font-family:inherit;
  cursor:pointer;
  z-index:898;
  box-shadow:0 10px 28px rgba(255,107,0,.38);
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  gap:6px;
  letter-spacing:.2px;
  transition:transform .15s,box-shadow .15s;
}
#services-cart-gonext:active{ transform:scale(.95); box-shadow:0 6px 16px rgba(255,107,0,.28); }

/* ── Services Booking Wizard ────────────────────────────────────── */
.swiz-overlay{ z-index:1200; }

.swiz-card{
  width:min(96vw, 520px);
  max-height:92dvh;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  border-radius:20px;
  padding:0;
}
.swiz-card .cmodal-head{
  flex-shrink:0;
  padding:16px 20px 14px;
  border-bottom:1px solid var(--line);
}
.swiz-body{
  flex:1;
  overflow-y:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  padding:0 20px 20px;
}
/* Booking-форма внутри модалки — отступы и тени адаптируем */
.swiz-body .bform-card{
  box-shadow:none;
  border:none;
  padding:16px 0 0;
  margin:0;
}
.swiz-body .booking-layout{ display:block; }
.swiz-body .booking-summary{ display:none; }
.swiz-body .bform-nav{
  position:sticky;
  bottom:0;
  background:var(--bg-card,var(--surface));
  padding:12px 0 4px;
  margin-top:8px;
  border-top:1px solid var(--line);
  z-index:2;
}
.swiz-body .booking-steps{
  padding:14px 0 4px;
  margin-bottom:4px;
}
.swiz-body .booking-success{
  text-align:center;
  padding:24px 0;
}
/* ── PartsCart FAB ─────────────────────────────────────────────── */
#parts-cart-fab{
  display:none;
  position:fixed;
  right:18px;
  bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom, 0px) + 80px); /* выше services-cart-fab */
  width:56px;
  height:56px;
  border:none;
  border-radius:50%;
  background:linear-gradient(180deg, #38bdf8 0%, #0ea5e9 100%);
  color:#fff;
  font-size:22px;
  cursor:pointer;
  z-index:897;
  box-shadow:0 10px 28px rgba(14,165,233,.38);
  align-items:center;
  justify-content:center;
}
#parts-cart-fab:active{ transform:scale(.95); }
@media (min-width: 769px){
  #parts-cart-fab{ display:none !important; }
}
/* Кнопка «В корзину» на карточке */
.parts-cart-btn.active{
  background:rgba(14,165,233,.12);
  border-color:#0ea5e9;
  color:#0ea5e9;
}

/* ── Floating back button — под-страницы категорий ─────────────── */
#section-back-fab {
  display: none;
  position: fixed;
  left: 18px;
  bottom: calc(var(--bottom-nav-h, 68px) + env(safe-area-inset-bottom, 0px) + 14px);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: var(--bg2);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--text);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  z-index: 895;
  box-shadow: 0 4px 16px rgba(0,0,0,.28);
  align-items: center;
  justify-content: center;
  -webkit-tap-highlight-color: transparent;
  transition: transform .12s, background .12s;
}
#section-back-fab:active {
  transform: scale(.88);
  background: var(--surface);
}


.onb-next-btn{
  width:100%;
  min-height:44px;
  justify-content:center;
  margin-top:12px;
}

/* ── Booking wizard step 4 — auth confirmed block ──────────────── */
.booking-auth-confirmed{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  background:rgba(34,197,94,.08);
  border:1.5px solid rgba(34,197,94,.3);
  border-radius:14px;
}
.booking-auth-confirmed__check{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#22c55e,#16a34a);
  color:#fff;font-size:18px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.booking-auth-confirmed__name{font-size:15px;font-weight:700;color:var(--text);}
.booking-auth-confirmed__phone{font-size:13px;color:var(--text3);margin-top:2px;}
.booking-auth-fields{ display:flex; flex-direction:column; gap:4px; }

/* ── Step 4 OTP row ─────────────────────────────────────────────── */
.bstep4-otp-row{
  display:flex;
  gap:10px;
  justify-content:center;
  margin:4px 0 8px;
}
.bstep4-otp-row .otp-box{
  width:54px;height:58px;
  border-radius:12px;
  border:2px solid var(--line);
  background:var(--surface);
  font-size:24px;font-weight:800;
  text-align:center;
  color:var(--text);
  transition:border-color .15s;
  outline:none;
  font-family:inherit;
  -moz-appearance:textfield;
}
.bstep4-otp-row .otp-box:focus{ border-color:var(--orange); }
.bstep4-otp-row .otp-box::-webkit-inner-spin-button,
.bstep4-otp-row .otp-box::-webkit-outer-spin-button{ -webkit-appearance:none; }

/* ── Step 3 vehicle loading state ───────────────────────────────── */
.bv-loading{
  display:flex;
  align-items:center;
  gap:10px;
  padding:18px 14px;
  font-size:14px;
  color:var(--text3);
  background:var(--surface);
  border-radius:12px;
  border:1.5px solid var(--line);
}
.bv-loading-dot{
  width:18px;height:18px;border-radius:50%;
  border:2px solid var(--orange);
  border-top-color:transparent;
  animation:bv-spin .7s linear infinite;
  flex-shrink:0;
}
@keyframes bv-spin{ to{ transform:rotate(360deg); } }

/* ── Vehicle add modal — должна быть выше booking wizard (z:1200) ── */
#vehicle-add-modal{ z-index: 1300 !important; }

/* ── Vehicle add modal — компактный размер внутри booking wizard ── */
.swiz-overlay ~ #vehicle-add-modal .cmodal-box,
body:has(.swiz-overlay.open) #vehicle-add-modal .cmodal-box{
  max-width:360px;
  padding:18px 16px 16px;
}
body:has(.swiz-overlay.open) #vehicle-add-modal .vehicle-quick-create-note{
  font-size:12px;
  margin-bottom:10px;
}
body:has(.swiz-overlay.open) #vehicle-add-modal .vehicle-quick-photo-box{
  display:none;
}
body:has(.swiz-overlay.open) #vehicle-add-modal .profile-form{
  gap:8px;
}
body:has(.swiz-overlay.open) #vehicle-add-modal .pf-input{
  padding:9px 11px;
  font-size:13px;
}

/* ══════════════════════════════════════════════════════
   Booking Step 3 — выбор автомобиля
══════════════════════════════════════════════════════ */
.bstep3-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:4px;
}

/* Карточка авто */
.bstep3-car-btn{
  display:flex;
  align-items:center;
  gap:13px;
  width:100%;
  padding:13px 14px;
  border:1.5px solid var(--line);
  border-radius:14px;
  background:var(--surface);
  cursor:pointer;
  text-align:left;
  transition:border-color .15s, background .15s;
  position:relative;
}
.bstep3-car-btn:not(.selected):hover{
  border-color:var(--orange);
  background:rgba(255,107,0,.04);
}
.bstep3-car-btn.selected{
  border-color:var(--orange);
  background:rgba(255,107,0,.07);
}

.bstep3-car-ico{
  font-size:24px;
  flex-shrink:0;
  width:36px;
  text-align:center;
}

.bstep3-car-main{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:3px;
}
.bstep3-car-title{
  font-size:14px;
  font-weight:700;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.bstep3-car-meta{
  font-size:12px;
  color:var(--text3);
}

.bstep3-car-check{
  font-size:16px;
  font-weight:800;
  color:var(--orange);
  flex-shrink:0;
}
.bstep3-car-badge{
  font-size:11px;
  font-weight:700;
  color:var(--orange);
  background:rgba(255,107,0,.1);
  border:1px solid rgba(255,107,0,.25);
  border-radius:999px;
  padding:2px 8px;
  flex-shrink:0;
}

/* Кнопка добавить */
.bstep3-add-row{
  margin-top:10px;
}
.bstep3-add-btn{
  width:100%;
  justify-content:center;
  font-size:13px;
  padding:10px 16px;
  border-radius:12px;
  color:var(--text2);
  border-color:var(--line);
}
.bstep3-add-btn:hover{
  border-color:var(--orange);
  color:var(--orange);
}

/* Превью черновика */
.bstep3-preview-wrap{
  margin-top:14px;
}

/* ══════════════════════════════════════════════════════
   Loyalty — реальная система баллов
══════════════════════════════════════════════════════ */

/* Hero-блок */
.loy-hero{
  position:relative;
  overflow:hidden;
  padding:28px 24px 20px;
  text-align:center;
  margin-bottom:14px;
}
.loy-hero-glow{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.loy-hero-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 16px;
  border-radius:999px;
  border:1.5px solid;
  font-size:13px;
  font-weight:800;
  margin-bottom:14px;
  letter-spacing:.3px;
  position:relative;
}
.loy-hero-pts{
  font-family:'Oswald',sans-serif;
  font-size:54px;
  font-weight:700;
  line-height:1;
  color:var(--text);
  letter-spacing:-1px;
  position:relative;
}
.loy-hero-sub{
  font-size:12px;
  color:var(--text3);
  margin-top:4px;
  margin-bottom:16px;
  position:relative;
}

/* Progress bar */
.loy-hero-bar-wrap{ position:relative; margin-bottom:12px; }
.loy-hero-bar{
  height:8px;
  border-radius:999px;
  background:var(--line);
  overflow:hidden;
  margin-bottom:6px;
}
.loy-hero-bar-fill{
  height:100%;
  border-radius:999px;
  transition:width .6s cubic-bezier(.4,0,.2,1);
  min-width:4px;
}
.loy-hero-bar-labels{
  display:flex;
  justify-content:space-between;
  font-size:11px;
  color:var(--text3);
  gap:8px;
}

/* Статы */
.loy-hero-stats{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 8px;
  margin:12px 0;
  position:relative;
}
.loy-hero-stat{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:3px;
}
.loy-hero-stat-val{
  font-family:'Oswald',sans-serif;
  font-size:18px;
  font-weight:700;
  color:var(--text);
  line-height:1;
}
.loy-hero-stat-lbl{
  font-size:10px;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.6px;
}
.loy-hero-stat-sep{
  width:1px;
  height:32px;
  background:var(--line);
  flex-shrink:0;
}
.loy-hero-actions{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
  position:relative;
  margin-top:4px;
}

/* Уровни */
.loy-levels-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:14px;
}
.loy-lvl-card{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border:1.5px solid var(--line);
  border-radius:14px;
  background:var(--surface);
  opacity:.55;
  transition:opacity .2s,border-color .2s;
}
.loy-lvl-card.loy-lvl-done{ opacity:.85; }
.loy-lvl-card.loy-lvl-cur{
  opacity:1;
  border-color:var(--orange);
  background:rgba(255,107,0,.06);
}
.loy-lvl-ico{ font-size:22px; flex-shrink:0; }
.loy-lvl-body{ flex:1; min-width:0; }
.loy-lvl-name{
  font-size:13px;
  font-weight:700;
  color:var(--text);
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.loy-lvl-you{
  font-size:10px;
  font-weight:700;
  color:var(--orange);
  background:rgba(255,107,0,.12);
  padding:1px 6px;
  border-radius:999px;
}
.loy-lvl-range{ font-size:11px; color:var(--text3); margin-top:2px; }
.loy-lvl-disc{ font-size:12px; font-weight:700; margin-top:3px; }
.loy-lvl-tick{ font-size:16px; font-weight:800; flex-shrink:0; }

/* Как зарабатывать */
.loy-how{ padding:18px 20px; margin-bottom:14px; }
.loy-how-title{
  font-size:14px;
  font-weight:700;
  margin-bottom:14px;
  color:var(--text);
}
.loy-how-grid{ display:flex; flex-direction:column; gap:12px; }
.loy-how-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:13px;
}
.loy-how-item > span{ font-size:20px; flex-shrink:0; margin-top:1px; }
.loy-how-item b{ display:block; font-weight:700; color:var(--text); margin-bottom:2px; }
.loy-how-item p{ color:var(--text3); margin:0; font-size:12px; line-height:1.4; }

/* История транзакций */
.loy-history{ overflow:hidden; margin-bottom:14px; }
.loy-history-head{
  padding:14px 18px 10px;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--text3);
  border-bottom:1px solid var(--line);
}
.loy-history-body{ padding:0 18px; }
.loy-txn{
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 0;
  border-bottom:1px solid var(--line);
}
.loy-txn:last-child{ border-bottom:none; }
.loy-txn-pts{
  font-family:'Oswald',sans-serif;
  font-size:16px;
  font-weight:700;
  min-width:60px;
  text-align:right;
  flex-shrink:0;
}
.loy-txn-earn{ color:var(--green,#22c55e); }
.loy-txn-spend{ color:#ef4444; }
.loy-txn-body{ flex:1; min-width:0; }
.loy-txn-label{ font-size:13px; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.loy-txn-date{ font-size:11px; color:var(--text3); margin-top:2px; }
.loy-history-empty{
  padding:20px 0;
  font-size:13px;
  color:var(--text3);
  line-height:1.5;
}

@media (max-width:480px){
  .loy-levels-grid{ grid-template-columns:1fr; }
  .loy-hero-pts{ font-size:44px; }
}

/* ══════════════════════════════════════════════════════
   Комментарии к новостям
══════════════════════════════════════════════════════ */
.nac-wrap{
  max-width:740px;
  margin:0 auto 40px;
  padding:0 16px;
}
.nac-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
}
.nac-title{
  font-family:'Oswald',sans-serif;
  font-size:20px;
  font-weight:700;
  color:var(--text);
  margin:0;
}
.nac-count{
  font-size:13px;
  color:var(--text3);
  font-weight:500;
}
.nac-item{
  display:flex;
  gap:12px;
  margin-bottom:16px;
}
.nac-item-av{
  width:36px;
  height:36px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orange),#ff8b3d);
  color:#fff;
  font-weight:800;
  font-size:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.nac-item-body{
  flex:1;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  padding:11px 14px;
}
.nac-item-meta{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:6px;
  flex-wrap:wrap;
}
.nac-item-name{
  font-size:13px;
  font-weight:700;
  color:var(--text);
}
.nac-item-date{
  font-size:11px;
  color:var(--text3);
}
.nac-del{
  margin-left:auto;
  background:none;
  border:none;
  color:var(--text3);
  cursor:pointer;
  font-size:14px;
  padding:0 4px;
  line-height:1;
  opacity:.6;
}
.nac-del:hover{ opacity:1; color:#ef4444; }
.nac-item-text{
  font-size:14px;
  color:var(--text);
  line-height:1.55;
  white-space:pre-wrap;
  word-break:break-word;
}
.nac-form{
  display:flex;
  gap:12px;
  margin-top:20px;
}
.nac-form-av{
  width:36px;
  height:36px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orange),#ff8b3d);
  color:#fff;
  font-weight:800;
  font-size:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  margin-top:4px;
}
.nac-form-right{ flex:1; }
.nac-textarea{
  width:100%;
  padding:12px 14px;
  border:1.5px solid var(--line);
  border-radius:12px;
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  font-family:inherit;
  resize:vertical;
  min-height:80px;
  box-sizing:border-box;
  transition:border-color .15s;
}
.nac-textarea:focus{ border-color:var(--orange); outline:none; }
.nac-form-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:8px;
}
.nac-form-who{
  font-size:12px;
  color:var(--text3);
}
.nac-empty{
  font-size:13px;
  color:var(--text3);
  padding:16px 0 20px;
  text-align:center;
}
.nac-login-hint{
  text-align:center;
  padding:20px 0;
}

/* ══════════════════════════════════════════════════════
   Отзывы — улучшенный дизайн
══════════════════════════════════════════════════════ */
.rvs-rating-block{
  display:flex;
  align-items:flex-start;
  gap:28px;
  padding:24px 28px;
  margin-bottom:28px;
  flex-wrap:wrap;
}
.rvs-rating-big{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  min-width:100px;
}
.rvs-avg{
  font-family:'Oswald',sans-serif;
  font-size:56px;
  font-weight:700;
  color:var(--text);
  line-height:1;
}
.rvs-stars{
  font-size:18px;
  color:#f5b800;
  letter-spacing:2px;
}
.rvs-count{
  font-size:12px;
  color:var(--text3);
  text-align:center;
}
.rvs-bars{
  flex:1;
  min-width:160px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.rvs-bar-row{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
}
.rvs-bar-n{ color:var(--text3); min-width:24px; text-align:right; }
.rvs-bar-track{
  flex:1;
  height:7px;
  background:var(--line);
  border-radius:999px;
  overflow:hidden;
}
.rvs-bar-fill{
  height:100%;
  background:linear-gradient(90deg,#f5b800,#ff8b3d);
  border-radius:999px;
  transition:width .5s ease;
  min-width:2px;
}
.rvs-bar-c{ color:var(--text3); min-width:18px; }
.rvs-actions{
  display:flex;
  flex-direction:column;
  gap:8px;
  align-self:center;
}

/* Форма отзыва */
.rvs-form-header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.rvs-form-av{
  width:42px;
  height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orange),#ff8b3d);
  color:#fff;
  font-weight:800;
  font-size:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.rvs-form-who{ font-size:15px; font-weight:700; color:var(--text); }
.rvs-form-sub{ font-size:12px; color:var(--text3); margin-top:2px; }
.rvs-stars-wrap{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}
.rvs-stars-hint{
  font-size:12px;
  color:var(--text3);
}
.rvs-form-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:14px;
  flex-wrap:wrap;
}
.rvs-login-cta{
  text-align:center;
  padding:24px 16px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}
.rvs-login-ico{ font-size:36px; }
.rvs-login-title{ font-size:18px; font-weight:700; color:var(--text); }
.rvs-login-sub{ font-size:13px; color:var(--text3); max-width:320px; line-height:1.5; }

@media (max-width:560px){
  .rvs-rating-block{ padding:16px; gap:16px; }
  .rvs-avg{ font-size:44px; }
  .rvs-actions{ flex-direction:row; flex-wrap:wrap; }
}

/* ══════════════════════════════════════════════════════
   Cabinet Car — компактные карточки гаража
══════════════════════════════════════════════════════ */
.vcar-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
  padding-top:4px;
}
.vcar-title{
  font-family:'Oswald',sans-serif;
  font-size:20px;
  font-weight:700;
  margin:0;
  color:var(--text);
}
.vcar-grid{
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* Компактная карточка авто */
.vcard{
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 14px;
  border:1.5px solid var(--line);
  border-radius:14px;
  background:var(--surface);
  cursor:pointer;
  text-align:left;
  width:100%;
  transition:border-color .15s,background .15s;
}
.vcard:hover{
  border-color:var(--orange);
  background:rgba(255,107,0,.04);
}
.vcard-ico{
  width:44px;
  height:44px;
  border-radius:12px;
  background:var(--bg2);
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex-shrink:0;
}
.vcard-ico-emoji{ font-size:24px; line-height:1; }
.vcard-ico-img{ width:100%; height:100%; object-fit:cover; border-radius:11px; }
.vcard-body{ flex:1; min-width:0; }
.vcard-title{
  font-size:14px;
  font-weight:700;
  color:var(--text);
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.vcard-sub{
  font-size:12px;
  color:var(--text3);
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.vcard-def-badge{
  font-size:10px;
  font-weight:700;
  color:var(--orange);
  background:rgba(255,107,0,.1);
  border:1px solid rgba(255,107,0,.25);
  border-radius:999px;
  padding:2px 7px;
}
.vcard-arrow{
  font-size:18px;
  color:var(--text3);
  flex-shrink:0;
}

/* ── Vehicle Detail Modal ── */
.vdm-box{
  max-width:480px;
  max-height:88vh;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.vdm-body{
  overflow-y:auto;
  flex:1;
  padding-bottom:8px;
}
.vdm-photo-wrap{
  margin-bottom:14px;
  border-radius:12px;
  overflow:hidden;
  max-height:180px;
}
.vdm-photo{ width:100%; height:180px; object-fit:cover; display:block; }

.vdm-hero{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.vdm-hero-ico{
  font-size:28px;
  width:48px;
  height:48px;
  border-radius:12px;
  background:var(--bg2);
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.vdm-hero-title{ font-size:16px; font-weight:700; color:var(--text); }
.vdm-hero-sub{ font-size:12px; color:var(--text3); margin-top:2px; }

.vdm-fill-wrap{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.vdm-fill-bar{
  flex:1;
  height:6px;
  background:var(--line);
  border-radius:999px;
  overflow:hidden;
}
.vdm-fill-bar > div{
  height:100%;
  border-radius:999px;
  min-width:4px;
}
.vdm-fill-bar.good > div{ background:#22c55e; }
.vdm-fill-bar.mid  > div{ background:#f5b800; }
.vdm-fill-bar.low  > div{ background:#ef4444; }
.vdm-fill-lbl{ font-size:11px; color:var(--text3); flex-shrink:0; }

.vdm-stats{
  display:flex;
  gap:0;
  background:var(--bg2);
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 8px;
  margin-bottom:16px;
}
.vdm-stat{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
  border-right:1px solid var(--line);
}
.vdm-stat:last-child{ border-right:none; }
.vdm-stat b{ font-family:'Oswald',sans-serif; font-size:17px; font-weight:700; color:var(--text); }
.vdm-stat span{ font-size:10px; color:var(--text3); text-transform:uppercase; letter-spacing:.5px; }

.vdm-section-title{
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--text3);
  margin:14px 0 8px;
}
.vdm-fields{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  margin-bottom:4px;
}
.vdm-field{
  background:var(--bg2);
  border:1px solid var(--line);
  border-radius:9px;
  padding:8px 10px;
}
.vdm-field-lbl{ display:block; font-size:10px; color:var(--text3); margin-bottom:3px; }
.vdm-field-val{ display:block; font-size:13px; font-weight:600; color:var(--text); word-break:break-word; }

.vdm-actions{
  display:flex;
  gap:8px;
  margin-top:16px;
  flex-wrap:wrap;
}
.vdm-actions .btn{ flex:1; justify-content:center; min-width:80px; }
.vdm-del{ color:#ef4444 !important; border-color:#ef444440 !important; }

#vehicle-detail-modal{ z-index:1200 !important; }

/* ── Cab avatar — фото из галереи ── */
.cab-avatar-wrap{
  position:relative;
}
.cab-avatar--photo{
  width:64px;
  height:64px;
  border-radius:50%;
  object-fit:cover;
  border:3px solid var(--orange);
  display:block;
}
.cab-av-camera{
  position:absolute;
  bottom:0;
  right:0;
  width:22px;
  height:22px;
  border-radius:50%;
  background:var(--orange);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  box-shadow:0 1px 4px rgba(0,0,0,.3);
  pointer-events:none;
}
.cab-avatar-wrap:hover .cab-av-camera{
  transform:scale(1.15);
  transition:transform .15s;
}

/* ══════════════════════════════════════════════════════
   Cabinet Stats Tab
══════════════════════════════════════════════════════ */
.cst-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:22px;
}
.cst-card{
  padding:16px 14px;
  text-align:center;
  border-radius:14px;
}
.cst-card-ico{ font-size:22px; margin-bottom:6px; }
.cst-card-val{
  font-family:'Oswald',sans-serif;
  font-size:24px;
  font-weight:700;
  color:var(--text);
  line-height:1;
  margin-bottom:4px;
}
.cst-card-lbl{ font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:.6px; }

.cst-section-title{
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--text3);
  margin:18px 0 10px;
}
.cst-orders{ display:flex; flex-direction:column; gap:6px; }
.cst-order-row{
  display:flex;
  align-items:center;
  gap:12px;
  padding:11px 14px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  cursor:pointer;
  text-align:left;
  width:100%;
  transition:border-color .15s;
}
.cst-order-row:hover{ border-color:var(--orange); }
.cst-order-ico{ font-size:18px; flex-shrink:0; }
.cst-order-body{ flex:1; min-width:0; }
.cst-order-name{
  display:block;
  font-size:13px;
  font-weight:600;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.cst-order-meta{ display:block; font-size:11px; color:var(--text3); margin-top:2px; }
.cst-order-price{ font-size:13px; font-weight:700; color:var(--orange); flex-shrink:0; }
.cst-empty{ padding:18px 0; font-size:13px; color:var(--text3); display:flex; align-items:center; }

.cst-actions{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-bottom:20px;
}
.cst-action-btn{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  padding:14px 8px 12px;
  background:var(--surface);
  border:1.5px solid var(--line);
  border-radius:14px;
  cursor:pointer;
  font-size:22px;
  transition:border-color .15s,background .15s;
}
.cst-action-btn:hover{ border-color:var(--orange); background:rgba(255,107,0,.05); }
.cst-action-btn span{ font-size:11px; color:var(--text2); font-weight:600; }

@media(max-width:400px){
  .cst-grid{ grid-template-columns:repeat(2,1fr); }
  .cst-actions{ grid-template-columns:repeat(2,1fr); }
}



/* Vehicle add modal — correct mobile scroll with sticky header/footer */
#vehicle-add-modal{
  align-items:center;
  justify-content:center;
  padding:12px;
  overflow:hidden;
}
#vehicle-add-modal .vehicle-add-modal-box{
  width:min(100vw - 24px, 560px) !important;
  max-height:min(92dvh, calc(100dvh - 24px));
  padding:0 !important;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
#vehicle-add-modal .vehicle-add-modal-head{
  position:sticky;
  top:0;
  z-index:3;
  flex-shrink:0;
  background:linear-gradient(180deg, rgba(20,24,33,.98), rgba(20,24,33,.94));
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
#vehicle-add-modal .vehicle-add-modal-body{
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  padding:16px 18px calc(16px + env(safe-area-inset-bottom, 0px));
}
#vehicle-add-modal .vehicle-add-modal-grid{
  align-items:start;
}
#vehicle-add-modal .vehicle-add-modal-form{
  min-width:0;
}
#vehicle-add-modal .vehicle-add-modal-actions{
  position:sticky;
  bottom:0;
  z-index:2;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  grid-column:1/-1;
  margin-top:8px;
  padding-top:12px;
  padding-bottom:max(2px, env(safe-area-inset-bottom, 0px));
  background:linear-gradient(180deg, rgba(20,24,33,0), rgba(20,24,33,.96) 22%);
}
@media (max-width:720px){
  #vehicle-add-modal{
    align-items:flex-end;
    padding:8px;
  }
  #vehicle-add-modal .vehicle-add-modal-box{
    width:min(100vw - 16px, 560px) !important;
    max-height:min(94dvh, calc(100dvh - 12px));
    border-radius:20px;
  }
  #vehicle-add-modal .vehicle-add-modal-body{
    padding:14px 14px calc(14px + env(safe-area-inset-bottom, 0px));
  }
  #vehicle-add-modal .vehicle-add-modal-actions .btn{
    width:100%;
    flex:1 1 100%;
  }
}

/* ── Приёмка авто: пульс ─────────────────────────────────────── */
@keyframes _karetaPulse {
  0%,100% { opacity:1; box-shadow:0 0 0 2px rgba(34,197,94,.5); }
  50%      { opacity:.92; box-shadow:0 0 0 5px rgba(34,197,94,.15); }
}

/* ── Parts Modal: bottom sheet mobile ────────────────────────── */
#master-parts-modal.open {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
}
#master-parts-modal > div {
  animation: _sheetSlideUp .28s cubic-bezier(.32,1,.6,1);
  width: 100%;
}
@keyframes _sheetSlideUp {
  from { transform: translateY(60px); opacity: .4; }
  to   { transform: translateY(0);    opacity: 1;  }
}

/* ── btn-ghost ────────────────────────────────────────────────── */
.btn.btn-ghost {
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--text2);
}
.btn.btn-ghost:active { opacity: .7; }

/* ── Catalog items ────────────────────────────────────────────── */
.mp-cat-item { transition: background .12s; }
.mp-cat-item:active { background: var(--surface) !important; }

@media (min-width: 640px) {
  #master-parts-modal > div {
    border-radius: 18px !important;
    max-height: 88vh !important;
    margin: auto !important;
    position: relative !important;
    bottom: auto !important;
  }
  #master-parts-modal.open {
    align-items: center;
  }
}

/* ── Master Cabinet: scrollable tab nav ──────────────────────── */
#mp-cabinet [data-subtabs="cabinet"] {
  scrollbar-width: none;
}
#mp-cabinet [data-subtabs="cabinet"]::-webkit-scrollbar { display: none; }

/* ── Resume editor ────────────────────────────────────────────── */
#master-resume-editor { animation: _karetaPulse .3s ease; }

/* ── Stat grid 3-col ─────────────────────────────────────────── */
@media (max-width: 400px) {
  .mcab-stat-grid { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── Masters public page ───────────────────────────────────────── */
.master-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}
.master-post-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}
#master-create-post, #master-post-detail {
  position: fixed; inset: 0; background: rgba(0,0,0,.6);
  backdrop-filter: blur(4px); z-index: 9000;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  animation: fadeIn .2s ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
#master-create-post:not(.open), #master-post-detail:not(.open) { display: none; }

/* Кнопка публикации на выполненных заявках */
.btn-publish-story {
  color: #34d399; border-color: rgba(52,211,153,.3);
}

/* ═══════════════════════════════════════════════════════════
   СТРАНИЦА МАСТЕРОВ — карточки и профиль
   ═══════════════════════════════════════════════════════════ */

/* ── Грид-сетка карточек ── */
.masters-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
}

/* ── Карточка мастера ── */
.master-card {
  border-radius: 20px;
  overflow: hidden;
  background: var(--bg2);
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: transform .18s, box-shadow .18s, border-color .18s;
  text-decoration: none;
  color: inherit;
}
.master-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 56px rgba(0,0,0,.35);
  border-color: var(--mc, var(--orange-brd));
}
.master-card:focus-visible {
  outline: 2px solid var(--mc, var(--orange));
  outline-offset: 2px;
}

/* Cover-зона */
.master-card__cover {
  height: 120px;
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--mc-dim, rgba(52,211,153,.15)), transparent);
}
.master-card__cover img {
  width: 100%; height: 100%; object-fit: cover; opacity: .45;
}
.master-card__cover-icon {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 56px; opacity: .1;
}
.master-card__cover-grad {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 30%, rgba(0,0,0,.5));
}
.master-card__rating-badge {
  position: absolute; top: 10px; right: 10px;
  background: rgba(0,0,0,.65); backdrop-filter: blur(8px);
  padding: 3px 10px; border-radius: 99px;
  font-size: 12px; font-weight: 700; color: #fbbf24;
}
.master-card__posts-badge {
  position: absolute; top: 10px; left: 10px;
  background: rgba(0,0,0,.55); backdrop-filter: blur(6px);
  padding: 3px 9px; border-radius: 99px;
  font-size: 11px; color: rgba(255,255,255,.8);
}
.master-card__status {
  position: absolute; left: 12px; bottom: 12px;
  z-index: 2;
  padding: 4px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 700;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(12,18,27,.72);
  color: #fff;
}
.master-card__status--online { color: #86efac; }
.master-card__status--replying { color: #fcd34d; }
.master-card__status--busy { color: #fca5a5; }

/* Аватар */
.master-card__avatar {
  position: absolute; bottom: -24px; left: 16px;
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--mc-dim, rgba(52,211,153,.2));
  border: 3px solid var(--bg2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 20px; font-weight: 700;
  color: var(--mc, #34d399);
  box-shadow: 0 2px 14px rgba(0,0,0,.4);
}

/* Body */
.master-card__body {
  padding: 32px 16px 12px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.master-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.master-card__name {
  font-family: 'Oswald', sans-serif;
  font-size: 18px; font-weight: 700; line-height: 1.15;
}
.master-card__price {
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 800;
  color: var(--mc, #34d399);
  background: var(--mc-dim, rgba(52,211,153,.12));
  border: 1px solid var(--mc-brd, rgba(52,211,153,.25));
  padding: 6px 10px;
  border-radius: 10px;
}
.master-card__biz {
  font-size: 11px; font-weight: 700;
  color: var(--mc, #34d399);
  display: flex; align-items: center; gap: 4px;
}
.master-card__spec {
  font-size: 12px; color: var(--text2); margin-top: 2px;
}
.master-card__addr {
  font-size: 11px; color: var(--text3);
  display: flex; align-items: center; gap: 4px; margin-top: 2px;
}
.master-card__shop {
  font-size: 11px; color: var(--mc, #34d399);
  display: flex; align-items: center; gap: 4px; margin-top: 2px;
}
.master-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.master-card__meta-item {
  font-size: 11px;
  color: var(--text3);
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
}
.master-card__stats {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 2px;
}
.master-card__stat {
  font-size: 11px; color: var(--text2);
  padding: 3px 8px; border-radius: 6px;
}
.master-card__stat--green  { background: rgba(52,211,153,.08); border: 1px solid rgba(52,211,153,.2); }
.master-card__stat--blue   { background: rgba(96,165,250,.08); border: 1px solid rgba(96,165,250,.2); }
.master-card__stat--violet { background: rgba(167,139,250,.10); border: 1px solid rgba(167,139,250,.24); }
.master-card__services,
.master-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.master-card__service,
.master-card__badge {
  font-size: 11px;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--mc-dim, rgba(52,211,153,.1));
  border: 1px solid var(--mc-brd, rgba(52,211,153,.2));
  color: var(--mc, #34d399);
  font-weight: 700;
}
.master-card__badge {
  background: rgba(255,255,255,.03);
  color: var(--text2);
  border-color: var(--line);
}

/* Footer */
.master-card__footer {
  padding: 12px 16px 16px;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.master-card__action {
  appearance: none;
  border: 1px solid var(--line);
  border-radius: 12px;
  min-height: 40px;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.master-card__action:hover {
  transform: translateY(-1px);
}
.master-card__action--ghost {
  background: rgba(255,255,255,.03);
  color: var(--text);
}
.master-card__action--outline {
  background: transparent;
  border-color: var(--mc-brd, rgba(52,211,153,.25));
  color: var(--mc, #34d399);
}
.master-card__action--primary {
  background: linear-gradient(180deg, var(--mc, #34d399), color-mix(in srgb, var(--mc, #34d399) 70%, #0b1320));
  color: #07111b;
  border-color: transparent;
}

/* ── Профиль мастера — Hero ── */
.master-profile-hero {
  border-bottom: 1px solid var(--line);
  padding: 24px 0 32px;
}
.master-profile-hero__inner {
  display: flex; gap: 22px; align-items: flex-start; flex-wrap: wrap;
}
.master-profile-hero__avatar {
  width: 92px; height: 92px;
  border-radius: 50%;
  background: var(--mc-dim, rgba(52,211,153,.15));
  border: 3px solid var(--mc, #34d399);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 34px; font-weight: 700;
  color: var(--mc, #34d399);
  flex-shrink: 0;
  box-shadow: 0 4px 24px var(--mc-dim, rgba(52,211,153,.3));
}
.master-profile-hero__name {
  font-family: 'Oswald', sans-serif;
  font-size: 30px; font-weight: 700; line-height: 1.1;
}
.master-profile-hero__biz {
  font-size: 13px; color: var(--mc, #34d399);
  font-weight: 600; margin-top: 5px;
  display: flex; align-items: center; gap: 5px;
}
.master-profile-hero__spec {
  font-size: 14px; color: var(--text2); margin-top: 5px;
}
.master-profile-badges {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px;
}
.master-profile-badge {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 13px; border-radius: 99px;
  font-size: 12px; font-weight: 600;
}
.master-profile-badge--gold   { background: rgba(251,191,36,.1); border: 1px solid rgba(251,191,36,.28); color: #fbbf24; }
.master-profile-badge--blue   { background: rgba(96,165,250,.1); border: 1px solid rgba(96,165,250,.25); color: #60a5fa; }
.master-profile-badge--green  { background: rgba(52,211,153,.1); border: 1px solid rgba(52,211,153,.25); color: #34d399; }
.master-profile-badge--muted  { background: var(--surface); border: 1px solid var(--line); color: var(--text2); }

/* CTA */
.master-profile-cta {
  display: flex; flex-direction: column; gap: 8px; flex-shrink: 0;
}

/* Секции профиля */
.master-section {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 22px 24px;
}
.master-section__title {
  font-family: 'Oswald', sans-serif;
  font-size: 17px; font-weight: 700;
  margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}

/* Посты-работы в профиле */
.master-posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.master-post-card {
  border-radius: 14px; overflow: hidden;
  background: var(--bg2);
  border: 1px solid var(--line);
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  display: flex; flex-direction: column;
}
.master-post-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(0,0,0,.3);
}
.master-post-card__cover {
  height: 140px; position: relative; overflow: hidden;
}
.master-post-card__cover img {
  width: 100%; height: 100%; object-fit: cover;
}
.master-post-card__cover-icon {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 40px; opacity: .2;
}
.master-post-card__cover-grad {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(0,0,0,.55));
}
.master-post-card__cat-badge {
  position: absolute; top: 8px; left: 8px;
  color: #fff; font-size: 10px; font-weight: 700;
  padding: 3px 9px; border-radius: 99px;
}
.master-post-card__photos-badge {
  position: absolute; top: 8px; right: 8px;
  background: rgba(0,0,0,.55); backdrop-filter: blur(6px);
  color: #fff; font-size: 10px; padding: 3px 8px; border-radius: 99px;
}
.master-post-card__body {
  padding: 11px 13px;
  flex: 1; display: flex; flex-direction: column; gap: 4px;
}
.master-post-card__title {
  font-weight: 700; font-size: 14px; line-height: 1.4;
}
.master-post-card__preview {
  font-size: 12px; color: var(--text2); line-height: 1.5;
}
.master-post-card__meta {
  display: flex; align-items: center; gap: 8px;
  margin-top: 5px; flex-wrap: wrap;
}
.master-post-card__meta-item {
  font-size: 11px; color: var(--text3);
}

/* Отзыв */
.master-review-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 15px 18px;
}
.master-review-card__header {
  display: flex; align-items: center;
  justify-content: space-between; gap: 8px;
  margin-bottom: 8px;
}
.master-review-card__name { font-weight: 700; font-size: 13px; }
.master-review-card__stars { color: #fbbf24; font-size: 15px; letter-spacing: 1px; }
.master-review-card__text { font-size: 13px; color: var(--text2); line-height: 1.6; }
.master-review-card__date { font-size: 11px; color: var(--text3); margin-top: 5px; }

/* CTA-banner в профиле */
.master-cta-banner {
  border-radius: 16px;
  padding: 24px;
  text-align: center;
  border: 1px solid var(--mc-brd, rgba(52,211,153,.2));
}
.master-cta-banner__title {
  font-family: 'Oswald', sans-serif;
  font-size: 20px; font-weight: 700; margin-bottom: 6px;
}
.master-cta-banner__sub {
  font-size: 13px; color: var(--text2); margin-bottom: 18px;
}
.master-cta-banner__btns {
  display: flex; justify-content: center; gap: 10px; flex-wrap: wrap;
}

/* Пустое состояние мастеров */
.masters-empty {
  text-align: center; padding: 56px 20px;
}
.masters-empty__icon { font-size: 52px; margin-bottom: 14px; }
.masters-empty__title {
  font-family: 'Oswald', sans-serif;
  font-size: 22px; font-weight: 700; margin-bottom: 8px;
}
.masters-empty__sub { font-size: 14px; color: var(--text3); }

/* Hero страницы мастеров */
.masters-hero {
  background: var(--bg2);
  border-bottom: 1px solid var(--line);
  padding: 36px 0 28px;
}
.masters-hero__title {
  font-family: 'Oswald', sans-serif;
  font-size: 30px; font-weight: 700; margin-bottom: 8px;
}
.masters-hero__sub {
  font-size: 14px; color: var(--text2); max-width: 540px; line-height: 1.6;
}

/* Мобильные адаптации */
@media (max-width: 600px) {
  .masters-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .master-card__cover { height: 90px; }
  .master-card__avatar { width: 42px; height: 42px; font-size: 16px; bottom: -18px; }
  .master-card__body { padding: 24px 10px 10px; }
  .master-card__name { font-size: 15px; }
  .master-card__footer { grid-template-columns: 1fr; }
  .master-card__action { min-height: 38px; }
  .master-profile-hero__avatar { width: 72px; height: 72px; font-size: 26px; }
  .master-profile-hero__name { font-size: 24px; }
  .master-section { padding: 16px; }
  .master-posts-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
}
@media (max-width: 400px) {
  .masters-grid { grid-template-columns: 1fr; }
}


.master-card[data-master-id]{ cursor:pointer; }
.master-card[data-master-id]:focus-visible{ outline:2px solid var(--orange); outline-offset:3px; }
.master-card[data-master-id] > *{ pointer-events:none; }
.master-card[data-master-id] [data-no-master-open],
.master-card[data-master-id] button,
.master-card[data-master-id] a,
.master-card[data-master-id] input,
.master-card[data-master-id] select,
.master-card[data-master-id] textarea,
.master-card[data-master-id] label{ pointer-events:auto; }
