/* ==========================================================================
   NV Product Catalog — карточка товара маркетплейса (v2)
   Namespace: .nvmc-*  (изолирован от старых .nvpc-* стилей product.css,
   которые всё ещё использует старый шаблон templates/product-page.php —
   намеренно не трогаем их, чтобы не сломать старую выдачу).
   ========================================================================== */
.nvmc{--ink:#0a0a0b;--ink-2:#5b5d63;--ink-3:#8b8d94;--line:#e8e8ea;--line-2:#f1f1f3;
  --bg:#f6f6f7;--card:#ffffff;--brand:#2f5bff;--brand-ink:#1a3ed1;--brand-soft:#eef2ff;
  --green:#0f9d58;--green-soft:#e7f6ee;--amber:#b9760a;--amber-soft:#fbf1df;
  --red:#d8412f;--red-soft:#fdeceb;--radius:16px;--radius-sm:11px;
  --shadow-sm:0 1px 2px rgba(10,10,11,.05);--shadow:0 1px 2px rgba(10,10,11,.04),0 10px 30px rgba(10,10,11,.07);
  font-family:'Inter',system-ui,sans-serif;color:var(--ink);line-height:1.5;max-width:1180px;margin:0 auto;padding:0 16px 40px;
}
.nvmc *{box-sizing:border-box}
.nvmc h1,.nvmc h2,.nvmc h3,.nvmc h4{font-family:'Manrope','Inter',sans-serif;letter-spacing:-.02em;margin:0}
.nvmc a{color:inherit;text-decoration:none}
.nvmc button{font-family:inherit}

.nvmc-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:4px 9px;border-radius:7px;line-height:1}
.nvmc-b-green{background:var(--green-soft);color:var(--green)}
.nvmc-b-brand{background:var(--brand-soft);color:var(--brand-ink)}
.nvmc-b-gray{background:#f0f0f2;color:var(--ink-2)}
.nvmc-stars{color:#f5a623;letter-spacing:1px}
.nvmc-verif{color:var(--brand);display:inline-flex}

.nvmc-btn{font-family:'Manrope';font-weight:700;border:0;border-radius:11px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.15s;font-size:14px;white-space:nowrap}
.nvmc-btn-primary{background:var(--brand);color:#fff;padding:12px 16px}.nvmc-btn-primary:hover{background:var(--brand-ink)}
.nvmc-btn-call{background:#fff;color:var(--ink);border:1px solid var(--line);padding:11px 14px;font-family:'Inter';font-weight:700}
.nvmc-btn-call:hover{border-color:var(--ink-3)}
.nvmc-btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);padding:11px 15px}.nvmc-btn-ghost:hover{border-color:var(--ink-3)}
.nvmc-btn-soft{background:var(--brand-soft);color:var(--brand-ink);padding:12px 16px}.nvmc-btn-soft:hover{background:#e2e8ff}
.nvmc-btn[disabled]{opacity:.6;cursor:not-allowed}

.nvmc-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.nvmc-section{margin:34px 0}
.nvmc-section>h2{font-size:21px;margin-bottom:16px;display:flex;align-items:center;gap:9px}
.nvmc-section>h2 .nvmc-cnt{font-size:13px;font-weight:600;color:var(--ink-3);font-family:'Inter'}
.nvmc-ico{color:var(--brand);flex-shrink:0}
.nvmc-ico svg{width:20px;height:20px;display:block}

/* ===== HERO ===== */
.nvmc-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:26px;align-items:start;margin:20px 0 8px}
.nvmc-gallery__main{width:100%;aspect-ratio:4/3;border-radius:14px;object-fit:cover;background:#f0f0f2;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.nvmc-gallery__main img{width:100%;height:100%;object-fit:cover}
.nvmc-gallery__placeholder{color:var(--ink-3);font-size:14px;text-align:center}
.nvmc-gallery__counter{position:absolute;bottom:10px;right:10px;background:rgba(10,10,11,.6);color:#fff;font-size:12px;padding:3px 9px;border-radius:20px}
.nvmc-gallery__thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.nvmc-gallery__thumb{flex:1;min-width:60px;aspect-ratio:1.3;border-radius:9px;background:#f0f0f2;border:1px solid var(--line);cursor:pointer;overflow:hidden}
.nvmc-gallery__thumb img{width:100%;height:100%;object-fit:cover}
.nvmc-gallery__thumb--active{outline:2px solid var(--brand);outline-offset:1px}

.nvmc-h-title{font-size:24px;line-height:1.18;margin:2px 0 12px}
.nvmc-h-meta{display:flex;gap:9px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.nvmc-h-price{display:flex;align-items:baseline;gap:10px;margin-bottom:16px}
.nvmc-h-price .nvmc-big{font-family:'Manrope';font-weight:800;font-size:30px}
.nvmc-h-price .nvmc-u{font-size:13px;color:var(--ink-2)}
.nvmc-h-price .nvmc-from{font-size:12px;color:var(--ink-3)}

.nvmc-about{border:1px solid var(--line);border-radius:13px;overflow:hidden;margin-bottom:16px}
.nvmc-about .nvmc-r{display:flex;justify-content:space-between;gap:14px;padding:10px 14px;font-size:13px;border-bottom:1px solid var(--line-2)}
.nvmc-about .nvmc-r:last-child{border:0}
.nvmc-about .nvmc-r span:first-child{color:var(--ink-2)}
.nvmc-about .nvmc-r span:last-child{font-weight:600;text-align:right}

.nvmc-best-offer{border:1.5px solid var(--brand);border-radius:14px;padding:16px;position:relative;background:#fbfcff}
.nvmc-best-offer::before{content:"Лучшее предложение";position:absolute;top:-11px;left:16px;background:var(--brand);color:#fff;font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px;font-family:'Manrope'}
.nvmc-bo-co{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.nvmc-bo-co .nvmc-lg{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff;font-family:'Manrope';font-weight:800;flex-shrink:0}
.nvmc-bo-co h4{font-size:15px;display:flex;align-items:center;gap:6px}
.nvmc-bo-co .nvmc-sub{font-size:12px;color:var(--ink-2);margin-top:2px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.nvmc-bo-price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin:2px 0 12px}
.nvmc-bo-price__big{font-family:'Manrope';font-weight:800;font-size:22px;color:var(--ink)}
.nvmc-bo-price__u{font-size:12px;color:var(--ink-2)}
.nvmc-bo-price__tier{font-size:11px;color:var(--ink-3);width:100%}
.nvmc-bo-facts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:13px}
.nvmc-bo-facts .nvmc-f{font-size:12px;color:var(--ink-2);display:inline-flex;align-items:center;gap:5px;background:#f5f6f8;padding:6px 9px;border-radius:8px}
.nvmc-bo-cta{display:flex;gap:8px;align-items:stretch}
.nvmc-bo-cta .nvmc-btn-primary{flex:1 1 auto;min-width:0;padding:12px 10px;font-size:13px}
.nvmc-bo-cta .nvmc-btn-primary,
.nvmc-bo-cta .nvmc-btn-call{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nvmc-bo-cta .nvmc-btn-call{flex:0 1 auto;min-width:0;padding:11px 12px;font-size:13px}
@media(max-width:380px){
  .nvmc-bo-cta{flex-wrap:wrap}
  .nvmc-bo-cta .nvmc-btn-primary,
  .nvmc-bo-cta .nvmc-btn-call{flex:1 1 100%}
}
.nvmc-phone-num{font-family:'Manrope';font-weight:700}

/* ===== TRUST ===== */
.nvmc-trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.nvmc-trust-grid .nvmc-t{padding:16px;text-align:left}
.nvmc-trust-grid .nvmc-t .nvmc-ico{margin-bottom:9px}
.nvmc-trust-grid .nvmc-t b{font-family:'Manrope';font-size:13.5px;display:block;margin-bottom:3px}
.nvmc-trust-grid .nvmc-t p{font-size:12px;color:var(--ink-2);line-height:1.45;margin:0}

/* ===== CHARACTERISTICS ===== */
.nvmc-specs{display:grid;grid-template-columns:1fr 1fr;gap:0 36px}
.nvmc-specs .nvmc-s{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line-2);font-size:13.5px}
.nvmc-specs .nvmc-s span:first-child{color:var(--ink-2)}
.nvmc-specs .nvmc-s span:last-child{font-weight:600;text-align:right}
.nvmc-desc{font-size:14.5px;color:var(--ink-2);line-height:1.65;padding:22px 24px}
.nvmc-desc p{margin:0 0 10px}
.nvmc-desc-empty{color:var(--ink-3);font-style:italic}

/* ===== OFFERS ===== */
.nvmc-offer{display:grid;grid-template-columns:1.5fr 1fr .9fr 1.1fr auto;gap:18px;align-items:center;padding:18px 20px;border-bottom:1px solid var(--line-2)}
.nvmc-offer:last-child{border:0}
.nvmc-offer--top{background:#fbfcff}
.nvmc-offer[hidden]{display:none}
.nvmc-co{display:flex;align-items:center;gap:12px}
.nvmc-co .nvmc-lg{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;color:#fff;font-family:'Manrope';font-weight:800;font-size:16px;flex-shrink:0}
.nvmc-co h4{font-size:14.5px;display:flex;align-items:center;gap:6px}
.nvmc-co .nvmc-rate{font-size:12px;color:var(--ink-2);margin-top:3px;display:flex;align-items:center;gap:5px}
.nvmc-co .nvmc-verified{font-size:11.5px;color:var(--green);display:flex;align-items:center;gap:4px;margin-top:4px}
.nvmc-co .nvmc-hours{font-size:11.5px;color:var(--ink-3);margin-top:4px;display:flex;align-items:center;gap:5px}
.nvmc-o-price .nvmc-big{font-family:'Manrope';font-weight:800;font-size:19px}
.nvmc-o-price .nvmc-u{font-size:11.5px;color:var(--ink-2)}
.nvmc-o-price .nvmc-tier{font-size:11px;color:var(--ink-3);margin-top:3px}
.nvmc-o-dep .nvmc-l{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3)}
.nvmc-o-dep .nvmc-v{font-weight:700;font-size:14px;margin-top:2px}
.nvmc-o-dep .nvmc-ret{font-size:10.5px;color:var(--green);margin-top:2px}
.nvmc-o-get{font-size:12px;color:var(--ink-2);display:flex;flex-direction:column;gap:4px}
.nvmc-o-get span{display:flex;align-items:center;gap:5px}
.nvmc-o-cta{display:flex;flex-direction:column;gap:8px;min-width:170px}
.nvmc-desclink{font-size:12px;color:var(--brand-ink);display:inline-flex;align-items:center;gap:4px;margin-top:4px}

.nvmc-sort{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.nvmc-chip{font-size:12.5px;font-weight:600;color:var(--ink-2);border:1px solid var(--line);background:#fff;padding:7px 12px;border-radius:9px;cursor:pointer}
.nvmc-chip.nvmc-on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ===== MAP ===== */
.nvmc-map-wrap{display:grid;grid-template-columns:1.6fr 1fr;gap:0;overflow:hidden}
.nvmc-map-canvas{height:340px;background:linear-gradient(135deg,#e9eef3,#dde5ec);position:relative}
.nvmc-map-canvas .ymaps-2-1-79-map,.nvmc-map-canvas [class*="ymaps"]{border-radius:0}
.nvmc-map-list{padding:8px 0;max-height:340px;overflow:auto}
.nvmc-map-item{display:flex;gap:11px;padding:13px 18px;border-bottom:1px solid var(--line-2);cursor:pointer}
.nvmc-map-item:hover{background:#fafafb}
.nvmc-map-item .nvmc-lg{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;color:#fff;font-family:'Manrope';font-weight:800;font-size:13px;flex-shrink:0}
.nvmc-map-item h5{font-size:13.5px;display:flex;align-items:center;gap:5px;margin:0}
.nvmc-map-item .nvmc-mi-sub{font-size:11.5px;color:var(--ink-2);margin-top:3px}
.nvmc-map-item .nvmc-mi-price{font-size:12px;font-weight:700;color:var(--brand-ink);margin-top:4px}
.nvmc-map-empty{padding:24px 18px;color:var(--ink-3);font-size:13px;text-align:center}

/* ===== BUNDLE / SIMILAR ===== */
.nvmc-bundle{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.nvmc-bnd{display:flex;gap:12px;padding:14px;align-items:center}
.nvmc-bnd .nvmc-img{width:56px;height:56px;border-radius:10px;background:#f0f0f2;border:1px solid var(--line);flex-shrink:0;overflow:hidden}
.nvmc-bnd .nvmc-img img{width:100%;height:100%;object-fit:cover}
.nvmc-bnd h5{font-size:13px;line-height:1.3;margin:0}
.nvmc-bnd .nvmc-p{font-size:12px;color:var(--brand-ink);font-weight:700;margin-top:4px}

.nvmc-similar{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.nvmc-sim{padding:14px}
.nvmc-sim .nvmc-img{aspect-ratio:1.2;border-radius:11px;background:#f0f0f2;border:1px solid var(--line);position:relative;margin-bottom:11px;overflow:hidden}
.nvmc-sim .nvmc-img img{width:100%;height:100%;object-fit:cover}
.nvmc-sim .nvmc-rateb{position:absolute;bottom:8px;left:8px;background:#0c8b53;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:6px}
.nvmc-sim .nvmc-p{font-family:'Manrope';font-weight:800;font-size:16px}
.nvmc-sim .nvmc-pu{font-size:11px;color:var(--ink-2)}
.nvmc-sim .nvmc-name{font-size:13px;margin:5px 0 10px;line-height:1.35;min-height:34px}
.nvmc-sim .nvmc-meta{font-size:11px;color:var(--ink-3);margin-bottom:9px}

/* ===== FAQ ===== */
.nvmc-faq .nvmc-q{padding:15px 22px;border-bottom:1px solid var(--line-2)}
.nvmc-faq .nvmc-q:last-child{border:0}
.nvmc-faq .nvmc-q summary{font-family:'Manrope';font-weight:700;font-size:14px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:10px}
.nvmc-faq .nvmc-q summary::-webkit-details-marker{display:none}
.nvmc-faq .nvmc-q summary .nvmc-chev{transition:.2s;color:var(--ink-3);flex-shrink:0}
.nvmc-faq .nvmc-q[open] summary .nvmc-chev{transform:rotate(180deg)}
.nvmc-faq .nvmc-q p{font-size:13.5px;color:var(--ink-2);line-height:1.6;margin:10px 0 0}

/* ===== REVIEWS ===== */
.nvmc-rev-summary{display:flex;gap:24px;align-items:center;padding:18px 22px;margin-bottom:16px;flex-wrap:wrap}
.nvmc-rev-summary .nvmc-num{font-family:'Manrope';font-weight:800;font-size:46px;line-height:1}
.nvmc-rev-summary .nvmc-bars{flex:1;min-width:180px}
.nvmc-bar-row{display:flex;align-items:center;gap:9px;font-size:11.5px;color:var(--ink-2);margin:3px 0}
.nvmc-bar-row .nvmc-tr{width:100px;height:6px;background:#eee;border-radius:3px;overflow:hidden}
.nvmc-bar-row .nvmc-tr i{display:block;height:100%;background:#f5a623;border-radius:3px}
.nvmc-rev-grid{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}
.nvmc-rev-form{padding:22px 24px}
.nvmc-rev-form h3{font-size:17px;margin-bottom:5px}
.nvmc-rev-form .nvmc-sm{font-size:12.5px;color:var(--ink-2);margin-bottom:16px}
.nvmc-starpick{display:flex;gap:5px;font-size:26px;color:#e0e0e3;margin-bottom:16px;cursor:pointer}
.nvmc-starpick span.nvmc-on{color:#f5a623}
.nvmc-field{margin-bottom:12px}
.nvmc-field label{font-size:12px;font-weight:600;color:var(--ink-2);display:block;margin-bottom:6px}
.nvmc-field input,.nvmc-field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:14px;font-family:'Inter';background:#fafafb;transition:.15s}
.nvmc-field input:focus,.nvmc-field textarea:focus{outline:0;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(47,91,255,.1)}
.nvmc-field textarea{min-height:96px;resize:vertical}
.nvmc-agree{display:flex;gap:8px;font-size:12px;color:var(--ink-2);margin:6px 0 16px;align-items:flex-start}
.nvmc-agree input{margin-top:2px}
.nvmc-review{padding:18px 22px;border-bottom:1px solid var(--line-2)}
.nvmc-review:last-child{border:0}
.nvmc-rv-head{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.nvmc-rv-av{width:38px;height:38px;border-radius:10px;background:var(--brand-soft);color:var(--brand-ink);display:grid;place-items:center;font-weight:800;font-family:'Manrope';flex-shrink:0}
.nvmc-rv-head h5{font-size:14px;margin:0}
.nvmc-rv-head .nvmc-d{font-size:11.5px;color:var(--ink-3);margin-top:1px}
.nvmc-rv-text{font-size:13.5px;color:var(--ink-2);line-height:1.6}
.nvmc-rv-company{font-size:11.5px;color:var(--ink-3);margin-top:8px;display:flex;align-items:center;gap:5px}
.nvmc-reviews-empty{padding:24px;text-align:center;color:var(--ink-3);font-size:13.5px}
.nvmc-review-msg{padding:10px 13px;border-radius:10px;font-size:13px;margin-top:10px}
.nvmc-review-msg--ok{background:var(--green-soft);color:var(--green)}
.nvmc-review-msg--err{background:var(--red-soft);color:var(--red)}

/* ===== breadcrumb (использует уже существующие классы темы, тут только маркетплейс-обёртка) ===== */
.nvmc-crumb{font-size:12.5px;color:var(--ink-3);margin:14px 0;display:flex;gap:7px;align-items:center;flex-wrap:wrap}

/* ===== sticky mobile bar ===== */
.nvmc-mbar{display:none}

@media(max-width:980px){
  .nvmc-hero{grid-template-columns:1fr}
  .nvmc-specs,.nvmc-similar,.nvmc-trust-grid,.nvmc-map-wrap,.nvmc-rev-grid,.nvmc-bundle{grid-template-columns:1fr}
  .nvmc-offer{grid-template-columns:1fr 1fr;gap:14px}
  .nvmc-offer .nvmc-o-cta{grid-column:1/-1;flex-direction:row;flex-wrap:wrap}
  .nvmc-similar{grid-template-columns:1fr 1fr}
  .nvmc-map-canvas{height:240px}
}
@media(max-width:560px){
  .nvmc-similar{grid-template-columns:1fr 1fr}
  .nvmc-offer{grid-template-columns:1fr}
  .nvmc-mbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:600;background:#fff;border-top:1px solid var(--line);padding:10px 14px;gap:10px;box-shadow:0 -4px 20px rgba(0,0,0,.06)}
  .nvmc-mbar .nvmc-btn{flex:1}
  body.nvmc-has-mbar{padding-bottom:74px}
}

/* ===== модалка заявки (унаследована от карточки компании, оформлена под новый дизайн) ===== */
.nv-lead-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}
.nv-lead-modal[hidden]{display:none}
.nv-lead-modal__overlay{position:absolute;inset:0;background:rgba(10,10,11,.5)}
.nv-lead-modal__window{position:relative;background:#fff;border-radius:18px;padding:26px;max-width:420px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.nv-lead-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.nv-lead-modal__title{font-size:18px;font-family:'Manrope';font-weight:800}
.nv-lead-modal__close{border:0;background:#f5f6f8;width:32px;height:32px;border-radius:9px;font-size:18px;cursor:pointer;color:var(--ink-2)}
.nv-lead-modal__company-label{font-size:13px;color:var(--ink-2);margin-bottom:16px}
.nv-lead-channels{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.nv-lead-channel{font-size:12.5px;font-weight:600;color:var(--ink-2);border:1px solid var(--line);padding:7px 11px;border-radius:9px;cursor:pointer}
.nv-lead-channel.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.nv-lead-field{margin-bottom:12px}
.nv-lead-label{font-size:12px;font-weight:600;color:var(--ink-2);display:block;margin-bottom:6px}
.nv-lead-req{color:var(--red)}
.nv-lead-input,.nv-lead-textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:14px;font-family:'Inter';background:#fafafb}
.nv-lead-input:focus,.nv-lead-textarea:focus{outline:0;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(47,91,255,.1)}
.nv-lead-textarea{min-height:80px;resize:vertical}
.nv-lead-error{background:var(--red-soft);color:var(--red);padding:10px 13px;border-radius:10px;font-size:13px;margin-bottom:12px}
.nv-lead-error[hidden]{display:none}
.nv-lead-submit{width:100%;padding:13px;background:var(--brand);color:#fff;border:0;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.nv-lead-submit:hover{background:var(--brand-ink)}
.nv-lead-submit:disabled{opacity:.7;cursor:not-allowed}
.nv-lead-privacy{text-align:center;font-size:11px;color:var(--ink-3);margin:10px 0 0}
.nv-lead-success{text-align:center;padding:12px 0}
.nv-lead-success[hidden]{display:none}
.nv-lead-success__icon{font-size:44px;margin-bottom:10px}
.nv-lead-success__title{font-size:19px;font-weight:800;font-family:'Manrope';margin:0 0 8px}
.nv-lead-success__text{color:var(--ink-2);font-size:13.5px;margin:0 0 18px}
