 :root{
    --brand:#e72254;
    --brand-ink:#101828;
    --chip-bg:#fff;
    --chip-br:rgba(231,34,84,.28);
    --chip-hover:#fff5f7;
  }

  /* ===== ЛЕНТА ГОРОДОВ ===== */
  .city-scroll{
    display:flex; flex-wrap:nowrap; gap:.6rem;
    overflow-x:auto; overflow-y:hidden;
    white-space:nowrap;
    -webkit-overflow-scrolling:touch;   /* iOS инерция */
    touch-action:pan-x;                 /* скролл пальцем горизонтально */
    padding:.5rem .25rem .75rem;
    scrollbar-width:none;               /* Firefox: скрыть */
    -ms-overflow-style:none;            /* старый Edge/IE: скрыть */
    overscroll-behavior-x:contain;
    cursor:grab;                        /* drag-scroll */
    -webkit-tap-highlight-color:transparent;
  }
  .city-scroll.grabbing{ cursor:grabbing; user-select:none; }
  .city-scroll::-webkit-scrollbar{ width:0; height:0; } /* WebKit: скрыть */

  /* ===== КНОПКИ-ЧИПЫ ===== */
  .city-chip{
    appearance:none;
    border:1px solid var(--chip-br);
    background:var(--chip-bg);
    color:var(--brand-ink);
    padding:.48rem 1rem;
    border-radius:9999px;
    font-weight:600; line-height:1;
    cursor:pointer;
    transition:background .15s, border-color .15s, color .15s, transform .08s, box-shadow .15s;
    white-space:nowrap;
  }
  .city-chip:hover{
    background:var(--chip-hover);
    border-color:rgba(231,34,84,.45);
  }
  .city-chip:active{ transform:translateY(1px); }

  /* Фокус клавиатурой */
  .city-chip:focus-visible{
    outline:none;
    box-shadow:0 0 0 3px #fff, 0 0 0 5px rgba(231,34,84,.45);
  }

  /* Активный */
  .city-chip[aria-pressed="true"]{
    background:var(--brand);
    color:#fff;
    border-color:var(--brand);
  }
  .city-chip[aria-pressed="true"]:hover{ filter:brightness(.96); }

  /* ===== ОБВЁРТКА СО СТРЕЛКАМИ (если используешь) ===== */
  .city-bar{
    display:grid; grid-template-columns:auto 1fr auto;
    gap:.5rem; align-items:center;
  }
  .city-nav{
    width:36px; height:36px; border-radius:9999px;
    border:1px solid rgba(0,0,0,.08); background:#fff;
    box-shadow:0 2px 8px rgba(0,0,0,.06);
    color:var(--brand); font-size:18px; line-height:1;
    display:inline-flex; align-items:center; justify-content:center;
    cursor:pointer; transition:border-color .15s, color .15s, transform .08s, opacity .15s;
    user-select:none;
  }
  .city-nav:hover{ border-color:rgba(231,34,84,.45); }
  .city-nav:active{ transform:translateY(1px); }
  .city-nav:disabled{ opacity:.35; cursor:not-allowed; transform:none; }

  /* Мобилка */
  @media (max-width:576px){
    .city-chip{ padding:.44rem .8rem; font-weight:600; }
    .city-nav{ width:32px; height:32px; }
  }

  /* Меньше анимации, если пользователь просит */
  @media (prefers-reduced-motion: reduce){
    .city-chip, .city-nav{ transition:none; }
  }
/* ===== Modern minimal table with brand header (#e72254) ===== */
#scheduleTable{
  --bg:#fff;
  --text:#636363;
  --accent:#e72254;
  --line:#e6e6e6;
  --headText:#fff;
  --zebra:#fcfcfc;
  --hover:#f9f9f9;
  --shadow:0 6px 20px rgba(0,0,0,.05);

  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:var(--bg);
  color:var(--text);
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow);
  table-layout:auto;
  min-width:920px; /* чтобы колонки не схлопывались */
}

/* Шапка */
#scheduleTable thead th{
  background:var(--accent);
  color:var(--headText);
  font-weight:600;
  font-size:14px;
  letter-spacing:.01em;
  padding:14px 18px;
  white-space:nowrap;
  position:sticky;
  top:0;
  z-index:2;
  border-bottom:1px solid var(--line);
}
#scheduleTable thead th + th{
  border-left:1px solid rgba(255,255,255,.25);
}

/* Ячейки */
#scheduleTable td{
  padding:14px 18px;
  font-size:14px;
  line-height:1.45;
  vertical-align:top;
  color:var(--text);
  border:0;
  background:transparent;
}

/* Тонкая сетка */
#scheduleTable tbody tr + tr td{ border-top:1px solid var(--line) !important; }
#scheduleTable tbody td + td{ border-left:1px solid var(--line) !important; }

/* Зебра и hover */
#scheduleTable tbody tr:nth-child(even) td{ background:var(--zebra); }
#scheduleTable tbody tr:hover td{ background:var(--hover); }

/* Выравнивания */
#scheduleTable td:nth-child(1),
#scheduleTable td:nth-child(2),
#scheduleTable td:nth-child(3){ text-align:center; }
#scheduleTable td:nth-child(5){
  text-align:right;
  font-variant-numeric:tabular-nums;
}

/* 1-й столбец — только дата (на всякий случай прячем возможные .t/.sep) */
#scheduleTable td.col-date{ white-space:nowrap; }
#scheduleTable td.col-date .d{ white-space:nowrap; }
#scheduleTable td.col-date .t,
#scheduleTable td.col-date .sep{ display:none !important; }

/* Переносы в "Дни" */
#scheduleTable td:nth-child(2),
#scheduleTable .rr-table-title{
  white-space:normal !important;
  line-height:1.35;
}
#scheduleTable td:nth-child(2) .rr-table-title{ white-space:pre-line; }

/* Вторичный текст и ссылки */
#scheduleTable .rr-table-doc-name{ opacity:.85; }
#scheduleTable a,
#scheduleTable .rr-table-title,
#scheduleTable .rr-table-doc-name{ color:var(--text); }

/* Caption / статус */
#scheduleTable caption, #scheduleState{ color:#9a9a9a; }

/* Контейнер: горизонтальный скролл на мобилках */
.time-table-area .rr-table-main.table-responsive{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
   overflow-y: visible;
   max-height: none;
}


/* Адаптив */
@media (max-width:576px){
  #scheduleTable{ min-width:760px; }
  #scheduleTable thead th{ font-size:12px; padding:10px 12px; }
  #scheduleTable td{ font-size:12.5px; padding:10px 12px; }
}
@media (max-width:768px){
  #scheduleTable thead th{ font-size:13px; padding:10px 12px; }
  #scheduleTable td{ font-size:13px; padding:10px 12px; }
  #scheduleTable td:nth-child(5){ text-align:left; }
}
/* === Кнопка "Записаться" как в макете =============================== */
.rr-header-1-contat .rr-btn-border{
  /* базовая геометрия */
  display:inline-flex;
  align-items:center;
  gap:12px;
  height:56px;
  padding:0 28px;
  /* цвета из палитры */
  background:#e72254;
  color:#fff;
  border:none;
  /* главное — убрать «пилюлю» у темы */
  border-radius:8px !important;             /* было 9999px */
  box-shadow:0 6px 20px rgba(0,0,0,.08);
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.02em;
  line-height:1;
}

/* круг с плюсиком справа */
.rr-header-1-contat .rr-btn-border i{
  width:34px;
  height:34px;
  border-radius:50%;
  background:#223342;                        /* тёмный круг */
  color:#fff;
  display:inline-grid;
  place-items:center;
  font-size:16px;
  margin-left:4px;
}

/* лёгкая диагональная ленточка в правом нижнем углу (как на примере) */
.rr-header-1-contat .rr-btn-border::after{
  content:"";
  position:absolute;
  right:-16px; bottom:-16px;
  width:80px; height:80px;
  transform:rotate(45deg);
  background:linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,0));
  pointer-events:none;
  border-radius:12px;
}

/* hover / focus */
.rr-header-1-contat .rr-btn-border:hover{ filter:brightness(1.03); transform:translateY(-1px); }
.rr-header-1-contat .rr-btn-border:active{ transform:translateY(0); }

/* На всякий случай снимаем скругление у любых «общих» классов темы */
.rr-btn, .rr-btn-border, .theme-btn, .btn{
  border-radius:8px !important;
}

/* Опционально: делаем ссылку-кнопку ссылкой без подчеркивания */
.rr-header-1-contat .rr-btn-border, 
.rr-header-1-contat .rr-btn-border:hover{
  text-decoration:none; color:#fff;
}

/* адаптив: поменьше на узких экранах */
@media (max-width: 576px){
  .rr-header-1-contat .rr-btn-border{ height:46px; padding:0 18px; }
  .rr-header-1-contat .rr-btn-border i{ width:30px; height:30px; font-size:14px; }
}
/* контейнер со скроллом */
.table-scroll{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch; /* плавный скролл на iOS */
}

/* чтобы таблица не сжималась до экрана и появлялся скролл */
#scheduleTable{
  min-width: 920px;        /* подгони под свои колонки */
  width: 100%;
}

/* чуть компактнее шрифты/отступы на телефонах */
@media (max-width: 576px){
  #scheduleTable{ min-width: 760px; }
  #scheduleTable th, #scheduleTable td{
    font-size: 13px;
    padding: 10px 12px;
  }
}