.tw-select {
  appearance: none;
  background-color: #ffffff;
  border: 1px solid #cbd5f5;
  border-radius: 0.75rem;
  color: #0f172a;
  padding: 0.625rem 2.5rem 0.625rem 0.875rem;
  font-size: 0.9375rem;
  line-height: 1.25rem;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
}

.tw-select:hover {
  border-color: #94a3b8;
}

.tw-select:focus {
  border-color: #1f2937;
  outline: none;
  box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.15);
}

.tw-select:disabled {
  background-color: #e2e8f0;
  color: #64748b;
  cursor: not-allowed;
}

.tw-step {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  background-color: #ffffff;
  padding: 0.75rem 1rem;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.tw-step:hover {
  border-color: #cbd5f5;
}

.tw-step:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.tw-step-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 9999px;
  border: 1px solid #cbd5f5;
  background-color: #f8fafc;
  font-weight: 600;
  font-size: 0.875rem;
  color: #0f172a;
}

.tw-step-eyebrow {
  display: block;
  font-size: 0.6875rem;
  text-transform: uppercase;
  color: #64748b;
  letter-spacing: 0.08em;
}

.tw-step-title {
  display: block;
  font-size: 0.9375rem;
  font-weight: 600;
  color: #0f172a;
}

.tw-step[data-step-state="active"] {
  border-color: #1f2937;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
}

.tw-step[data-step-state="active"] .tw-step-badge {
  border-color: #1f2937;
  background-color: #1f2937;
  color: #ffffff;
}

.tw-step[data-step-state="completed"] {
  border-color: #16a34a;
  background-color: #f0fdf4;
}

.tw-step[data-step-state="completed"] .tw-step-badge {
  border-color: #16a34a;
  background-color: #16a34a;
  color: #ffffff;
}

.tw-step[aria-disabled="true"] {
  opacity: .55;
  cursor: not-allowed;
  pointer-events: none;
}

[data-service-summary-description] {
  white-space: pre-line;
}

.tw-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1rem;
  border-radius: 1rem;
  border: 1px solid #e2e8f0;
  background: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  color: #0f172a;
  cursor: pointer;
  transition: border-color .15s ease, background-color .15s ease, color .15s ease, box-shadow .15s ease;
}
.tw-chip:hover { border-color: #cbd5f5; }
.tw-chip[aria-pressed="true"] { background: #0f172a; color: #fff; border-color: #0f172a; }

/* Мобильный вид: только кружки с цифрами этапов */
@media (max-width: 640px) {
  .tw-step { padding: 0; border: 0; background: transparent; box-shadow: none; }
}

/* Явно показываем подписи шагов на экранах ≥640px, даже если Tailwind utility не подтянулся */
@media (min-width: 640px) {
  .tw-step-text { display: inline !important; }
}

.tw-progress { width: 100%; height: 4px; background: #e2e8f0; border-radius: 9999px; overflow: hidden; }
.tw-progress-bar { height: 100%; width: 0%; background: #0f172a; transition: width .25s ease; }
.hidden { display: none; }
[data-admin-tabs] {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.tw-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #0f172a;
  border-radius: 0.75rem;
  padding: 0.5rem 0.875rem;
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  transition: border-color .15s ease, background-color .15s ease, color .15s ease;
}

.tw-tab:hover { border-color: #cbd5f5; }
.tw-tab:focus-visible { outline: 2px solid #2563eb; outline-offset: 2px; }

.tw-tab[data-state="active"] {
  background: #0f172a;
  color: #fff;
  border-color: #0f172a;
}

/* Slot grid: 3 cols on mobile, 6 on md+ */
.slot-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
@media (min-width: 768px) {
  .slot-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }
}

/* Step panels animations */
.tw-anim-in { animation: twFadeInUp .38s cubic-bezier(.21,.94,.31,.99) both; will-change: transform, opacity; }
.tw-anim-out { animation: twFadeOutUp .28s cubic-bezier(.2,.7,.4,1) both; will-change: transform, opacity; }
@keyframes twFadeInUp {
  from { opacity: 0; transform: translateY(14px) scale(.98); }
  60%  { opacity: .9; transform: translateY(2px) scale(1.002); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes twFadeOutUp {
  from { opacity: 1; transform: translateY(0) scale(1); }
  to   { opacity: 0; transform: translateY(-10px) scale(.995); }
}

/* Directional (forward/back) slide animations for step transitions */
.tw-anim-in-forward { animation: twSlideInRight .48s cubic-bezier(.2,.75,.2,1) both; will-change: transform, opacity; }
.tw-anim-out-forward { animation: twSlideOutLeft .34s cubic-bezier(.2,.7,.4,1) both; will-change: transform, opacity; }
.tw-anim-in-back { animation: twSlideInLeft .48s cubic-bezier(.2,.75,.2,1) both; will-change: transform, opacity; }
.tw-anim-out-back { animation: twSlideOutRight .34s cubic-bezier(.2,.7,.4,1) both; will-change: transform, opacity; }

@keyframes twSlideInRight {
  from { opacity: 0; transform: translateX(22px) translateY(8px) scale(.985); }
  60%  { opacity: .96; transform: translateX(2px) translateY(1px) scale(1.002); }
  to   { opacity: 1; transform: translateX(0) translateY(0) scale(1); }
}
@keyframes twSlideOutLeft {
  from { opacity: 1; transform: translateX(0) translateY(0) scale(1); }
  to   { opacity: 0; transform: translateX(-18px) translateY(-6px) scale(.992); }
}
@keyframes twSlideInLeft {
  from { opacity: 0; transform: translateX(-22px) translateY(8px) scale(.985); }
  60%  { opacity: .96; transform: translateX(-2px) translateY(1px) scale(1.002); }
  to   { opacity: 1; transform: translateX(0) translateY(0) scale(1); }
}
@keyframes twSlideOutRight {
  from { opacity: 1; transform: translateX(0) translateY(0) scale(1); }
  to   { opacity: 0; transform: translateX(18px) translateY(-6px) scale(.992); }
}
