/* ============================================================================
   Aurinia — попередній запис до лікаря.
   Оновлений візуальний стиль: спокійна біло-блакитна клінічна палітра,
   серифний характер (Cormorant Garamond + Georgia), м'які «скляні» поверхні,
   делікатні тіні. Великі тап-таргети, високий контраст — зручно літнім людям
   на телефоні. Drop-in: усі наявні селектори збережено.

   PROPOSED (композиція шапки):
     • лейбл «ПОПЕРЕДНІЙ ЗАПИС» — центрований банер на всю ширину шапки;
     • щит лишається ліворуч (розмір/позиція без змін);
     • блок імені (прізвище + ім'я + спеціальність) зсунуто ПРАВОРУЧ,
       вирівняно по правому краю — врівноважує лівий щит;
     • опис лишається широким абзацом нижче, читабельним;
     • на телефоні все складається в охайну центровану колонку.
   ========================================================================== */

:root {
  /* — Сині (медичні, чисті) — */
  --blue:        #2a6cb0;   /* основний акцент */
  --blue-dk:     #1d4e84;   /* заголовки, насичений */
  --blue-dp:     #143a64;   /* найтемніший — текст на світлому */
  --blue-soft:   #eef4fb;   /* фон сторінки */
  --blue-line:   #d4e3f4;   /* тонкі лінії/межі */
  --blue-tint:   #f3f8ff;   /* картки / вільні слоти */
  --blue-glass:  rgba(255, 255, 255, .72);

  /* — Стани — */
  --green:       #2c8f63;   /* успіх / ваш запис */
  --green-dk:    #1f6f4b;
  --green-soft:  #e6f5ec;
  --red:         #c9534f;   /* помилка / скасувати */
  --red-dk:      #a83c39;
  --red-soft:    #fbecea;
  --gray:        #7d93aa;   /* зайнято / неактивне */
  --gray-soft:   #eef2f7;

  /* — Чорнила (текст) — */
  --ink:         #22405c;
  --ink-soft:    #5c728b;
  --ink-faint:   #93a6bb;

  /* — Акцент-золото (стримана коштовна деталь для рамок/розділювачів) — */
  --gold:        #c8a36a;
  --gold-soft:   rgba(200, 163, 106, .42);

  /* — Радіуси / тіні / рух — */
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 26px;
  --shadow-sm: 0 2px 8px rgba(20, 58, 100, .06);
  --shadow-md: 0 10px 30px rgba(29, 78, 132, .10);
  --shadow-lg: 0 24px 64px rgba(20, 45, 80, .22);
  --ring: 0 0 0 4px rgba(42, 108, 176, .18);
  --ease: cubic-bezier(.22, .61, .36, 1);

  --serif:   'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --display: 'Yeseva One', 'Cormorant Garamond', Georgia, serif;
  --body:    Georgia, 'Times New Roman', serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--body);
  color: var(--ink);
  background:
    radial-gradient(1200px 520px at 50% -160px, #ffffff 0%, rgba(255,255,255,0) 70%),
    linear-gradient(180deg, var(--blue-soft) 0%, #f6f9fd 100%);
  background-attachment: fixed;
  line-height: 1.55;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: rgba(42, 108, 176, .18); }

.container { max-width: 1060px; margin: 0 auto; padding: 0 20px; }

/* ============================================================================
   Шапка лікаря — композований «герой»
   Делікатне синє панно + тематичний водяний знак хребта дають глибину,
   щоб сторінка не була суцільно білою.

   КОМПОЗИЦІЯ (PROPOSED):
     1) Зверху — центрований лейбл-банер «ПОПЕРЕДНІЙ ЗАПИС» на всю ширину.
     2) Нижче — рядок: щит ЛІВОРУЧ + текстовий блок праворуч.
     3) Усередині тексту — блок імені вирівняно ПО ПРАВОМУ КРАЮ
        (асиметрія, врівноважена лівим щитом), а опис — широкий абзац нижче.
     Ліва/права межі шапки збігаються з картками запису (.container = 1060px).
   ========================================================================== */
.site-header {
  position: relative;
  text-align: center;
  padding: 60px 0 72px;
  background:
    radial-gradient(820px 380px at 50% -120px, rgba(42,108,176,.16) 0%, rgba(42,108,176,0) 70%),
    linear-gradient(180deg, #ffffff 0%, #eaf2fb 62%, var(--blue-tint) 100%);
  border-bottom: 1px solid var(--blue-line);
  overflow: hidden;
}
/* стара тонка акцентна лінія більше не потрібна — її замінює хвиля .hero-wave */
.site-header::after { content: none; }

/* — Тематичний водяний знак: хребет — стриманий, ледь помітний.
   Центрований по сторінці, тож сидить рівно за центрованою парою щит+текст
   і працює як спокійна вертикальна вісь композиції. — */
.hero-spine {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -54%);
  width: 78px;
  height: 360px;
  color: var(--blue);
  opacity: .06;
  pointer-events: none;
  z-index: 0;
}
.hero-spine ellipse {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
}
.hero-spine-g { transform-origin: 40px 180px; }

/* усе наповнення шапки — над водяним знаком */
.site-header .container { position: relative; z-index: 1; }

/* — Кругла рамка під фото лікаря; поки фото немає — монограма — */
.doc-avatar {
  position: relative;
  width: 116px;
  height: 116px;
  margin: 0 auto 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(120% 120% at 50% 22%, #ffffff 0%, var(--blue-tint) 70%, #e6f0fb 100%);
  /* подвійна рамка: тонке золото всередині + синій ореол — стримана «коштовність» */
  box-shadow:
    0 0 0 1px var(--gold-soft),
    0 0 0 7px #ffffff,
    0 0 0 8px var(--blue-line),
    var(--shadow-md);
  overflow: hidden;
}
/* якщо власник додасть <img> усередину .doc-avatar — фото займе весь круг */
.doc-avatar img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
.doc-monogram {
  font-family: var(--display);
  font-size: 46px;
  line-height: 1;
  letter-spacing: .02em;
  color: var(--blue-dk);
  /* делікатний градієнт у заливці монограми */
  background: linear-gradient(165deg, var(--blue) 0%, var(--blue-dp) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  user-select: none;
  -webkit-user-select: none;
}

.doc-logo {
  display: block; width: 160px; height: auto; margin: 0 auto 18px;
  filter: drop-shadow(0 8px 16px rgba(29, 78, 132, .30));
}
@media (max-width: 520px) { .doc-logo { width: 110px; } }

.doc-surname {
  margin: 0; font-family: var(--serif);
  font-size: 48px; font-weight: 700; line-height: 1.0;
  letter-spacing: .03em; text-transform: uppercase; color: var(--blue-dp);
}
.doc-given {
  font-family: var(--serif); font-size: 33px; font-weight: 500;
  color: var(--blue-dk); margin-top: 4px; letter-spacing: .01em;
}
@media (max-width: 760px) { .doc-surname { font-size: 40px; } .doc-given { font-size: 27px; } }
@media (max-width: 380px) { .doc-surname { font-size: 34px; } .doc-given { font-size: 24px; } }

/* ──────────────────────────────────────────────────────────────────────────
   Композиція «візитки»
   ────────────────────────────────────────────────────────────────────────── */

/* Обгортка всієї шапки: вертикальний стек — центрований лейбл, потім рядок. */
.hero-head {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/* 1) Центрований банер-лейбл «ПОПЕРЕДНІЙ ЗАПИС» — над усім, по центру шапки. */
.hero-head > .hero-tag {
  align-self: center;
  margin: 0 0 30px;
}

/* 2) Рядок: щит ліворуч + текстовий блок, що заповнює решту ширини. */
.hero-row {
  display: flex;
  align-items: center;           /* високий щит вирівняно по центру тексту */
  justify-content: flex-start;   /* щит ліворуч */
  gap: 50px;
  text-align: left;
  /* без max-width — шапка такої ж ширини, як картки нижче (.container = 1060px) */
}
.hero-row .doc-logo {
  margin: 0;
  flex: none;
  align-self: center;
  /* легке оптичне підняття: візуальна маса щита трохи нижча за його бокс */
  transform: translateY(-2px);
}

/* текстовий блок заповнює всю ширину праворуч від щита */
.hero-text {
  flex: 1 1 auto;
  max-width: none;
  min-width: 0;
}

/* 3) Блок імені — зсунутий ПРАВОРУЧ, вирівняний по правому краю.
   Створює свідому асиметрію: щит зліва ⇄ ім'я справа. */
.hero-name {
  text-align: center;
  /* абсолютний центр сторінки: зсув на ширину щита+проміжку (160+50) */
  padding-right: 210px;
}
.hero-name .doc-surname,
.hero-name .doc-given { display: block; }

/* Тимчасовий блюр ПІБ (прапорець blur_name у doctor.toml) — щоб випадково не записувались */
.hero-name.blurred .doc-surname,
.hero-name.blurred .doc-given {
  filter: blur(9px);
  user-select: none;
  -webkit-user-select: none;
  pointer-events: none;
}

/* орнаментальна риска під спеціальністю — по центру */
.hero-name .doc-title { padding-top: 16px; margin-top: 12px; }
.hero-name .doc-title::before { left: 50%; right: auto; transform: translateX(-50%); width: 116px; }
.hero-name .doc-title::after  { left: 50%; right: auto; transform: translateX(-50%) rotate(45deg); }

.hero-name .doc-creds { justify-content: center; margin-top: 18px; }

/* Опис — широкий абзац під рядком імені, на всю ширину тексту, читабельний.
   Лівий край опису свідомо НЕ збігається з краєм імені — це й дає
   «асиметрично-врівноважену» композицію, яку хотів власник. */
.hero-text .doc-desc {
  max-width: none;
  margin: 22px 0 0;
  text-align: left;
}

/* Планшети: трохи стискаємо проміжок */
@media (max-width: 760px) {
  .hero-row { gap: 36px; }
  .hero-head > .hero-tag { margin-bottom: 24px; }
  .hero-name { padding-right: 0; }
}

/* Телефон: усе складається в охайний центрований стек */
@media (max-width: 620px) {
  .hero-head { align-items: center; }
  .hero-head > .hero-tag { margin-bottom: 18px; }
  .hero-row { flex-direction: column; gap: 18px; text-align: center; max-width: 100%; }
  .hero-row .doc-logo { transform: none; }
  .hero-text { max-width: 100%; }
  .hero-name { text-align: center; padding-right: 0; }
  .hero-name .doc-creds { justify-content: center; }
  .hero-name .doc-title::before { left: 50%; right: auto; transform: translateX(-50%); width: 116px; }
  .hero-name .doc-title::after  { left: 50%; right: auto; transform: translateX(-50%) rotate(45deg); }
  .hero-text .doc-desc { margin-left: auto; margin-right: auto; text-align: center; }
}

.hero-tag {
  display: inline-block;
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .34em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0 0 18px;
  padding: 7px 20px 6px;
  border: 1px solid var(--blue-line);
  border-radius: 999px;
  background: var(--blue-glass);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.doc-name {
  margin: 0;
  font-family: var(--serif);
  font-size: 56px;
  font-weight: 700;
  letter-spacing: .005em;
  line-height: 1.04;
  color: var(--blue-dp);
}
/* делікатна орнаментальна риска під спеціальністю */
.doc-title {
  position: relative;
  font-family: var(--serif);
  font-size: 23px;
  font-style: italic;
  color: var(--blue);
  margin-top: 14px;
  padding-top: 14px;
  letter-spacing: .01em;
}
.doc-title::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 116px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold) 18%, var(--gold) 82%, transparent);
  opacity: .8;
}
/* маленький ромб-діамант на рисці */
.doc-title::after {
  content: "";
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 6px;
  height: 6px;
  background: var(--gold);
  border-radius: 1px;
}

.doc-creds {
  list-style: none; padding: 0; margin: 22px 0 0;
  display: flex; flex-wrap: wrap; gap: 9px; justify-content: center;
}
.doc-creds li {
  background: #fff;
  border: 1px solid var(--blue-line);
  border-radius: 999px;
  padding: 6px 16px;
  font-size: 14px;
  color: var(--blue-dk);
  box-shadow: var(--shadow-sm);
}

.doc-desc {
  max-width: 640px;
  margin: 24px auto 0;
  font-size: 18.5px;
  line-height: 1.65;
  color: var(--ink-soft);
}

/* — Хвилястий роздільник унизу шапки — */
.hero-wave {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  width: 100%;
  height: 64px;
  display: block;
  z-index: 1;
  pointer-events: none;
}
.hero-wave path {
  fill: #f6f9fd;          /* зливається з фоном сторінки під шапкою */
  stroke: var(--blue-line);
  stroke-width: 1;
}

/* ============================================================================
   Розкладка
   ========================================================================== */
/* «Попередній запис» — пілюля-лейбл (попередній дизайн) під лінією шапки,
   як заголовок до самого запису: зверху лікар, а ось і сам запис — нижче. */
/* Та сама сітка, що й у записі (1fr 332px), щоб «Попередній запис»
   центрувався НАД ПАНЕЛЛЮ СЛОТІВ (ліва колонка), а не по центру сторінки. */
.book-intro {
  display: grid;
  grid-template-columns: 1fr 332px;
  gap: 24px;
  margin: 18px auto 0;
}
.book-intro .hero-tag { grid-column: 1; justify-self: center; }

.layout {
  display: grid;
  grid-template-columns: 1fr 332px;
  gap: 24px;
  padding-top: 28px;
  padding-bottom: 72px;
  align-items: start;
}

.card {
  position: relative;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.92));
  border: 1px solid var(--blue-line);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: var(--shadow-md);
}
/* тонка верхня світлова смужка на картках — м'який «преміум» блиск */
.card::before {
  content: "";
  position: absolute;
  left: 18px; right: 18px; top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.9), transparent);
  border-radius: 1px;
}

.card-title {
  margin: 0 0 18px;
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 700;
  letter-spacing: .01em;
  color: var(--blue-dp);
  display: flex;
  align-items: center;
  gap: 12px;
}
.card-title::before {
  content: "";
  width: 6px; height: 26px; border-radius: 6px; flex: none;
  background: linear-gradient(180deg, var(--blue), var(--blue-dk));
}

/* «Мої записи» трохи світліша панель, щоб відрізнялась від календаря.
   Календар лишається звичайним блоком — липкими є лише заголовки днів (.day-head). */
.bookings { background: linear-gradient(180deg, #ffffff, var(--blue-tint)); }

/* ============================================================================
   Легенда
   ========================================================================== */
.legend {
  display: flex; flex-wrap: wrap; gap: 8px 18px;
  margin: 0 0 20px;
  padding: 12px 16px;
  font-size: 14px;
  color: var(--ink-soft);
  background: var(--blue-tint);
  border: 1px solid var(--blue-line);
  border-radius: var(--r-md);
}
.legend span { display: inline-flex; align-items: center; gap: 8px; }
.dot { width: 14px; height: 14px; border-radius: 5px; display: inline-block; flex: none; }
.dot.free  { background: #fff; border: 1.5px solid var(--blue); }
.dot.mine  { background: var(--green); box-shadow: inset 0 0 0 2px rgba(255,255,255,.55); }
.dot.taken { background: var(--gray); }
.dot.brk   {
  background: repeating-linear-gradient(45deg, var(--gray-soft), var(--gray-soft) 3px, #fff 3px, #fff 6px);
  border: 1px solid var(--blue-line);
}
.dot.unavail { background: #e3e8ee; border: 1px solid #cdd6e0; }

/* ============================================================================
   Блок дня
   ========================================================================== */
.day-block { margin-bottom: 26px; }
.day-block:last-child { margin-bottom: 0; }

.day-head {
  position: sticky; top: 0; z-index: 3;
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px;
  padding: 12px 4px 12px;
  margin-bottom: 14px;
  /* справді напівпрозоре «скляне» тло — слоти видимо проступають крізь блюр при скролі */
  background: rgba(247, 250, 254, .68);
  backdrop-filter: blur(10px) saturate(1.08);
  -webkit-backdrop-filter: blur(10px) saturate(1.08);
  border-bottom: 1px solid var(--blue-line);
}
.day-head b {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 700;
  color: var(--blue-dp);
  letter-spacing: .01em;
}
.day-head .day-date {
  font-family: var(--serif);
  font-size: 18px;
  font-style: italic;
  color: var(--blue);
  margin-left: 10px;
}
.day-head .day-free {
  font-size: 13px;
  font-weight: 600;
  color: var(--green-dk);
  white-space: nowrap;
  background: var(--green-soft);
  border: 1px solid rgba(44,143,99,.28);
  border-radius: 999px;
  padding: 4px 12px;
  letter-spacing: .01em;
}

/* ============================================================================
   Сітка слотів
   ========================================================================== */
.slots-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 9px;
}

.slot {
  padding: 14px 4px;
  border-radius: var(--r-sm);
  text-align: center;
  font-family: var(--body);
  font-size: 15.5px;
  font-weight: 700;
  letter-spacing: .01em;
  border: 1.5px solid transparent;
  color: var(--ink);
  user-select: none;
  -webkit-user-select: none;
  font-variant-numeric: tabular-nums;
}

/* ВІЛЬНО — найпомітніший стан: білий, синя межа, готовий до натискання.
   Додано делікатний вертикальний градієнт і м'який внутрішній блиск —
   слот виглядає трохи «об'ємним», лишаючись чистим. */
.slot.free {
  background: linear-gradient(180deg, #ffffff 0%, #f4f9ff 100%);
  border-color: var(--blue);
  color: var(--blue-dk);
  cursor: pointer;
  box-shadow: var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,.9);
  transition: transform .14s var(--ease), background .14s var(--ease),
              color .14s var(--ease), box-shadow .14s var(--ease);
}
.slot.free:hover {
  background: linear-gradient(180deg, var(--blue), var(--blue-dk));
  color: #fff;
  border-color: var(--blue-dk);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(29, 78, 132, .28);
}
.slot.free:active { transform: translateY(0); }
.slot.free:focus-visible { outline: none; box-shadow: var(--ring); }

/* ВАШ ЗАПИС — зелений, заповнений, з «галочкою» для розрізнення без кольору */
.slot.mine {
  background: var(--green-soft);
  border-color: var(--green);
  color: var(--green-dk);
  position: relative;
}
.slot.mine::after {
  content: "✓";
  position: absolute; top: 3px; right: 5px;
  font-size: 11px; line-height: 1; color: var(--green);
}

/* ЗАЙНЯТО — приглушений сірий, без рамки-акценту */
.slot.taken {
  background: var(--gray-soft);
  color: var(--gray);
  border-color: transparent;
  cursor: not-allowed;
}

/* МИНУЛО — найделікатніший, ледь помітний, перекреслений */
.slot.past {
  background: #f6f8fb;
  color: var(--ink-faint);
  border-color: transparent;
  cursor: not-allowed;
  text-decoration: line-through;
  text-decoration-color: rgba(147,166,187,.6);
}

/* ПЕРЕРВА — діагональна штриховка + тире, чітко «непридатний» вигляд */
.slot.break,
.slot.brk {
  background: repeating-linear-gradient(45deg, var(--gray-soft), var(--gray-soft) 6px, #fff 6px, #fff 12px);
  color: var(--gray);
  border-color: var(--blue-line);
  font-size: 13px; font-weight: 600;
  cursor: not-allowed;
  display: flex; align-items: center; justify-content: center;
}

.slots-empty {
  grid-column: 1 / -1;
  color: var(--ink-soft);
  padding: 28px 20px;
  text-align: center;
  font-style: italic;
  font-size: 17px;
}

/* ============================================================================
   Мої записи
   ========================================================================== */
.booking-item {
  position: relative;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 14px 16px 14px 20px;
  border: 1px solid var(--blue-line);
  border-radius: var(--r-md);
  margin-bottom: 12px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.booking-item:last-child { margin-bottom: 0; }
/* акцентна стрічка зліва — підкреслює «активний» запис */
.booking-item::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--blue), var(--blue-dk));
}
.booking-item .bk-when {
  font-family: var(--serif);
  font-weight: 700;
  font-size: 26px;
  line-height: 1;
  color: var(--blue-dp);
}
.booking-item .bk-when small {
  display: block;
  margin-top: 5px;
  font-family: var(--body);
  font-weight: 400;
  font-size: 13.5px;
  color: var(--ink-soft);
}

.btn-cancel {
  flex: none;
  background: #fff;
  border: 1.5px solid var(--red);
  color: var(--red-dk);
  border-radius: var(--r-sm);
  padding: 9px 15px;
  font-family: var(--body);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background .14s var(--ease), color .14s var(--ease);
}
.btn-cancel:hover { background: var(--red); color: #fff; }
.btn-cancel:focus-visible { outline: none; box-shadow: 0 0 0 4px rgba(201,83,79,.2); }

.tg-link {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 16px; padding: 13px 14px;
  border-radius: var(--r-md);
  background: linear-gradient(180deg, #eaf4fd, #ddeefb);
  border: 1px solid var(--blue-line);
  color: var(--blue-dk); text-decoration: none;
  font-family: var(--body); font-weight: 700; font-size: 15px;
  box-shadow: var(--shadow-sm);
  transition: background .14s var(--ease), transform .1s var(--ease);
}
.tg-link:hover { background: linear-gradient(180deg, #ddeefb, #cfe6fa); }
.tg-link:active { transform: translateY(1px); }

.tg-login-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; margin-top: 12px; padding: 13px 14px;
  border-radius: var(--r-md);
  background: linear-gradient(180deg, var(--blue), var(--blue-dk));
  color: #fff; border: none; cursor: pointer;
  font-family: var(--body); font-weight: 700; font-size: 15px;
  box-shadow: 0 6px 16px rgba(29,78,132,.22);
  transition: filter .14s var(--ease), transform .1s var(--ease);
}
.tg-login-btn:hover { filter: brightness(1.06); }
.tg-login-btn:active { transform: translateY(1px); }

.bookings-empty {
  color: var(--ink-soft);
  font-size: 15px;
  font-style: italic;
  padding: 6px 2px;
}

/* ============================================================================
   Модалка
   ========================================================================== */
.modal-overlay {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  background: rgba(20, 45, 80, .42);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: overlay-in .2s var(--ease);
}
.modal-overlay[hidden] { display: none; }

.modal {
  position: relative;
  background: linear-gradient(180deg, #ffffff, var(--blue-tint));
  border: 1px solid var(--blue-line);
  border-radius: var(--r-xl);
  max-width: 400px; width: 100%;
  padding: 32px 28px 24px;
  text-align: center;
  box-shadow: var(--shadow-lg);
  animation: modal-in .24s var(--ease);
  overflow: hidden;
}
/* тонка золота волосина зверху модалки */
.modal::before {
  content: "";
  position: absolute;
  left: 28px; right: 28px; top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-soft), transparent);
}

.modal-icon {
  font-size: 30px; line-height: 1;
  width: 66px; height: 66px; margin: 0 auto 16px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
}
.modal-icon.ok   { color: var(--green); background: var(--green-soft); box-shadow: inset 0 0 0 1px rgba(44,143,99,.25); }
.modal-icon.err  { color: var(--red);   background: var(--red-soft);   box-shadow: inset 0 0 0 1px rgba(201,83,79,.25); }
.modal-icon.ask  { color: var(--blue);  background: #e9f2fc;           box-shadow: inset 0 0 0 1px rgba(42,108,176,.22); }

.modal-title {
  margin: 0 0 10px;
  font-family: var(--serif);
  font-size: 27px;
  font-weight: 700;
  color: var(--blue-dp);
}
.modal-text {
  margin: 0 0 24px;
  font-size: 16.5px;
  line-height: 1.55;
  color: var(--ink-soft);
}
.modal-text b { color: var(--ink); }

.modal-actions { display: flex; gap: 12px; }
.modal-actions button {
  flex: 1;
  padding: 15px 14px;
  border-radius: var(--r-md);
  font-family: var(--body);
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background .14s var(--ease), color .14s var(--ease),
              filter .14s var(--ease), transform .1s var(--ease);
}
.modal-actions button:active { transform: translateY(1px); }
.modal-actions button:focus-visible { outline: none; box-shadow: var(--ring); }

.btn-primary {
  background: linear-gradient(180deg, var(--blue), var(--blue-dk));
  color: #fff;
  box-shadow: 0 6px 16px rgba(29, 78, 132, .26);
}
.btn-primary:hover { filter: brightness(1.06); }

.btn-ghost {
  background: #fff;
  border-color: var(--blue-line) !important;
  color: var(--ink);
}
.btn-ghost:hover { background: var(--gray-soft); }

.btn-danger {
  background: linear-gradient(180deg, var(--red), var(--red-dk));
  color: #fff;
  box-shadow: 0 6px 16px rgba(201, 83, 79, .26);
}
.btn-danger:hover { filter: brightness(1.05); }

@keyframes overlay-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes modal-in {
  from { opacity: 0; transform: translateY(12px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ============================================================================
   Адаптив
   ========================================================================== */
@media (max-width: 980px) {
  .slots-grid { grid-template-columns: repeat(6, 1fr); }
  .doc-name { font-size: 50px; }
}

@media (max-width: 760px) {
  body { font-size: 16px; }
  .layout {
    grid-template-columns: 1fr;
    gap: 18px;
    padding-top: 22px;
    padding-bottom: 56px;
  }
  /* На телефоні — «Попередній запис» в одну колонку, по центру */
  .book-intro { grid-template-columns: 1fr; }
  .book-intro .hero-tag { grid-column: auto; }
  /* На телефоні «Мої записи» — над календарем */
  .bookings { order: -1; }

  .site-header { padding: 38px 0 52px; }
  .doc-avatar { width: 96px; height: 96px; margin-bottom: 18px; }
  .doc-monogram { font-size: 38px; }
  .hero-spine { width: 64px; height: 300px; opacity: .06; }
  .hero-wave { height: 46px; }
  .doc-name { font-size: 40px; }
  .doc-title { font-size: 20px; }
  .doc-desc { font-size: 17px; }
  .hero-tag { font-size: 13px; letter-spacing: .26em; }

  .slots-grid { grid-template-columns: repeat(4, 1fr); gap: 10px; }
  .slot { padding: 17px 4px; font-size: 17px; }

  .day-head { padding: 12px 2px; }
  .day-head b { font-size: 21px; }
  .day-head .day-date { font-size: 16px; }

  .modal-actions { flex-direction: column-reverse; }
}

@media (max-width: 380px) {
  .doc-name { font-size: 34px; }
  .slots-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Менше анімацій для тих, хто їх вимкнув */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}
