@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

/* ─── Variables ─── */
:root {
  --bg:           #0e1319;
  --bg-surface:   #161d28;
  --bg-card:      rgba(255,255,255,0.045);
  --bg-card-hover:rgba(255,255,255,0.07);
  --border:       rgba(255,255,255,0.07);
  --border-light: rgba(255,255,255,0.13);

  --blue:   #29aedb;
  --blue-d: rgba(41,174,219,0.14);
  --green:  #4caf50;
  --yellow: #ffd966;
  --red:    #ea384c;
  --orange: #dc6919;
  --gray:   #6c7a8a;
  --purple: #9999ff;

  --text:       #eef2f7;
  --text-sub:   #7a8fa6;
  --text-muted: #3d4f61;

  --r-card: 20px;
  --r-btn:  13px;
  --r-pill: 100px;

  --nav-h: 64px;
  --font: 'Manrope', system-ui, sans-serif;

  --shadow: 0 2px 20px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.04) inset;
}

/* ✅ reset для button в карточці */
.meeting-card__header { position: relative; display:block; width:100%; }

.meeting-card__header { position: relative; }
.card-toggle-hit{
  position:absolute;
  inset:0;
  background:transparent;
  border:0;
  padding:0;
  cursor:pointer;
}

.map-link, .phone-row, .phone-btn { position: relative; z-index: 3; }
.card-toggle-hit { z-index: 1; }
.meeting-card__header > *:not(.card-toggle-hit) { position: relative; z-index: 2; }

/* але НЕ перекривати зону форм/посилань/кнопок */
.meeting-actions, .meeting-actions * { position: relative; z-index: 2; }

.card-toggle-hit:focus-visible {
  outline: 2px solid rgba(41,174,219,.55);
  outline-offset: 2px;
  border-radius: var(--r-card);
}

/* ✅ анімація стрілки */
.toggle-icon { transition: transform .18s ease; }
.card-toggle-hit[aria-expanded="true"] ~ .card-top .toggle-icon { transform: rotate(180deg); }


/* ─── Base ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

body::before {
  content: '';
  position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 90% 40% at 15% 0%, rgba(41,174,219,0.07) 0%, transparent 55%),
    radial-gradient(ellipse 60% 30% at 85% 100%, rgba(153,153,255,0.05) 0%, transparent 55%);
  pointer-events: none; z-index: 0;
}

/* ─── Date Nav ─── */
.date-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px 10px;
  position: sticky; top: 0; z-index: 50;
  background: linear-gradient(180deg, var(--bg) 75%, transparent);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}

.date-nav-btn {
  width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid var(--border-light);
  background: var(--bg-card); color: var(--text);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.18s;
  -webkit-tap-highlight-color: transparent;
}
.date-nav-btn:active { transform: scale(0.9); background: var(--blue-d); border-color: var(--blue); }

#current-date {
  font-size: 1.15rem; font-weight: 800;
  letter-spacing: -0.025em; color: var(--text);
  cursor: pointer; user-select: none;
}

/* ─── Section Header ─── */
.section-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 2px 18px 14px;
}
.section-title { font-size: 1.35rem; font-weight: 800; letter-spacing: -0.03em; }
.count-badge {
  font-size: 0.72rem; font-weight: 700; color: var(--text-sub);
  background: var(--bg-card); border: 1px solid var(--border);
  padding: 3px 10px; border-radius: var(--r-pill);
}

/* ─── Loading ─── */
#loading-indicator { text-align: center; padding: 48px 20px; color: var(--text-sub); }
.spin-ring {
  width: 30px; height: 30px;
  border: 2px solid var(--border-light); border-top-color: var(--blue);
  border-radius: 50%; animation: spin .75s linear infinite;
  margin: 0 auto 10px;
}
@keyframes spin { to { transform: rotate(360deg); } }
.load-text { font-size: 0.82rem; font-weight: 500; }

#no-meetings-message {
  text-align: center; padding: 64px 20px;
  color: var(--text-muted); font-size: 1rem; font-weight: 500;
}

/* ─── Meetings List ─── */
#meetings-container {
  position: relative; z-index: 1;
  padding: 0 14px calc(var(--nav-h) + 24px);
  display: flex; flex-direction: column; gap: 10px;
}

/* ─── Meeting Card ─── */
.meeting-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-card); overflow: hidden;
  box-shadow: var(--shadow); cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform 0.18s, background 0.18s;
  position: relative;
}
.meeting-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
}
.meeting-card:active { transform: scale(0.985); background: var(--bg-card-hover); }

/* left status bar via style attribute --status-color */
.meeting-card::after {
  content: '';
  position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: var(--status-color, transparent);
}

/* ─── Card Body ─── */
.card-body { padding: 13px 14px 13px 18px; }

.card-top {
  display: flex; align-items: center;
  justify-content: space-between; margin-bottom: 8px;
}

.card-time {
  display: flex; align-items: center; gap: 5px;
  font-size: 0.8rem; font-weight: 600; color: var(--text-sub);
  font-variant-numeric: tabular-nums;
}
.card-time svg { opacity: 0.55; }

.card-status {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.68rem; font-weight: 800;
  padding: 3px 9px; border-radius: var(--r-pill);
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--status-color, var(--text-sub));
  background: color-mix(in srgb, var(--status-color, #6c7a8a) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--status-color, #6c7a8a) 28%, transparent);
  cursor: pointer; -webkit-tap-highlight-color: transparent;
}

.card-title {
  font-size: 0.92rem; font-weight: 700; color: var(--text);
  margin-bottom: 9px; line-height: 1.3; letter-spacing: -0.01em;
}

.card-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 9px;
}

.card-title-btn {
  margin-bottom: 0;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.card-title-btn:hover {
  color: #9ed7ff;
}

.card-title-edit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.04);
  color: var(--text-sub);
  cursor: pointer;
  flex-shrink: 0;
}

.card-title-edit-btn:hover {
  color: #9ed7ff;
  border-color: rgba(41, 174, 219, 0.35);
}

.inline-title-edit {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.inline-title-input {
  flex: 1 1 320px;
  min-width: 220px;
}

.inline-title-edit .f-btn {
  width: auto;
  margin-top: 0;
  padding: 11px 16px;
  flex: 0 0 auto;
}

.inline-title-edit .f-input {
  width: auto;
}

.meeting-type-badge {
  display: inline-flex;
  align-items: center;
  margin-bottom: 10px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #9ed7ff;
  background: rgba(41, 174, 219, 0.14);
  border: 1px solid rgba(41, 174, 219, 0.28);
}

/* ─── Info Rows ─── */
.card-info { display: flex; flex-direction: column; gap: 5px; }

.info-row {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 0.8rem; color: var(--text-sub); line-height: 1.4;
}

.info-icon {
  width: 20px; height: 20px; border-radius: 6px;
  background: rgba(255,255,255,0.05); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 1px;
}
.info-icon svg { opacity: 0.65; }

.info-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.info-text.wrap { white-space: normal; }

/* ─── Description ─── */
.card-desc {
  margin-top: 9px; padding: 8px 11px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 10px;
  font-size: 0.78rem; color: var(--text-sub);
  line-height: 1.5; white-space: pre-wrap; word-break: break-word;
}

/* ─── Phones ─── */
.phone-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }

.phone-btn {
  font-family: var(--font); font-size: 0.78rem; font-weight: 700;
  color: var(--green); background: rgba(76,175,80,0.1);
  border: 1px solid rgba(76,175,80,0.28); border-radius: var(--r-pill);
  padding: 5px 13px; cursor: pointer;
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.phone-btn:active { background: rgba(76,175,80,0.22); transform: scale(0.95); }

/* ─── Map link ─── */
.map-link {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font); font-size: 0.78rem; font-weight: 600;
  color: var(--blue); background: var(--blue-d);
  border: 1px solid rgba(41,174,219,0.22); border-radius: var(--r-pill);
  padding: 5px 13px; text-decoration: none; margin-top: 8px;
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.map-link:active { background: rgba(41,174,219,0.22); }

/* ─── Comments ─── */
.comments-wrap { margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border); }
.comment-entry { padding: 4px 0; border-bottom: 1px solid rgba(255,255,255,0.04); }
.comment-entry:last-child { border-bottom: none; }
.comment-meta { font-size: 0.7rem; color: var(--text-muted); margin-bottom: 2px; }
.comment-body { font-size: 0.8rem; color: var(--text-sub); line-height: 1.4; }
.no-comment { font-size: 0.76rem; color: var(--text-muted); font-style: italic; }

/* ─── Actions Panel ─── */
.meeting-actions {
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.18); padding: 14px;
  animation: fadeSlide 0.2s ease;
}

.meeting-sections {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
}

.panel-section {
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.025);
}

.panel-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.panel-section__title {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.panel-section__empty {
  color: var(--text-sub);
  font-size: 0.82rem;
  line-height: 1.5;
}

.detail-grid {
  display: grid;
  gap: 10px;
}

.detail-row {
  display: grid;
  gap: 4px;
}

.detail-label {
  font-size: 0.72rem;
  color: var(--text-muted);
}

.detail-value {
  font-size: 0.88rem;
  color: var(--text);
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
}

.report-summary-meta {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--blue);
  margin-bottom: 10px;
}

.report-summary-item + .report-summary-item,
.report-summary-block {
  margin-top: 10px;
}

.report-summary-question {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-bottom: 4px;
}

.report-summary-answer,
.report-summary-block__value {
  font-size: 0.86rem;
  color: var(--text);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
}

.report-summary-block__label {
  font-size: 0.72rem;
  color: var(--text-muted);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.clinic-details-cta {
  padding: 10px 12px;
}

.clinic-details-btn {
  margin-top: 0;
}

.sheet-backdrop {
  position: fixed;
  inset: 0;
  display: none;
  align-items: flex-end;
  justify-content: center;
  background: rgba(7, 10, 14, 0.76);
  backdrop-filter: blur(8px);
  z-index: 1200;
  padding: 16px;
}

.sheet-backdrop.open {
  display: flex;
}

.modal-open-sheet {
  overflow: hidden;
}

.sheet-modal {
  width: 100%;
  max-width: 720px;
  max-height: 88vh;
  overflow: auto;
  background: #141b24;
  border: 1px solid var(--border);
  border-radius: 24px 24px 18px 18px;
  box-shadow: 0 -16px 48px rgba(0, 0, 0, 0.32);
  padding: 18px 16px calc(18px + env(safe-area-inset-bottom));
}

.sheet-modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.sheet-modal__header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sheet-modal__eyebrow {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 4px;
}

.sheet-modal__edit {
  border: 1px solid rgba(41,174,219,0.28);
  background: rgba(41,174,219,0.12);
  color: var(--blue);
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
}

.sheet-modal__title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--text);
  line-height: 1.3;
}

.sheet-modal__close {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
}

.sheet-modal__body {
  display: grid;
  gap: 14px;
}

.clinic-modal-address {
  font-size: 0.86rem;
  color: var(--text-sub);
  line-height: 1.5;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.025);
}

.clinic-modal-empty {
  color: var(--text-sub);
  font-size: 0.86rem;
  line-height: 1.5;
}

.clinic-modal-section {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.025);
}

.clinic-modal-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.panel-section__header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-left: auto;
  gap: 12px;
  flex-wrap: wrap;
}

.clinic-all-photos-wrap {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.clinic-all-photos-title {
  margin-bottom: 10px;
  font-size: 0.76rem;
  font-weight: 800;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.clinic-modal-section__title {
  font-size: 0.76rem;
  font-weight: 800;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.clinic-modal-grid {
  display: grid;
  gap: 12px;
}

.clinic-modal-field {
  display: grid;
  gap: 4px;
}

.clinic-modal-field__label {
  font-size: 0.72rem;
  color: var(--text-muted);
}

.clinic-modal-field__value {
  font-size: 0.88rem;
  color: var(--text);
  line-height: 1.5;
  word-break: break-word;
}

.clinic-modal-field__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.clinic-modal-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(41,174,219,0.1);
  border: 1px solid rgba(41,174,219,0.18);
  color: var(--blue);
}

.clinic-modal-link {
  color: var(--blue);
  text-decoration: none;
}

.clinic-edit-form {
  display: grid;
  gap: 4px;
}

.clinic-edit-section {
  padding: 14px 0 2px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.clinic-edit-section:first-child {
  padding-top: 0;
  border-top: none;
}

.clinic-edit-grid {
  display: grid;
  gap: 4px;
}

.clinic-multiselect {
  display: grid;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 11px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-light);
  position: relative;
  z-index: 4;
}

.clinic-multiselect__option {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.9rem;
  color: var(--text);
  cursor: pointer;
  min-height: 42px;
  padding: 6px 2px;
  border-radius: 10px;
  -webkit-tap-highlight-color: transparent;
}

.clinic-multiselect__option:hover {
  background: rgba(255,255,255,0.035);
}

.clinic-multiselect__option:active {
  background: rgba(41,174,219,0.08);
}

.clinic-multiselect__option input[type="checkbox"] {
  width: 22px;
  height: 22px;
  accent-color: var(--blue);
  flex: 0 0 auto;
}

.clinic-edit-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 8px;
}
@keyframes fadeSlide { from{opacity:0;transform:translateY(-5px)} to{opacity:1;transform:translateY(0)} }

.action-bar { display: grid; grid-template-columns: repeat(3,1fr); gap: 7px; margin-bottom: 10px; }

.act-btn {
  font-family: var(--font); font-size: 0.72rem; font-weight: 800;
  border: none; border-radius: var(--r-btn); padding: 12px 4px;
  cursor: pointer; letter-spacing: 0.03em; text-transform: uppercase;
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.act-btn:active { transform: scale(0.94); opacity: 0.85; }
.act-report   { background: linear-gradient(135deg,#1eaedb,#1080b0); color:#fff; }
.act-continue { background: linear-gradient(135deg,#065985,#044768); color:#fff; }
.act-cancel   { background: rgba(255,255,255,0.06); color: var(--text-sub); border: 1px solid var(--border-light); }

/* ─── Extend Chips ─── */
.extend-chips { display: flex; flex-wrap: wrap; gap: 7px; padding: 4px 0 6px; animation: fadeSlide 0.15s ease; }

.chip {
  font-family: var(--font); font-size: 0.82rem; font-weight: 700;
  background: rgba(6,89,133,0.28); color: var(--blue);
  border: 1px solid rgba(41,174,219,0.22); border-radius: var(--r-pill);
  padding: 8px 16px; cursor: pointer;
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.chip:active { background: rgba(41,174,219,0.22); transform: scale(0.95); }

/* ─── Sub-form toggle row ─── */
.toggle-row { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-bottom: 10px; }

.toggle-btn-danger {
  font-family: var(--font); font-size: 0.8rem; font-weight: 700;
  background: rgba(234,56,76,0.12); color: var(--red);
  border: 1px solid rgba(234,56,76,0.28); border-radius: var(--r-btn);
  padding: 11px; cursor: pointer; text-align: center;
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.toggle-btn-warn {
  font-family: var(--font); font-size: 0.8rem; font-weight: 700;
  background: rgba(255,217,102,0.1); color: var(--yellow);
  border: 1px solid rgba(255,217,102,0.25); border-radius: var(--r-btn);
  padding: 11px; cursor: pointer; text-align: center;
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.toggle-btn-danger:active, .toggle-btn-warn:active { transform: scale(0.96); opacity: 0.82; }

/* ─── Form Elements ─── */
.f-label {
  display: block; font-size: 0.72rem; font-weight: 700;
  color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.07em; margin: 10px 0 5px;
}
.f-input, .f-textarea, .f-select {
  font-family: var(--font); font-size: 0.88rem; color: var(--text);
  background: rgba(255,255,255,0.05); border: 1px solid var(--border-light);
  border-radius: 11px; padding: 11px 13px; width: 100%;
  outline: none; transition: border-color 0.2s;
  -webkit-appearance: none; appearance: none;
}
.f-input:focus, .f-textarea:focus, .f-select:focus {
  border-color: var(--blue); background: rgba(41,174,219,0.05);
}
.f-input::placeholder, .f-textarea::placeholder { color: var(--text-muted); }
.f-input[type="date"], .f-input[type="time"] { color-scheme: dark; }
.f-textarea { resize: none; min-height: 76px; line-height: 1.5; }
.f-select option { background: #1e2736; color: var(--text); }

.f-btn {
  font-family: var(--font); font-size: 0.88rem; font-weight: 800;
  border: none; border-radius: var(--r-btn); padding: 14px; width: 100%;
  cursor: pointer; transition: all 0.15s; margin-top: 10px;
  letter-spacing: 0.02em; -webkit-tap-highlight-color: transparent;
}
.f-btn:active { transform: scale(0.97); opacity: 0.9; }
.f-btn-danger   { background: linear-gradient(135deg,#c0392b,#ea384c); color:#fff; }
.f-btn-warn     { background: linear-gradient(135deg,#d4960a,#ffd966); color:#1a1000; }
.f-btn-primary  { background: linear-gradient(135deg,#1eaedb,#1080b0); color:#fff; }
.f-btn:disabled {
  background: rgba(255,255,255,0.08) !important;
  color: var(--text-muted) !important;
  border: 1px solid var(--border) !important;
  cursor: not-allowed;
  box-shadow: none;
  opacity: 0.8;
}

/* ─── Report panel ─── */
.report-panel {
  background: rgba(255,255,255,0.02); border: 1px solid var(--border);
  border-radius: 12px; padding: 13px; margin-top: 10px;
  animation: fadeSlide 0.15s ease;
}

.report-question-list {
  display: grid;
  gap: 12px;
}

.report-question-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.03);
  position: relative;
  z-index: 3;
}

.report-question-label {
  margin: 0;
}

.report-question-text {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.45;
}

.report-panel,
.report-questions,
.dialogue,
.extra-fields,
.report-answer-input,
.report-bound-input,
.btn-send-report {
  position: relative;
  z-index: 4;
}

.btn-send-report {
  min-height: 56px;
}

.report-empty-state {
  color: var(--text-sub);
  font-size: 0.86rem;
  line-height: 1.5;
}

/* ─── Bottom Nav ─── */
.bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0;
  height: var(--nav-h);
  background: rgba(11,15,20,0.92);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--border); z-index: 1000;
}
.bottom-nav ul { display: flex; width: 100%; height: 100%; list-style: none; padding: 0; margin: 0; }
.nav-item { flex: 1; }
.nav-link {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 3px;
  width: 100%; height: 100%;
  color: var(--text-muted); text-decoration: none;
  font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  transition: color 0.15s; -webkit-tap-highlight-color: transparent; padding: 0 4px;
}
.nav-link svg { display: block; transition: transform 0.15s; }
.nav-link:active { color: var(--blue); }
.nav-link:active svg { transform: scale(0.88); }

/* ─── Recording ─── */
.recording-indicator .dot {
  width: 10px; height: 10px; background: var(--red);
  border-radius: 50%; display: inline-block; animation: blink 1s infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

/* ─── Pulse ─── */
.pulse { animation: pulse-anim 1.5s infinite; }
@keyframes pulse-anim {
  0%   { box-shadow: 0 0 0 0   rgba(41,174,219,.5); }
  70%  { box-shadow: 0 0 0 10px rgba(41,174,219,0); }
  100% { box-shadow: 0 0 0 0   rgba(41,174,219,0); }
}

/* ─── Bootstrap override ─── */
.btn-outline-light { border-color: rgba(255,255,255,0.15) !important; color: var(--text-sub) !important; }

/* ─── Utility ─── */
.d-none { display: none !important; }
.container-fluid { position: relative; z-index: 1; }


/* ─── Tags ─── */
.tag {
  display: inline-flex;
  align-items: center;
  font-size: 0.66rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid currentColor;
}
.tag-info {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 12%, transparent);
}
.tag-muted {
  color: var(--text-muted);
  background: rgba(255,255,255,0.04);
}

::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-light); border-radius: 3px; }

/* =========================
   UI kit (shared)
   ========================= */
.page{
  min-height:100vh;
  padding:16px 14px calc(var(--nav-h) + 18px);
}
.page-with-nav{ padding-bottom: calc(var(--nav-h) + 18px); }
.page-center{
  display:flex; align-items:center; justify-content:center;
  padding:18px 14px;
}
.page-header{ margin: 8px 2px 14px; }
.page-title{
  margin:0;
  font-size: 1.55rem;
  letter-spacing:-0.02em;
}
.page-subtitle{
  margin-top:6px;
  color: var(--text-muted);
  font-size: .92rem;
}

.ui-card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.ui-card-pad{ padding: 14px; }
.list-stack{ display:flex; flex-direction:column; gap:10px; }
.ui-empty{ color: var(--text-muted); }

.ui-form .hint{
  margin-top:10px;
  color: var(--text-muted);
  font-size: .86rem;
}

.ui-row{ display:flex; gap:10px; align-items:stretch; }
.ui-row-btn{ flex: 0 0 auto; min-width: 110px; }

/* Рядок пошуку — завжди горизонтальний */
.search-row{ display:flex; gap:10px; align-items:stretch; }
.search-row .f-input{ flex:1; min-width:0; }
.search-row-btn{ flex: 0 0 auto; white-space: nowrap; padding-left:20px; padding-right:20px; }
.ui-col{ flex:1; min-width: 0; }

/* Alerts */
.ui-alert{
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  margin: 10px 0 0;
}
.ui-alert-danger{
  background: rgba(234,56,76,0.12);
  border-color: rgba(234,56,76,0.35);
  color: #ffb3bb;
}

/* Chips / tags */
.chips-line{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  display:inline-flex; align-items:center; justify-content:center;
  gap:6px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.03);
  color: var(--text);
  font-weight: 700;
  font-size: .82rem;
  line-height:1;
  -webkit-tap-highlight-color: transparent;
}
.chip:active{ transform: scale(0.98); }
.chip[disabled]{ opacity:.65; cursor:not-allowed; }
.chip-radio{ padding: 0; overflow:hidden; }
.chip-radio input{
  appearance:none; -webkit-appearance:none;
  width:0; height:0; position:absolute; opacity:0;
}
.chip-radio{ padding: 8px 12px; }
.chip-radio:has(input:checked){
  border-color: color-mix(in srgb, var(--accent) 60%, var(--border));
  box-shadow: 0 0 0 2px rgba(41,174,219,0.18) inset;
}

/* Clinic cards */
.clinic-item{ padding: 14px; cursor:pointer; }
.clinic-item.active{
  border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
  box-shadow: 0 0 0 2px rgba(41,174,219,0.18) inset, var(--shadow);
}
.clinic-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.clinic-name{ font-weight: 800; letter-spacing:-0.01em; }
.clinic-sub{ margin-top:6px; color: var(--text-muted); font-size: .9rem; }
.clinic-phones{ margin-top:10px; display:flex; flex-wrap:wrap; gap:8px; }
.clinic-cta{ margin-top:10px; }

/* Auth */
.auth-card{
  width:min(520px, 100%);
  padding: 22px 20px;
}

.auth-card .page-header{
  margin: 2px 0 18px;
}

.auth-form{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.auth-form .f-label{
  margin: 0;
}

.auth-form .f-input{
  margin: 0;
}

.auth-form .f-input + .f-label{
  margin-top: 2px;
}

.auth-form .f-btn{
  width: 100%;
  margin-top: 6px;
}

.auth-card .ui-alert{
  margin: 0 0 14px;
}

/* Meeting form on add-meeting */
.meeting-form{ margin-top: 10px; }
.form-title{ margin:0 0 10px; font-size: 1.05rem; }

@media (max-width: 520px){
  .ui-row{ flex-direction:column; }
  .ui-row-btn{ width:100%; min-width: 0; }
  .auth-card{
    padding: 18px 16px;
  }
}

.confirm-popup{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(6px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
}

.confirm-box{
  width:90%;
  max-width:340px;
  background:#161d28;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  padding:20px;
  text-align:center;
}

.confirm-title{
  font-size:1.1rem;
  font-weight:800;
  margin-bottom:10px;
}

.confirm-text{
  font-size:.9rem;
  color:#7a8fa6;
  margin-bottom:18px;
}

.confirm-actions{
  display:flex;
  gap:10px;
}

.confirm-btn{
  flex:1;
  padding:10px;
  border-radius:10px;
  border:none;
  font-weight:700;
}

.confirm-btn.cancel{
  background:rgba(255,255,255,.08);
  color:#7a8fa6;
}

.confirm-btn.ok{
  background:#29aedb;
  color:white;
}

.card.loading {
  opacity: 0.6;
  pointer-events: none;
  position: relative;
}

.card.loading::after{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.25);
  backdrop-filter: blur(2px);
}

.meeting-card.loading {
  pointer-events: none;
  opacity: 0.6;
}

.meeting-card.loading::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.25);
  z-index: 5;
}

.modal-backdrop.show{
  opacity: .65;
}

.modal .modal-content{
  background: var(--bg-surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--border-light) !important;
  border-radius: 18px !important;
  box-shadow: var(--shadow) !important;
}

.modal .modal-header{
  border-bottom: 1px solid var(--border) !important;
}

.modal .modal-footer{
  border-top: 1px solid var(--border) !important;
}

.modal .modal-title{
  color: var(--text) !important;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.modal #confirmModalText{
  color: var(--text-sub) !important;
  font-size: .95rem;
  line-height: 1.45;
}

/* кнопка X */
.modal .btn-close{
  filter: invert(1) grayscale(1);
  opacity: .7;
}
.modal .btn-close:hover{ opacity: 1; }

/* кнопки внизу */
#confirmModal .btn.btn-secondary{
  background: rgba(255,255,255,0.08) !important;
  border: 1px solid var(--border) !important;
  color: var(--text-sub) !important;
  border-radius: 12px !important;
  font-weight: 700;
}
#confirmModal .btn.btn-secondary:active{
  transform: scale(0.98);
}

#confirmModal .btn.btn-danger{
  background: linear-gradient(135deg,#c0392b,#ea384c) !important;
  border: none !important;
  color: #fff !important;
  border-radius: 12px !important;
  font-weight: 800;
}
#confirmModal .btn.btn-danger:active{
  transform: scale(0.98);
}

/* Meetings UX refresh */
.meeting-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  margin-bottom: 12px;
  padding: 12px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.05);
}

.summary-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.summary-company {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.35;
}

.summary-person {
  font-size: 0.78rem;
  color: var(--text-sub);
}

.summary-phone-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  padding: 6px 14px;
  border: 1px solid rgba(76,175,80,0.28);
  border-radius: var(--r-pill);
  background: rgba(76,175,80,0.1);
  color: var(--green);
  font-family: var(--font);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.35;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}

.summary-phone-btn:hover,
.summary-phone-btn:focus-visible {
  background: rgba(76,175,80,0.18);
  border-color: rgba(76,175,80,0.4);
}

.summary-phone-btn:active {
  background: rgba(76,175,80,0.24);
  transform: scale(0.98);
}

.summary-side {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
  justify-content: flex-end;
}

.bitrix-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.06);
  color: var(--text);
  font-family: var(--font);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.35;
  text-decoration: none;
  transition: all 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}

.bitrix-link-btn:hover,
.bitrix-link-btn:focus-visible {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.18);
}

.bitrix-link-btn:active {
  transform: scale(0.98);
}

.meeting-meta {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.meeting-preview,
.meeting-history,
.meeting-report {
  margin-top: 10px;
  padding: 11px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 12px;
}

.meeting-preview__label,
.meeting-history__label,
.meeting-report__label {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}

.meeting-report__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
}

.meeting-report__header .meeting-report__label {
  margin-bottom: 0;
}

.meeting-preview__body,
.meeting-history__body,
.meeting-report__body {
  font-size: 0.8rem;
  line-height: 1.55;
  color: var(--text-sub);
  white-space: pre-wrap;
  word-break: break-word;
}

.report-edit-btn {
  border: 0;
  background: transparent;
  color: var(--blue);
  font-family: var(--font);
  font-size: 0.76rem;
  font-weight: 700;
  padding: 0;
  white-space: nowrap;
}

.history-toggle {
  margin-top: 8px;
  border: 0;
  background: transparent;
  color: var(--blue);
  font-family: var(--font);
  font-size: 0.78rem;
  font-weight: 700;
  padding: 0;
}

.contact-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.history-list {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.history-entry {
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.04);
}

.history-meta {
  font-size: 0.68rem;
  color: var(--text-muted);
  margin-bottom: 4px;
}

.history-text {
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--text-sub);
}

.busy-block {
  display: none;
  margin-top: 8px;
}

.busy-loading {
  display: none;
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(41, 174, 219, 0.08);
  border: 1px solid rgba(41, 174, 219, 0.2);
  color: var(--blue);
  font-size: 0.8rem;
  font-weight: 600;
}

.busy-loading.visible {
  display: block;
}

.busy-label {
  font-size: 0.72rem;
  color: var(--text-muted);
  margin-bottom: 4px;
}

.busy-times {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.busy-chip {
  padding: 5px 10px;
  border-radius: var(--r-pill);
  background: rgba(255, 217, 102, 0.08);
  border: 1px solid rgba(255, 217, 102, 0.22);
  color: var(--yellow);
  font-size: 0.74rem;
  font-weight: 700;
}

.time-conflict-warn {
  display: none;
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(234, 56, 76, 0.1);
  border: 1px solid rgba(234, 56, 76, 0.24);
  color: #ff9ca8;
  font-size: 0.8rem;
  font-weight: 600;
}

.time-conflict-warn.visible {
  display: block;
}

.photo-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}

.photo-gallery--compact {
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 10px;
}

.photo-card {
  display: grid;
  gap: 8px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  align-content: start;
}

.photo-card__image-wrap {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
}

.photo-card__image-btn {
  padding: 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  appearance: none;
}

.photo-card__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-card__meta {
  min-height: 32px;
  font-size: 0.72rem;
  line-height: 1.4;
  color: var(--text-muted);
  word-break: break-word;
}

.photo-card__delete {
  border: 1px solid rgba(234, 56, 76, 0.25);
  background: rgba(234, 56, 76, 0.12);
  color: #ffb4bd;
  border-radius: 10px;
  padding: 8px 10px;
  font-size: 0.78rem;
  font-weight: 700;
}

.photo-preview {
  width: min(calc(100vw - 32px), 920px);
  max-height: 92vh;
  margin: auto;
  overflow-x: hidden;
}

.photo-preview__body {
  display: grid;
  gap: 14px;
  overflow-x: hidden;
}

.photo-preview__stage {
  width: 100%;
  max-height: 72vh;
  overflow: auto;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.025);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
}

.photo-preview__image {
  display: block;
  max-width: 100%;
  max-height: 68vh;
  width: auto;
  height: auto;
  border-radius: 14px;
}

.photo-preview__meta {
  color: var(--text-sub);
  font-size: 0.82rem;
  line-height: 1.5;
  overflow-wrap: anywhere;
  word-break: break-word;
}

#photoPreviewModal {
  align-items: center;
  justify-content: center;
}

#photoPreviewModal .sheet-modal {
  border-radius: 24px;
}

#photoPreviewModal .sheet-modal__title {
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 640px) {
  .meeting-summary {
    grid-template-columns: 1fr;
  }

  .summary-side {
    justify-content: flex-start;
  }

  .action-bar {
    grid-template-columns: 1fr;
  }

  .photo-gallery,
  .photo-gallery--compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .panel-section__header {
    align-items: flex-start;
  }

  .panel-section__header-actions {
    flex: 0 0 auto;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
  }
}

.meeting-edit-form {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.meeting-edit-actions {
  display: flex;
  gap: 12px;
  margin-top: 16px;
}

.meeting-edit-search-results {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.meeting-edit-search-item {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid rgba(61, 192, 255, 0.2);
  border-radius: 14px;
  background: rgba(255,255,255,0.03);
  color: #fff;
  text-align: left;
}

.meeting-edit-search-item__title {
  display: block;
  font-weight: 600;
}

.meeting-edit-search-item__meta,
.meeting-edit-search-empty {
  display: block;
  margin-top: 4px;
  color: rgba(255,255,255,0.65);
  font-size: 13px;
}
