/* ============================================================================
 *  styles.css  —  Оформление: интерфейс на чистом белом фоне (ТЗ),
 *  отчёт — в фирменном «кашмирском» стиле обложки (бежевая бумага, глубокий
 *  красный, золотые разделители, мандала). Заголовки — Jaipur, текст — Arial.
 * ========================================================================== */

@font-face {
  font-family: 'Jaipur';
  src: url('../fonts/jaipur.ttf') format('truetype');
  font-weight: normal;
  font-display: swap;
}

:root {
  --red: #df2227;
  --orange: #ef5024;
  --red-dark: #c41d21;
  --gold: #ef5024;
  --ink: #2b2118;
  --terracotta: #ef5024;
  --paper: #ffffff;
  --paper-light: #ffffff;
  --line: #f0d9d6;
  --green: #1d7a33;
  --shadow: 0 6px 22px rgba(223, 34, 39, 0.12);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: #ffffff;
  color: var(--ink);
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-size: 15px;
  line-height: 1.6;
}

.font-jaipur { font-family: 'Jaipur', Arial, sans-serif; }

/* ---- Шапка приложения ---------------------------------------------------- */
.app-header {
  background: linear-gradient(135deg, var(--red) 0%, var(--orange) 100%);
  color: #fff;
  padding: 26px 20px 22px;
  text-align: center;
  border-bottom: 4px solid var(--gold);
}
.app-header h1 {
  font-family: 'Jaipur', Arial, sans-serif;
  font-weight: normal;
  margin: 0;
  font-size: 34px;
  letter-spacing: 1px;
}
.app-header p { margin: 6px 0 0; opacity: 0.92; font-size: 14px; }

/* ---- Каркас -------------------------------------------------------------- */
.wrap { max-width: 1080px; margin: 0 auto; padding: 28px 20px 80px; }

.card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 24px 26px;
  margin-bottom: 22px;
}
.card > h2 {
  font-family: 'Jaipur', Arial, sans-serif;
  font-weight: normal;
  color: var(--red-dark);
  margin: 0 0 4px;
  font-size: 24px;
}
.card > h2 .num {
  display: inline-block;
  width: 30px; height: 30px; line-height: 30px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-family: Arial, sans-serif;
  font-size: 15px;
  text-align: center;
  margin-right: 10px;
  vertical-align: middle;
}
.card .hint { color: #8a7a68; font-size: 13px; margin: 0 0 18px; }

/* ---- Поля формы ---------------------------------------------------------- */
.grid { display: grid; gap: 16px; }
.grid.cols-2 { grid-template-columns: 1fr 1fr; }
.grid.cols-3 { grid-template-columns: 1fr 1fr 1fr; }

label { display: block; font-size: 13px; font-weight: bold; color: var(--terracotta); margin-bottom: 5px; }

input, select, textarea {
  width: 100%;
  padding: 11px 13px;
  border: 1px solid #d9d0c0;
  border-radius: 10px;
  font-family: inherit;
  font-size: 15px;
  color: var(--ink);
  background: #fffdfa;
  transition: border-color 0.15s, box-shadow 0.15s;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(223, 34, 39, 0.12);
}
textarea { resize: vertical; min-height: 160px; line-height: 1.6; }

.field-autocomplete { position: relative; }
.suggestions {
  position: absolute; z-index: 30; left: 0; right: 0; top: 100%;
  background: #fff; border: 1px solid #d9d0c0; border-radius: 0 0 10px 10px;
  max-height: 240px; overflow-y: auto; box-shadow: var(--shadow);
}
.suggestions div { padding: 9px 13px; cursor: pointer; font-size: 14px; }
.suggestions div:hover, .suggestions div.active { background: #fdecea; }
.suggestions .coord { color: #9a8a78; font-size: 12px; }

/* ---- Список вложений (изображения) -------------------------------------- */
.attach-list { display: flex; flex-direction: column; gap: 12px; margin-top: 14px; }
.attach-item {
  display: flex; gap: 12px; align-items: flex-start;
  border: 1px solid var(--line); border-radius: 12px; padding: 10px; background: #fffdfa;
}
.attach-thumb {
  width: 130px; height: 96px; object-fit: cover; flex: none;
  border-radius: 8px; border: 1px solid var(--line);
}
.attach-fields { flex: 1; display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.attach-row { display: flex; gap: 8px; flex-wrap: wrap; }
.attach-row .attach-section { max-width: 220px; }
.btn-attach-del {
  background: #fff; color: var(--red); border: 1.5px solid var(--red);
  border-radius: 8px; padding: 8px 14px; cursor: pointer; font-weight: bold; font-family: inherit;
}
.btn-attach-del:hover { background: #fdecea; }

/* ---- Кнопки -------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  border: none; border-radius: 12px;
  font-family: inherit; font-size: 15px; font-weight: bold;
  cursor: pointer; transition: transform 0.12s, box-shadow 0.12s, background 0.15s;
}
.btn-primary { background: linear-gradient(135deg, var(--red), var(--orange)); color: #fff; box-shadow: var(--shadow); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(223,34,39,0.28); }
.btn-primary:active { transform: translateY(0); }
.btn-ghost { background: #fff; color: var(--red-dark); border: 1.5px solid var(--red); }
.btn-ghost:hover { background: #fbeeee; transform: translateY(-1px); }
.btn-gold { background: linear-gradient(135deg, var(--orange), #d63d12); color: #fff; }
.btn-gold:hover { transform: translateY(-2px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

.toolbar { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.toolbar .spacer { flex: 1; }

.status-pill { font-size: 12px; color: #8a7a68; }

/* ---- Уведомление об автосохранении -------------------------------------- */
.toast {
  position: fixed; right: 22px; bottom: 22px;
  background: var(--ink); color: #fff; padding: 11px 18px; border-radius: 10px;
  font-size: 13px; opacity: 0; transform: translateY(12px);
  transition: opacity 0.3s, transform 0.3s; pointer-events: none; z-index: 80;
}
.toast.show { opacity: 0.95; transform: translateY(0); }

/* ---- Таблица планет ------------------------------------------------------ */
.ptable { width: 100%; border-collapse: collapse; font-size: 14px; }
.ptable th, .ptable td { padding: 9px 10px; text-align: left; border-bottom: 1px solid var(--line); }
.ptable th { background: #fdeceb; color: var(--red-dark); font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; }
.ptable tr:last-child td { border-bottom: none; }
.dot { display: inline-block; width: 11px; height: 11px; border-radius: 50%; margin-right: 7px; vertical-align: -1px; }
.dot.green { background: var(--green); }
.dot.red { background: var(--red); }
.dot.neutral { background: #b9aa95; }
.st-green { color: var(--green); font-weight: bold; }
.st-red { color: var(--red); font-weight: bold; }
.st-neutral { color: #8a7a68; }

/* ---- Превью отчёта ------------------------------------------------------- */
.report-preview { background: #f1f1f1; padding: 24px; border-radius: 16px; overflow-x: auto; }

/* ============================================================================
 *  ЛИСТ ОТЧЁТА — формат A4, фирменный «кашмирский» стиль обложки
 * ========================================================================== */
.page {
  width: 210mm;
  min-height: 297mm;
  margin: 0 auto 22px;
  background:
    #ffffff;
  color: var(--ink);
  position: relative;
  padding: 24mm 20mm 22mm;
  box-shadow: 0 8px 30px rgba(0,0,0,0.18);
  overflow: hidden;
}
.page::before {
  /* тонкая внутренняя рамка как на обложке */
  content: '';
  position: absolute; inset: 10mm;
  border: 1px solid rgba(223,34,39,0.30);
  border-radius: 4px;
  pointer-events: none;
}

/* верхняя/нижняя красные полосы как на обложке */
.page-bar-top, .page-bar-bottom {
  position: absolute; left: 0; right: 0; height: 7mm;
  background: linear-gradient(90deg, var(--red), var(--orange), var(--red));
}
.page-bar-top { top: 0; }
.page-bar-bottom { bottom: 0; }
.page-bar-bottom .footline {
  color: #ffffff; font-size: 9px; text-align: center; line-height: 7mm;
  font-family: Arial, sans-serif; letter-spacing: 0.5px;
}

.report-content { position: relative; z-index: 2; }

/* Обложка */
.cover { text-align: center; display: flex; flex-direction: column; min-height: 236mm; }
.cover-title {
  font-family: 'Jaipur', Arial, sans-serif;
  color: var(--red-dark);
  font-size: 40px;
  margin: 18mm 0 4mm;
  letter-spacing: 1px;
}
.cover-type { font-size: 17px; color: var(--terracotta); margin-bottom: 12mm; }
.cover-frame {
  flex: 1;
  border: 1.5px solid rgba(223,34,39,0.45);
  border-radius: 10px;
  margin: 0 6mm 10mm;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  position: relative;
  background:
    radial-gradient(closest-side, rgba(223,34,39,0.05), transparent 70%);
}
.cover-frame .mandala { opacity: 0.10; width: 120mm; height: 120mm; position: absolute; }
.cover-client { position: relative; z-index: 2; }
.cover-client .name { font-family: 'Jaipur', Arial, sans-serif; font-size: 30px; color: var(--red-dark); }
.cover-client .sub { font-size: 15px; color: var(--terracotta); margin-top: 6px; }
.cover-meta { text-align: left; max-width: 120mm; margin: 0 auto 12mm; font-size: 15px; }
.cover-meta div { margin: 3px 0; }
.cover-meta b { color: var(--red-dark); }
.cover-meta .lbl { color: #8a7a68; }

/* Заголовки разделов отчёта */
.r-h1 {
  font-family: 'Jaipur', Arial, sans-serif;
  color: var(--red-dark); font-size: 26px;
  margin: 0 0 4px; text-align: center;
}
.r-h2 {
  font-family: 'Jaipur', Arial, sans-serif;
  color: var(--red-dark); font-size: 20px;
  margin: 16px 0 6px;
  border-bottom: 1px solid rgba(239,80,36,0.6);
  padding-bottom: 4px;
}
.gold-sep {
  height: 14px; margin: 6px auto 14px; width: 60%;
  background-image: linear-gradient(90deg, transparent, var(--gold), transparent);
  background-size: 100% 1.5px; background-position: center; background-repeat: no-repeat;
  position: relative;
}
.gold-sep::after {
  content: '✦'; color: var(--gold); position: absolute; left: 50%; top: 50%;
  transform: translate(-50%,-50%); background: var(--paper-light); padding: 0 8px; font-size: 12px;
}
.report-content p { margin: 0 0 9px; text-align: justify; }
.report-content .note-block {
  background: rgba(223,34,39,0.05);
  border-left: 3px solid var(--red);
  padding: 10px 14px; border-radius: 0 8px 8px 0; margin: 8px 0;
}
.report-content .note-block .src-tag { font-size: 11px; color: var(--terracotta); font-weight: bold; text-transform: uppercase; letter-spacing: 0.5px; }
.report-content .note-block p { text-align: left; }

/* изображения-вложения в отчёте */
.r-figure { margin: 12px auto; text-align: center; page-break-inside: avoid; break-inside: avoid; }
.r-figure img {
  max-width: 100%; max-height: 165mm;
  border: 1px solid rgba(223,34,39,0.25); border-radius: 8px;
}
.r-figure figcaption { font-size: 12px; color: var(--terracotta); margin-top: 5px; font-style: italic; }

.chart-wrap { text-align: center; margin: 8px 0 14px; }
.chart-legend { font-size: 12px; color: #8a7a68; text-align: center; margin-top: 6px; }

.r-table { width: 100%; border-collapse: collapse; font-size: 12.5px; margin: 8px 0; }
.r-table th, .r-table td { padding: 6px 8px; border: 1px solid rgba(223,34,39,0.18); text-align: left; }
.r-table th { background: rgba(223,34,39,0.08); color: var(--red-dark); }

/* карточки рекомендуемых камней */
.gem-card {
  display: flex; gap: 14px; align-items: flex-start;
  border: 1px solid rgba(223,34,39,0.18); border-radius: 12px;
  padding: 12px 14px; margin: 0 0 12px;
  page-break-inside: avoid; break-inside: avoid;
}
.gem-vis { flex: none; width: 64px; height: 64px; display: block; }
.gem-svg { width: 64px; height: 64px; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.18)); }
.gem-info { flex: 1; min-width: 0; }
.gem-info h4 { font-family: 'Jaipur', Arial, sans-serif; color: var(--red-dark); margin: 0 0 2px; font-size: 17px; font-weight: normal; }
.gem-info ul { margin: 4px 0 6px; padding-left: 18px; }
.gem-info li { margin: 1px 0; }
.gem-link { display: inline-block; color: var(--red); font-weight: bold; text-decoration: none; border-bottom: 1px solid rgba(223,34,39,0.4); }
.gem-link:hover { color: var(--orange); }
.gem-caution { background: rgba(239,80,36,0.06); border-left: 3px solid var(--orange); padding: 8px 12px; border-radius: 0 8px 8px 0; font-size: 13px; }

.remedy { margin: 0 0 12px; }
.remedy h4 { font-family:'Jaipur',Arial,sans-serif; color: var(--red-dark); margin: 0 0 3px; font-size: 16px; font-weight: normal; }
.remedy .reason { font-size: 12px; color: var(--terracotta); margin-bottom: 4px; }
.remedy ul { margin: 0; padding-left: 18px; }
.remedy li { margin: 2px 0; }

.report-footer { text-align: center; margin-top: 18px; padding-top: 12px; border-top: 1px solid rgba(239,80,36,0.6); }
.report-footer .school { font-family:'Jaipur',Arial,sans-serif; color: var(--red-dark); font-size: 18px; }
.report-footer .lines { font-size: 13px; color: var(--terracotta); margin-top: 4px; }
.report-footer .sign { margin-top: 10px; font-size: 14px; }

/* ---- Тело отчёта (плавная вёрстка, авто-пагинация при печати) ----------- */
.report-body {
  width: 210mm;
  margin: 0 auto;
  background:
    #ffffff;
  color: var(--ink);
  padding: 16mm 20mm 16mm;
  box-shadow: 0 8px 30px rgba(0,0,0,0.18);
}
.print-furniture { display: none; }

/* ---- Индикатор загрузки -------------------------------------------------- */
.overlay {
  position: fixed; inset: 0; background: rgba(255,255,255,0.85);
  display: none; align-items: center; justify-content: center; z-index: 90; flex-direction: column;
}
.overlay.show { display: flex; }
.spinner {
  width: 56px; height: 56px; border: 5px solid #eaddc8; border-top-color: var(--red);
  border-radius: 50%; animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.overlay p { margin-top: 16px; color: var(--red-dark); font-weight: bold; }

.hidden { display: none !important; }
.error-text { color: var(--red); font-size: 13px; margin-top: 6px; }

/* ---- Адаптивность -------------------------------------------------------- */
@media (max-width: 820px) {
  .grid.cols-2, .grid.cols-3 { grid-template-columns: 1fr; }
  .app-header h1 { font-size: 26px; }
  .page { width: 100%; padding: 16px; min-height: auto; }
  .page::before { inset: 6px; }
  .cover { min-height: auto; }
  .report-body { width: 100%; padding: 16px; }
  .report-preview { padding: 12px; }
}

/* ============================================================================
 *  ПЕЧАТЬ / PDF (A4)
 * ========================================================================== */
@media print {
  /* симметричные поля 13 мм со всех сторон — контент никогда не обрезается */
  @page { size: A4; margin: 13mm; }
  html, body {
    background: #ffffff;
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  .app-header, .wrap > .card, .toolbar, .toast, .overlay, .no-print { display: none !important; }
  .wrap { padding: 0; max-width: none; }
  .report-preview { background: none; padding: 0; }
  #report-root { display: block !important; }

  /* ГИБКАЯ ширина — заполняет печатаемую область, не вылезает за поля */
  .page {
    width: auto; min-height: calc(297mm - 26mm); margin: 0; box-shadow: none;
    padding: 14mm 12mm; overflow: visible;
    page-break-after: always; break-after: page;
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  .page::before { inset: 4mm; }
  .report-body {
    width: auto; box-shadow: none; padding: 0 6mm; background: #ffffff;
  }
  /* «фурнитура» (фикс. полосы + подпись) повторяется на каждой странице;
     собственные полосы обложки скрываем во избежание двойных */
  .page-bar-top, .page-bar-bottom { display: none !important; }
  .print-furniture { display: block; }
  /* полосы выходят в поля (-13мм) до самого края листа — фон «в обрез» */
  .pf-top, .pf-bottom {
    position: fixed; left: -13mm; right: -13mm; height: 6mm;
    background: linear-gradient(90deg, var(--red), var(--orange), var(--red));
  }
  .pf-top { top: -13mm; }
  .pf-bottom { bottom: -13mm; }
  .pf-foot {
    position: fixed; bottom: -9mm; left: -13mm; right: -13mm; height: 5mm;
    text-align: center; color: #ffffff; font-size: 8px; line-height: 5mm;
    letter-spacing: 0.4px;
  }
  .r-h2, .remedy, .chart-wrap, .r-table, .report-content p, .report-footer, .r-figure {
    page-break-inside: avoid; break-inside: avoid;
  }
  .r-h2 { page-break-after: avoid; }
  .r-figure img { max-height: 150mm; }
}
