/* ===== Shared contact modal (used in /blog/*) =====
   Источник: index.html (главная страница). Один источник правды.
   Для подключения: <link rel="stylesheet" href="/css/contact-modal.css">
   Цветовые переменные (--navy-800, --gold-500 и т.д.) должны быть объявлены в :root страницы. */

/* Scroll lock */
html.scroll-locked,body.scroll-locked{overflow:hidden!important}

/* Тост (для ошибок отправки лида) */
.email-toast{
  position:fixed;bottom:24px;left:50%;transform:translate(-50%, 20px);
  background:var(--navy-800);color:#fff;padding:12px 18px;border-radius:8px;
  box-shadow:0 10px 30px rgba(6,22,51,0.3);z-index:400;
  display:flex;align-items:center;gap:10px;
  font-size:14px;line-height:1.4;
  opacity:0;visibility:hidden;transition:opacity .25s ease, transform .25s ease, visibility .25s;
  max-width:calc(100vw - 32px);
}
.email-toast.visible{opacity:1;visibility:visible;transform:translate(-50%, 0)}
.email-toast svg{color:var(--gold-400);flex-shrink:0}
.email-toast strong{color:var(--gold-400);font-weight:600;word-break:break-all}
.email-toast.lead-error{background:#8C2B2B}
.email-toast.lead-error svg{color:#FFB4B4}

/* Модалка */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(6,22,51,0.6);z-index:300;
  display:none;align-items:center;justify-content:center;padding:24px;
  backdrop-filter:blur(4px);
}
.modal-backdrop.open{display:flex;animation:cm-fadeIn .25s ease}
@keyframes cm-fadeIn{from{opacity:0}to{opacity:1}}
.modal-backdrop .modal{background:#fff;max-width:440px;width:100%;position:relative;max-height:90vh;overflow:hidden;animation:cm-slideUp .3s ease;display:flex;flex-direction:column;border-radius:4px}
@keyframes cm-slideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}

.modal-close{
  position:absolute;top:14px;right:14px;width:32px;height:32px;border:none;background:rgba(255,255,255,0.92);border-radius:50%;
  cursor:pointer;color:var(--navy-800);display:grid;place-items:center;z-index:3;
  transition:background .2s,color .2s;
}
.modal-close:hover{background:var(--navy-800);color:#fff}
.modal-close:focus-visible{outline:2px solid var(--gold-500);outline-offset:2px}

.modal-header{display:flex;align-items:center;gap:14px;padding:16px 52px 14px 22px;border-bottom:1px solid var(--line);flex-shrink:0;background:#fff}
.modal-avatar{
  width:48px;height:48px;border-radius:50%;flex-shrink:0;overflow:hidden;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  display:grid;place-items:center;color:#fff;
  font-family:'Playfair Display',serif;font-size:18px;font-weight:500;letter-spacing:0.02em;
}
.modal-avatar img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
.modal-avatar picture{display:contents}
.modal-person-name{font-weight:600;font-size:15px;color:var(--navy-800);line-height:1.2;margin-bottom:3px}
.modal-person-meta{font-size:11px;color:var(--muted);line-height:1.4}

.modal-tabs{display:flex;background:#F7F5EF;flex-shrink:0;border-bottom:1px solid var(--line)}
.modal-tab{
  flex:1;padding:12px 10px;border:none;background:transparent;cursor:pointer;
  font-family:inherit;font-size:13px;font-weight:600;color:var(--muted);letter-spacing:0.02em;
  transition:color .2s,background .2s;position:relative;
}
.modal-tab:hover{color:var(--navy-800)}
.modal-tab.active{color:var(--navy-800);background:#fff}
.modal-tab.active::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--gold-500)}
.modal-tab:focus-visible{outline:2px solid var(--gold-500);outline-offset:-4px;border-radius:2px}

.modal-scroll{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:16px 22px 18px}
.modal-pane{display:none}
.modal-pane.active{display:block;animation:cm-fadeIn .2s ease}
.modal-pane-title{font-family:'Playfair Display',serif;font-weight:500;font-size:18px;color:var(--navy-800);line-height:1.2;margin:0 0 4px}
.modal-pane-sub{font-size:13px;color:var(--muted);line-height:1.45;margin:0 0 12px}
.modal-pane-sub.pane-sub-compact{margin:0 0 8px;font-size:12px}

.modal .field{margin-bottom:10px}
.modal .field > label{display:block;font-size:11px;color:var(--navy-800);font-weight:600;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:4px}
.modal .field input[type="tel"],
.modal .field input[type="email"],
.modal .field input[type="text"],
.modal .field textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);background:#fff;color:var(--ink);
  font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s;
}
.modal .field input:focus,.modal .field textarea:focus{outline:none;border-color:var(--gold-500);box-shadow:0 0 0 3px rgba(201,169,110,0.15)}
.modal .field textarea{resize:vertical;min-height:52px;line-height:1.45}
.modal .field .err{color:#C0392B;font-size:12px;margin-top:3px;min-height:14px;line-height:1.4}

.reply-channel{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.reply-option{cursor:pointer;position:relative;min-width:0}
.reply-option input{position:absolute;opacity:0;pointer-events:none}
.reply-option span{
  display:block;text-align:center;padding:14px 4px;border:1px solid var(--line);font-size:12px;font-weight:600;
  letter-spacing:0.02em;color:var(--muted);transition:all .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
@media (max-width:400px){
  .reply-channel{grid-template-columns:repeat(2,1fr);gap:6px}
}
.reply-option:hover span{border-color:var(--gold-500);color:var(--navy-800)}
.reply-option input:checked ~ span{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}
.reply-option input:focus-visible ~ span{outline:2px solid var(--gold-500);outline-offset:2px}

.modal .consent{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:var(--muted);line-height:1.45;margin:4px 0 10px;cursor:pointer}
.modal .consent input{margin-top:2px;flex-shrink:0;accent-color:var(--navy-800)}
.modal .consent a{color:var(--navy-800);text-decoration:underline;text-decoration-color:var(--gold-500)}
.modal .submit-btn{
  width:100%;padding:11px;font-size:14px;font-weight:600;background:var(--navy-800);color:#fff;
  border:none;cursor:pointer;font-family:inherit;letter-spacing:0.02em;transition:background .2s;
}
.modal .submit-btn:hover{background:var(--navy-900)}
.modal .submit-btn:disabled{opacity:0.6;cursor:not-allowed}
.modal .submit-btn:focus-visible{outline:2px solid var(--gold-500);outline-offset:2px}

.modal-trust{
  padding:8px 22px;border-top:1px solid var(--line);background:#FBFAF7;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:11px;color:var(--muted);flex-shrink:0;
}
.modal-trust-label{color:var(--muted)}
.modal-trust a{color:var(--navy-800);text-decoration:underline;text-decoration-color:var(--gold-500);font-weight:600}
.modal-trust a:hover{color:var(--gold-500)}

@media (max-width:480px){
  .modal-header{padding:18px 46px 14px 16px;gap:10px}
  .modal-avatar{width:42px;height:42px;font-size:15px}
  .modal-person-name{font-size:14px}
  .modal-scroll{padding:18px 16px}
  .modal-pane-title{font-size:18px}
  .modal-trust{padding:10px 16px}
}

/* На стрице блога article a получает gold-underline — отменяем для модалки */
article .modal-backdrop a{text-decoration:none}
