/* ============ HOME — HERO ============ */
.hero {
  position: relative;
  padding: clamp(64px, 9vw, 140px) 0 clamp(56px, 8vw, 120px);
  background: #1d1d1d;
  color: #FAF6EE;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(184,151,90,0.18) 0%, transparent 60%);
  pointer-events: none;
}
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='none'/%3E%3Ccircle cx='2' cy='2' r='0.4' fill='rgba(255,255,255,0.04)'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: 0.6;
}
.hero .container { position: relative; z-index: 1; }

.hero-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 80px;
  align-items: end;
}
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 48px; }
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--r-pill);
  margin-bottom: 32px;
}
.hero-eyebrow::before { content: ''; width: 6px; height: 6px; background: var(--success); border-radius: 50%; }

.hero h1 {
  color: #FAF6EE;
  font-size: clamp(48px, 8vw, 120px);
  line-height: 0.98;
  margin-bottom: 28px;
  letter-spacing: -0.03em;
}
.hero h1 em { color: var(--gold-light); }

.hero p {
  font-size: clamp(15px, 1.4vw, 18px);
  color: rgba(255,255,255,0.55);
  line-height: 1.65;
  max-width: 44ch;
  margin-bottom: 40px;
  font-weight: 300;
}
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }

.hero-side {
  border-left: 1px solid rgba(255,255,255,0.1);
  padding-left: 48px;
}
@media (max-width: 980px) {
  .hero-side { border-left: none; padding-left: 0; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 32px; }
}
.hero-side .eyebrow { color: rgba(255,255,255,0.4); margin-bottom: 24px; }
.hero-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.hero-stat .num { font-family: var(--font-display); font-size: 48px; font-weight: 300; color: #FAF6EE; line-height: 1; margin-bottom: 6px; }
.hero-stat .num em { color: var(--gold-light); }
.hero-stat .label { font-size: 12px; color: rgba(255,255,255,0.4); line-height: 1.5; }

/* ============ SERVICES SECTION ============ */
.services-section { background: var(--cream); }
.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 980px) { .services-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .services-grid { grid-template-columns: 1fr; } }

.service-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: transform var(--t-base), background var(--t-base), border-color var(--t-base);
  cursor: pointer;
  min-height: 280px;
}
.service-card:hover {
  transform: translateY(-4px);
  background: var(--sage-light);
  border-color: var(--sage);
}
.service-icon {
  width: 56px; height: 56px;
  background: var(--cream-deep);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
  transition: background var(--t-base);
}
.service-card:hover .service-icon { background: var(--white); }
.service-card h4 { font-size: 20px; font-family: var(--font-display); font-weight: 400; }
.service-card p { font-size: 14px; color: var(--stone); line-height: 1.6; flex: 1; }
.service-card .price-from {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  font-size: 12px;
  color: var(--stone);
}
.service-card .price-from strong { font-family: var(--font-display); font-size: 18px; color: var(--dark); font-weight: 500; letter-spacing: 0; }

/* ============ MAP PROMO ============ */
.map-promo {
  background: linear-gradient(135deg, #2C3A2E 0%, #1A2218 100%);
  color: #FAF6EE;
  border-radius: var(--r-2xl);
  overflow: hidden;
  position: relative;
}
.map-promo-inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0;
  align-items: stretch;
  min-height: 460px;
}
@media (max-width: 860px) { .map-promo-inner { grid-template-columns: 1fr; min-height: 0; } }

.map-promo-text { padding: clamp(32px, 5vw, 64px); display: flex; flex-direction: column; justify-content: center; }
.map-promo-text .badge { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.7); border-color: rgba(255,255,255,0.15); margin-bottom: 20px; align-self: flex-start; }
.map-promo-text h2 { color: #FAF6EE; max-width: 14ch; margin-bottom: 16px; }
.map-promo-text p { color: rgba(255,255,255,0.55); font-size: 15px; line-height: 1.7; max-width: 40ch; margin-bottom: 28px; }
.map-promo-text .btn-gold { align-self: flex-start; }

.map-promo-visual {
  background: #1F2A20;
  position: relative;
  overflow: hidden;
  min-height: 280px;
}
.map-promo-visual::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(107,123,110,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(107,123,110,0.12) 1px, transparent 1px);
  background-size: 32px 32px;
}
.map-promo-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 60% 40%, transparent 0%, rgba(31,42,32,0.6) 70%);
}
.pin {
  position: absolute;
  width: 10px; height: 10px;
  background: var(--gold);
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.3);
  z-index: 1;
}
.pin.active {
  width: 16px; height: 16px;
  background: var(--success);
  box-shadow: 0 0 24px rgba(107,203,119,0.6);
  animation: pulse 2.5s infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(107,203,119,0.6); }
  50% { box-shadow: 0 0 0 16px rgba(107,203,119,0); }
}

/* ============ STEPS / HOW IT WORKS ============ */
.steps-section { background: var(--cream-deep); }
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  position: relative;
}
@media (max-width: 860px) { .steps-grid { grid-template-columns: 1fr 1fr; gap: 16px; } }
@media (max-width: 540px) { .steps-grid { grid-template-columns: 1fr; } }

.step {
  background: var(--white);
  border-radius: var(--r-xl);
  padding: 28px;
  border: 1px solid var(--border);
  position: relative;
}
.step .num {
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: 300;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 20px;
  font-style: italic;
}
.step h4 { font-size: 17px; font-family: var(--font-body); font-weight: 500; margin-bottom: 6px; }
.step p { font-size: 13px; color: var(--stone); line-height: 1.55; }

/* ============ SUBSCRIPTION TIERS ============ */
.tiers-section { background: var(--cream); }

.tiers-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 1080px) { .tiers-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .tiers-grid { grid-template-columns: 1fr; } }

.tier {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base);
}
.tier:hover { border-color: var(--border-strong); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.tier.featured { background: var(--gold-soft); border-color: var(--gold); }
.tier.featured:hover { border-color: var(--gold); }
.tier .tier-label { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--stone); }
.tier.featured .tier-label { color: var(--gold); }
.tier .tier-price { font-family: var(--font-display); font-size: 44px; font-weight: 300; color: var(--dark); line-height: 1; }
.tier .tier-price span { font-size: 14px; color: var(--stone); font-family: var(--font-body); font-weight: 300; }
.tier .tier-desc { font-size: 13px; color: var(--stone); line-height: 1.6; }
.tier ul { display: flex; flex-direction: column; gap: 10px; flex: 1; padding-top: 16px; border-top: 1px solid var(--border); }
.tier li { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--dark); line-height: 1.5; }
.tier li::before {
  content: ''; flex-shrink: 0; margin-top: 6px;
  width: 14px; height: 14px;
  background: rgba(107,203,119,0.15);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%238FD89A' stroke-width='1.5'%3E%3Cpolyline points='2,6 5,9 10,3'/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
}
.tier .btn { margin-top: auto; }
.tier-ico {
  width: 56px; height: 56px;
  background: var(--cream-deep);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
}
.tier h4 { font-size: 20px; font-family: var(--font-display); font-weight: 400; }

/* ============ REVIEWS ============ */
.reviews-section { background: var(--cream); }
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 980px) { .reviews-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .reviews-grid { grid-template-columns: 1fr; } }

.review {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.review .stars { color: var(--gold); letter-spacing: 1px; font-size: 14px; }
.review .text { font-size: 14px; color: var(--dark); line-height: 1.65; flex: 1; }
.review .author { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--border); }
.review .avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--cream-deep);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--gold);
  flex-shrink: 0;
}
.review .author-info .name { font-size: 14px; font-weight: 500; color: var(--dark); }
.review .author-info .meta { font-size: 12px; color: var(--stone); }

.reviews-source {
  display: flex;
  gap: 16px;
  margin-top: 32px;
  flex-wrap: wrap;
}
.review-badge {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-size: 13px;
  color: var(--stone);
}
.review-badge strong { color: var(--dark); font-weight: 500; }
.review-badge .stars { color: var(--gold); font-size: 13px; }

/* ============ ABOUT / TRUST ============ */
.about-section { background: var(--cream); }
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 980px) { .about-grid { grid-template-columns: 1fr; gap: 32px; } }

.about-image {
  background: var(--sage-dark);
  border-radius: var(--r-2xl);
  aspect-ratio: 4/5;
  position: relative;
  overflow: hidden;
}
.about-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 30% 70%, rgba(184,151,90,0.3) 0%, transparent 50%),
    radial-gradient(circle at 70% 30%, rgba(107,123,110,0.4) 0%, transparent 60%);
}
.about-image .icon-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: clamp(64px, 12vw, 140px);
  font-weight: 300;
  color: rgba(245,240,232,0.9);
  font-style: italic;
}

.about-text h2 { margin-bottom: 24px; }
.about-text p { font-size: 15px; line-height: 1.75; color: var(--stone); margin-bottom: 16px; }
.about-text .stat-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid var(--border);
}
.about-text .stat .num { font-family: var(--font-display); font-size: 44px; font-weight: 300; color: var(--dark); line-height: 1; }
.about-text .stat .label { font-size: 13px; color: var(--stone); margin-top: 6px; }

/* ============ FAQ ============ */
.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--t-fast);
}
.faq-item[open] { border-color: var(--gold); }
.faq-item summary {
  list-style: none;
  padding: 20px 24px;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 400;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  font-size: 28px;
  color: var(--gold);
  font-weight: 300;
  line-height: 1;
  transition: transform var(--t-base);
}
.faq-item[open] summary::after { content: '−'; }
.faq-item .faq-body {
  padding: 0 24px 24px;
  font-size: 14px;
  color: var(--stone);
  line-height: 1.7;
  max-width: 80ch;
}

/* ============ CTA SECTION ============ */
.cta-section {
  background: #1d1d1d;
  color: #FAF6EE;
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute;
  bottom: -200px; left: -100px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(184,151,90,0.15) 0%, transparent 60%);
}
.cta-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 980px) { .cta-inner { grid-template-columns: 1fr; gap: 32px; } }
.cta-inner h2 { color: #FAF6EE; margin-bottom: 20px; }
.cta-inner p { color: rgba(255,255,255,0.55); font-size: 16px; line-height: 1.7; max-width: 44ch; }
.cta-form { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--r-xl); padding: 28px; }
.cta-form .form-input, .cta-form .form-select { background: var(--cream); border-color: transparent; }
.cta-form .form-label { color: rgba(255,255,255,0.5); }
.cta-form .form-note { color: rgba(255,255,255,0.4); }

/* ============ INTERACTIVE MAP PAGE ============ */
.map-page { background: var(--cream); }
.map-layout {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 0;
  height: calc(100vh - 80px);
  min-height: 600px;
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  overflow: hidden;
  background: var(--white);
}
@media (max-width: 980px) {
  .map-layout { grid-template-columns: 1fr; height: auto; }
}

.map-sidebar {
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  background: var(--white);
  min-height: 0;
  overflow: hidden;
}
.map-sidebar-head { padding: 24px; border-bottom: 1px solid var(--border); }
.map-sidebar-head h3 { font-size: 22px; margin-bottom: 4px; }
.map-sidebar-head p { font-size: 13px; color: var(--stone); }
.map-filters { padding: 16px 24px; display: flex; flex-direction: column; gap: 12px; border-bottom: 1px solid var(--border); }
.map-list { flex: 1; min-height: 0; overflow-y: auto; padding: 8px 0; }
@media (max-width: 980px) { .map-list { max-height: 240px; } }
.plot-unplaced { color: var(--gold); }
.map-leaflet.is-placing,
.map-leaflet.is-placing .leaflet-container { cursor: crosshair; }

/* Карта — инструмент разметки (admin) */
.map-draw-panel {
  position: absolute; top: 16px; left: 16px; z-index: 1000;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 10px;
  box-shadow: var(--shadow-md);
  display: flex; flex-direction: column; gap: 6px; width: 156px;
}
.map-draw-h { font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--stone); }
.map-draw-hint { font-size: 11.5px; color: var(--gold); line-height: 1.45; }
.map-draw-panel .btn { width: 100%; }
.map-draw-clear {
  color: #C0392B; margin-top: 2px;
  border-top: 1px solid var(--border); border-radius: 0;
  padding-top: 9px;
}
.map-draw-clear:hover { background: rgba(192,57,43,0.08); color: #A93226; }
.map-draw-field { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 12px; color: var(--stone); }
.map-draw-num { width: 64px; padding: 6px 8px; font-size: 13px; }
.map-draw-input { padding: 7px 9px; font-size: 13px; width: 100%; }
.layout-label span {
  display: inline-block;
  background: rgba(28,28,26,0.82); color: #fff;
  font-size: 11px; font-weight: 600;
  padding: 2px 7px; border-radius: 4px; white-space: nowrap;
}

/* --- сектор-сетка: подписи на карте --- */
.grid-rownum span {
  display: inline-block;
  background: rgba(28,28,26,0.7); color: #fff;
  font-size: 10px; font-weight: 700;
  min-width: 16px; text-align: center;
  padding: 1px 4px; border-radius: 3px;
}
.grid-sector-label span {
  display: inline-block;
  background: var(--gold, #B8975A); color: #fff;
  font-size: 12px; font-weight: 700; letter-spacing: 0.02em;
  padding: 3px 10px; border-radius: 5px; white-space: nowrap;
  box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.grid-sector-label { cursor: pointer; }

/* --- модалка привязки участка к месту --- */
.map-assign-addr {
  margin: 0 0 14px; font-size: 13px; color: var(--gold, #B8975A); font-weight: 600;
}
.map-assign-empty {
  margin: 8px 0 0; font-size: 13px; color: var(--stone); line-height: 1.5;
}
.map-assign-list {
  display: flex; flex-direction: column; gap: 8px;
  max-height: 52vh; overflow-y: auto; margin-top: 4px;
}
.map-assign-item {
  display: flex; flex-direction: column; gap: 3px;
  text-align: left; width: 100%;
  padding: 11px 14px;
  background: var(--cream, #F7F3EC);
  border: 1px solid var(--border, #E5DECF);
  border-radius: 10px; cursor: pointer;
  transition: background var(--t-fast, .15s), border-color var(--t-fast, .15s);
}
.map-assign-item:hover { background: var(--cream-deep, #EFE8D8); border-color: var(--gold, #B8975A); }
.map-assign-name { font-size: 14px; font-weight: 600; color: var(--dark, #1C1C1A); }
.map-assign-meta { font-size: 12px; color: var(--stone, #8A8578); }

.plot-item {
  padding: 14px 24px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background var(--t-fast);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.plot-item:hover { background: var(--cream); }
.plot-item.active { background: var(--cream-deep); border-left: 3px solid var(--gold); padding-left: 21px; }
.plot-item .info .title { font-size: 14px; font-weight: 500; color: var(--dark); margin-bottom: 2px; }
.plot-item .info .sub { font-size: 12px; color: var(--stone); }
.plot-item .status {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.status.ok { background: var(--success); }
.status.warn { background: var(--gold); }
.status.alert { background: var(--danger); }

.map-canvas {
  position: relative;
  overflow: hidden;
  min-height: 480px;
  background: var(--cream-deep);
  isolation: isolate;
}
.map-leaflet {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 480px;
  z-index: 0;
}
/* reset.css задаёт img { max-width: 100% } — для Leaflet-тайлов это ломает раскладку */
.leaflet-container img.leaflet-tile,
.leaflet-pane img {
  max-width: none !important;
  max-height: none !important;
}
/* Leaflet panes work in z 200-700; ставим оверлеи выше */
.map-overlay-info,
.map-legend,
.plot-detail-card { z-index: 1000; }

/* Подпись на карте */
.cemetery-label {
  background: transparent;
  border: none;
  pointer-events: none;
  text-align: center;
}
.cemetery-label span {
  display: inline-block;
  background: rgba(28,28,26,0.78);
  color: #FAF6EE;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  white-space: nowrap;
}

/* Маркеры участков — никаких transform на SVG: они скакали бы относительно
   начала координат карты. Размер меняем через setStyle в JS. */
.plot-pin {
  filter: drop-shadow(0 1px 3px rgba(0,0,0,0.25));
  cursor: pointer;
}
.plot-pin.is-active {
  filter: drop-shadow(0 0 6px rgba(184,151,90,0.85));
}

.map-overlay-info {
  position: absolute;
  top: 16px; left: 16px;
  background: rgba(28,28,26,0.78);
  backdrop-filter: blur(12px);
  border-radius: var(--r-md);
  padding: 12px 16px;
  color: #FAF6EE;
  border: 1px solid rgba(255,255,255,0.1);
  pointer-events: none;
}
.map-overlay-info .title { font-size: 13px; font-weight: 500; margin-bottom: 2px; }
.map-overlay-info .meta { font-size: 11px; color: rgba(255,255,255,0.6); }

.map-legend {
  position: absolute;
  bottom: 16px; left: 16px;
  background: rgba(28,28,26,0.78);
  backdrop-filter: blur(12px);
  border-radius: var(--r-md);
  padding: 12px 16px;
  display: flex;
  gap: 16px;
  font-size: 11px;
  color: rgba(255,255,255,0.78);
  border: 1px solid rgba(255,255,255,0.1);
  flex-wrap: wrap;
  pointer-events: none;
}
.legend-item { display: flex; align-items: center; gap: 6px; }
.legend-item .dot { width: 8px; height: 8px; border-radius: 50%; }

.plot-detail-card {
  position: absolute;
  top: 16px; right: 16px;
  background: var(--cream);
  border-radius: var(--r-lg);
  padding: 20px;
  width: 280px;
  box-shadow: var(--shadow-xl);
  display: none;
}
.plot-detail-card.open { display: block; }
.plot-detail-card h4 { font-family: var(--font-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
.plot-detail-card .meta { font-size: 12px; color: var(--stone); margin-bottom: 16px; }
.plot-detail-card .row { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
.plot-detail-card .row:last-of-type { border-bottom: none; margin-bottom: 16px; }
.plot-detail-card .row .label { color: var(--stone); }
.plot-detail-card .row .value { color: var(--dark); font-weight: 500; }
.plot-detail-card .map-detail-block { padding: 10px 0; border-bottom: 1px solid var(--border); }
.plot-detail-card .map-detail-block:last-child { border-bottom: none; }
.map-detail-h {
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--stone); margin-bottom: 6px;
}
.map-detail-client { font-size: 14px; font-weight: 500; color: var(--dark); }
.map-detail-phone {
  display: inline-block; margin-top: 2px;
  font-size: 13px; color: var(--gold); text-decoration: none;
}
.map-detail-phone:hover { text-decoration: underline; }
.map-detail-date { font-size: 13px; color: var(--dark); padding: 2px 0; }
.map-detail-muted { font-size: 13px; color: var(--stone); }
.map-detail-empty {
  font-size: 13px; color: var(--stone);
  background: var(--cream-deep); border-radius: 8px;
  padding: 11px 13px; text-align: center;
}

@media (max-width: 980px) {
  .plot-detail-card { position: static; width: 100%; box-shadow: none; border-radius: 0; }
  .map-canvas { min-height: 400px; }
}

/* ============ CABINET ============ */
.cabinet-section { background: var(--cream); min-height: 70vh; }
/* HTML-атрибут [hidden] перебивается любым display:grid/flex — гарантируем что hidden работает */
.cabinet-section [hidden] { display: none !important; }
.cabinet-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
}
@media (max-width: 860px) { .cabinet-layout { grid-template-columns: 1fr; } }

.cabinet-sidebar {
  background: var(--white);
  border-radius: var(--r-xl);
  padding: 24px;
  border: 1px solid var(--border);
  height: fit-content;
}
.cabinet-profile { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--border); }
.cabinet-profile .avatar {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--cream-deep);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--gold);
}
.cabinet-profile .name { font-size: 15px; font-weight: 500; }
.cabinet-profile .phone { font-size: 12px; color: var(--stone); }

.cabinet-menu { display: flex; flex-direction: column; gap: 2px; }
.cabinet-menu button {
  text-align: left;
  padding: 12px 14px;
  font-size: 14px;
  color: var(--stone);
  border-radius: var(--r-md);
  transition: background var(--t-fast), color var(--t-fast);
  display: flex; align-items: center; gap: 10px;
}
.cabinet-menu button:hover { background: var(--cream); color: var(--dark); }
.cabinet-menu button.active { background: #1d1d1d; color: #FAF6EE; }

.cabinet-content { background: var(--white); border-radius: var(--r-xl); padding: 32px; border: 1px solid var(--border); min-height: 480px; }
.cabinet-content h2 { font-size: 32px; margin-bottom: 8px; }
.cabinet-content .lead { margin-bottom: 24px; font-size: 14px; }

.order-list { display: flex; flex-direction: column; gap: 12px; }
.order-item-wrap { display: flex; flex-direction: column; gap: 0; }
.order-item-wrap .order-item { border-radius: var(--r-md) var(--r-md) 0 0; }
.order-item-wrap .order-manager { border-radius: 0 0 var(--r-md) var(--r-md); border-top: 1px dashed var(--border); }
.order-item-wrap:has(.order-manager) .order-item { border-bottom: none; }
/* fallback для браузеров без :has() */
.order-manager + .order-item { border-bottom: none; }
.order-manager {
  background: linear-gradient(180deg, var(--cream) 0%, #F4ECDC 100%);
  border: 1px solid var(--border);
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.order-manager-label {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--stone);
  white-space: nowrap;
}
.order-manager-info { font-size: 13px; }
.order-manager-info strong { color: var(--dark); font-weight: 500; }
.order-manager-info a { color: var(--gold); }
.order-manager-info a:hover { text-decoration: underline; }
.order-item {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 16px;
  align-items: center;
  padding: 16px;
  background: var(--cream);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
}
@media (max-width: 540px) { .order-item { grid-template-columns: 1fr; gap: 8px; } }
.order-item .order-icon {
  width: 40px; height: 40px;
  background: var(--white);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.order-item .title { font-size: 14px; font-weight: 500; margin-bottom: 2px; }
.order-item .meta { font-size: 12px; color: var(--stone); }
.order-item .price { font-family: var(--font-display); font-size: 18px; font-weight: 500; color: var(--dark); }
.order-item .status-badge {
  font-size: 11px; padding: 4px 10px; border-radius: var(--r-pill);
  letter-spacing: 0.04em;
}
.status-badge.done { background: rgba(107,203,119,0.15); color: #2C7A35; }
.status-badge.progress { background: rgba(184,151,90,0.15); color: var(--gold); }
.status-badge.new { background: rgba(107,123,110,0.15); color: var(--sage-dark); }

.empty-state {
  text-align: center;
  padding: 48px 16px;
  color: var(--stone);
}
.empty-state .icon { font-size: 48px; margin-bottom: 16px; opacity: 0.4; }
.empty-state h4 { font-family: var(--font-display); font-size: 24px; font-weight: 400; color: var(--dark); margin-bottom: 8px; }
.empty-state p { font-size: 14px; margin-bottom: 20px; }

/* ----- AUTH GATE (вход в кабинет) ----- */
.cabinet-auth {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 24px;
  margin-top: 8px;
}
@media (max-width: 860px) { .cabinet-auth { grid-template-columns: 1fr; } }
.cabinet-auth-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 40px;
}
.cabinet-auth-card .eyebrow { display: block; margin-bottom: 12px; }
.cabinet-auth-card h2 { font-size: clamp(28px, 4vw, 40px); margin-bottom: 12px; }
.cabinet-auth-card .lead { margin-bottom: 28px; font-size: 15px; }
.cabinet-auth-form { margin-top: 8px; }
.cabinet-auth-note {
  margin-top: 16px;
  font-size: 12px;
  color: var(--stone);
  line-height: 1.5;
  text-align: center;
}
.cabinet-auth-side {
  background: #1d1d1d;
  color: #FAF6EE;
  border-radius: var(--r-xl);
  padding: 32px;
  display: flex;
  flex-direction: column;
}
.cabinet-auth-side h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 24px;
  color: #FAF6EE;
  margin-bottom: 20px;
}
.cabinet-auth-side ul { display: flex; flex-direction: column; gap: 14px; }
.cabinet-auth-side li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 14px;
  color: rgba(245, 240, 232, 0.85);
  line-height: 1.4;
}
.cabinet-auth-side li span {
  font-size: 18px;
  line-height: 1;
  flex-shrink: 0;
}

/* ----- общие хедеры панелей и empty state в кабинете ----- */
.panel-head-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 24px;
  gap: 16px;
  flex-wrap: wrap;
}
.cabinet-empty {
  text-align: center;
  padding: 48px 16px;
  color: var(--stone);
}
.cabinet-empty-icon { font-size: 40px; margin-bottom: 12px; opacity: 0.5; }
.cabinet-empty h4 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  color: var(--dark);
  margin-bottom: 6px;
}
.cabinet-empty p {
  font-size: 14px;
  margin: 0 auto 18px;
  max-width: 42ch;
  line-height: 1.5;
}

/* ----- карточка подписки ----- */
.cabinet-sub-card {
  background: var(--cream-deep);
  border: none;
  margin-bottom: 24px;
}
.cabinet-sub-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 16px;
}
.cabinet-sub-head h3 { font-family: var(--font-display); font-weight: 400; font-size: 26px; }
.cabinet-sub-head p { font-size: 13px; color: var(--stone); margin: 4px 0 0; }
.cabinet-sub-price { text-align: right; }
.cabinet-sub-price .amount {
  font-family: var(--font-display);
  font-size: 36px;
  color: var(--dark);
  line-height: 1;
}
.cabinet-sub-price .period { font-size: 12px; color: var(--stone); margin-top: 4px; }
.cabinet-sub-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
@media (max-width: 540px) { .cabinet-sub-grid { grid-template-columns: 1fr; gap: 10px; } }
.cabinet-sub-grid .label {
  font-size: 11px;
  color: var(--stone);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.cabinet-sub-grid .value { font-weight: 500; }
.cabinet-sub-actions {
  display: flex;
  gap: 8px;
  margin-top: 20px;
  flex-wrap: wrap;
}
/* Подписка — годовой план визитов */
.cabinet-sub-head h3 { margin-top: 8px; }
.sub-progress { margin: 2px 0 18px; }
.sub-progress-bar {
  height: 6px;
  background: var(--border);
  border-radius: 999px;
  overflow: hidden;
}
.sub-progress-bar span {
  display: block;
  height: 100%;
  background: var(--gold);
  border-radius: 999px;
  transition: width var(--t-base);
}
.sub-progress-label {
  font-size: 12px;
  color: var(--stone);
  margin-top: 8px;
  letter-spacing: 0.02em;
}
.sub-visits {
  border-top: 1px solid var(--border);
  padding-top: 4px;
}
.sub-visit {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 0;
  border-bottom: 1px solid var(--border);
}
.sub-visit:last-child { border-bottom: none; }
.sub-visit-dot {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 600;
  border: 1.5px solid var(--border-strong);
  color: transparent;
  background: var(--white);
}
.sub-visit.done .sub-visit-dot {
  background: #6BCB77; border-color: #6BCB77; color: #fff;
}
.sub-visit.next .sub-visit-dot {
  border-color: var(--gold);
  background: var(--gold-soft);
  box-shadow: 0 0 0 3px var(--gold-soft);
}
.sub-visit-body { flex: 1; min-width: 0; }
.sub-visit-month { font-weight: 500; font-size: 14.5px; color: var(--dark); }
.sub-visit.done .sub-visit-month { color: var(--stone); }
.sub-visit-tag {
  display: inline-block;
  font-size: 10px; letter-spacing: 0.07em; text-transform: uppercase;
  color: var(--gold);
  border: 1px solid var(--gold);
  border-radius: 999px;
  padding: 1px 7px;
  margin-left: 6px;
  vertical-align: 1px;
}
.sub-visit-hint { font-size: 12px; color: var(--stone); margin-top: 2px; }
.sub-visit-right { flex-shrink: 0; }
.sub-visit-day {
  font-family: var(--font-body);
  font-size: 13px;
  padding: 7px 10px;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: var(--white);
  color: var(--dark);
  cursor: pointer;
}
.sub-visit.next .sub-visit-day { border-color: var(--gold); }
.sub-visit-done { font-size: 13px; font-weight: 500; color: #4FA85B; }
.sub-visit.has-photos { cursor: pointer; }
.sub-visit.has-photos:hover { background: rgba(28,28,26,0.02); }
.sub-visit-chev {
  display: inline-block; margin-left: 8px;
  color: var(--stone); font-size: 10px;
  transition: transform var(--t-fast);
}
.sub-visit.open .sub-visit-chev { transform: rotate(180deg); }
.sub-visit-gallery {
  padding: 6px 0 16px 34px;
  border-bottom: 1px solid var(--border);
}
.sub-visit-gallery .report-gallery-group { margin-top: 10px; }
.sub-legacy-note {
  font-size: 13px; color: var(--stone); line-height: 1.6;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 12px 14px;
  margin: 4px 0 0;
}

.cabinet-section-h {
  margin: 32px 0 12px;
  font-size: 14px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
}

/* ----- фотоотчёты ----- */
.reports-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.report-card { padding: 0; overflow: hidden; }
.report-thumb {
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.45);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 24px;
}
.report-body { padding: 14px; }
.report-body .title { font-size: 14px; font-weight: 500; margin-bottom: 2px; }
.report-body .meta { font-size: 12px; color: var(--stone); }

/* ============ CONTACT PAGE ============ */
.contact-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 980px) { .contact-grid { grid-template-columns: 1fr; } }

.contact-info {
  background: #1d1d1d;
  color: #FAF6EE;
  padding: 40px;
  border-radius: var(--r-2xl);
  position: relative;
  overflow: hidden;
}
.contact-info::before {
  content: '';
  position: absolute;
  top: -100px; right: -100px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(184,151,90,0.2) 0%, transparent 60%);
}
.contact-info h2 { color: #FAF6EE; font-size: 36px; margin-bottom: 12px; position: relative; }
.contact-info p { color: rgba(255,255,255,0.6); font-size: 14px; line-height: 1.7; margin-bottom: 32px; position: relative; }

.contact-block { display: flex; gap: 16px; padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,0.08); position: relative; }
.contact-block:last-child { border-bottom: none; }
.contact-block .icon-wrap {
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.05);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold-light);
  flex-shrink: 0;
}
.contact-block .label { font-size: 11px; color: rgba(255,255,255,0.4); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 4px; }
.contact-block .value { color: #FAF6EE; font-size: 16px; }
.contact-block a:hover { color: var(--gold-light); }

.contact-form { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-2xl); padding: 40px; }
.contact-form h3 { font-size: 28px; margin-bottom: 8px; }
.contact-form p { font-size: 14px; color: var(--stone); margin-bottom: 24px; }

/* ============ REVIEWS PAGE GRID ============ */
.reviews-page-grid {
  columns: 3 320px;
  column-gap: 16px;
}
.reviews-page-grid .review {
  break-inside: avoid;
  margin-bottom: 16px;
  display: block;
}

/* ============ SERVICES PAGE — БЛОК «ОПИСАНИЕ + ПРАЙС» ============ */
.svc-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 860px) {
  .svc-detail-grid {
    grid-template-columns: 1fr;  /* стек в одну колонку: сначала описание, потом прайс */
    gap: 24px;
  }
}

/* ============ REVIEWS PAGE — HERO ============ */
.reviews-hero-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: center;
}
.reviews-rating-card {
  text-align: center;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 32px;
}
@media (max-width: 860px) {
  .reviews-hero-grid { grid-template-columns: 1fr; gap: 24px; }
  .reviews-rating-card { padding: 24px; }
}

/* ============ PRICE TABLE ============ */
.price-table {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
}
.price-row {
  display: grid;
  grid-template-columns: 2fr 1fr auto;
  gap: 16px;
  padding: 20px 24px;
  align-items: center;
  border-bottom: 1px solid var(--border);
}
.price-row:last-child { border-bottom: none; }
.price-row:hover { background: var(--cream); }
.price-row .name { font-size: 15px; font-weight: 500; }
.price-row .desc { font-size: 12px; color: var(--stone); margin-top: 2px; }
.price-row .price-cell { font-family: var(--font-display); font-size: 22px; font-weight: 500; }
@media (max-width: 540px) {
  .price-row { grid-template-columns: 1fr; gap: 8px; }
  .price-row .price-cell { font-size: 18px; }
}

/* ============ MISC ============ */
.divider-section { padding: 0; }
.divider-section .container { padding-top: 0; padding-bottom: 0; border-top: 1px solid var(--border); }

/* ============ CONSTRUCTOR ============ */
.constructor-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr) 300px;
  gap: 24px;
  align-items: stretch;
}
@media (max-width: 1080px) {
  .constructor-layout { grid-template-columns: 240px minmax(0, 1fr); }
  .constructor-layout > aside:last-child { grid-column: 1 / -1; }
}
@media (max-width: 720px) {
  .constructor-layout { grid-template-columns: 1fr; }
}

.constructor-side { display: flex; }
.constructor-panel {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 20px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.constructor-panel .panel-head h4 {
  margin-top: 4px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  letter-spacing: -0.01em;
}

.category-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.category-item {
  text-align: left;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--dark);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--r-md);
  padding: 10px 14px;
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.category-item:hover {
  background: var(--cream-deep);
}
.category-item.is-active {
  background: #1d1d1d;
  color: #FAF6EE;
  border-color: var(--dark);
}

/* ----- decor categories (right panel) ----- */
.decor-categories {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.decor-cat-tile {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 12px 14px;
  cursor: pointer;
  text-align: left;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.decor-cat-tile:hover {
  background: var(--white);
  border-color: var(--gold);
  transform: translateY(-1px);
}
.decor-cat-ico {
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-md);
  background: var(--gold-soft);
  color: var(--gold);
}
.decor-cat-ico svg { width: 20px; height: 20px; }
.decor-cat-text {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.decor-cat-text strong {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 14px;
  color: var(--dark);
}
.decor-cat-text small {
  font-size: 11px;
  color: var(--stone);
  margin-top: 2px;
}
.decor-cat-count {
  flex: 0 0 auto;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  color: var(--stone);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  padding: 2px 8px;
  min-width: 28px;
  text-align: center;
}
.decor-cat-tile:hover .decor-cat-count {
  color: var(--dark);
  border-color: var(--border-strong);
}
.decor-hint {
  margin-top: 8px;
  font-size: 12px;
  color: var(--stone-light);
  font-style: italic;
  text-align: center;
}

/* ===== Обустройство (цветник/лавка/стол/ограда) — модалка ===== */
.equipment-form .form-row + .form-row { margin-top: 12px; }
.equipment-actions {
  display: flex;
  gap: 10px;
  margin-top: 20px;
}
@media (max-width: 540px) {
  .equipment-actions { flex-direction: column; gap: 8px; }
}

/* Бейдж-счётчик на кнопке (количество выбранных опций) */
.badge-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  margin-left: 4px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
  color: var(--dark);
  background: var(--gold);
  border-radius: 9px;
}
.btn:hover .badge-count {
  background: var(--gold-light);
}

.constructor-stage {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-width: 0;
}

.canvas-toolbar { display: flex; flex-direction: column; gap: 10px; }
.hint-btn {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--stone);
  background: transparent;
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-pill);
  padding: 8px 14px;
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.hint-btn:hover, .hint-btn.is-open { color: var(--dark); border-color: var(--dark); }
.hint-text {
  font-size: 14px;
  color: var(--stone);
  background: var(--cream);
  border-left: 3px solid var(--gold);
  padding: 12px 16px;
  border-radius: 0 var(--r-md) var(--r-md) 0;
  line-height: 1.6;
}

.canvas-container {
  position: relative;
  width: 100%;
  aspect-ratio: 700 / 500;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  isolation: isolate;
}
#monumentCanvas {
  display: block;
  width: 100%;
  height: 100%;
}
#draggableItemsContainer {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
#draggableItemsContainer > * { pointer-events: auto; }

.draggable-item, .draggable-text-item {
  position: absolute;
  cursor: grab;
  z-index: 1000;
  user-select: none;
  border-radius: 6px;
  outline: 1px dashed transparent;
  outline-offset: 4px;
  transition: outline-color var(--t-fast), box-shadow var(--t-fast);
}
.draggable-item:hover, .draggable-text-item:hover {
  outline-color: rgba(184, 151, 90, 0.45);
}
.draggable-item.is-dragging, .draggable-text-item.is-dragging {
  cursor: grabbing;
  outline-color: rgba(184, 151, 90, 0.6);
}
.draggable-item.is-selected, .draggable-text-item.is-selected {
  outline: 2px solid var(--gold);
  outline-offset: 4px;
  box-shadow: 0 0 0 6px rgba(184, 151, 90, 0.12);
}
.draggable-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
  -webkit-user-drag: none;
}
.draggable-item.item-missing {
  background: repeating-linear-gradient(45deg, var(--cream), var(--cream) 6px, var(--cream-deep) 6px, var(--cream-deep) 12px);
}
.draggable-text-item {
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
  text-align: center;
  white-space: pre-line;
  min-width: 200px;
  padding: 4px 6px;
  line-height: 1.25;
}
.draggable-text-item.text-color-dark {
  color: var(--dark);
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.65);
}
.draggable-text-item .text-content {
  pointer-events: none;
  white-space: pre-line;
}
/* В режиме редактирования включаем взаимодействие, чтобы пользователь
   мог кликать внутрь текста и ставить курсор. Outline + чуть приглушённый
   фон — чтобы было видно, что поле редактируется. */
.draggable-text-item .text-content.text-editing {
  pointer-events: auto;
  cursor: text;
  outline: 2px dashed var(--gold, #B8975A);
  outline-offset: 4px;
  background: rgba(0, 0, 0, 0.18);
  border-radius: 4px;
  min-width: 1ch;
  caret-color: var(--gold, #B8975A);
}
.draggable-text-item.text-color-dark .text-content.text-editing {
  background: rgba(255, 255, 255, 0.55);
}

.item-toolbar {
  position: absolute;
  top: -44px;
  left: 50%;
  transform: translateX(-50%);
  display: none;
  align-items: center;
  gap: 2px;
  background: #1d1d1d;
  border-radius: var(--r-pill);
  padding: 4px;
  box-shadow: var(--shadow-lg);
  animation: toolbarIn 0.18s ease-out;
  white-space: nowrap;
}
.draggable-item.is-selected .item-toolbar,
.draggable-text-item.is-selected .item-toolbar {
  display: inline-flex;
}
.draggable-item.toolbar-below .item-toolbar,
.draggable-text-item.toolbar-below .item-toolbar {
  top: auto;
  bottom: -44px;
}
@keyframes toolbarIn {
  from { opacity: 0; transform: translateX(-50%) translateY(4px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.draggable-item.toolbar-below .item-toolbar,
.draggable-text-item.toolbar-below .item-toolbar {
  animation-name: toolbarInBelow;
}
@keyframes toolbarInBelow {
  from { opacity: 0; transform: translateX(-50%) translateY(-4px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.item-tool {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 50%;
  background: transparent;
  color: #FAF6EE;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast);
}
.item-tool svg { width: 14px; height: 14px; }
.item-tool .tool-label { font-family: var(--font-display); font-size: 14px; line-height: 1; }
.item-tool .tool-label small { font-size: 10px; vertical-align: super; margin-left: 1px; }
.item-tool:hover { background: rgba(255, 255, 255, 0.12); color: #fff; }
.item-tool.tool-delete:hover { background: var(--danger); color: #fff; }
.item-tool + .item-tool { margin-left: 2px; }

.variants-area { display: flex; flex-direction: column; gap: 10px; }
.variants-label {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
}
.variants-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: 160px;
  overflow-y: auto;
  padding-right: 4px;
}
.variants-buttons::-webkit-scrollbar { width: 6px; }
.variants-buttons::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: var(--r-pill); }
.variant-btn {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  color: var(--dark);
  background: var(--cream-deep);
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  padding: 6px 12px;
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.variant-btn:hover { background: var(--cream); border-color: var(--border-strong); }
.variant-btn.is-active {
  background: var(--gold);
  color: var(--dark);
  border-color: var(--gold);
}
.variants-empty { font-size: 13px; color: var(--stone); font-style: italic; }

.canvas-controls {
  display: flex;
  gap: 12px;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.canvas-controls-left {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.btn-danger-ghost {
  background: transparent;
  color: var(--danger);
  border: 1px solid rgba(194, 91, 91, 0.35);
}
.btn-danger-ghost:hover {
  background: var(--danger);
  color: #fff;
  border-color: var(--danger);
}
.btn-danger-ghost svg { flex-shrink: 0; }

/* ============ DECOR PICKER OVERLAY ============ */
.decor-picker {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: rgba(28, 28, 26, 0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity var(--t-base);
  padding: 0;
}
.decor-picker.is-open { opacity: 1; }
.decor-picker[hidden] { display: none; }
body.picker-open { overflow: hidden; }

.decor-picker-panel {
  width: 100%;
  max-width: 1100px;
  max-height: 86vh;
  background: var(--cream);
  border-radius: var(--r-2xl) var(--r-2xl) 0 0;
  display: flex;
  flex-direction: column;
  padding: 28px 32px 32px;
  transform: translateY(100%);
  transition: transform var(--t-base);
}
@media (min-width: 760px) {
  .decor-picker { align-items: center; padding: 32px; }
  .decor-picker-panel { border-radius: var(--r-2xl); max-height: 80vh; }
}
.decor-picker.is-open .decor-picker-panel { transform: none; }

.decor-picker-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.decor-picker-head h3 {
  margin-top: 4px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(24px, 3vw, 32px);
  letter-spacing: -0.01em;
}
.decor-picker-close {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-pill);
  background: transparent;
  border: 1px solid var(--border-strong);
  color: var(--stone);
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  flex-shrink: 0;
}
.decor-picker-close:hover { background: #1d1d1d; color: #FAF6EE; border-color: var(--dark); }

.decor-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, 130px);
  grid-auto-rows: 130px;
  justify-content: center;
  gap: 12px;
  overflow-y: auto;
  padding: 4px;
  flex: 1 1 auto;
  min-height: 200px;
}
.decor-picker-grid::-webkit-scrollbar { width: 8px; }
.decor-picker-grid::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: var(--r-pill); }

/* Кресты — вертикальные ячейки, контент идёт по высоте */
.decor-picker-grid.picker-grid-tall {
  grid-template-columns: repeat(auto-fill, 110px);
  grid-auto-rows: 150px;
}

/* Шрифт — широкие ячейки для читаемого превью */
.decor-picker-grid.picker-grid-font {
  grid-template-columns: repeat(auto-fill, 200px);
  grid-auto-rows: 120px;
}

.picker-tile {
  position: relative;
  width: 100%;
  height: 100%;
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 4px;
  cursor: pointer;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
.picker-tile:hover {
  background: var(--white);
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.picker-tile img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.picker-tile.picker-tile-missing { background: repeating-linear-gradient(45deg, var(--cream), var(--cream) 6px, var(--cream-deep) 6px, var(--cream-deep) 12px); }
.picker-tile-empty { font-size: 14px; color: var(--stone-light); }

.picker-tile.picker-upload {
  background: var(--gold-soft);
  border: 1px dashed var(--gold);
  flex-direction: column;
  gap: 6px;
  color: var(--dark);
  text-align: center;
}
.picker-tile.picker-upload:hover { background: var(--gold); color: var(--dark); }
.picker-upload-ico {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--white);
  color: var(--gold);
}
.picker-upload-ico svg { width: 20px; height: 20px; }
.picker-upload-label { font-family: var(--font-body); font-size: 12px; font-weight: 500; }
.picker-upload-hint { font-size: 10px; color: var(--stone); letter-spacing: 0.06em; text-transform: uppercase; }

.picker-tile.picker-font {
  flex-direction: column;
  gap: 2px;
  text-align: center;
  background: var(--white);
  padding: 12px;
}
.picker-font-sample {
  font-size: 18px;
  color: var(--dark);
  line-height: 1.1;
}
.picker-font-dates {
  font-size: 13px;
  color: var(--stone);
  line-height: 1.1;
}
.picker-font-name {
  margin-top: auto;
  font-family: var(--font-body);
  font-size: 10px;
  color: var(--stone);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.picker-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 40px;
  color: var(--stone);
  font-style: italic;
}

/* flash на тайле после добавления — короткий золотой пульс */
.picker-tile.flash-added {
  animation: tilePulse 0.5s ease-out;
}
@keyframes tilePulse {
  0%   { box-shadow: 0 0 0 0 rgba(184, 151, 90, 0.55); border-color: var(--gold); }
  60%  { box-shadow: 0 0 0 12px rgba(184, 151, 90, 0); border-color: var(--gold); }
  100% { box-shadow: 0 0 0 0 rgba(184, 151, 90, 0); }
}

/* ===== Эпитафии (готовые фразы) ===== */
.decor-picker-grid.picker-grid-wide {
  grid-template-columns: repeat(auto-fill, 280px);
  grid-auto-rows: 90px;
}
.picker-tile.picker-epitaph {
  background: var(--white);
  padding: 12px 16px;
  text-align: center;
  font-size: 18px;
  color: var(--dark);
  line-height: 1.25;
}
.picker-tile.picker-epitaph:hover { background: var(--cream); }

/* ===== Toolbar пикера (например, выбор шрифта для эпитафий) ===== */
.decor-picker-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 4px 14px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.decor-picker-toolbar[hidden] { display: none; }
.picker-toolbar-label {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--stone);
}
.picker-font-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.picker-font-tab {
  width: 52px;
  height: 40px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--white);
  font-size: 18px;
  color: var(--dark);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color var(--t-fast), background var(--t-fast), color var(--t-fast);
}
.picker-font-tab:hover { border-color: var(--gold); }
.picker-font-tab.is-active {
  background: #1d1d1d;
  color: #FAF6EE;
  border-color: var(--dark);
}

/* ===== snap-направляющие при перетаскивании ===== */
.snap-guide {
  position: absolute;
  background: var(--gold);
  pointer-events: none;
  z-index: 1500;
  box-shadow: 0 0 6px rgba(184, 151, 90, 0.7);
}
.snap-guide.snap-v { top: 0; bottom: 0; width: 1px; }
.snap-guide.snap-h { left: 0; right: 0; height: 1px; }

/* ===== плашка примерной цены ===== */
.price-tag {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 14px 18px;
  background: var(--cream-deep);
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  border-radius: var(--r-md);
}
.price-tag-label {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--stone);
}
.price-tag-amount {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 500;
  color: var(--dark);
  line-height: 1.1;
  margin-top: 2px;
}
.price-tag-hint {
  font-size: 11px;
  color: var(--stone);
  margin-top: 4px;
  line-height: 1.4;
}

/* ===== restore-баннер (восстановление черновика) ===== */
.restore-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 16px;
  background: var(--gold-soft);
  border: 1px solid rgba(184, 151, 90, 0.35);
  border-radius: var(--r-md);
  flex-wrap: wrap;
}
.restore-banner-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 13px;
}
.restore-banner-text strong { font-weight: 500; color: var(--dark); }
.restore-banner-text span { color: var(--stone); font-size: 12px; }
.restore-banner-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.constructor-note {
  margin-top: 24px;
  padding: 20px 24px;
  background: var(--sage-light);
  border-radius: var(--r-lg);
  border-left: 3px solid var(--sage);
}
.constructor-note p {
  font-size: 14px;
  color: var(--sage-dark);
  line-height: 1.6;
  margin: 0;
}

/* «Заказ от: ...» в модалках, когда пользователь залогинен */
.modal-from {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 14px;
  flex-wrap: wrap;
}
.modal-from-info { display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.modal-from-label {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--stone);
}
.modal-from strong { font-weight: 500; color: var(--dark); }
.modal-from-sep { color: var(--stone-light); }
.modal-from-phone { color: var(--dark); }
.modal-from-switch {
  font-size: 12px;
  color: var(--stone);
  text-decoration: underline;
  text-decoration-color: var(--border-strong);
  text-underline-offset: 3px;
  white-space: nowrap;
}
.modal-from-switch:hover { color: var(--dark); }

/* «золотистый» CTA-баннер в модалке (предложение перейти в конструктор и т.п.) */
.modal-cta-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  margin-bottom: 18px;
  background: var(--gold-soft);
  border: 1px solid rgba(184, 151, 90, 0.35);
  border-radius: var(--r-md);
  color: var(--dark);
  text-decoration: none;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.modal-cta-banner:hover {
  background: var(--gold);
  border-color: var(--gold);
}
.modal-cta-banner-ico {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-md);
  background: var(--white);
  color: var(--gold);
}
.modal-cta-banner:hover .modal-cta-banner-ico { color: var(--dark); }
.modal-cta-banner-text {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 13px;
  line-height: 1.4;
  color: var(--stone);
}
.modal-cta-banner-text strong {
  font-weight: 500;
  color: var(--dark);
  font-size: 14px;
}
.modal-cta-banner:hover .modal-cta-banner-text { color: var(--dark-soft); }
.modal-cta-banner-arrow {
  font-size: 18px;
  color: var(--gold);
  flex-shrink: 0;
  transition: transform var(--t-fast);
}
.modal-cta-banner:hover .modal-cta-banner-arrow {
  color: var(--dark);
  transform: translateX(2px);
}

/* предупреждение в модалках (напр. потеря оплаченного периода при смене тарифа) */
.modal-warning {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 16px;
  margin-bottom: 18px;
  background: rgba(184, 151, 90, 0.10);
  border: 1px solid rgba(184, 151, 90, 0.35);
  border-radius: var(--r-md);
  font-size: 13px;
  line-height: 1.5;
  color: var(--dark);
}
.modal-warning-ico {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--gold);
  margin-top: 2px;
}
.modal-warning strong { font-weight: 500; display: block; margin-bottom: 4px; }

/* плашка контекста (например, участок при смене тарифа) */
.modal-context-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--gold-soft);
  border: 1px solid rgba(184, 151, 90, 0.25);
  border-radius: var(--r-md);
  margin-bottom: 16px;
  font-size: 14px;
}
.modal-context-label {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--stone);
}
.modal-context-row strong { font-weight: 500; color: var(--dark); }

/* модалка отправки заказа из конструктора */
.constructor-order-summary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 14px 16px;
  margin-bottom: 20px;
}
.constructor-order-summary > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.constructor-order-summary span {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--stone);
}
.constructor-order-summary strong {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 15px;
  color: var(--dark);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.constructor-order-summary .muted { color: var(--stone-light); font-weight: 400; }
@media (max-width: 540px) {
  .constructor-order-summary { grid-template-columns: 1fr; gap: 6px; padding: 12px 14px; }
  .constructor-order-summary strong { font-size: 14px; }
}

/* список обустройства внутри модалки отправки */
.constructor-order-equipment {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 12px 16px;
  margin-bottom: 14px;
}
.constructor-order-equipment-label {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--stone);
  display: block;
  margin-bottom: 8px;
}
.constructor-order-equipment ul { display: flex; flex-direction: column; gap: 6px; }
.constructor-order-equipment li {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: 10px;
  align-items: baseline;
  font-size: 13px;
}
@media (max-width: 540px) {
  .constructor-order-equipment li { grid-template-columns: 1fr auto; }
  .constructor-order-equipment li .eq-variant { grid-column: 1 / -1; color: var(--stone); font-size: 12px; }
}
.constructor-order-equipment .eq-name { color: var(--dark); font-weight: 500; }
.constructor-order-equipment .eq-variant { color: var(--stone); }
.constructor-order-equipment .eq-price {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--dark);
  white-space: nowrap;
}

/* ориентир. итог */
.constructor-order-total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 14px 16px;
  margin-bottom: 18px;
  background: var(--gold-soft);
  border: 1px solid rgba(184, 151, 90, 0.35);
  border-radius: var(--r-md);
}
.constructor-order-total span {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--stone);
}
.constructor-order-total strong {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--dark);
  font-weight: 500;
}

/* ============ ПАМЯТНЫЕ ДАТЫ ============ */
.dates-widget {
  background: linear-gradient(135deg, #F4ECDC 0%, #E8DCC2 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px 22px;
  margin-bottom: 24px;
}
.dates-widget-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.dates-widget-head h3 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  margin-top: 4px;
}
.dates-widget-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dates-widget-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  background: rgba(255,255,255,0.55);
  border-radius: var(--r-md);
  padding: 12px 14px;
}
.dates-widget-ico { font-size: 22px; }
.dates-widget-meta .title { font-size: 14px; font-weight: 500; }
.dates-widget-meta .sub { font-size: 12px; color: var(--stone); margin-top: 2px; }
.dates-widget-cta { display: flex; align-items: center; gap: 10px; }
.dates-widget-cta .badge {
  background: #1d1d1d;
  color: #FAF6EE;
  font-size: 11px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  letter-spacing: 0.04em;
}
@media (max-width: 540px) {
  .dates-widget-item { grid-template-columns: auto 1fr; }
  .dates-widget-cta { grid-column: 1 / -1; justify-content: space-between; margin-top: 4px; }
}

.dates-list { display: flex; flex-direction: column; gap: 10px; }
.date-item {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
}
.date-ico {
  width: 42px; height: 42px;
  background: var(--cream);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.date-title { font-size: 15px; font-weight: 500; margin-bottom: 2px; }
.date-meta { font-size: 12px; color: var(--stone); }
.date-when .badge {
  background: var(--sage);
  color: #fff;
  font-size: 11px;
  padding: 5px 11px;
  border-radius: var(--r-pill);
  letter-spacing: 0.04em;
}
.date-when .badge.badge-warn { background: var(--gold); }
.date-actions { display: flex; gap: 4px; }
.date-actions .btn { padding: 6px 10px; min-width: 0; }
@media (max-width: 640px) {
  .date-item { grid-template-columns: auto 1fr; }
  .date-when, .date-actions { grid-column: 1 / -1; }
  .date-actions { justify-content: flex-end; }
}

/* ============ СТРАНИЦЫ ПАМЯТИ — КАБИНЕТ ============ */
.memorials-list { display: flex; flex-direction: column; gap: 12px; }
.memorial-item {
  display: grid;
  grid-template-columns: 88px 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 16px 18px;
}
.memorial-photo {
  width: 88px; height: 88px;
  border-radius: var(--r-md);
  background: var(--cream);
  display: flex; align-items: center; justify-content: center;
  color: var(--stone-light);
  flex-shrink: 0;
}
.memorial-title { font-family: var(--font-display); font-size: 22px; font-weight: 400; }
.memorial-meta { font-size: 12px; color: var(--stone); margin: 4px 0 6px; }
.memorial-link { font-size: 12px; word-break: break-all; }
.memorial-link a { color: var(--gold); }
.memorial-actions { display: flex; flex-direction: column; gap: 6px; }
.memorial-actions .btn { white-space: nowrap; }
@media (max-width: 720px) {
  .memorial-item { grid-template-columns: 64px 1fr; }
  .memorial-photo { width: 64px; height: 64px; }
  .memorial-actions { grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; }
}

/* ============ QR МОДАЛКА ============ */
.qr-modal { text-align: center; padding-top: 12px; }
.qr-image {
  width: 260px;
  height: 260px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 12px;
  background: var(--white);
  margin: 0 auto 16px;
  display: block;
}
.qr-url { font-size: 12px; margin-bottom: 12px; word-break: break-all; }
.qr-url a { color: var(--gold); }
.qr-hint { font-size: 13px; color: var(--stone); margin-bottom: 18px; line-height: 1.55; }

/* ============ ПУБЛИЧНАЯ СТРАНИЦА ПАМЯТИ ============ */
.memorial-page {
  background: linear-gradient(180deg, #F8F2E6 0%, var(--cream) 240px);
  min-height: 70vh;
  padding: 60px 0 80px;
}
.memorial-card {
  background: var(--white);
  border-radius: var(--r-xl);
  padding: 48px 56px;
  max-width: 720px;
  margin: 0 auto;
  border: 1px solid var(--border);
  box-shadow: 0 10px 40px rgba(58,58,58,0.06);
}
@media (max-width: 640px) { .memorial-card { padding: 28px 22px; } }
.memorial-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 32px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--border);
}
.memorial-hero-photo {
  width: 160px; height: 160px;
  border-radius: 50%;
  background: var(--cream);
  background-size: cover;
  background-position: center;
  margin-bottom: 20px;
  display: flex; align-items: center; justify-content: center;
  color: var(--stone-light);
  box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.memorial-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 400;
  margin-bottom: 8px;
}
.memorial-years {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  color: var(--stone);
  letter-spacing: 0.02em;
}
.memorial-bio {
  font-size: 16px;
  line-height: 1.7;
  color: var(--dark);
  white-space: pre-line;
  margin-bottom: 32px;
}
.memorial-section-h {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  margin: 24px 0 16px;
}
.condolence-form {
  background: var(--cream);
  border-radius: var(--r-md);
  padding: 18px;
  margin-bottom: 20px;
}
.condolence-list { display: flex; flex-direction: column; gap: 12px; }
.condolence {
  background: var(--cream);
  border-radius: var(--r-md);
  padding: 14px 16px;
}
.condolence-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 6px;
}
.condolence-name { font-weight: 500; font-size: 14px; }
.condolence-date { font-size: 11px; color: var(--stone); }
.condolence-text { font-size: 14px; line-height: 1.55; color: var(--dark); }
.memorial-not-found {
  text-align: center;
  padding: 80px 24px;
  max-width: 480px;
  margin: 0 auto;
}
.memorial-not-found h2 { font-family: var(--font-display); font-size: 32px; font-weight: 400; margin-bottom: 12px; }
.memorial-not-found p { color: var(--stone); margin-bottom: 24px; }

/* ============ БЛОГ ============ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  margin-top: 32px;
}
.blog-card {
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
}
.blog-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,0.06); }
.blog-card-cover {
  aspect-ratio: 16 / 9;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.5);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 26px;
}
.blog-card-body { padding: 20px 22px 22px; display: flex; flex-direction: column; flex: 1; }
.blog-card-tag {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--gold);
  margin-bottom: 8px;
}
.blog-card h3 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  margin-bottom: 10px;
  color: var(--dark);
}
.blog-card p { font-size: 14px; color: var(--stone); line-height: 1.5; margin-bottom: 14px; flex: 1; }
.blog-card-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--stone);
}
.blog-card-foot a { color: var(--dark); font-weight: 500; }

/* статья */
.article-page { background: var(--cream); padding: 60px 0 80px; }
.article-wrap {
  max-width: 760px;
  margin: 0 auto;
  background: var(--white);
  border-radius: var(--r-xl);
  border: 1px solid var(--border);
  padding: 48px 56px;
}
@media (max-width: 640px) { .article-wrap { padding: 28px 22px; } }
.article-meta { font-size: 12px; color: var(--stone); margin-bottom: 18px; letter-spacing: 0.08em; text-transform: uppercase; }
.article-wrap h1 {
  font-family: var(--font-display);
  font-size: clamp(30px, 4vw, 44px);
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 24px;
}
.article-wrap h2 {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 400;
  margin: 32px 0 14px;
}
.article-wrap h3 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  margin: 24px 0 10px;
}
.article-wrap p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--dark);
  margin-bottom: 16px;
}
.article-wrap ul, .article-wrap ol {
  font-size: 16px;
  line-height: 1.75;
  color: var(--dark);
  margin: 0 0 16px 22px;
}
.article-wrap li { margin-bottom: 6px; }
.article-wrap blockquote {
  border-left: 3px solid var(--gold);
  padding: 8px 0 8px 20px;
  margin: 22px 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 19px;
  color: var(--dark);
  line-height: 1.5;
}
.article-cta {
  background: linear-gradient(135deg, #F4ECDC 0%, #E8DCC2 100%);
  border-radius: var(--r-md);
  padding: 22px 24px;
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.article-cta strong { font-family: var(--font-display); font-size: 22px; font-weight: 400; }
.article-back { display: inline-block; margin-bottom: 18px; font-size: 13px; color: var(--stone); }
.article-back:hover { color: var(--dark); }

/* ============ MANAGER PANEL ============ */

/* Вкладки */
.mgr-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 28px;
}
.mgr-tab {
  background: none;
  border: none;
  padding: 12px 18px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--stone);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color .15s, border-color .15s;
}
.mgr-tab:hover { color: var(--dark); }
.mgr-tab.active { color: var(--dark); border-bottom-color: var(--gold); font-weight: 500; }

/* Карточка выдачи роли */
.mgr-grant-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 24px;
  max-width: 520px;
}
.radio-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  cursor: pointer;
  font-size: 14px;
  user-select: none;
  transition: background .15s, border-color .15s;
}
.radio-pill:has(input:checked) {
  background: var(--cream);
  border-color: var(--dark);
}
.radio-pill input { margin: 0; }

/* Список команды */
.mgr-team-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.team-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 14px 18px;
  flex-wrap: wrap;
}
.team-row-info { min-width: 0; flex: 1 1 260px; }
.team-row-name {
  font-family: var(--font-display);
  font-size: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.team-row-meta {
  font-size: 13px;
  color: var(--stone);
  margin-top: 4px;
}
.team-row-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.team-role-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: var(--r-pill);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.team-role-badge.admin   { background: #1d1d1d; color: #FAF6EE; }
.team-role-badge.manager { background: var(--cream); color: var(--dark); border: 1px solid var(--border); }

/* Audit-лог */
.mgr-audit-log {
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px 20px;
}
.audit-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.audit-row:last-child { border-bottom: none; }
.audit-when {
  font-size: 12px;
  color: var(--stone);
  min-width: 150px;
  font-variant-numeric: tabular-nums;
}
.audit-text {
  flex: 1 1 280px;
  font-size: 14px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.mgr-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.mgr-stat {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px;
  text-align: center;
  cursor: pointer;
  transition: border-color .15s, background .15s, transform .12s, box-shadow .15s;
  font-family: inherit;
}
.mgr-stat:hover {
  border-color: var(--dark);
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
  transform: translateY(-1px);
}
.mgr-stat.mgr-stat-active {
  border-color: var(--gold);
  background: rgba(184,151,90,0.08);
  box-shadow: inset 0 0 0 1px var(--gold);
}
.mgr-stat.mgr-stat-active .label {
  color: var(--dark);
  font-weight: 500;
}
.mgr-stat .num {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 500;
  color: var(--dark);
  line-height: 1.1;
}
.mgr-stat .label {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--stone);
  margin-top: 6px;
}
.mgr-filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 24px;
  align-items: center;
}
.mgr-filters .form-input { flex: 1 1 180px; min-width: 0; }
.mgr-filters input[type="search"] { flex: 2 1 280px; }
.mgr-orders { display: flex; flex-direction: column; gap: 14px; }

/* Менеджер — подписки и план визитов */
.mgr-subs { display: flex; flex-direction: column; gap: 16px; }
.mgr-sub-card { background: var(--white); border: 1px solid var(--border); }
.mgr-sub-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  flex-wrap: wrap; gap: 12px; margin-bottom: 14px;
}
.mgr-sub-head h3 { font-family: var(--font-display); font-weight: 400; font-size: 21px; }
.mgr-sub-head p { font-size: 13px; color: var(--stone); margin-top: 3px; }
.mgr-sub-meta { display: flex; align-items: center; gap: 12px; }
.mgr-sub-progress { font-size: 12px; color: var(--stone); letter-spacing: 0.02em; }
.mgr-sub-visits { border-top: 1px solid var(--border); }
.mgr-sub-visit {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.mgr-sub-visit:last-child { border-bottom: none; }
.mgr-sub-visit-m { font-weight: 500; font-size: 14px; flex: 0 0 130px; }
.mgr-sub-visit-s { font-size: 13px; color: var(--stone); flex: 1 1 200px; }
.mgr-sub-visit.done .mgr-sub-visit-s { color: #4FA85B; font-weight: 500; }
.mgr-sub-visit-act { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.mgr-visit-date {
  font-size: 13px; padding: 6px 8px; width: auto;
  border: 1px solid var(--border-strong); border-radius: 8px;
}
.mgr-sub-legacy { font-size: 13px; color: var(--stone); }
.mgr-map-frame {
  width: 100%; height: 76vh; min-height: 460px;
  border: 1px solid var(--border); border-radius: 12px;
  display: block; background: var(--cream);
}

/* Кабинет — карточка участка с данными усопшего */
.form-opt { color: var(--stone); font-weight: 400; }
.plot-card { margin-bottom: 14px; }
.plot-card-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 12px;
}
.plot-card-name {
  font-family: var(--font-display); font-size: 20px;
  font-weight: 400; color: var(--dark); line-height: 1.2;
}
.plot-card-sub { font-size: 12px; color: var(--stone); margin-top: 3px; }
.plot-card-info {
  margin-top: 12px; padding-top: 12px;
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 6px;
}
.plot-card-row { font-size: 13.5px; color: var(--dark); line-height: 1.5; }
.plot-card-actions { display: flex; gap: 8px; margin-top: 14px; }

/* Менеджер — справочник кладбищ */
.mgr-cem-add { display: flex; gap: 10px; margin-bottom: 20px; flex-wrap: wrap; }
.mgr-cem-add .form-input { flex: 1 1 280px; }
.mgr-cem-list { display: flex; flex-direction: column; gap: 8px; max-width: 560px; }
.mgr-cem-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-md); font-size: 14px;
}

/* Менеджер — участки клиентов */
.mgr-plots { display: flex; flex-direction: column; gap: 14px; }
.mgr-plot-card { background: var(--white); border: 1px solid var(--border); }
.mgr-plot-card.is-incomplete { border-color: var(--gold); }
.mgr-plot-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px; margin-bottom: 12px;
}
.mgr-plot-head h3 { font-family: var(--font-display); font-weight: 400; font-size: 20px; }
.mgr-plot-head p { font-size: 13px; color: var(--stone); margin-top: 3px; }
.mgr-plot-info {
  border-top: 1px solid var(--border); padding-top: 12px;
  display: flex; flex-direction: column; gap: 6px;
}
.mgr-plot-row { font-size: 13.5px; color: var(--dark); line-height: 1.5; }
.mgr-plot-warn { color: var(--gold); font-weight: 500; }
.mgr-vphotos {
  display: flex; flex-wrap: wrap; gap: 24px;
  padding: 12px 0 14px;
  border-bottom: 1px solid var(--border);
}
.mgr-vphoto-group { flex: 1 1 240px; }
.mgr-vphoto-label {
  display: block; margin-bottom: 8px;
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--stone);
}
.mgr-vphoto-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.mgr-vphoto {
  position: relative; width: 76px; height: 76px;
  border-radius: 8px; overflow: hidden;
  background: var(--cream-deep); flex-shrink: 0;
}
.mgr-vphoto img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mgr-vphoto-rm {
  position: absolute; top: 3px; right: 3px;
  width: 20px; height: 20px; border-radius: 50%;
  background: rgba(0,0,0,0.62); color: #fff;
  font-size: 14px; line-height: 1;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.mgr-vphoto-add {
  width: 76px; height: 76px; border-radius: 8px;
  border: 1.5px dashed var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; color: var(--stone); cursor: pointer;
  text-align: center; flex-shrink: 0; padding: 4px;
}
.mgr-vphoto-add:hover { border-color: var(--gold); color: var(--gold); }

.mgr-order-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 20px;
}
.mgr-order-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.mgr-order-title { font-size: 16px; font-weight: 500; margin-bottom: 4px; }
.mgr-order-meta { font-size: 13px; color: var(--stone); }
.mgr-order-created { font-size: 11px; color: var(--stone-light); margin-top: 4px; }
.mgr-order-price {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 500;
  color: var(--dark);
  white-space: nowrap;
}
.mgr-client {
  background: var(--cream);
  border-radius: var(--r-md);
  padding: 10px 14px;
  margin-bottom: 12px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 6px 16px;
  font-size: 13px;
}
.mgr-client-label { color: var(--stone); }
.mgr-controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 8px;
}
.mgr-controls label {
  display: block;
  font-size: 12px;
  color: var(--stone);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.mgr-controls label .form-input { margin-top: 4px; }
.mgr-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}
@media (max-width: 640px) {
  .mgr-controls { grid-template-columns: 1fr; }
  .mgr-order-head { flex-direction: column; }
  .mgr-order-price { font-size: 18px; }
}

/* ============ CABINET LOADING ============ */
.cabinet-loading {
  text-align: center;
  padding: 80px 20px;
  color: var(--stone);
}
.cabinet-loading p { font-size: 14px; margin-top: 16px; }
.cabinet-loading-spinner {
  width: 40px;
  height: 40px;
  margin: 0 auto;
  border: 3px solid var(--border);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: cabinet-spin 0.8s linear infinite;
}
@keyframes cabinet-spin {
  to { transform: rotate(360deg); }
}

/* ============================================================
   MOBILE POLISH (≤540px) — улучшения адаптива
   ------------------------------------------------------------
   1) Инпуты ≥16px чтобы iOS Safari не зумил при фокусе
   2) Body text 13px → 14-15px для читаемости
   3) Floating .call-bar учитывает home-indicator (safe-area)
   4) Tap-targets минимум 44px
   ============================================================ */
@media (max-width: 540px) {
  /* iOS zoom-fix: все интерактивные поля ≥16px */
  .form-input,
  .form-select,
  .form-textarea,
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="password"],
  input[type="search"],
  input[type="number"],
  textarea,
  select {
    font-size: 16px;
  }

  /* Чуть крупнее body text для читаемости с руки */
  p,
  .lead,
  .form-note,
  .checkbox,
  .order-manager-info,
  .cabinet-sub-head p,
  .map-sidebar-head p {
    font-size: 15px;
  }
  .step p,
  .tier .tier-desc,
  .tier li,
  .review-badge,
  .about-text .stat .label {
    font-size: 14px;
  }

  /* Floating call-bar: учесть safe-area iPhone и не цепляться о футер */
  .call-bar {
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
  }

  /* Tap-targets: btn-sm иногда меньше 44px высотой */
  .btn-sm {
    min-height: 44px;
    padding: 12px 18px;
  }

  /* Менеджерская: фильтры в столбик, не теряются */
  .mgr-filters {
    flex-direction: column;
    align-items: stretch;
  }
  .mgr-filters .form-input { flex: 1 1 auto; }

  /* Команда: ряд в столбик при узком экране */
  .team-row {
    flex-direction: column;
    align-items: flex-start;
  }
  .team-row-actions {
    width: 100%;
    justify-content: flex-end;
  }

  /* Audit log: время и текст в столбик */
  .audit-row { flex-direction: column; gap: 4px; }
  .audit-when { min-width: 0; }

  /* Радио-пилюли роли: на новой строке если узко */
  .radio-pill { font-size: 15px; padding: 10px 16px; }
}

/* ============================================
   Менеджерская: Памятные даты (удержание)
   ============================================ */
.mgr-dates {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mgr-date-card {
  display: grid;
  grid-template-columns: 140px 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 18px 20px;
  background: var(--cream, #FAF6EE);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
  transition: border-color .2s ease, transform .2s ease;
}
.mgr-date-card:hover { border-color: var(--gold, #B8975A); }

.mgr-date-card.mgr-date-urgent {
  border-left: 4px solid var(--gold, #B8975A);
  background: linear-gradient(90deg, rgba(184,151,90,0.06), transparent 30%);
}

.mgr-date-when {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  min-width: 0;
}
.mgr-date-ico { font-size: 24px; line-height: 1; }
.mgr-date-days {
  font-family: var(--font-display, serif);
  font-size: 17px;
  color: var(--dark, #1d1d1d);
  font-weight: 500;
}
.mgr-date-date {
  font-size: 12px;
  color: var(--stone, #777);
  text-transform: lowercase;
}

.mgr-date-info { min-width: 0; }
.mgr-date-title {
  font-family: var(--font-display, serif);
  font-size: 18px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 4px;
}
.mgr-date-type {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 6px;
  background: rgba(0,0,0,0.05);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--stone, #777);
  font-family: var(--font-body, sans-serif);
  vertical-align: middle;
}
.mgr-date-plot {
  font-size: 13px;
  color: var(--stone, #777);
  margin-bottom: 4px;
}
.mgr-date-client {
  font-size: 14px;
  color: var(--dark, #1d1d1d);
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.mgr-date-client .sep { color: var(--stone-light, #aaa); }
.mgr-date-client a { color: var(--gold, #B8975A); text-decoration: none; }
.mgr-date-client a:hover { text-decoration: underline; }

.mgr-date-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: stretch;
  min-width: 160px;
}

@media (max-width: 720px) {
  .mgr-date-card {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 14px 16px;
  }
  .mgr-date-when {
    flex-direction: row;
    justify-content: flex-start;
    text-align: left;
    gap: 10px;
  }
  .mgr-date-actions {
    flex-direction: row;
    flex-wrap: wrap;
    min-width: 0;
  }
}

/* ============================================
   Менеджерская: Календарь
   ============================================ */
.mgr-cal-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 20px;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.08));
}
.mgr-cal-nav {
  display: flex;
  gap: 8px;
  align-items: center;
}
.mgr-cal-title {
  font-family: var(--font-display, serif);
  font-size: 22px;
  color: var(--dark, #1d1d1d);
  min-width: 200px;
  text-align: center;
}
.mgr-cal-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  align-items: center;
  font-size: 12px;
}
.mgr-cal-chip {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  padding: 2px 8px;
  border-radius: 6px;
  background: rgba(0,0,0,0.04);
  color: var(--stone, #777);
}
.mgr-cal-toggle {
  cursor: pointer;
  display: inline-flex;
  gap: 4px;
  align-items: center;
  font-size: 14px;
  color: var(--stone, #777);
}
.mgr-cal-toggle input { margin: 0; }

.mgr-cal-grid {
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
  overflow: hidden;
  background: var(--white);
}
.mgr-cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: var(--cream, #FAF6EE);
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.08));
}
.mgr-cal-weekday {
  padding: 10px 0;
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--stone, #777);
  font-weight: 500;
}
.mgr-cal-cells {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.mgr-cal-cell {
  min-height: 110px;
  padding: 6px 8px;
  border-right: 1px solid var(--border, rgba(0,0,0,0.06));
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.06));
  cursor: pointer;
  background: var(--white);
  transition: background .15s ease;
  display: flex;
  flex-direction: column;
  gap: 3px;
  overflow: hidden;
}
.mgr-cal-cell:nth-child(7n) { border-right: 0; }
.mgr-cal-cell:hover:not(.empty) { background: var(--cream, #FAF6EE); }
.mgr-cal-cell.empty { cursor: default; background: rgba(0,0,0,0.015); }
.mgr-cal-cell.today {
  background: linear-gradient(180deg, rgba(184,151,90,0.10), rgba(184,151,90,0.04));
}
.mgr-cal-cell.today .mgr-cal-daynum {
  color: var(--gold, #B8975A);
  font-weight: 600;
}
.mgr-cal-cell.selected {
  outline: 2px solid var(--gold, #B8975A);
  outline-offset: -2px;
}
.mgr-cal-daynum {
  font-family: var(--font-display, serif);
  font-size: 14px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 2px;
}
.mgr-cal-event {
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 11px;
  line-height: 1.3;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mgr-cal-event.type-memorial { background: #8C6B2E; }
.mgr-cal-event.type-visit    { background: #3A6B40; }
.mgr-cal-event.type-billing  { background: #5A5A7A; }
.mgr-cal-event.type-order    { background: #B8975A; }
.mgr-cal-more {
  font-size: 11px;
  color: var(--stone, #777);
  padding: 0 6px;
  font-style: italic;
}

/* Карточка выбранного дня */
.mgr-cal-day {
  margin-top: 20px;
  padding: 18px 20px;
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
  background: var(--cream, #FAF6EE);
}
.mgr-cal-day-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}
.mgr-cal-day-head h3 {
  font-family: var(--font-display, serif);
  font-size: 20px;
  margin: 0;
}
.mgr-cal-day-head [data-mgr-cal-close-day] {
  font-size: 22px;
  line-height: 1;
  padding: 4px 12px;
}
.mgr-cal-day-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mgr-cal-day-item {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 12px 16px;
  background: var(--white);
  border-radius: 10px;
  border-left: 4px solid #ccc;
}
.mgr-cal-day-item.type-memorial { border-left-color: #8C6B2E; }
.mgr-cal-day-item.type-visit    { border-left-color: #3A6B40; }
.mgr-cal-day-item.type-billing  { border-left-color: #5A5A7A; }
.mgr-cal-day-item.type-order    { border-left-color: #B8975A; }
.mgr-cal-day-ico {
  font-size: 22px;
  text-align: center;
}
.mgr-cal-day-title {
  font-family: var(--font-display, serif);
  font-size: 16px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 2px;
}
.mgr-cal-day-sub {
  font-size: 13px;
  color: var(--stone, #777);
}

@media (max-width: 720px) {
  .mgr-cal-controls { flex-direction: column; align-items: stretch; gap: 12px; }
  .mgr-cal-nav { justify-content: center; }
  .mgr-cal-title { min-width: 0; flex: 1; }
  .mgr-cal-cell { min-height: 70px; padding: 4px 4px; }
  .mgr-cal-daynum { font-size: 12px; }
  .mgr-cal-event {
    font-size: 0;
    padding: 0;
    height: 8px;
    border-radius: 2px;
    text-overflow: clip;
  }
  .mgr-cal-more { font-size: 10px; padding: 0 2px; }
  .mgr-cal-day-item { grid-template-columns: 32px 1fr; }
  .mgr-cal-day-actions { grid-column: 1 / -1; }
}

/* ============================================
   Договоры — кабинет
   ============================================ */
.contracts-list { display: flex; flex-direction: column; gap: 10px; }
.contract-item {
  display: grid;
  grid-template-columns: 40px 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 14px 18px;
}
.contract-ico { font-size: 22px; text-align: center; }
.contract-title {
  font-family: var(--font-display, serif);
  font-size: 17px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 2px;
}
.contract-meta { font-size: 13px; color: var(--stone, #777); }
.contract-client {
  font-size: 13px;
  color: var(--dark, #1d1d1d);
  margin-top: 4px;
  font-weight: 500;
}
.contract-actions { display: flex; gap: 6px; }

@media (max-width: 640px) {
  .contract-item {
    grid-template-columns: 32px 1fr;
    gap: 10px;
  }
  .contract-item .status-badge,
  .contract-actions { grid-column: 1 / -1; }
  .contract-actions { justify-content: flex-end; }
}

/* ============================================
   Договоры — менеджерская
   ============================================ */
.mgr-contracts { display: flex; flex-direction: column; gap: 12px; }
.mgr-contract-card {
  padding: 18px 20px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
}
.mgr-contract-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 14px;
}
.mgr-contract-title {
  font-family: var(--font-display, serif);
  font-size: 18px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 4px;
}
.mgr-contract-meta { font-size: 13px; color: var(--stone, #777); line-height: 1.55; }
.mgr-contract-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-end;
}
.mgr-contract-controls label {
  display: flex;
  flex-direction: column;
  font-size: 12px;
  color: var(--stone, #777);
  gap: 4px;
}
.mgr-contract-upload {
  display: inline-flex;
  cursor: pointer;
}

@media (max-width: 640px) {
  .mgr-contract-head { flex-direction: column; gap: 8px; }
  .mgr-contract-controls { flex-direction: column; align-items: stretch; }
}

/* ============================================
   Сезонный калькулятор подписки
   ============================================ */
.season-builder { margin-bottom: 20px; }

.season-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 16px;
}
.season-presets-label {
  font-size: 13px;
  color: var(--stone, #777);
}
.season-preset {
  padding: 7px 14px;
  border: 1px solid var(--border, rgba(0,0,0,0.12));
  background: var(--white);
  border-radius: 999px;
  font-family: inherit;
  font-size: 13px;
  color: var(--dark, #1d1d1d);
  cursor: pointer;
  transition: all .15s ease;
}
.season-preset:hover { border-color: var(--gold, #B8975A); }
.season-preset.active {
  background: var(--gold, #B8975A);
  color: #fff;
  border-color: var(--gold, #B8975A);
}
.season-preset-clear {
  color: var(--danger, #c0392b);
  border-color: rgba(192,57,43,0.3);
}
.season-preset-clear:hover {
  border-color: var(--danger, #c0392b);
  background: rgba(192,57,43,0.06);
}

.season-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 18px;
}
.season-month {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 12px;
  border: 1.5px solid var(--border, rgba(0,0,0,0.1));
  border-radius: 10px;
  cursor: pointer;
  background: var(--white);
  transition: border-color .15s ease, background .15s ease;
  position: relative;
}
.season-month:hover { border-color: var(--gold, #B8975A); }
.season-month.on {
  border-color: var(--gold, #B8975A);
  background: rgba(184,151,90,0.08);
}
.season-month.on::after {
  content: '✓';
  position: absolute;
  top: 6px; right: 8px;
  font-size: 12px;
  color: var(--gold, #B8975A);
  font-weight: 700;
}
.season-month-name {
  font-family: var(--font-display, serif);
  font-size: 15px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 2px;
}
.season-month-work {
  font-size: 11px;
  color: var(--stone, #777);
  line-height: 1.35;
}

/* Чипы выбранных месяцев в сводке (без цен) */
.season-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0 12px;
}
.season-chip {
  font-size: 12px;
  padding: 4px 10px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.1));
  border-radius: 999px;
  color: var(--dark, #1d1d1d);
}

/* Детали визитов — количество и день */
.season-details {
  margin-bottom: 16px;
}
.season-details:empty { display: none; }
.season-details-title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--stone, #777);
  margin-bottom: 10px;
}
.season-detail-row {
  padding: 12px 0;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.06));
}
.season-detail-row:last-of-type { border-bottom: 0; }
.season-detail-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.season-detail-name {
  font-family: var(--font-display, serif);
  font-size: 16px;
  color: var(--dark, #1d1d1d);
}
.season-detail-days {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.season-day-pick {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.season-day-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--stone, #777);
}
.season-detail-day {
  width: 100%;
  font-size: 13px;
  padding: 7px 10px;
}
.season-detail-day.has-surcharge {
  border-color: var(--gold, #B8975A);
  background: rgba(184,151,90,0.06);
}
.season-day-flag {
  font-size: 11px;
  color: var(--gold, #B8975A);
  line-height: 1.35;
  margin-top: 2px;
}
.season-sum-row.surcharge {
  color: var(--gold, #B8975A);
  font-size: 13px;
  align-items: flex-start;
}
.season-stepper {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--border, rgba(0,0,0,0.14));
  border-radius: 8px;
  overflow: hidden;
}
.season-step {
  width: 30px;
  height: 30px;
  border: 0;
  background: var(--cream, #FAF6EE);
  color: var(--dark, #1d1d1d);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  transition: background .15s ease;
}
.season-step:hover { background: var(--gold, #B8975A); color: #fff; }
.season-step-val {
  width: 34px;
  text-align: center;
  font-size: 15px;
  font-weight: 600;
  color: var(--dark, #1d1d1d);
}
.season-details-hint {
  font-size: 12px;
  color: var(--stone, #777);
  margin: 10px 0 0;
  font-style: italic;
}

@media (max-width: 540px) {
  .season-detail-days { grid-template-columns: 1fr 1fr; }
}

.season-summary {
  background: var(--cream, #FAF6EE);
  border-radius: 12px;
  padding: 16px 18px;
}
.season-empty {
  margin: 0;
  color: var(--stone, #777);
  font-size: 14px;
  text-align: center;
}
.season-sum-list {
  margin-bottom: 8px;
  max-height: 180px;
  overflow-y: auto;
}
.season-sum-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
  padding: 4px 0;
  color: var(--dark, #1d1d1d);
}
.season-sum-row.subtotal {
  border-top: 1px solid var(--border, rgba(0,0,0,0.1));
  padding-top: 8px;
  margin-top: 4px;
  font-weight: 500;
}
.season-sum-row.discount { color: #2C7A35; }
.season-sum-row.total {
  border-top: 2px solid var(--gold, #B8975A);
  margin-top: 6px;
  padding-top: 10px;
  font-family: var(--font-display, serif);
  font-size: 20px;
  font-weight: 600;
}
.season-sum-note {
  margin-top: 6px;
  font-size: 12px;
  color: var(--stone, #777);
  text-align: right;
}

@media (max-width: 540px) {
  .season-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Калькулятор подписки на странице subscriptions.html */
.season-page-wrap {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 28px;
  align-items: start;
}
.season-page-form {
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 16px;
  padding: 24px 26px;
}
.season-page-fields { margin-top: 18px; }
.season-page-contacts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.season-page-aside {
  background: #1d1d1d;
  color: #FAF6EE;
  border-radius: 16px;
  padding: 24px 26px;
  position: sticky;
  top: 20px;
}
.season-page-aside h3 {
  font-family: var(--font-display, serif);
  font-size: 22px;
  margin: 0 0 16px;
  color: #FAF6EE;
}
.season-page-aside ul {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}
.season-page-aside li {
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 10px;
  color: rgba(250, 246, 238, 0.85);
}
.season-aside-note {
  font-size: 13px;
  line-height: 1.55;
  color: rgba(250, 246, 238, 0.7);
  padding: 12px 14px;
  background: rgba(250, 246, 238, 0.06);
  border-radius: 10px;
  margin-bottom: 10px;
}
.season-aside-note strong { color: var(--gold, #B8975A); }

@media (max-width: 860px) {
  .season-page-wrap { grid-template-columns: 1fr; }
  .season-page-aside { position: static; }
}
@media (max-width: 540px) {
  .season-page-contacts { grid-template-columns: 1fr; }
  .season-page-form { padding: 18px 16px; }
}

/* ============================================
   Редактор цен (менеджерская, admin)
   ============================================ */
.pricing-block {
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
  padding: 20px 22px;
  margin-bottom: 20px;
}
.pricing-block h3 {
  font-family: var(--font-display, serif);
  font-size: 22px;
  margin: 0 0 6px;
  color: var(--dark, #1d1d1d);
}
.pricing-block-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.pricing-hint {
  font-size: 13px;
  color: var(--stone, #777);
  margin: 0 0 16px;
  line-height: 1.5;
}
.pricing-months { display: flex; flex-direction: column; gap: 10px; }
.pricing-month-row {
  display: grid;
  grid-template-columns: 110px 160px 1fr;
  gap: 12px;
  align-items: end;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.06));
}
.pricing-month-row:last-child { border-bottom: 0; padding-bottom: 0; }
.pricing-month-name {
  font-family: var(--font-display, serif);
  font-size: 16px;
  color: var(--dark, #1d1d1d);
  padding-bottom: 9px;
}
.pricing-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: var(--stone, #777);
}
.pricing-field-wide { grid-column: auto; }
.pricing-disc-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1.6fr auto;
  gap: 12px;
  align-items: end;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.06));
}
.pricing-disc-row:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.pricing-surcharge-row {
  display: grid;
  grid-template-columns: 1.6fr 1fr 0.7fr 0.7fr 0.8fr auto;
  gap: 12px;
  align-items: end;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.06));
}
.pricing-surcharge-row:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.pricing-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}
.pricing-saved-note { font-size: 13px; }

@media (max-width: 720px) {
  .pricing-month-row { grid-template-columns: 1fr 1fr; }
  .pricing-month-name { grid-column: 1 / -1; padding-bottom: 0; }
  .pricing-field-wide { grid-column: 1 / -1; }
  .pricing-disc-row { grid-template-columns: 1fr 1fr; }
  .pricing-surcharge-row { grid-template-columns: 1fr 1fr; }
}

/* ============================================
   Order detail view
   ============================================ */
.mgr-open-hint {
  font-size: 12px;
  color: var(--gold, #B8975A);
  margin-left: 8px;
  font-weight: 400;
  opacity: 0;
  transition: opacity .15s ease;
}
.mgr-order-card:hover .mgr-open-hint { opacity: 1; }

.mgr-order-detail {
  padding: 0;
}
.mgr-detail-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
  padding-bottom: 18px;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.08));
  flex-wrap: wrap;
}
.mgr-detail-title {
  font-family: var(--font-display, serif);
  font-size: 30px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 4px;
}
.mgr-detail-sub {
  font-size: 15px;
  color: var(--stone, #777);
  margin-bottom: 4px;
}
.mgr-detail-created {
  font-size: 13px;
  color: var(--stone, #777);
}
.mgr-detail-rating {
  background: rgba(184,151,90,0.08);
  padding: 10px 14px;
  border-radius: 8px;
  margin-bottom: 20px;
  font-size: 14px;
}
.mgr-detail-rating .stars { font-size: 16px; color: var(--gold, #B8975A); }

.mgr-detail-section {
  margin-bottom: 32px;
}
.mgr-detail-section h3 {
  font-family: var(--font-display, serif);
  font-size: 22px;
  margin: 0 0 14px;
  color: var(--dark, #1d1d1d);
}
.mgr-detail-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  gap: 12px;
  flex-wrap: wrap;
}
.mgr-detail-section-head h3 { margin: 0; }

.mgr-detail-client-card {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 18px 20px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
  flex-wrap: wrap;
}
.mgr-detail-client-name {
  font-family: var(--font-display, serif);
  font-size: 20px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 6px;
}
.mgr-detail-client-contacts {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  font-size: 14px;
  color: var(--dark, #1d1d1d);
}
.mgr-detail-client-contacts a {
  color: var(--gold, #B8975A);
  text-decoration: none;
}
.mgr-detail-comment {
  margin-top: 12px;
  padding: 10px 14px;
  background: var(--cream, #FAF6EE);
  border-radius: 8px;
  font-size: 14px;
}
.mgr-detail-client-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.mgr-detail-form {
  padding: 18px 20px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
}
.mgr-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}
.mgr-detail-grid label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: var(--stone, #777);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.mgr-detail-linked-card {
  padding: 16px 18px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 12px;
  margin-bottom: 10px;
}
.mgr-detail-linked-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  flex-wrap: wrap;
}
.mgr-detail-linked-head .meta {
  font-size: 13px;
  color: var(--stone, #777);
  margin-top: 4px;
}
.mgr-detail-linked-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

@media (max-width: 720px) {
  .mgr-detail-title { font-size: 22px; }
  .mgr-detail-grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================
   Фотоотчёты — менеджерская
   ============================================ */
.mgr-reports { display: flex; flex-direction: column; gap: 14px; }
.mgr-report-card {
  padding: 18px 20px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
}
.mgr-report-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.mgr-report-title {
  font-family: var(--font-display, serif);
  font-size: 18px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 4px;
}
.mgr-report-meta { font-size: 13px; color: var(--stone, #777); line-height: 1.55; }
.mgr-report-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: flex-start; }

.mgr-report-photos-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px dashed var(--border, rgba(0,0,0,0.08));
}
.mgr-report-group-title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--stone, #777);
  margin-bottom: 8px;
  font-weight: 500;
}
.mgr-report-photos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
}
.mgr-report-photo {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  overflow: hidden;
  background: var(--cream, #FAF6EE);
}
.mgr-report-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.mgr-report-photo-remove {
  position: absolute;
  top: 4px; right: 4px;
  width: 22px; height: 22px;
  border: 0;
  border-radius: 50%;
  background: rgba(0,0,0,0.55);
  color: #fff;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  display: flex; align-items: center; justify-content: center;
}
.mgr-report-photo-remove:hover { background: var(--danger, #c0392b); }

/* ============================================
   Фотоотчёты — кабинет (галерея клиента)
   ============================================ */
.report-card-full {
  padding: 16px 18px;
  background: var(--white);
  margin-bottom: 12px;
}
.report-card-head { margin-bottom: 12px; }
.report-card-full .title {
  font-family: var(--font-display, serif);
  font-size: 17px;
  color: var(--dark, #1d1d1d);
  margin-bottom: 4px;
}
.report-card-full .meta { font-size: 13px; color: var(--stone, #777); }

.report-gallery-group { margin-top: 12px; }
.report-gallery-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--stone, #777);
  margin-bottom: 6px;
}
.report-gallery-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 6px;
}
.report-thumb-small {
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  overflow: hidden;
  cursor: zoom-in;
  background: var(--cream, #FAF6EE);
}
.report-thumb-small img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .25s ease;
}
.report-thumb-small:hover img { transform: scale(1.05); }

/* ============================================
   KPI / Аналитика
   ============================================ */
.kpi-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 28px;
}
.kpi-card {
  padding: 18px 20px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
}
.kpi-num {
  font-family: var(--font-display, serif);
  font-size: 32px;
  color: var(--dark, #1d1d1d);
  line-height: 1.1;
}
.kpi-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--stone, #777);
  margin-top: 4px;
}
.kpi-section-h {
  font-family: var(--font-display, serif);
  font-size: 22px;
  margin: 6px 0 14px;
  color: var(--dark, #1d1d1d);
}
.kpi-charts {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 20px;
  margin-bottom: 28px;
}
.kpi-chart-wrap {
  padding: 18px 20px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
}
.kpi-chart-wrap h3 {
  font-family: var(--font-display, serif);
  font-size: 18px;
  margin: 0 0 12px;
  color: var(--dark, #1d1d1d);
}
.kpi-chart-wrap canvas { max-height: 280px; }

.kpi-top {
  padding: 18px 20px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 14px;
}
.kpi-top h3 {
  font-family: var(--font-display, serif);
  font-size: 18px;
  margin: 0 0 12px;
}
.kpi-top-table {
  width: 100%;
  border-collapse: collapse;
}
.kpi-top-table th, .kpi-top-table td {
  padding: 10px 6px;
  text-align: left;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.06));
}
.kpi-top-table th {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--stone, #777);
  font-weight: 500;
}

@media (max-width: 720px) {
  .kpi-charts { grid-template-columns: 1fr; }
}

/* ============================================
   Страницы ошибок 404 / 500
   ============================================ */
.error-page {
  padding: 60px 0 120px;
  background: var(--cream, #FAF6EE);
  min-height: 70vh;
  display: flex;
  align-items: center;
}
.error-page-inner {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}
.error-illustration {
  position: relative;
  display: inline-block;
  margin: 0 auto 28px;
}
.error-candle {
  font-size: 72px;
  display: block;
}
.error-code {
  font-family: var(--font-display, serif);
  font-size: 96px;
  color: var(--gold, #B8975A);
  letter-spacing: 0.04em;
  line-height: 1;
  margin-top: -8px;
}
.error-page h1 {
  font-family: var(--font-display, serif);
  font-size: 44px;
  font-weight: 400;
  color: var(--dark, #1d1d1d);
  margin: 0 0 18px;
  line-height: 1.15;
}
.error-page h1 em {
  font-style: italic;
  color: var(--gold, #B8975A);
}
.error-page .lead {
  font-size: 17px;
  color: var(--stone, #777);
  margin: 0 0 32px;
  line-height: 1.55;
}
.error-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.error-help {
  font-size: 14px;
  color: var(--stone, #777);
  margin: 0;
}
.error-help a { color: var(--gold, #B8975A); }
@media (max-width: 640px) {
  .error-page h1 { font-size: 32px; }
  .error-code { font-size: 72px; }
  .error-candle { font-size: 56px; }
}

/* ============================================
   Telegram floating widget
   ============================================ */
.tg-widget {
  position: fixed;
  right: 18px;
  bottom: 90px; /* выше call-bar */
  z-index: 8500;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px 12px 14px;
  background: linear-gradient(135deg, #B8975A 0%, #9c7d44 100%);
  color: #1d1d1d;
  text-decoration: none;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.02em;
  box-shadow: 0 8px 24px rgba(184, 151, 90, 0.45);
  transition: transform .2s ease, box-shadow .2s ease;
}
.tg-widget:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(184, 151, 90, 0.55);
}
.tg-widget svg { display: block; flex-shrink: 0; }
.tg-widget.tg-widget-with-banner { bottom: 200px; }

@media (max-width: 640px) {
  .tg-widget {
    bottom: 80px;
    padding: 10px 14px 10px 12px;
    font-size: 13px;
  }
  .tg-widget-label { display: none; }
  .tg-widget.tg-widget-with-banner { bottom: 220px; }
}

/* На страницах с call-bar (главная и т.п.) — поднимаем ещё выше */
body:has(.call-bar) .tg-widget { bottom: 110px; }
@media (max-width: 640px) {
  body:has(.call-bar) .tg-widget { bottom: 100px; }
}

/* ============================================
   Свежие отзывы (загруженные из БД)
   ============================================ */
.reviews-published-head { margin-bottom: 14px; }
.review.review-fresh {
  border-left: 3px solid var(--gold, #B8975A);
}

/* ============================================
   Invite-tabs (magic link / password)
   ============================================ */
.invite-tabs {
  display: flex;
  gap: 6px;
  margin: 18px 0 16px;
  padding: 4px;
  background: var(--cream, #FAF6EE);
  border-radius: 10px;
}
.invite-tabs button {
  flex: 1;
  padding: 10px 14px;
  border: 0;
  background: transparent;
  border-radius: 8px;
  font-family: inherit;
  font-size: 14px;
  color: var(--stone, #777);
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.invite-tabs button.active {
  background: var(--white);
  color: var(--dark, #1d1d1d);
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

/* ============================================
   Семейный доступ
   ============================================ */
.family-context-banner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: linear-gradient(90deg, rgba(184,151,90,0.15), rgba(184,151,90,0.06));
  border: 1px solid var(--gold, #B8975A);
  border-radius: 10px;
  margin-bottom: 18px;
  font-size: 14px;
}
.family-section { margin-top: 28px; }
.family-section .cabinet-section-h {
  font-family: var(--font-display, serif);
  font-size: 20px;
  margin: 0 0 12px;
  color: var(--dark, #1d1d1d);
}
.family-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 10px;
  margin-bottom: 8px;
}
.family-row.active {
  border-color: var(--gold, #B8975A);
  background: linear-gradient(90deg, rgba(184,151,90,0.06), transparent);
}
.family-row-info strong {
  font-family: var(--font-display, serif);
  font-size: 16px;
  color: var(--dark, #1d1d1d);
  display: block;
  margin-bottom: 4px;
}
.family-row-info .meta {
  font-size: 13px;
  color: var(--stone, #777);
  line-height: 1.4;
}
.cabinet-empty-inline {
  padding: 14px 18px;
  color: var(--stone, #777);
  font-size: 14px;
  font-style: italic;
}

@media (max-width: 640px) {
  .family-row { flex-direction: column; align-items: stretch; }
}

/* ============================================
   Рейтинги заказов и звёзды
   ============================================ */
.stars {
  display: inline-flex;
  gap: 4px;
  font-size: 22px;
  line-height: 1;
}
.stars .star {
  color: rgba(0,0,0,0.18);
  transition: color .15s ease, transform .1s ease;
}
.stars .star.filled { color: var(--gold, #B8975A); }
.stars[data-rate-stars] .star {
  cursor: pointer;
}
.stars[data-rate-stars] .star:hover {
  transform: scale(1.15);
}
.order-rating {
  margin-top: 10px;
  padding: 14px 18px;
  border-radius: 10px;
  background: var(--cream, #FAF6EE);
  border-left: 3px solid var(--gold, #B8975A);
}
.order-rating.done {
  border-left-color: #2C7A35;
}
.order-rating-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.order-rating-head strong {
  font-family: var(--font-display, serif);
  font-size: 16px;
  color: var(--dark, #1d1d1d);
}
.order-rating-comment {
  margin: 8px 0 0;
  font-style: italic;
  color: var(--dark, #1d1d1d);
  font-size: 14px;
  line-height: 1.5;
}
.order-rating-meta {
  margin-top: 6px;
  font-size: 12px;
  color: var(--stone, #777);
  display: flex;
  gap: 6px;
  align-items: center;
}
.order-rate-form {
  margin-top: 14px;
}
.order-rate-form textarea {
  width: 100%;
  resize: vertical;
  min-height: 70px;
}

/* ============================================
   Юридические страницы (privacy / terms / cookies)
   ============================================ */
.legal-section {
  padding: 40px 0 80px;
  background: var(--cream, #FAF6EE);
}
.legal-article {
  max-width: 760px;
  margin: 0 auto;
  background: var(--white);
  padding: 40px 48px;
  border-radius: 14px;
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  font-size: 15px;
  line-height: 1.65;
  color: var(--dark, #1d1d1d);
}
.legal-article h2 {
  font-family: var(--font-display, serif);
  font-size: 26px;
  font-weight: 400;
  margin: 36px 0 14px;
  color: var(--dark, #1d1d1d);
}
.legal-article h3 {
  font-family: var(--font-display, serif);
  font-size: 20px;
  font-weight: 400;
  margin: 22px 0 10px;
  color: var(--dark, #1d1d1d);
}
.legal-article p { margin: 0 0 14px; }
.legal-article ul, .legal-article ol {
  margin: 0 0 16px;
  padding-left: 24px;
}
.legal-article li { margin-bottom: 6px; }
.legal-article a {
  color: var(--gold, #B8975A);
  text-decoration: underline;
}
.legal-article a:hover { color: var(--dark, #1d1d1d); }
.legal-article code {
  background: var(--cream, #FAF6EE);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 13px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}
.legal-meta {
  color: var(--stone, #777);
  font-size: 13px;
  margin: 0 0 28px;
  border-bottom: 1px solid var(--border, rgba(0,0,0,0.08));
  padding-bottom: 16px;
}
.legal-intro {
  font-size: 16px;
  color: var(--dark, #1d1d1d);
  padding: 14px 16px;
  background: var(--cream, #FAF6EE);
  border-left: 4px solid var(--gold, #B8975A);
  border-radius: 6px;
}

@media (max-width: 640px) {
  .legal-article { padding: 28px 22px; }
  .legal-article h2 { font-size: 22px; }
}

/* ============================================
   Cookie-баннер
   ============================================ */
.cookies-banner {
  position: fixed;
  bottom: 12px;
  left: 12px;
  right: 12px;
  z-index: 9000;
  background: rgba(29, 29, 29, 0.96);
  color: #FAF6EE;
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  animation: cookies-slide-up .35s ease;
  max-width: 1100px;
  margin: 0 auto;
}
@keyframes cookies-slide-up {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.cookies-banner-inner {
  display: flex;
  gap: 24px;
  align-items: center;
  padding: 16px 22px;
}
.cookies-banner-text { flex: 1; min-width: 0; }
.cookies-banner-text strong {
  display: block;
  font-family: var(--font-display, serif);
  font-size: 16px;
  margin-bottom: 4px;
  color: #FAF6EE;
}
.cookies-banner-text p {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: rgba(250, 246, 238, 0.78);
}
.cookies-banner-text a {
  color: var(--gold, #B8975A);
  text-decoration: underline;
}
.cookies-banner-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.cookies-banner .btn-ghost {
  border-color: rgba(250, 246, 238, 0.3);
  color: #FAF6EE;
}
.cookies-banner .btn-ghost:hover {
  background: rgba(250, 246, 238, 0.1);
}

@media (max-width: 720px) {
  /* Компактный режим: только короткий текст + 2 кнопки в одну строку, низ-узкая полоска */
  .cookies-banner {
    left: 8px; right: 8px; bottom: 8px;
    border-radius: 12px;
  }
  .cookies-banner-inner {
    flex-direction: row; align-items: center;
    gap: 10px; padding: 10px 12px;
  }
  .cookies-banner-text strong { font-size: 13px; margin-bottom: 0; }
  .cookies-banner-text p {
    font-size: 11px; line-height: 1.4;
    /* На мобиле — короткая версия, оставляем только первое предложение */
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .cookies-banner-actions { gap: 6px; flex-shrink: 0; }
  .cookies-banner-actions .btn { padding: 8px 12px !important; min-height: 36px !important; font-size: 12px !important; white-space: nowrap; }
}
@media (max-width: 420px) {
  /* Совсем узкие экраны: скрываем текст, оставляем компактную плашку с кнопками */
  .cookies-banner-text p { display: none; }
}

/* Пока виден cookies-banner: cookies-banner должен быть ВЫШЕ sticky-bar/call-bar. */
body.has-cookies-banner { padding-bottom: 200px !important; }
@media (max-width: 720px) {
  body.has-cookies-banner .cookies-banner { bottom: calc(70px + env(safe-area-inset-bottom, 0px)); }
  body.has-cookies-banner { padding-bottom: 220px !important; }
}
@media (max-width: 860px) and (min-width: 721px) {
  body.has-cookies-banner .call-bar { bottom: 96px; }
}
@media (max-width: 420px) {
  body.has-cookies-banner { padding-bottom: 220px !important; }
}


/* ============================================================
   MANAGER PANEL — MOBILE POLISH (≤768px)
   Менеджер должен полноценно работать с телефона: открыть заявку,
   позвонить клиенту, поменять статус, поставить фото-отчёт.
   Базовое правило: горизонтальные ряды стэкаются, кнопки ≥44px,
   контролы full-width, ширина под палец.
   ============================================================ */

@media (max-width: 768px) {
  /* Tabs: 12 штук не помещаются — горизонтальный скролл, sticky к шапке */
  .mgr-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    margin-bottom: 18px;
    padding-bottom: 2px;
    scrollbar-width: thin;
    /* Лёгкий фон-индикатор, что есть прокрутка вправо */
    background:
      linear-gradient(to right, var(--cream) 0, transparent 12px),
      linear-gradient(to left,  var(--cream) 0, transparent 12px),
      linear-gradient(to right, rgba(0,0,0,0.05), transparent 12px),
      linear-gradient(to left,  rgba(0,0,0,0.05), transparent 12px);
    background-position: left center, right center, left center, right center;
    background-repeat: no-repeat;
    background-size: 12px 100%, 12px 100%, 8px 100%, 8px 100%;
    background-attachment: local, local, scroll, scroll;
  }
  .mgr-tab {
    flex: 0 0 auto;
    white-space: nowrap;
    padding: 12px 14px;
    font-size: 14px;
    min-height: 44px;
  }

  /* Stats: 2 колонки вместо auto-fit (меньше скачет ширина) */
  .mgr-stats {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .mgr-stat { padding: 12px; }
  .mgr-stat .num { font-size: 22px; }
  .mgr-stat .label { font-size: 10px; }

  /* Карточка заявки в списке: тапабельнее, отступы под палец */
  .mgr-order-card {
    padding: 14px 16px;
    border-radius: 12px;
  }
  .mgr-order-head { gap: 8px; }
  .mgr-order-title { font-size: 15px; line-height: 1.35; }
  .mgr-order-meta { font-size: 12.5px; }
  .mgr-order-price { font-size: 17px; }

  /* Клиентский блок: лейблы и значения сложить в столбик */
  .mgr-client {
    grid-template-columns: 1fr;
    gap: 4px 0;
    padding: 10px 12px;
    font-size: 13px;
  }

  /* Детали заявки: заголовок, статус — в столбик */
  .mgr-detail-head {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding-bottom: 14px;
    margin-bottom: 18px;
  }
  .mgr-detail-title { font-size: 20px; line-height: 1.2; }
  .mgr-detail-sub  { font-size: 13.5px; }
  .mgr-detail-created { font-size: 12px; }

  /* Карточка клиента в детали: имя сверху, кнопки снизу */
  .mgr-detail-client-card {
    flex-direction: column;
    align-items: stretch;
    padding: 14px 16px;
  }
  .mgr-detail-client-contacts { gap: 10px 14px; font-size: 13.5px; }
  .mgr-detail-client-actions {
    width: 100%;
    justify-content: stretch;
  }
  .mgr-detail-client-actions .btn { flex: 1 1 auto; min-height: 44px; }

  /* Управление заявкой — поля в один столбец */
  .mgr-detail-grid { grid-template-columns: 1fr; gap: 14px; }
  .mgr-detail-grid label { font-size: 11px; }
  .mgr-detail-form { padding: 14px 16px; }

  /* Секции — компактнее */
  .mgr-detail-section { margin-bottom: 22px; }
  .mgr-detail-section h3 { font-size: 18px; margin-bottom: 12px; }
  .mgr-detail-section-head { gap: 10px; }

  /* Привязанные отчёты/договоры — карточки в столбик */
  .mgr-detail-linked-card { padding: 12px 14px; }
  .mgr-detail-linked-head { flex-direction: column; align-items: stretch; gap: 10px; }
  .mgr-detail-linked-actions {
    width: 100%;
    justify-content: stretch;
  }
  .mgr-detail-linked-actions .btn { flex: 1 1 auto; min-height: 44px; }

  /* Подписки клиентов — кладём sub-meta под голову */
  .mgr-sub-head {
    flex-direction: column;
    align-items: stretch;
  }
  .mgr-sub-meta { justify-content: space-between; }
  .mgr-sub-visit-act { flex-wrap: wrap; }

  /* Кнопки в actions менеджера — на всю ширину карточки */
  .mgr-actions { flex-direction: column; align-items: stretch; }
  .mgr-actions .btn { width: 100%; min-height: 44px; }

  /* Кладбища и участки клиента */
  .mgr-cem-add { flex-direction: column; align-items: stretch; }
  .mgr-cem-row { padding: 10px 14px; font-size: 13.5px; }
  .mgr-plot-head { flex-direction: column; align-items: stretch; gap: 8px; }
  .mgr-vphotos { gap: 14px; padding: 10px 0 12px; }
  .mgr-vphoto, .mgr-vphoto-add { width: 64px; height: 64px; }

  /* Фото-отчёты — карточки */
  .mgr-report-card { padding: 14px 16px; }

  /* Карта в менеджерской — высокая, но не во весь viewport (бар header виден) */
  .mgr-map-frame { height: 65vh; min-height: 380px; }

  /* Шапка сайта чуть компактнее, чтобы не съедала экран */
  .site-header { padding: 10px 0; }

  /* Туллы фильтров поверх широких списков */
  .mgr-filters .form-input { width: 100%; }
}

/* iPhone SE / узкие телефоны (≤420px) — ещё агрессивнее ужимаем */
@media (max-width: 420px) {
  .mgr-stats { grid-template-columns: 1fr 1fr; }
  .mgr-stat .num { font-size: 20px; }
  .mgr-detail-title { font-size: 18px; }
  .mgr-detail-section h3 { font-size: 16px; }
  .mgr-tabs { gap: 0; }
  .mgr-tab { padding: 11px 12px; }
}

/* ============================================================
   CATALOG (catalog.html) — галерея 142 моделей памятников
   ============================================================ */
.catalog-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}
.catalog-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.catalog-chip {
  background: transparent;
  border: 1px solid var(--border, rgba(0,0,0,0.12));
  border-radius: 999px;
  padding: 7px 14px;
  font-size: 13px;
  color: var(--dark, #1d1d1d);
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.catalog-chip:hover { border-color: var(--dark, #1d1d1d); }
.catalog-chip.active {
  background: #1d1d1d;
  color: #FAF6EE;
  border-color: var(--dark, #1d1d1d);
}
.catalog-search {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1 1 280px;
  max-width: 480px;
}
.catalog-search .form-input { flex: 1 1 auto; }
.catalog-count {
  font-size: 12px;
  color: var(--stone, #777);
  white-space: nowrap;
}

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
}
.catalog-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  padding: 12px;
  background: var(--white, #fff);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 12px;
  cursor: pointer;
  text-align: center;
  transition: border-color .15s, transform .15s, box-shadow .15s;
}
.catalog-card:hover {
  border-color: var(--gold, #B8975A);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
}
.catalog-card-img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  background: var(--cream, #FAF6EE);
  border-radius: 8px;
  overflow: hidden;
}
.catalog-card-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.catalog-card-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--dark, #1d1d1d);
  line-height: 1.3;
}
.catalog-card-id {
  font-size: 11px;
  color: var(--stone, #777);
  letter-spacing: 0.04em;
}

.catalog-empty {
  padding: 60px 20px;
  text-align: center;
  color: var(--stone, #777);
}

/* Модалка детали модели */
.catalog-detail {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(280px, 1.2fr);
  gap: 24px;
  align-items: start;
}
.catalog-detail-img {
  background: var(--cream, #FAF6EE);
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 4 / 5;
}
.catalog-detail-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.catalog-detail-id {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold, #B8975A);
  margin-bottom: 4px;
}
.catalog-detail-info h3 {
  font-family: var(--font-display, serif);
  font-size: 26px;
  font-weight: 400;
  margin: 0 0 8px;
  line-height: 1.2;
}
.catalog-detail-desc {
  color: var(--stone, #777);
  font-size: 14px;
  margin-bottom: 16px;
}
.catalog-order-form .form-row { margin-bottom: 12px; }

@media (max-width: 720px) {
  .catalog-detail { grid-template-columns: 1fr; }
  .catalog-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
  .catalog-card { padding: 8px; }
  .catalog-card-name { font-size: 13px; }
}

/* ============================================================
   CATALOG ADMIN (вкладка в менеджерской) — переименование моделей
   ============================================================ */
.mgr-catalog-toolbar {
  display: flex;
  gap: 12px;
  margin-bottom: 18px;
  flex-wrap: wrap;
  align-items: center;
}
.mgr-catalog-toolbar .form-input { flex: 1 1 240px; }
.mgr-catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}
.mgr-catalog-card {
  background: var(--white);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 10px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.mgr-catalog-card.is-dirty {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold), 0 4px 12px rgba(184,151,90,0.18);
}
.mgr-catalog-card.is-dirty::after {
  content: '●';
  position: absolute;
  top: 8px;
  right: 8px;
  color: var(--gold);
  font-size: 12px;
  pointer-events: none;
}
.mgr-catalog-card { position: relative; }
.mgr-catalog-card-img {
  aspect-ratio: 4 / 5;
  background: var(--cream, #FAF6EE);
  border-radius: 8px;
  overflow: hidden;
}
.mgr-catalog-card-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.mgr-catalog-card-id {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--stone, #777);
}
.mgr-catalog-card input,
.mgr-catalog-card select {
  width: 100%;
  padding: 7px 10px;
  font-size: 13px;
  border: 1px solid var(--border, rgba(0,0,0,0.12));
  border-radius: 6px;
  background: var(--white);
  font-family: inherit;
}
.mgr-catalog-card .form-row { margin: 0; }

/* Командная вкладка: аватарки и неактивные */
.team-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cream-deep, #F1ECDD);
  color: var(--dark);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: 1px solid var(--border);
}
.team-row { gap: 14px; }
.team-row-inactive { opacity: 0.55; }
.team-row-inactive .team-avatar { background: var(--border); }
.team-row-stats span { white-space: nowrap; }

/* Глобальный поиск в шапке менеджерской */
.mgr-global-search { position: relative; flex: 0 1 320px; min-width: 0; }
.mgr-global-input { font-size: 13px !important; padding: 8px 12px !important; height: 36px; }
.mgr-global-results {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  background: var(--white); border: 1px solid var(--border); border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.12);
  max-height: 480px; overflow-y: auto; z-index: 1000;
}
.gs-section { padding: 6px 0; }
.gs-section + .gs-section { border-top: 1px solid var(--border); }
.gs-section-title {
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--stone); padding: 8px 14px 6px;
}
.gs-row {
  display: flex; flex-direction: column; gap: 2px;
  padding: 8px 14px; cursor: pointer;
  transition: background .12s;
  text-decoration: none; color: var(--dark);
}
.gs-row:hover { background: var(--cream); }
.gs-row-title { font-size: 14px; font-weight: 500; }
.gs-row-meta  { font-size: 12px; color: var(--stone); }

@media (max-width: 768px) {
  .mgr-global-search { display: none; }
}

/* Bulk-actions bar */
.mgr-bulk-bar {
  position: fixed; left: 50%; bottom: 20px;
  transform: translateX(-50%);
  background: #1d1d1d; color: #FAF6EE;
  padding: 10px 16px; border-radius: 999px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
  z-index: 2147483600;
  max-width: calc(100vw - 32px);
}
.mgr-bulk-bar .btn { background: rgba(255,255,255,0.10); color: #FAF6EE; border-color: rgba(255,255,255,0.25); }
.mgr-bulk-bar .btn:hover { background: rgba(255,255,255,0.20); }
.mgr-bulk-bar select.form-input { background: rgba(255,255,255,0.10); color: #FAF6EE; border-color: rgba(255,255,255,0.25); }
.mgr-order-check {
  width: 18px; height: 18px; margin-right: 10px; accent-color: var(--gold);
  flex-shrink: 0; align-self: flex-start; margin-top: 2px; cursor: pointer;
}
.mgr-order-selected { outline: 2px solid var(--gold); outline-offset: -2px; }

/* Onboarding-checklist + PWA promo */
.onboarding-checklist {
  position: relative;
  background: linear-gradient(135deg, rgba(184,151,90,0.10), rgba(184,151,90,0.04));
  border: 1px solid rgba(184,151,90,0.4);
  border-radius: 12px;
  padding: 18px 20px 14px;
  margin: 18px 0 24px;
}
.onboarding-checklist h4 {
  margin: 0 0 4px;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 400;
}
.onboarding-progress {
  font-size: 12px;
  color: var(--stone);
  margin: 0 0 14px;
  letter-spacing: 0.04em;
}
.onboarding-checklist ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.onboarding-checklist li {
  display: flex;
  gap: 12px;
  align-items: center;
  background: var(--white);
  border-radius: 8px;
  padding: 10px 14px;
  border: 1px solid var(--border);
}
.onboarding-checklist li.done { opacity: 0.55; }
.onb-tick {
  width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream-deep);
  color: var(--stone);
  font-weight: 600;
  flex-shrink: 0;
}
.onboarding-checklist li.done .onb-tick { background: #2C7A35; color: #fff; }
.onb-text { flex: 1; }
.onb-text strong { display: block; font-size: 14px; }
.onb-text small { font-size: 12px; color: var(--stone); }
.onboarding-dismiss {
  position: absolute; top: 8px; right: 10px;
  background: none; border: none; cursor: pointer;
  font-size: 18px; color: var(--stone); line-height: 1;
}

.pwa-install-promo {
  position: fixed; left: 50%; bottom: 16px;
  transform: translateX(-50%);
  background: #1d1d1d; color: #FAF6EE;
  padding: 10px 14px; border-radius: 12px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  box-shadow: 0 12px 32px rgba(0,0,0,0.20);
  z-index: 2147483600;
  max-width: calc(100vw - 24px);
  font-size: 13px;
}
.pwa-install-promo .btn-primary { background: var(--gold); color: var(--dark); border-color: var(--gold); }
.pwa-install-promo .btn-ghost { color: #FAF6EE; border-color: rgba(255,255,255,0.25); padding: 6px 10px; }

/* Touch-targets ≥ 44px на мобиле — палец должен попадать без промахов.
   Размещаем ПОСЛЕ всех базовых правил, чтобы каскад не перебивал. */
@media (max-width: 768px) {
  .variant-btn { padding: 12px 14px; font-size: 13px; min-height: 44px; }
  .season-step { width: 44px; height: 44px; font-size: 22px; border-radius: 8px; }
  .season-step-val { width: 48px; font-size: 17px; }
  .category-item { min-height: 44px; padding: 12px 14px; font-size: 14px; }
}

/* ============================================================
   MOBILE ADDENDUM — финальные правила.
   Идут в самом конце файла, чтобы каскад работал поверх
   базовых стилей и любых компонентных правил выше.
   ============================================================ */

/* 1. iOS auto-zoom fix: input < 16px вызывает зум при фокусе.
   На < 768px поднимаем всем формам шрифт до 16px. */
@media (max-width: 768px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="password"],
  input[type="number"],
  input[type="search"],
  input[type="url"],
  input[type="date"],
  input[type="time"],
  input[type="datetime-local"],
  textarea,
  select,
  .form-input,
  .form-textarea,
  .form-select {
    font-size: 16px !important;
  }
}

/* 2. Модалки — full-screen на мобильном, sticky close.
   Селекторы покрывают и dialog-overlay, и старые .modal */
@media (max-width: 768px) {
  .modal-overlay,
  .dialog-overlay,
  [data-modal-overlay] {
    padding: 0 !important;
    align-items: stretch !important;
  }
  .modal,
  .dialog,
  .modal-content,
  [data-modal-content] {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    border-radius: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .modal-close,
  .dialog-close,
  [data-modal-close] {
    position: sticky;
    top: 8px;
    margin-left: auto;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
  }
}

/* 3. Менеджерская: детальная карточка как overlay на мобиле,
      stat-tiles в 2 колонки */
@media (max-width: 768px) {
  .mgr-stats,
  .stat-tiles {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
  .mgr-stat-tile,
  .stat-tile {
    padding: 12px !important;
    font-size: 13px !important;
  }
  .mgr-stat-tile-value,
  .stat-tile-value {
    font-size: 22px !important;
  }
  .mgr-detail,
  .mgr-order-detail,
  [data-order-detail] {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2147483500 !important;
    background: var(--cream, #f8f4ec);
    overflow-y: auto;
    padding: 16px;
    -webkit-overflow-scrolling: touch;
  }
  .mgr-detail-close,
  [data-detail-close] {
    position: sticky;
    top: 0;
    background: var(--cream, #f8f4ec);
    padding: 8px 0;
    z-index: 10;
  }
  .mgr-layout,
  .mgr-grid {
    grid-template-columns: 1fr !important;
  }
}

/* 4. KPI charts: canvas масштабируется, подписи мельче */
@media (max-width: 768px) {
  .kpi-chart,
  .mgr-chart,
  canvas.kpi-canvas {
    max-width: 100% !important;
    height: auto !important;
    width: 100% !important;
  }
  .kpi-section,
  .mgr-kpi-section {
    overflow-x: hidden;
  }
}

/* 5. Footer-форма: одной колонкой + место для cookies-banner */
@media (max-width: 768px) {
  .footer-form,
  .footer-contact-form,
  form[data-form="contact"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
  }
  .footer-form .form-row,
  .footer-contact-form .form-row {
    flex-direction: column !important;
    gap: 10px !important;
  }
  .footer-form button[type="submit"],
  .footer-contact-form button[type="submit"] {
    width: 100% !important;
  }
  body.has-cookies-banner .site-footer,
  body.has-cookies-banner .footer {
    padding-bottom: 140px !important;
  }
}

/* 6. Кабинет: табы — горизонтальный скролл, контент с боковым отступом */
@media (max-width: 768px) {
  .cabinet-tabs,
  [data-cabinet-tabs],
  .tabs-nav {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 4px;
    padding: 0 12px;
    margin: 0 -12px 12px;
  }
  .cabinet-tabs::-webkit-scrollbar,
  .tabs-nav::-webkit-scrollbar { display: none; }
  .cabinet-tab,
  .tab-btn,
  .tabs-nav button {
    flex-shrink: 0 !important;
    white-space: nowrap !important;
    min-height: 44px;
    padding: 10px 14px;
    font-size: 14px;
  }
  .cabinet-content,
  .tab-content,
  [data-tab-content] {
    padding-left: 12px;
    padding-right: 12px;
  }
}

/* 7. Галерея фото в кабинете */
@media (max-width: 768px) {
  .photos-grid,
  .originals-grid,
  [data-photos-grid] {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important;
    gap: 8px !important;
  }
  .photo-item,
  .original-item {
    font-size: 12px;
  }
  .photo-item img,
  .original-item img {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    object-fit: cover;
  }
}

/* 8. Конструктор: canvas масштаб, панель опций как bottom-sheet */
@media (max-width: 768px) {
  .constructor-canvas,
  #constructor-canvas,
  [data-constructor-canvas] {
    max-width: calc(100vw - 24px) !important;
    max-height: 70vh !important;
    width: auto !important;
    height: auto !important;
    margin: 0 auto;
    display: block;
  }
  .constructor-layout,
  .constructor-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .constructor-options-panel,
  .constructor-sidebar,
  [data-constructor-options] {
    position: sticky;
    bottom: 0;
    background: var(--white);
    border-top: 1px solid var(--border, #e6dfd1);
    padding: 12px;
    max-height: 50vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    z-index: 10;
  }
}

/* 9. Длинные тексты в карточках — не должны ломать сетку */
@media (max-width: 768px) {
  .service-card,
  .service-card-text,
  .subscription-feature,
  .plan-feature,
  .product-card-text,
  .card-description {
    word-break: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
  }
}

/* 10. Header на узких экранах: «Кабинет» в иконку, лого мельче.
   Используем чисто CSS-приём: text-indent + ::before с SVG-фоном.
   Никаких изменений HTML не нужно. */
@media (max-width: 480px) {
  .site-logo img,
  .header-logo img,
  header img.logo {
    height: 36px !important;
    width: auto !important;
  }
  .site-header .btn-sm,
  .header-actions .btn-sm {
    padding: 8px 12px;
    font-size: 13px;
  }
  .site-header a.btn[href="cabinet.html"],
  .site-header a.btn[href*="cabinet.html"] {
    font-size: 0 !important;
    line-height: 1 !important;
    padding: 0 !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border-radius: 999px !important;
  }
  .site-header a.btn[href="cabinet.html"]::before,
  .site-header a.btn[href*="cabinet.html"]::before {
    content: "";
    width: 20px;
    height: 20px;
    background-color: currentColor;
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 12a4 4 0 100-8 4 4 0 000 8zm0 2c-3.3 0-10 1.7-10 5v3h20v-3c0-3.3-6.7-5-10-5z'/></svg>") center/contain no-repeat;
    mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 12a4 4 0 100-8 4 4 0 000 8zm0 2c-3.3 0-10 1.7-10 5v3h20v-3c0-3.3-6.7-5-10-5z'/></svg>") center/contain no-repeat;
  }
  .phone-link {
    display: none !important;
  }
}

/* 11. Leaflet карта: контролы выше call-bar и cookies-banner */
@media (max-width: 768px) {
  .leaflet-bottom.leaflet-left,
  .leaflet-bottom.leaflet-right {
    bottom: calc(80px + env(safe-area-inset-bottom, 0px)) !important;
  }
  body.has-cookies-banner .leaflet-bottom.leaflet-left,
  body.has-cookies-banner .leaflet-bottom.leaflet-right {
    bottom: calc(160px + env(safe-area-inset-bottom, 0px)) !important;
  }
  .leaflet-popup {
    max-width: calc(100vw - 32px) !important;
  }
}

/* 12. Социальные иконки в футере: компактнее + tap-feedback */
@media (max-width: 768px) {
  .footer-socials,
  .social-links {
    gap: 12px !important;
    justify-content: flex-start !important;
  }
  .footer-socials a,
  .social-link {
    width: 44px;
    height: 44px;
    transition: transform 0.12s ease;
  }
  .footer-socials a:active,
  .social-link:active {
    transform: scale(0.9);
  }
}

/* ============================================================
   Memorial page enhancements: эпитафия, свеча, QR-блок
   ============================================================ */
.memorial-epitaph {
  margin: 24px auto 0;
  max-width: 540px;
  padding: 14px 22px;
  border-left: 3px solid var(--gold, #b8975a);
  font-family: var(--font-display, serif);
  font-style: italic;
  font-size: 18px;
  color: var(--stone, #555);
  line-height: 1.5;
  text-align: center;
}
.memorial-epitaph p { margin: 0; }

.memorial-candle-block {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 20px 22px;
  margin: 28px 0;
  background: linear-gradient(135deg, rgba(184,151,90,0.06), rgba(184,151,90,0.02));
  border: 1px solid rgba(184,151,90,0.20);
  border-radius: 12px;
}
.memorial-candle-block h3 {
  margin: 0 0 4px;
  font-family: var(--font-display, serif);
  font-size: 20px;
  font-weight: 400;
}
.memorial-candle-block p { margin: 0; font-size: 13.5px; color: var(--stone, #555); }
.memorial-candle-visual {
  position: relative;
  width: 60px;
  height: 80px;
  margin: 0 auto;
}
.memorial-candle-visual .candle-body {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 28px;
  height: 60px;
  background: linear-gradient(180deg, #f3e5c4, #d6c290);
  border-radius: 4px 4px 2px 2px;
  box-shadow: inset -3px 0 6px rgba(0,0,0,0.10);
}
.memorial-candle-visual .candle-body::before {
  content: '';
  position: absolute;
  top: -3px; left: 50%; transform: translateX(-50%);
  width: 2px; height: 8px;
  background: #333;
}
.memorial-candle-visual .candle-flame {
  position: absolute;
  top: 0; left: 50%; transform: translateX(-50%) scale(0);
  width: 16px; height: 22px;
  background: radial-gradient(ellipse at 50% 70%, #fff5b5, #ffa733 70%, transparent);
  border-radius: 50% 50% 30% 30%;
  transform-origin: 50% 100%;
  opacity: 0;
  transition: transform 0.4s cubic-bezier(.34,1.56,.64,1), opacity 0.4s;
  filter: blur(0.3px);
}
.memorial-candle-visual.is-lit .candle-flame {
  transform: translateX(-50%) scale(1);
  opacity: 1;
  animation: candle-flicker 1.4s ease-in-out infinite alternate;
}
@keyframes candle-flicker {
  0% { transform: translateX(-50%) scale(1) rotate(-1deg); filter: blur(0.3px) hue-rotate(0deg); }
  100% { transform: translateX(-50%) scale(1.07) rotate(1deg); filter: blur(0.4px) hue-rotate(-8deg); }
}

.memorial-qr-block {
  display: grid;
  grid-template-columns: 200px 1fr;
  align-items: flex-start;
  gap: 24px;
  padding: 22px;
  margin: 36px 0 0;
  background: var(--white);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 12px;
}
.memorial-qr-img img {
  display: block;
  width: 200px;
  height: 200px;
  border-radius: 6px;
  background: var(--white);
}
.memorial-qr-block h3 {
  margin: 0 0 6px;
  font-family: var(--font-display, serif);
  font-size: 22px;
  font-weight: 400;
}
.memorial-qr-block p {
  margin: 0 0 14px;
  font-size: 14px;
  color: var(--stone, #555);
  line-height: 1.5;
}
.memorial-qr-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

@media (max-width: 640px) {
  .memorial-candle-block {
    grid-template-columns: 60px 1fr;
    grid-template-areas: 'candle text' 'btn btn';
    gap: 12px;
    padding: 16px;
  }
  .memorial-candle-block > .memorial-candle-visual { grid-area: candle; }
  .memorial-candle-block > .memorial-candle-text { grid-area: text; }
  .memorial-candle-block > .btn { grid-area: btn; }
  .memorial-qr-block {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .memorial-qr-img { margin: 0 auto; }
  .memorial-qr-actions { justify-content: center; }
}

/* Print-режим: только QR + имя — для распечатки гравёру */
@media print {
  body.print-memorial > *:not(.memorial-page) { display: none !important; }
  body.print-memorial .memorial-card > *:not(.memorial-hero):not(.memorial-qr-block) { display: none !important; }
  body.print-memorial .memorial-candle-block,
  body.print-memorial .condolence-list,
  body.print-memorial .condolence-form,
  body.print-memorial .memorial-bio { display: none !important; }
  body.print-memorial .memorial-qr-actions { display: none !important; }
}

/* ============================================================
   AI-помощник — плавающая кнопка и панель чата
   ============================================================ */
.ai-helper-btn {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 2147483640;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  background: #1d1d1d;
  color: #f8f4ec;
  border: none;
  border-radius: 999px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(0,0,0,0.22);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.ai-helper-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,0.28); }
.ai-helper-btn.is-open .ai-helper-btn-label { display: none; }
.ai-helper-btn svg { flex-shrink: 0; }

.ai-helper-panel {
  position: fixed;
  bottom: 80px;
  right: 20px;
  z-index: 2147483641;
  width: 380px;
  max-width: calc(100vw - 40px);
  max-height: 70vh;
  background: var(--white);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.22);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: ai-panel-in 0.22s cubic-bezier(.34,1.56,.64,1);
}
.ai-helper-panel[hidden] { display: none; }
@keyframes ai-panel-in {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.ai-helper-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--border, #e6dfd1);
}
.ai-helper-head h3 {
  margin: 0;
  font-family: var(--font-display, serif);
  font-size: 18px;
  font-weight: 400;
}
.ai-helper-head p {
  margin: 4px 0 0;
  font-size: 12.5px;
  color: var(--stone, #555);
}
.ai-helper-close {
  background: none;
  border: none;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  color: var(--stone, #777);
  width: 32px;
  height: 32px;
  border-radius: 50%;
}
.ai-helper-close:hover { background: var(--cream-deep, #f0eadd); }
.ai-helper-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  -webkit-overflow-scrolling: touch;
}
.ai-helper-suggestions {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ai-helper-suggestions-inline {
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px dashed var(--border, #e6dfd1);
}
.ai-helper-suggestions small {
  display: block;
  color: var(--stone, #777);
  font-size: 11.5px;
  margin-bottom: 6px;
}
.ai-helper-chip {
  background: var(--cream-deep, #f0eadd);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 8px;
  padding: 10px 12px;
  text-align: left;
  font-family: inherit;
  font-size: 13px;
  color: var(--dark, #1d1d1d);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.ai-helper-chip:hover {
  background: rgba(184,151,90,0.08);
  border-color: var(--gold, #b8975a);
}
.ai-msg {
  max-width: 92%;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 13.5px;
  line-height: 1.5;
  word-wrap: break-word;
}
.ai-msg-user {
  align-self: flex-end;
  background: #1d1d1d;
  color: #f8f4ec;
  border-bottom-right-radius: 4px;
}
.ai-msg-bot {
  align-self: flex-start;
  background: var(--cream-deep, #f0eadd);
  color: var(--dark, #1d1d1d);
  border-bottom-left-radius: 4px;
}
.ai-msg-bot a { color: var(--gold, #b8975a); font-weight: 500; }
.ai-msg-bot strong { font-weight: 600; }
.ai-msg-typing {
  display: flex;
  gap: 4px;
  align-items: center;
  padding: 14px;
}
.ai-msg-typing span {
  width: 6px;
  height: 6px;
  background: var(--stone, #888);
  border-radius: 50%;
  animation: ai-dot 0.9s ease-in-out infinite;
}
.ai-msg-typing span:nth-child(2) { animation-delay: 0.15s; }
.ai-msg-typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes ai-dot {
  0%, 100% { opacity: 0.3; transform: translateY(0); }
  50% { opacity: 1; transform: translateY(-3px); }
}
.ai-helper-input {
  display: flex;
  gap: 6px;
  padding: 10px 12px;
  border-top: 1px solid var(--border, #e6dfd1);
}
.ai-helper-input input {
  flex: 1;
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 8px;
  padding: 10px 12px;
  font-family: inherit;
  font-size: 14px;
  background: var(--cream-deep, #f0eadd);
}
.ai-helper-input input:focus { outline: 2px solid var(--gold, #b8975a); outline-offset: 1px; background: var(--white); }
.ai-helper-input button {
  background: var(--gold, #b8975a);
  border: none;
  color: #fff;
  width: 40px;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ai-helper-foot {
  font-size: 11.5px;
  color: var(--stone, #777);
  text-align: center;
  padding: 8px 12px 12px;
  margin: 0;
  border-top: 1px solid var(--border, #e6dfd1);
}
.ai-helper-foot a { color: var(--gold, #b8975a); font-weight: 500; }

@media (max-width: 720px) {
  /* На мобильном поднимаем кнопку выше sticky-bar (70px высота) */
  .ai-helper-btn {
    bottom: calc(82px + env(safe-area-inset-bottom, 0px));
    right: 12px;
    padding: 9px 13px;
    font-size: 13px;
  }
  body.has-cookies-banner .ai-helper-btn {
    bottom: calc(200px + env(safe-area-inset-bottom, 0px));
  }
}
@media (max-width: 480px) {
  .ai-helper-panel {
    bottom: 0;
    right: 0;
    left: 0;
    width: 100vw;
    max-width: 100vw;
    height: 90dvh;
    max-height: 90dvh;
    border-radius: 14px 14px 0 0;
  }
}

/* ============================================================
   Epitaph generator (epitaphs.html)
   ============================================================ */
.epitaph-gen-section {
  padding: 32px 0 48px;
  background: var(--cream-deep, #f0eadd);
}
.epitaph-gen-card {
  background: var(--white);
  border-radius: 16px;
  padding: 32px;
  border: 1px solid var(--border, #e6dfd1);
  box-shadow: 0 4px 24px rgba(0,0,0,0.04);
}
.epitaph-gen-head { text-align: center; margin-bottom: 24px; }
.epitaph-gen-head h2 {
  margin: 6px 0;
  font-family: var(--font-display, serif);
  font-weight: 400;
}
.epitaph-gen-head p { color: var(--stone, #555); max-width: 580px; margin: 8px auto 0; }
.epitaph-gen-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 20px;
}
.epitaph-gen-grid .form-row:last-child { grid-column: 1 / -1; }
.epitaph-gen-styles {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.epitaph-gen-styles .radio-pill {
  background: var(--cream-deep, #f0eadd);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 999px;
  padding: 6px 14px;
  cursor: pointer;
  font-size: 13px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.epitaph-gen-styles .radio-pill input {
  margin: 0;
  accent-color: var(--gold, #b8975a);
}
.epitaph-gen-results {
  margin-top: 24px;
}
.epitaph-gen-results h3 {
  font-family: var(--font-display, serif);
  font-weight: 400;
  margin: 0 0 6px;
}
.epitaph-gen-hint { color: var(--stone, #555); font-size: 13.5px; margin: 0 0 16px; }
.epitaph-gen-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.epitaph-gen-item {
  padding: 18px 18px 14px;
  background: var(--cream-deep, #f0eadd);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.epitaph-gen-tag {
  align-self: flex-start;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--gold, #b8975a);
  font-weight: 500;
}
.epitaph-gen-item p {
  font-family: var(--font-display, serif);
  font-style: italic;
  font-size: 16px;
  line-height: 1.45;
  color: var(--dark, #1d1d1d);
  margin: 0;
  flex: 1;
}
.epitaph-gen-actions { display: flex; gap: 6px; flex-wrap: wrap; }

@media (max-width: 640px) {
  .epitaph-gen-card { padding: 22px; }
  .epitaph-gen-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Cookie settings modal — granular consent
   ============================================================ */
.cookies-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  animation: cookies-modal-fade 0.18s ease;
}
@keyframes cookies-modal-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
.cookies-modal {
  background: var(--white);
  border-radius: 14px;
  max-width: 540px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
}
.cookies-modal-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px 14px;
  border-bottom: 1px solid var(--border, #e6dfd1);
}
.cookies-modal-head h3 {
  margin: 0;
  font-family: var(--font-display, serif);
  font-size: 22px;
  font-weight: 400;
}
.cookies-modal-close {
  background: none;
  border: none;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  color: var(--stone, #777);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cookies-modal-close:hover { background: var(--cream-deep, #f0eadd); color: var(--dark, #1d1d1d); }
.cookies-modal-body {
  padding: 18px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cookies-modal-intro {
  margin: 0 0 4px;
  color: var(--stone, #555);
  font-size: 14px;
  line-height: 1.5;
}
.cookies-cat {
  display: flex;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  align-items: flex-start;
}
.cookies-cat:hover { border-color: var(--gold, #b8975a); background: rgba(184, 151, 90, 0.04); }
.cookies-cat.is-always { opacity: 0.85; cursor: default; }
.cookies-cat.is-always:hover { border-color: var(--border, #e6dfd1); background: transparent; }
.cookies-cat input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--gold, #b8975a);
  flex-shrink: 0;
  cursor: pointer;
}
.cookies-cat input[type="checkbox"]:disabled { cursor: default; }
.cookies-cat-text { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.cookies-cat-title {
  font-weight: 500;
  font-size: 14.5px;
  color: var(--dark, #1d1d1d);
}
.cookies-cat-title em {
  font-style: normal;
  font-size: 11.5px;
  color: var(--stone, #777);
  font-weight: 400;
  margin-left: 4px;
}
.cookies-cat-desc {
  font-size: 12.5px;
  color: var(--stone, #555);
  line-height: 1.45;
}
.cookies-modal-foot {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 24px 20px;
  border-top: 1px solid var(--border, #e6dfd1);
  flex-wrap: wrap;
}

@media (max-width: 480px) {
  .cookies-modal { border-radius: 14px 14px 0 0; max-height: 100vh; margin-top: auto; }
  .cookies-modal-overlay { align-items: flex-end; padding: 0; }
  .cookies-modal-head { padding: 16px 18px 12px; }
  .cookies-modal-body { padding: 14px 18px; }
  .cookies-modal-foot { padding: 12px 18px 18px; }
}

/* ============================================================
   Погода в ячейках менеджерского календаря
   ============================================================ */
.mgr-cal-weather {
  float: right;
  font-size: 14px;
  line-height: 1;
  margin-left: 4px;
}
.mgr-cal-weather-icon {
  display: inline-block;
  cursor: help;
}
.mgr-cal-cell-rainy {
  background: linear-gradient(180deg, rgba(120, 160, 220, 0.06), transparent 70%);
}
.mgr-cal-cell-rainy::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    -65deg,
    transparent 0,
    transparent 8px,
    rgba(80, 120, 200, 0.04) 8px,
    rgba(80, 120, 200, 0.04) 9px
  );
  border-radius: inherit;
}
.mgr-cal-cell { position: relative; }

/* ============================================================
   Поминальные дни 2026-2031 (pominalnye-dni.html)
   ============================================================ */
.pominal-page { padding: 24px 0 64px; }
.pominal-intro {
  background: var(--cream-deep);
  border-radius: 12px;
  padding: 22px 26px;
  margin-bottom: 36px;
  font-size: 15px;
  line-height: 1.65;
  color: var(--dark);
}
.pominal-intro p { margin: 0 0 12px; }
.pominal-intro p:last-child { margin-bottom: 0; }
.pominal-intro a { color: var(--gold); font-weight: 500; }
.pominal-intro strong { color: var(--dark); }

.pominal-glossary { margin-bottom: 40px; }
.pominal-glossary h2 {
  margin: 0 0 18px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 28px;
}
.pominal-glossary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
}
.pominal-glossary article {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px 20px;
}
.pominal-glossary article h3 {
  margin: 0 0 6px;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
}
.pominal-glossary article p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--stone);
}

.pominal-year-block { margin-bottom: 32px; }
.pominal-year-block h2 {
  margin: 0 0 12px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 26px;
  color: var(--gold);
}
.pominal-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--white);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border);
  font-size: 14px;
}
.pominal-table thead th {
  background: var(--cream-deep);
  padding: 12px 16px;
  text-align: left;
  font-weight: 500;
  font-size: 11.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--stone);
}
.pominal-table tbody td {
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  vertical-align: top;
}
.pominal-table tbody td:nth-child(2) {
  white-space: nowrap;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.pominal-table tbody td:nth-child(3) {
  font-size: 13px;
  color: var(--stone);
}
.pominal-table tr.pominal-highlight {
  background: rgba(184,151,90,0.06);
}
.pominal-table tr.pominal-highlight td { color: var(--dark); }
.pominal-table tr.pominal-highlight td:nth-child(3) { color: var(--stone); }
.pominal-table tr.pominal-highlight td strong { color: var(--gold); }

.pominal-traditions {
  margin-top: 48px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px 32px;
}
.pominal-traditions h2 {
  margin: 0 0 18px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 28px;
}
.pominal-traditions h3 {
  margin: 24px 0 8px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
}
.pominal-traditions h3:first-of-type { margin-top: 0; }
.pominal-traditions ul {
  margin: 0 0 12px;
  padding-left: 20px;
  line-height: 1.6;
}
.pominal-traditions ul li { margin-bottom: 6px; font-size: 14.5px; }
.pominal-traditions p { font-size: 14.5px; line-height: 1.6; color: var(--dark); }

.pominal-cta {
  margin-top: 40px;
  background: #1d1d1d;
  color: #FAF6EE;
  border-radius: 14px;
  padding: 32px;
  text-align: center;
}
.pominal-cta h2 {
  margin: 0 0 8px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 28px;
}
.pominal-cta p {
  margin: 0 auto;
  max-width: 560px;
  color: rgba(255,255,255,0.75);
  font-size: 15px;
  line-height: 1.55;
}

@media (max-width: 640px) {
  .pominal-table thead { display: none; }
  .pominal-table tr { display: block; padding: 10px 14px; border-top: 1px solid var(--border); }
  .pominal-table tr:first-child { border-top: none; }
  .pominal-table td { display: block; padding: 4px 0; border-top: none; }
  .pominal-table td:nth-child(1) { font-weight: 500; font-size: 14px; }
  .pominal-table td:nth-child(2) { color: var(--gold); font-size: 13.5px; }
  .pominal-table td:nth-child(3) { font-size: 12.5px; }
  .pominal-traditions { padding: 22px; }
  .pominal-cta { padding: 22px; }
  .pominal-cta h2 { font-size: 22px; }
}

/* ============================================================
   Поиск по сайту: FAB + модалка с результатами
   ============================================================ */
.search-fab {
  position: fixed;
  right: 20px;
  bottom: 136px;
  z-index: 2147483638;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cream-deep);
  border: 1px solid var(--border-strong);
  color: var(--dark);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 14px rgba(0,0,0,0.10);
  transition: transform 0.15s, box-shadow 0.15s;
}
.search-fab:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,0.16); }

.search-modal {
  position: fixed;
  inset: 0;
  z-index: 2147483646;
  background: rgba(0,0,0,0.55);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 80px 16px 16px;
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  animation: search-fade 0.18s ease;
}
@keyframes search-fade { from { opacity: 0; } to { opacity: 1; } }
.search-modal-inner {
  background: var(--white);
  border-radius: 14px;
  width: 100%;
  max-width: 640px;
  max-height: 78vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
}
html[data-theme="dark"] .search-modal-inner { background: var(--cream-deep); color: var(--dark); }
.search-modal-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border, #e6dfd1);
}
.search-modal-icon { color: var(--stone, #777); flex-shrink: 0; }
.search-modal-head input {
  flex: 1;
  border: none;
  outline: none;
  font-family: inherit;
  font-size: 17px;
  background: transparent;
  color: inherit;
}
.search-modal-close {
  background: none;
  border: none;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  color: var(--stone, #777);
  width: 32px; height: 32px;
  border-radius: 50%;
}
.search-modal-close:hover { background: var(--cream-deep, #f0eadd); }
.search-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0;
}
.search-hint, .search-empty {
  padding: 16px 20px;
  color: var(--stone, #555);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}
.search-empty a { color: var(--gold, #b8975a); font-weight: 500; }
.search-results { list-style: none; padding: 0; margin: 0; }
.search-results li { border-bottom: 1px solid var(--border, #e6dfd1); }
.search-results li:last-child { border-bottom: none; }
.search-results a {
  display: block;
  padding: 14px 20px;
  text-decoration: none;
  color: inherit;
  transition: background 0.12s;
}
.search-results a:hover { background: rgba(184,151,90,0.06); }
.search-result-title {
  display: block;
  font-weight: 500;
  font-size: 15px;
  margin-bottom: 4px;
  color: var(--dark, #1d1d1d);
}
.search-result-summary {
  display: block;
  font-size: 13px;
  color: var(--stone, #555);
  line-height: 1.5;
}
.search-results mark {
  background: rgba(184,151,90,0.30);
  color: inherit;
  padding: 0 2px;
  border-radius: 2px;
}

@media (max-width: 720px) {
  .search-fab {
    bottom: calc(140px + env(safe-area-inset-bottom, 0px));
    right: 12px;
  }
  .search-modal { padding: 40px 8px 8px; }
}

/* ============================================================
   A11y: тёмная тема + крупный шрифт + FAB-переключатель
   ============================================================ */

/* Тёмная тема — token swap.
   ----------------------------------------------------
   Переопределяем основные CSS-токены, чтобы все компоненты,
   использующие var(--white)/var(--cream)/var(--dark) и т.д.,
   автоматически переключались. Затем — точечные оверрайды для
   секций, которые ДОЛЖНЫ оставаться тёмными в обоих режимах
   (hero, cta, footer, sticky-bar) — они получают литеральный
   тёмный фон.
   ============================================================ */

html[data-theme="dark"] {
  /* Поверхности (light → dark) */
  --cream:        #1a1815;
  --cream-deep:   #221f1a;
  --white:        #25221d;

  /* Текст (dark → light) */
  --dark:         #f3eddf;
  --dark-soft:    #d8d2c5;
  --stone:        #a39c8f;
  --stone-light:  #7a746a;

  /* Бордеры (light alpha → light alpha) */
  --border:        rgba(243, 237, 223, 0.10);
  --border-strong: rgba(243, 237, 223, 0.18);

  /* Gold accent — оставляем; чуть теплее для тёмного фона */
  --gold:        #c9a86d;
  --gold-light:  #d9bb86;
  --gold-soft:   rgba(201, 168, 109, 0.18);
}

/* Body — на всякий случай явно */
html[data-theme="dark"] body { background: var(--cream); color: var(--dark); }
html[data-theme="dark"] .site-header { background: var(--cream); border-bottom-color: var(--border); }

/* «Всегда тёмные» секции — фиксируем литеральным фоном, чтобы свопнутые
   токены их не инвертировали. Текст на них — светлый. */
html[data-theme="dark"] .hero,
html[data-theme="dark"] .cta-section,
html[data-theme="dark"] .site-footer,
html[data-theme="dark"] .map-promo,
html[data-theme="dark"] .call-bar,
html[data-theme="dark"] .sticky-bar,
html[data-theme="dark"] .header-top {
  background: #0d0b08 !important;
  color: #f3eddf;
}
html[data-theme="dark"] .hero h1,
html[data-theme="dark"] .hero h2,
html[data-theme="dark"] .cta-section h1,
html[data-theme="dark"] .cta-section h2,
html[data-theme="dark"] .site-footer h5 { color: #f3eddf !important; }
html[data-theme="dark"] .hero p,
html[data-theme="dark"] .hero .lead,
html[data-theme="dark"] .cta-section p,
html[data-theme="dark"] .map-promo p { color: rgba(243,237,223,0.65) !important; }

/* Кнопка btn-primary — в светлой теме чёрная, в тёмной — золотая (контрастная) */
html[data-theme="dark"] .btn-primary {
  background: var(--gold) !important;
  color: #1a1815 !important;
  border-color: var(--gold) !important;
}
html[data-theme="dark"] .btn-primary:hover {
  background: var(--gold-light) !important;
  color: #1a1815 !important;
}
/* btn-ghost на светлом фоне (после swap — тёмном) */
html[data-theme="dark"] .btn-ghost {
  color: var(--dark);
  border-color: var(--border-strong);
}
html[data-theme="dark"] .btn-ghost:hover { background: var(--white); color: var(--dark); }
/* btn-ghost-dark на CTA-section — там фон литеральный тёмный */
html[data-theme="dark"] .btn-ghost-dark {
  color: #f3eddf;
  border-color: rgba(243,237,223,0.30);
}

/* Поля форм — точечный фон поярче подложки */
html[data-theme="dark"] .form-input,
html[data-theme="dark"] .form-select,
html[data-theme="dark"] .form-textarea {
  background: #2e2a23;
  color: var(--dark);
  border-color: var(--border-strong);
}
html[data-theme="dark"] .form-input::placeholder,
html[data-theme="dark"] .form-textarea::placeholder { color: var(--stone-light); }
html[data-theme="dark"] .radio-pill { background: #2e2a23; color: var(--dark); border-color: var(--border-strong); }

/* AI helper / поиск / a11y popover — внутренние поля */
html[data-theme="dark"] .ai-helper-input input,
html[data-theme="dark"] .search-modal-head input { background: #2e2a23; color: var(--dark); }
html[data-theme="dark"] .ai-msg-bot { background: #2e2a23; color: var(--dark); }
html[data-theme="dark"] .ai-msg-user { background: var(--gold); color: #1a1815; }
html[data-theme="dark"] .a11y-btn { background: #2e2a23; color: var(--dark); border-color: var(--border-strong); }
html[data-theme="dark"] .a11y-btn.is-active { background: var(--gold); color: #1a1815; border-color: var(--gold); }
html[data-theme="dark"] .ai-helper-chip { background: #2e2a23; color: var(--dark); border-color: var(--border); }
html[data-theme="dark"] .ai-helper-chip:hover { background: #353128; border-color: var(--gold); }

/* Skip-link */
html[data-theme="dark"] .skip-link { background: var(--gold); color: #1a1815; }

/* Heat-маркеры календаря, sage-фоны — нивелируем светлые градиенты */
html[data-theme="dark"] .mgr-cal-cell-rainy { background: linear-gradient(180deg, rgba(120, 160, 220, 0.10), transparent 70%); }

/* Stars / gold accents — однотонные */
html[data-theme="dark"] .stars { color: var(--gold); }

/* Sage / sage-light в кабинетных уведомлениях — не должны быть слишком светлыми */
html[data-theme="dark"] .sage-bg,
html[data-theme="dark"] [style*="--sage-light"] { background: #25221d !important; }

/* Cookies banner — оставляем тёмным (это и в светлой теме тёмный элемент) */
html[data-theme="dark"] .cookies-banner { background: #0d0b08; }

/* Memorial QR-блок — фон на тёмном тоже белый по дизайну? Делаем тёмным */
html[data-theme="dark"] .memorial-qr-img img { background: #f3eddf; }

/* Крупный шрифт. Сайт использует px, поэтому масштабируем
   ключевые элементы вручную. */
html[data-font-size="large"] {
  font-size: 18px;
}
html[data-font-size="large"] body { font-size: 17px; line-height: 1.6; }
html[data-font-size="large"] p,
html[data-font-size="large"] li,
html[data-font-size="large"] .lead { font-size: 1.07em; line-height: 1.65; }
html[data-font-size="large"] .btn { font-size: 16px; padding: 13px 22px; }
html[data-font-size="large"] .btn-sm { font-size: 14.5px; }
html[data-font-size="large"] .btn-lg { font-size: 17.5px; padding: 16px 28px; }
html[data-font-size="large"] h1 { font-size: clamp(40px, 9vw, 64px); }
html[data-font-size="large"] h2 { font-size: clamp(28px, 6vw, 44px); }
html[data-font-size="large"] h3 { font-size: 22px; }
html[data-font-size="large"] .form-input,
html[data-font-size="large"] .form-select,
html[data-font-size="large"] .form-textarea { font-size: 17px; padding: 14px 16px; }
html[data-font-size="large"] .nav-main a { font-size: 16px; }
html[data-font-size="large"] .faq-item summary { font-size: 19px; }
html[data-font-size="large"] .faq-answer { font-size: 16px; }
html[data-font-size="large"] .breadcrumb { font-size: 14px; }
html[data-font-size="large"] .ai-helper-chip { font-size: 14.5px; padding: 11px 14px; }

/* FAB-кнопка доступности (правый нижний угол, над AI-помощником) */
.a11y-fab {
  position: fixed;
  right: 20px;
  bottom: 80px;
  z-index: 2147483639;
}
.a11y-fab-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cream-deep);
  border: 1px solid var(--border-strong);
  color: var(--dark);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 14px rgba(0,0,0,0.10);
  transition: transform 0.15s, box-shadow 0.15s;
}
.a11y-fab-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,0.16); }

.a11y-popover {
  position: absolute;
  right: 0;
  bottom: 56px;
  width: 240px;
  background: var(--white);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
  padding: 14px;
  animation: a11y-pop 0.18s cubic-bezier(.34,1.56,.64,1);
}
html[data-theme="dark"] .a11y-popover { background: var(--cream-deep); color: var(--dark); }
@keyframes a11y-pop {
  from { opacity: 0; transform: translateY(8px) scale(0.96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.a11y-popover-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}
.a11y-popover-head strong {
  font-family: var(--font-display, serif);
  font-weight: 400;
  font-size: 16px;
}
.a11y-popover-close {
  background: none;
  border: none;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  color: var(--stone, #777);
  width: 26px; height: 26px;
  border-radius: 50%;
}
.a11y-popover-close:hover { background: var(--cream-deep, #f0eadd); }
.a11y-group { margin-bottom: 10px; }
.a11y-group:last-child { margin-bottom: 0; }
.a11y-group-label {
  display: block;
  font-size: 11.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--stone, #777);
  margin-bottom: 6px;
}
.a11y-group-btns {
  display: flex;
  gap: 4px;
}
.a11y-btn {
  flex: 1;
  background: var(--cream-deep, #f0eadd);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 8px;
  padding: 8px 10px;
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  color: var(--dark, #1d1d1d);
  transition: background 0.15s, border-color 0.15s;
}
.a11y-btn:hover { background: rgba(184,151,90,0.10); }
.a11y-btn.is-active {
  background: #1d1d1d;
  color: #f8f4ec;
  border-color: var(--dark, #1d1d1d);
}

/* На мобильном FAB слегка ниже + не пересекаемся с AI-помощником */
@media (max-width: 720px) {
  .a11y-fab {
    bottom: calc(82px + env(safe-area-inset-bottom, 0px));
    right: 12px;
  }
  body.has-cookies-banner .a11y-fab {
    bottom: calc(200px + env(safe-area-inset-bottom, 0px));
  }
  /* AI-помощник смещаем на 56px влево, FAB занимает крайнее правое */
  .ai-helper-btn { right: 64px; }
}

/* ============================================================
   Подсказка про шаринг календаря дат с семьёй
   ============================================================ */
.dates-family-hint {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: linear-gradient(135deg, rgba(184,151,90,0.10), rgba(184,151,90,0.03));
  border: 1px solid rgba(184,151,90,0.25);
  border-radius: 10px;
  margin: 12px 0 18px;
  flex-wrap: wrap;
}
.dates-family-hint-icon {
  font-size: 28px;
  flex-shrink: 0;
}
.dates-family-hint-text {
  flex: 1;
  min-width: 200px;
}
.dates-family-hint-text strong {
  display: block;
  margin-bottom: 2px;
  font-size: 14px;
}
.dates-family-hint-text p {
  margin: 0;
  font-size: 13px;
  color: var(--stone, #555);
  line-height: 1.45;
}

/* ============================================================
   «Тихий час» / DND в кабинете
   ============================================================ */
.dnd-block {
  margin: 18px 0;
  padding: 14px 16px;
  background: var(--cream, #f8f4ec);
  border-radius: 10px;
  border: 1px solid var(--border, #e6dfd1);
}
.dnd-block.is-active {
  background: rgba(184,151,90,0.10);
  border-color: var(--gold, #b8975a);
}
.dnd-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.dnd-head strong {
  display: block;
  margin-bottom: 4px;
  font-size: 14px;
}
.dnd-head p {
  font-size: 13px;
  color: var(--stone, #555);
  margin: 0;
  line-height: 1.45;
}
.dnd-status {
  flex-shrink: 0;
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,0.06);
  color: var(--stone, #777);
  font-weight: 500;
  white-space: nowrap;
}
.dnd-status.is-active {
  background: var(--gold, #b8975a);
  color: #fff;
}
.dnd-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* Индикатор «не беспокоить» на карточке заявки в менеджерской */
.mgr-dnd-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  background: rgba(220, 50, 50, 0.10);
  border: 1px solid rgba(220, 50, 50, 0.3);
  color: #c43;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 12px;
}

/* ============================================================
   Directory page «Куда обращаться» (where-to-go.html)
   ============================================================ */
.dir-page { padding: 32px 0 64px; }
.dir-callout {
  background: rgba(184,151,90,0.10);
  border-left: 4px solid var(--gold, #b8975a);
  border-radius: 6px;
  padding: 14px 18px;
  margin: 0 0 32px;
  font-size: 14px;
  color: var(--dark, #1d1d1d);
  line-height: 1.55;
}
.dir-callout a { color: var(--gold, #b8975a); font-weight: 500; }
.dir-section { margin-bottom: 44px; }
.dir-section h2 {
  font-family: var(--font-display, serif);
  font-weight: 400;
  font-size: 28px;
  margin: 0 0 6px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.dir-icon {
  font-size: 24px;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--cream-deep, #f0eadd);
  border-radius: 12px;
  flex-shrink: 0;
}
.dir-section-lead {
  color: var(--stone, #555);
  font-size: 14.5px;
  line-height: 1.55;
  margin: 0 0 20px 56px;
  max-width: 720px;
}
.dir-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-left: 56px;
}
.dir-card {
  background: var(--white);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 12px;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dir-card h3 {
  margin: 0;
  font-family: var(--font-display, serif);
  font-size: 18px;
  font-weight: 500;
  color: var(--dark, #1d1d1d);
}
.dir-card p { margin: 0; font-size: 14px; color: var(--stone, #555); line-height: 1.5; }
.dir-card .dir-addr {
  font-size: 13px;
  color: var(--dark, #1d1d1d);
  font-weight: 500;
  margin-bottom: 4px;
}
.dir-card .dir-hint {
  font-size: 12.5px;
  color: var(--stone, #777);
  font-style: italic;
  margin-top: 4px;
}
.dir-card-urgent {
  background: linear-gradient(135deg, rgba(184,151,90,0.10), rgba(184,151,90,0.03));
  border-color: rgba(184,151,90,0.30);
}
.dir-phone {
  display: inline-block;
  font-family: var(--font-display, serif);
  font-size: 30px;
  font-weight: 400;
  color: var(--gold, #b8975a);
  margin: 4px 0 8px;
  text-decoration: none;
  letter-spacing: 0.02em;
}
.dir-phone:hover { color: var(--dark, #1d1d1d); }
.dir-tips {
  list-style: none;
  padding: 0;
  margin: 0 0 0 56px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.dir-tips li {
  position: relative;
  padding-left: 22px;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--dark, #1d1d1d);
}
.dir-tips li::before {
  content: '→';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--gold, #b8975a);
  font-weight: 700;
}
.dir-cta {
  background: #1d1d1d;
  color: #f8f4ec;
  border-radius: 14px;
  padding: 32px;
  text-align: center;
  margin-top: 32px;
}
.dir-cta h3 {
  margin: 0 0 6px;
  font-family: var(--font-display, serif);
  font-weight: 400;
  font-size: 26px;
}
.dir-cta p {
  margin: 0 auto 18px;
  max-width: 520px;
  color: rgba(255,255,255,0.75);
  font-size: 15px;
}
.dir-cta > div {
  justify-content: center;
}

@media (max-width: 640px) {
  .dir-section h2 { font-size: 22px; }
  .dir-icon { width: 36px; height: 36px; font-size: 20px; }
  .dir-section-lead, .dir-grid, .dir-tips { margin-left: 0; }
  .dir-phone { font-size: 24px; }
  .dir-cta { padding: 22px; }
}

/* ============================================================
   «Приглядывание» — минимальный тариф на subscriptions.html
   ============================================================ */
.watch-tier-section {
  padding: 40px 0 16px;
}
.watch-tier-card {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 32px;
  align-items: stretch;
  background: linear-gradient(135deg, rgba(184,151,90,0.08), rgba(184,151,90,0.02));
  border: 1px solid rgba(184,151,90,0.28);
  border-radius: 16px;
  padding: 32px;
}
.watch-tier-text .eyebrow {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold, #b8975a);
}
.watch-tier-text h2 {
  margin: 0 0 12px;
  font-family: var(--font-display, serif);
  font-weight: 400;
  font-size: 32px;
}
.watch-tier-text h2 em { color: var(--gold, #b8975a); font-style: italic; }
.watch-tier-text > p {
  margin: 0 0 16px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--stone, #555);
}
.watch-tier-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.watch-tier-list li {
  position: relative;
  padding-left: 24px;
  font-size: 14px;
  color: var(--dark, #1d1d1d);
  line-height: 1.4;
}
.watch-tier-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 1px;
  color: var(--gold, #b8975a);
  font-weight: 700;
}
.watch-tier-price {
  background: var(--white);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 12px;
  text-align: center;
  border: 1px solid var(--border, #e6dfd1);
}
.watch-tier-amount {
  font-family: var(--font-display, serif);
  font-size: 42px;
  font-weight: 400;
  color: var(--dark, #1d1d1d);
  line-height: 1;
}
.watch-tier-amount small {
  font-family: var(--font-body, sans-serif);
  font-size: 14px;
  color: var(--stone, #777);
  font-weight: 400;
}
.watch-tier-note {
  margin: 0;
  font-size: 12px;
  color: var(--stone, #555);
  line-height: 1.45;
}

@media (max-width: 768px) {
  .watch-tier-card {
    grid-template-columns: 1fr;
    padding: 22px;
    gap: 20px;
  }
  .watch-tier-text h2 { font-size: 26px; }
  .watch-tier-amount { font-size: 36px; }
}

/* ============================================================
   FAQ section на лендинге
   ============================================================ */
.faq-section {
  padding: 80px 0;
  background: var(--cream-deep, #f0eadd);
}
.faq-section .section-header {
  text-align: center;
  margin-bottom: 48px;
}
.faq-list {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.faq-item {
  background: var(--white);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 12px;
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.faq-item[open] {
  border-color: var(--gold, #b8975a);
  box-shadow: 0 4px 24px rgba(184, 151, 90, 0.08);
}
.faq-item summary {
  padding: 18px 56px 18px 24px;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display, serif);
  font-size: 18px;
  font-weight: 400;
  color: var(--dark, #1d1d1d);
  position: relative;
  user-select: none;
  min-height: 44px;
  display: flex;
  align-items: center;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  width: 14px;
  height: 14px;
  border-right: 2px solid var(--stone, #888);
  border-bottom: 2px solid var(--stone, #888);
  transform: translateY(-70%) rotate(45deg);
  transition: transform 0.2s ease, border-color 0.2s ease;
}
.faq-item[open] summary::after {
  transform: translateY(-30%) rotate(-135deg);
  border-color: var(--gold, #b8975a);
}
.faq-item summary:hover { background: rgba(184, 151, 90, 0.04); }
.faq-answer {
  padding: 0 24px 20px;
  color: var(--stone, #555);
  font-size: 15px;
  line-height: 1.6;
}
.faq-answer p { margin: 0; }
.faq-answer a { color: var(--gold, #b8975a); }
.faq-cta {
  text-align: center;
  margin-top: 32px;
  color: var(--stone, #555);
}
.faq-cta a {
  color: var(--gold, #b8975a);
  font-weight: 500;
}

@media (max-width: 768px) {
  .faq-section { padding: 56px 0; }
  .faq-item summary { font-size: 16px; padding: 16px 48px 16px 18px; }
  .faq-item summary::after { right: 18px; width: 12px; height: 12px; }
  .faq-answer { padding: 0 18px 18px; font-size: 14px; }
}

/* ============================================================
   A11y addendum — focus, skip-link, reduced-motion, sr-only
   ============================================================ */

/* Видимый focus-ring только для клавиатуры (не для мыши/тача) */
:focus-visible {
  outline: 2px solid var(--gold, #b8975a);
  outline-offset: 2px;
  border-radius: 4px;
}
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible,
summary:focus-visible {
  outline: 2px solid var(--gold, #b8975a);
  outline-offset: 2px;
}
/* Уберём дефолтный focus на мыши */
button:focus:not(:focus-visible),
a:focus:not(:focus-visible) {
  outline: none;
}

/* Skip-link — на Tab появляется в левом верхнем углу */
.skip-link {
  position: absolute;
  top: -100px;
  left: 8px;
  background: #1d1d1d;
  color: #f8f4ec;
  padding: 10px 16px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  z-index: 2147483647;
  transition: top 0.18s ease;
}
.skip-link:focus { top: 8px; }

/* sr-only — текст для screen-reader, визуально скрыт */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* Менеджерский календарь: фокус «сегодня/завтра» */
.mgr-cal-focus {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 0 0 24px;
}
.mgr-cal-focus-col {
  background: var(--white);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 10px;
  padding: 14px 16px;
}
.mgr-cal-focus-col h4 {
  margin: 0 0 10px;
  font-family: var(--font-display, serif);
  font-size: 16px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 8px;
}
.mgr-cal-focus-count {
  background: var(--cream-deep, #f0eadd);
  color: var(--stone, #555);
  font-family: var(--font-body, sans-serif);
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 500;
}
.mgr-cal-focus-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.mgr-cal-focus-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  background: var(--cream-deep, #f0eadd);
  border-radius: 6px;
  padding: 8px 10px;
  font-size: 13px;
}
.mgr-cal-focus-item.type-memorial { background: rgba(255, 200, 100, 0.15); }
.mgr-cal-focus-item.type-visit { background: rgba(120, 200, 130, 0.13); }
.mgr-cal-focus-item.type-billing { background: rgba(180, 150, 255, 0.13); }
.mgr-cal-focus-item.type-order { background: rgba(200, 180, 130, 0.18); }
.mgr-cal-focus-ico { font-size: 16px; flex-shrink: 0; }
.mgr-cal-focus-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mgr-cal-focus-text b { font-weight: 500; word-break: break-word; }
.mgr-cal-focus-text small { color: var(--stone, #555); font-size: 11.5px; word-break: break-word; }
.mgr-cal-focus-empty { color: var(--stone, #777); font-style: italic; font-size: 12.5px; padding: 6px 0; }

@media (max-width: 768px) {
  .mgr-cal-focus { grid-template-columns: 1fr; gap: 10px; }
}

/* ============================================================
   Генератор некролога (nekrolog.html)
   ============================================================ */
.nekrolog-page { padding: 32px 0 64px; }
.nekrolog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px;
  max-width: 860px;
  margin: 0 auto;
}
.nekrolog-grid {
  display: grid;
  grid-template-columns: 1fr 120px 120px;
  gap: 14px;
  align-items: end;
}
@media (max-width: 720px) {
  .nekrolog-grid { grid-template-columns: 1fr 1fr; }
  .nekrolog-card { padding: 22px; }
}
.nekrolog-results-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.nekrolog-result {
  background: var(--cream-deep);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px 22px;
}
.nekrolog-result-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.nekrolog-result-tag {
  display: inline-block;
  background: var(--gold);
  color: #fff;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.nekrolog-result-meta {
  font-size: 12px;
  color: var(--stone);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.nekrolog-result-body {
  font-family: var(--font-display);
  font-size: 17.5px;
  line-height: 1.6;
  color: var(--dark);
  margin: 0 0 14px;
  white-space: pre-wrap;
}
.nekrolog-result-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.nekrolog-tips {
  max-width: 860px;
  margin: 32px auto 0;
  background: rgba(184,151,90,0.06);
  border-left: 3px solid var(--gold);
  border-radius: 8px;
  padding: 18px 22px;
}
.nekrolog-tips h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 20px;
  margin: 0 0 10px;
}
.nekrolog-tips ul {
  margin: 0;
  padding-left: 22px;
  line-height: 1.65;
}
.nekrolog-tips li { margin-bottom: 6px; font-size: 14.5px; }

@media print {
  .site-header, .site-footer, .skip-link, .sticky-bar,
  .ai-helper-btn, .search-fab, .a11y-fab, .nekrolog-tips,
  form[data-nekrolog-form] { display: none !important; }
  body { background: #fff; }
  .nekrolog-result { page-break-inside: avoid; }
  .nekrolog-result-actions { display: none !important; }
}

/* ============================================================
   Воронка прохождения заявок (KPI tab → секция «Воронка»)
   ============================================================ */
.mgr-funnel {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}
.mgr-funnel-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  margin: 0 0 18px;
}
.mgr-funnel-pipeline {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.mgr-funnel-step {
  flex: 1;
  min-width: 180px;
  padding: 18px 22px;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mgr-funnel-count {
  font-family: var(--font-display);
  font-size: 38px;
  line-height: 1;
  font-weight: 400;
}
.mgr-funnel-label {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.95;
}
.mgr-funnel-sub {
  font-size: 12px;
  opacity: 0.78;
  margin-top: 2px;
}
.mgr-funnel-arrow {
  font-size: 24px;
  color: var(--stone);
  font-weight: 600;
  flex-shrink: 0;
  text-align: center;
}
.mgr-funnel-arrow small {
  display: block;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.mgr-funnel-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
.mgr-funnel-metric {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 18px;
}
.mgr-funnel-metric-num {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 1;
  margin-bottom: 6px;
}
.mgr-funnel-metric-lbl {
  font-size: 12px;
  color: var(--stone);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.4;
}
.mgr-funnel-metric-lbl small {
  display: block;
  text-transform: none;
  letter-spacing: 0;
  font-size: 11.5px;
  margin-top: 3px;
  opacity: 0.8;
}

@media (max-width: 768px) {
  .mgr-funnel-pipeline { flex-direction: column; }
  .mgr-funnel-step { width: 100% !important; }
  .mgr-funnel-arrow { transform: rotate(90deg); margin: 4px 0; }
}

/* ============================================================
   Метрики менеджеров (вкладка «Команда» → «Метрики работы»)
   ============================================================ */
[data-metrics-period].is-active {
  background: #1d1d1d !important;
  color: #f8f4ec !important;
  border-color: #1d1d1d !important;
}
.mgr-metrics-wrap {
  background: var(--white);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 10px;
  padding: 16px;
}
.mgr-metrics-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.mgr-metrics-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  min-width: 720px;
}
.mgr-metrics-table th,
.mgr-metrics-table td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border, #e6dfd1);
  vertical-align: middle;
}
.mgr-metrics-table th {
  font-weight: 500;
  color: var(--stone, #777);
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: var(--cream-deep, #f0eadd);
}
.mgr-metrics-table th.num,
.mgr-metrics-table td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.mgr-metrics-table tbody tr:hover { background: rgba(184,151,90,0.04); }
.mgr-metrics-table tbody tr:last-child td { border-bottom: none; }
.mgr-metric-name { font-weight: 500; }
.mgr-metric-email { font-size: 11.5px; color: var(--stone, #777); }
.mgr-metric-empty { color: var(--stone-light, #aaa); }
.mgr-metrics-hint {
  margin-top: 12px;
  font-size: 11.5px;
  color: var(--stone, #777);
  line-height: 1.5;
}

/* ============================================================
   Шаблоны сообщений в карточке заявки
   ============================================================ */
.mgr-tpl-tabs {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.mgr-tpl-tab {
  background: var(--cream-deep, #f0eadd);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 999px;
  padding: 6px 14px;
  font-size: 12.5px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  font-family: inherit;
  color: var(--dark, #1d1d1d);
}
.mgr-tpl-tab:hover { background: rgba(184,151,90,0.10); }
.mgr-tpl-tab.is-active {
  background: #1d1d1d;
  color: #f8f4ec;
  border-color: var(--dark, #1d1d1d);
}
.mgr-tpl-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.mgr-tpl-card {
  background: var(--cream-deep, #f0eadd);
  border: 1px solid var(--border, #e6dfd1);
  border-radius: 8px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mgr-tpl-card-title {
  font-weight: 500;
  font-size: 13.5px;
  color: var(--dark, #1d1d1d);
}
.mgr-tpl-card-preview {
  font-size: 12px;
  color: var(--stone, #777);
  line-height: 1.4;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mgr-tpl-card-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .mgr-tpl-list { grid-template-columns: 1fr; }
}

/* Mini-кнопка для quick-templates в менеджерской */
.btn-xs {
  padding: 5px 10px !important;
  font-size: 11.5px !important;
  border-radius: 6px !important;
  line-height: 1.3 !important;
  min-height: auto !important;
}
.mgr-quick-templates .btn-xs {
  background: var(--cream-deep, #f0eadd);
  border: 1px solid var(--border, #e6dfd1);
  color: var(--dark, #1d1d1d);
}
.mgr-quick-templates .btn-xs:hover {
  background: rgba(184,151,90,0.10);
  border-color: var(--gold, #b8975a);
}

/* Глобальный prefers-reduced-motion — выключаем анимации
   (раньше было только для skeleton, расширяем на всё) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1 !important; transform: none !important; }
}
