/* ===== Combit24 — Dark Premium Theme ===== */
:root{
  --bg:#0a0e1a;
  --bg2:#0f1428;
  --bg3:#141a30;
  --surface:rgba(255,255,255,.04);
  --glass:rgba(255,255,255,.06);
  --glass-border:rgba(255,255,255,.1);
  --glass-hover:rgba(255,255,255,.1);
  --text:#eef0f6;
  --text-secondary:rgba(238,240,246,.65);
  --accent:#F05F40;
  --accent-rgb:240,95,64;
  --accent-hover:#e04e30;
  --accent-soft:rgba(240,95,64,.15);
  --accent-glow:0 0 20px rgba(240,95,64,.25);
  --green:#22c55e;
  --yellow:#eab308;
  --radius-sm:8px;
  --radius:12px;
  --radius-lg:16px;
  --radius-xl:20px;
  --shadow:0 4px 24px rgba(0,0,0,.4);
  --shadow-lg:0 8px 40px rgba(0,0,0,.5);
  --transition:all .2s ease;
  --font:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}

/* ===== Reset & Base ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
/* Плавный масштаб всего интерфейса в десктоп-диапазоне: на 1920+ — базовые 16px
   (референс не меняется), на «старых» мониторах (1280–1600) — компактнее, чтобы
   значки/тексты/отступы не выглядели огромными. Мобильная вёрстка (<992) — без изменений. */
@media (min-width:992px){
  html{font-size:clamp(13.5px, 9.1px + 0.36vw, 16px);}
}
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 1100px 600px at 15% 5%, rgba(var(--accent-rgb),.12), transparent),
    radial-gradient(ellipse 800px 500px at 85% 15%, rgba(100,120,255,.08), transparent),
    linear-gradient(180deg, var(--bg) 0%, var(--bg2) 50%, var(--bg3) 100%);
  background-attachment:fixed;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
main{flex:1}

a{color:var(--accent);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--accent-hover)}

/* ===== Stars Canvas ===== */
#bg-canvas{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.85;
}
#bg-canvas canvas{width:100%;height:100%;display:block}

/* ===== Bootstrap Dark Overrides ===== */
.navbar{
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  background:rgba(10,14,26,.75)!important;
  border-bottom:1px solid var(--glass-border);
  padding:.6rem 0;
  z-index:1030;
}
.navbar .container{position:relative;z-index:1}
.navbar-brand{
  font-weight:800;
  font-size:1.15rem;
  letter-spacing:.3px;
  color:var(--text)!important;
  display:flex;align-items:center;gap:.5rem;
}
.navbar-brand img{transition:filter .3s,transform .3s}
.navbar-brand:hover img{filter:drop-shadow(0 0 8px var(--accent)) brightness(1.15);transform:scale(1.05)}
.brand-icon{
  width:2rem;height:2rem;
  border-radius:var(--radius-sm);
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),rgba(var(--accent-rgb),.7));
  color:#fff;font-weight:900;font-size:.85rem;
  box-shadow:var(--accent-glow);
}
.navbar-dark .navbar-nav .nav-link{
  color:var(--text-secondary);
  font-size:.875rem;
  font-weight:500;
  padding:.45rem .75rem;
  border-radius:var(--radius-sm);
  transition:var(--transition);
}
.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link.active{
  color:var(--text);
  background:var(--surface);
}
.navbar-toggler{
  border:1px solid var(--glass-border);
  padding:.35rem .6rem;
  font-size:1.1rem;
}
.navbar-toggler:focus{box-shadow:0 0 0 2px rgba(var(--accent-rgb),.3)}
.navbar-toggler-icon{
  background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28238,240,246,.8%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")!important;
}
.offcanvas{
  background:rgba(10,14,26,.96)!important;
  backdrop-filter:blur(20px);
  border-left:1px solid var(--glass-border)!important;
}
.offcanvas-header{border-bottom:1px solid var(--glass-border)}
.offcanvas .btn-close{filter:invert(1) brightness(2)}

/* Header extras */
.header-phone{
  color:var(--text);font-weight:600;font-size:.9rem;
  white-space:nowrap;
}
.header-phone:hover{color:var(--accent)}
.header-branch{
  display:inline-flex;align-items:center;gap:4px;
  font-size:.8rem;color:var(--text-secondary);
  padding:.3rem .65rem;border-radius:999px;
  border:1px solid var(--glass-border);
  background:var(--surface);
  transition:var(--transition);
}
.header-branch:hover{color:var(--text);border-color:rgba(var(--accent-rgb),.3)}

/* Mode switch */
.top-bar{
  background:rgba(0,0,0,.35);
  border-bottom:1px solid var(--glass-border);
  padding:.3rem 0;
  font-size:.74rem;
}
.top-bar-btn{
  display:inline-flex;align-items:center;
  padding:.15rem .55rem;border-radius:999px;
  color:var(--text-secondary);
  font-size:.72rem;font-weight:500;
  transition:var(--transition);
  text-decoration:none;
}
.top-bar-btn:hover{color:var(--text)}
.top-bar-btn.active{
  color:var(--text);
  background:rgba(var(--accent-rgb),.15);
}
.top-bar-sep{
  width:1px;height:14px;
  background:var(--glass-border);
  margin:0 .25rem;
}

/* ===== Glass Card ===== */
.glass{
  background:var(--glass);
  backdrop-filter:blur(12px) saturate(1.2);
  -webkit-backdrop-filter:blur(12px) saturate(1.2);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.glass:hover{border-color:rgba(255,255,255,.15)}
.glass-link{display:block;text-decoration:none;color:var(--text)}
.glass-link:hover{
  color:var(--text);
  transform:translateY(-2px);
  border-color:rgba(var(--accent-rgb),.3);
  box-shadow:var(--shadow-lg),var(--accent-glow);
}

/* ===== Hero ===== */
.hero-section{
  padding:clamp(2rem,6vw,4rem) 0 clamp(1.25rem,3.5vw,2.5rem);
  position:relative;z-index:1;
}
.hero-title{
  font-size:clamp(1.7rem,1rem + 2.6vw,2.75rem);
  font-weight:800;
  line-height:1.12;letter-spacing:-.02em;
  margin-bottom:.75rem;
}
.hero-subtitle{
  font-size:clamp(.95rem,.92rem + .25vw,1.05rem);
  color:var(--text-secondary);
  line-height:1.6;max-width:560px;
}

/* ===== Section ===== */
.section{padding:clamp(1.75rem,5vw,3rem) 0;position:relative;z-index:1}
.section-title{
  font-size:clamp(1.3rem,1.05rem + 1vw,1.65rem);
  font-weight:700;
  margin-bottom:1rem;
}
.section-subtitle{
  color:var(--text-secondary);
  font-size:.95rem;line-height:1.6;
  margin-bottom:1.5rem;
}

/* ===== Buttons ===== */
.btn-accent{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;font-weight:600;
  border-radius:var(--radius);
  padding:.55rem 1.25rem;
  transition:var(--transition);
}
.btn-accent:hover{
  background:var(--accent-hover);
  border-color:var(--accent-hover);
  color:#fff;
  transform:translateY(-1px);
  box-shadow:var(--accent-glow);
}
.btn-accent:active{transform:translateY(0)}
.btn-outline-light{
  border-color:var(--glass-border);
  color:var(--text);
  border-radius:var(--radius);
  padding:.55rem 1.25rem;
  transition:var(--transition);
}
.btn-outline-light:hover{
  background:var(--glass);
  border-color:rgba(255,255,255,.2);
  color:var(--text);
}
.btn-glass{
  background:var(--glass);
  border:1px solid var(--glass-border);
  color:var(--text);
  border-radius:var(--radius);
  padding:.55rem 1.25rem;
  font-weight:500;
  transition:var(--transition);
}
.btn-glass:hover{
  background:var(--glass-hover);
  border-color:rgba(255,255,255,.2);
  color:var(--text);
}

/* ===== Kicker / Badge ===== */
.kicker{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.75rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--accent);
  padding:.35rem .75rem;
  border-radius:999px;
  border:1px solid rgba(var(--accent-rgb),.25);
  background:var(--accent-soft);
  margin-bottom:.75rem;
}
.badge-glass{
  background:var(--glass);
  border:1px solid var(--glass-border);
  color:var(--text-secondary);
  font-weight:500;font-size:.78rem;
  padding:.35rem .6rem;border-radius:var(--radius-sm);
}

/* ===== Feature cards ===== */
.feature-card{
  padding:1.25rem;
  border-radius:var(--radius-lg);
  border:1px solid var(--glass-border);
  background:var(--glass);
  transition:var(--transition);
}
.feature-card:hover{
  border-color:rgba(var(--accent-rgb),.25);
  background:var(--glass-hover);
}
.feature-icon{
  width:2.5rem;height:2.5rem;
  border-radius:var(--radius);
  display:grid;place-items:center;
  background:var(--accent-soft);
  color:var(--accent);
  font-size:1.1rem;
  margin-bottom:.75rem;
}
.feature-card h3{font-size:1rem;font-weight:700;margin-bottom:.35rem;color:var(--text-primary)}
.feature-card p{
  color:var(--text-secondary);
  font-size:.85rem;line-height:1.5;margin:0;
}
.feature-card .price-badge{
  display:inline-block;margin-top:.6rem;
  padding:.2rem .55rem;border-radius:999px;
  background:var(--accent-soft);color:var(--accent);
  font-size:.78rem;font-weight:700;
}
.hero-facts{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;
}
.hero-facts li{
  color:var(--text-secondary);font-size:.85rem;
  display:flex;align-items:center;gap:.35rem;
}

/* ===== Pills ===== */
.pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:.3rem .6rem;border-radius:999px;
  border:1px solid var(--glass-border);
  background:var(--surface);
  color:var(--text-secondary);
  font-size:.78rem;font-weight:500;
}
.pill-accent{
  border-color:rgba(var(--accent-rgb),.25);
  background:var(--accent-soft);
  color:var(--accent);
}

/* ===== Quick action grid ===== */
.quick-action{
  display:flex;align-items:center;gap:.6rem;
  padding:.75rem 1rem;
  border-radius:var(--radius);
  border:1px solid var(--glass-border);
  background:var(--surface);
  color:var(--text);
  cursor:pointer;text-align:left;
  font-size:.875rem;font-weight:500;
  transition:var(--transition);
  text-decoration:none;
}
.quick-action:hover{
  background:var(--glass);
  border-color:rgba(var(--accent-rgb),.25);
  color:var(--text);
}
.quick-action .icon{
  width:1.75rem;height:1.75rem;
  border-radius:var(--radius-sm);
  display:grid;place-items:center;
  background:var(--accent-soft);
  color:var(--accent);
  font-size:.8rem;flex-shrink:0;
}

/* ===== Price table ===== */
.price-table{
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.price-table .table{
  margin:0;color:var(--text);
  --bs-table-bg:transparent;
  --bs-table-color:var(--text);
  --bs-table-border-color:var(--glass-border);
  --bs-table-striped-bg:rgba(255,255,255,.02);
  --bs-table-hover-bg:rgba(255,255,255,.04);
}
.price-table thead{background:rgba(255,255,255,.04)}
.price-table thead th{
  font-weight:600;font-size:.85rem;
  color:var(--text-secondary);
  border-bottom-color:var(--glass-border);
  padding:.65rem .85rem;
}
.price-table tbody td{
  font-size:.875rem;
  padding:.6rem .85rem;
  vertical-align:middle;
  border-bottom-color:var(--glass-border);
}

/* ===== Specs ===== */
.spec-item{
  display:flex;justify-content:space-between;align-items:center;
  gap:1rem;padding:.6rem .85rem;
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  background:var(--surface);
  font-size:.875rem;
}
.spec-item .spec-label{color:var(--text-secondary)}
.spec-item .spec-value{font-weight:600;text-align:right}

/* ===== FAQ ===== */
.faq-item{
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  background:var(--surface);
  overflow:hidden;
  transition:var(--transition);
}
.faq-item:hover{border-color:rgba(var(--accent-rgb),.2)}
.faq-item summary{
  cursor:pointer;font-weight:600;font-size:.9rem;
  padding:.75rem 1rem;
  list-style:none;
  display:flex;justify-content:space-between;align-items:center;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-size:1.1rem;color:var(--accent);
  transition:transform .2s ease;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-answer{
  padding:0 1rem .75rem;
  color:var(--text-secondary);
  font-size:.875rem;line-height:1.6;
}

/* ===== Breadcrumbs ===== */
.breadcrumbs{
  font-size:.8rem;margin-bottom:.6rem;
  color:var(--text-secondary);
}
.breadcrumbs a{color:var(--text-secondary);text-decoration:none}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs span{margin:0 .3rem;opacity:.5}

/* ===== Check list ===== */
.check-list{list-style:none;padding:0;margin:0}
.check-list li{
  display:flex;gap:.5rem;align-items:flex-start;
  padding:.3rem 0;
  color:var(--text-secondary);
  font-size:.88rem;line-height:1.45;
}
.check-list li i{margin-top:.15rem;flex-shrink:0}

/* ===== Contact line ===== */
.contact-line{
  padding:.5rem 0;
  font-size:.9rem;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.contact-line:last-child{border-bottom:0}
.contact-label{color:var(--text-secondary);display:inline-block;min-width:70px}

/* ===== Footer ===== */
.site-footer{
  border-top:1px solid var(--glass-border);
  background:rgba(10,14,26,.85);
  backdrop-filter:blur(10px);
  padding:2.5rem 0 1.5rem;
  position:relative;z-index:1;
}
.site-footer h6{font-weight:700;font-size:.85rem;margin-bottom:.75rem;color:var(--text)}
.footer-link{
  display:block;color:var(--text-secondary);
  font-size:.85rem;padding:.2rem 0;
  transition:var(--transition);
}
.footer-link:hover{color:var(--accent)}
.footer-copy{
  border-top:1px solid var(--glass-border);
  margin-top:1.5rem;padding-top:1rem;
  color:var(--text-secondary);font-size:.8rem;
}
.footer-copy a{color:var(--text-secondary)}
.footer-copy a:hover{color:var(--accent)}

/* ===== Modal ===== */
.modal-dark .modal-content{
  background:rgba(15,20,40,.95);
  backdrop-filter:blur(20px) saturate(1.3);
  -webkit-backdrop-filter:blur(20px) saturate(1.3);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);
  color:var(--text);
}
.modal-dark .modal-header{border-bottom:1px solid var(--glass-border)}
.modal-dark .modal-header .btn-close{filter:invert(1) brightness(2)}
.modal-dark .modal-footer{border-top:1px solid var(--glass-border)}
.modal-dark .form-control,
.modal-dark .form-select{
  background:rgba(255,255,255,.04);
  border:1px solid var(--glass-border);
  color:var(--text);
  border-radius:var(--radius);
  padding:.55rem .85rem;
}
.modal-dark .form-control:focus,
.modal-dark .form-select:focus{
  background:rgba(255,255,255,.06);
  border-color:rgba(var(--accent-rgb),.5);
  box-shadow:0 0 0 3px rgba(var(--accent-rgb),.15);
  color:var(--text);
}
.modal-dark .form-control::placeholder{color:var(--text-secondary)}
.modal-dark .form-label{
  font-size:.8rem;font-weight:600;
  color:var(--text-secondary);margin-bottom:.3rem;
}

/* ===== Inline lead form ===== */
.lead-form .form-control,
.lead-form .form-select{
  background:rgba(255,255,255,.04);
  border:1px solid var(--glass-border);
  color:var(--text);
  border-radius:var(--radius);
  padding:.55rem .85rem;
}
.lead-form .form-control:focus,
.lead-form .form-select:focus{
  background:rgba(255,255,255,.06);
  border-color:rgba(var(--accent-rgb),.5);
  box-shadow:0 0 0 3px rgba(var(--accent-rgb),.15);
  color:var(--text);
}
.lead-form .form-control::placeholder{color:var(--text-secondary)}
.lead-form .form-label{
  font-size:.8rem;font-weight:600;
  color:var(--text-secondary);margin-bottom:.3rem;
}

/* ===== Prose (legal pages) ===== */
.prose{color:var(--text-secondary);line-height:1.75}
.prose h1,.prose h2,.prose h3{color:var(--text);margin-top:1.5rem}
.prose p{margin-bottom:.75rem}
.prose ul,.prose ol{padding-left:1.25rem}
.prose li{margin-bottom:.35rem}
.prose a{color:var(--accent)}

/* ===== Form validation ===== */
.form-control.is-invalid,
.form-select.is-invalid{
  border-color:#dc3545!important;
  box-shadow:0 0 0 2px rgba(220,53,69,.2);
}
.form-check-input.is-invalid{
  border-color:#dc3545!important;
}
.form-check-input.is-invalid~.invalid-feedback{display:block}
.invalid-feedback{
  font-size:.78rem;
  color:#f87171;
  margin-top:.25rem;
}

/* Phone input */
.js-phone-mask{
  font-variant-numeric:tabular-nums;
  letter-spacing:.03em;
}

/* ===== Misc utilities ===== */
.text-accent{color:var(--accent)!important}
.text-muted-custom{color:var(--text-secondary)!important}
.bg-glass{background:var(--glass)!important}
.border-glass{border-color:var(--glass-border)!important}

/* Status colors */
.stock-in{color:var(--green)}
.stock-pre{color:var(--yellow)}
.stock-out{color:var(--text-secondary)}

/* ===== Responsive tweaks ===== */
@media(max-width:991px){
  .hide-mobile{display:none!important}
}
@media(min-width:992px){
  .hide-desktop{display:none!important}
}

/* ===== Catalog ===== */

/* Breadcrumbs */
.cat-breadcrumbs{
  padding:.75rem 0;
  font-size:.8rem;
  color:var(--text-secondary);
  position:relative;z-index:1;
}
.cat-breadcrumbs a{color:var(--text-secondary);text-decoration:none}
.cat-breadcrumbs a:hover{color:var(--accent)}
.cat-bc-sep{margin:0 .4rem;opacity:.4}

/* Header */
.cat-header{
  padding:1.5rem 0 1rem;
  position:relative;z-index:1;
}
.cat-header-row{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:1rem;
}
.cat-title{
  font-size:clamp(1.35rem,1rem + 1.8vw,2rem);
  font-weight:800;margin:0;
  letter-spacing:-.02em;
}
.cat-count{
  color:var(--text-secondary);
  font-size:.85rem;margin:.25rem 0 0;
}

/* Search */
.cat-search{
  position:relative;
  max-width:600px;
}
.cat-search-icon{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--text-secondary);font-size:1rem;
  pointer-events:none;
}
.cat-search-input{
  width:100%;
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  color:var(--text);
  font-size:.9rem;
  padding:.65rem .75rem .65rem 2.5rem;
  transition:var(--transition);
}
.cat-search-input::placeholder{color:var(--text-secondary)}
.cat-search-input:focus{
  outline:none;
  border-color:rgba(var(--accent-rgb),.5);
  box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1);
  background:var(--glass-hover);
}
.cat-search-clear{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  color:var(--text-secondary);font-size:.85rem;
  background:none;border:none;padding:4px;cursor:pointer;
}
.cat-search-clear:hover{color:var(--text)}

/* Toolbar */
.cat-toolbar-section{
  padding:.5rem 0 1rem;
  position:relative;z-index:1;
}

/* Category pills */
.cat-pills-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  margin:0 -12px;padding:0 12px;
}
.cat-pills-wrap::-webkit-scrollbar{display:none}
.cat-pills{
  display:flex;gap:6px;
  white-space:nowrap;
  padding-bottom:4px;
}
.cat-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:.35rem .75rem;
  border-radius:999px;
  border:1px solid var(--glass-border);
  background:var(--surface);
  color:var(--text-secondary);
  font-size:.78rem;font-weight:500;
  text-decoration:none;
  transition:var(--transition);
  flex-shrink:0;
}
.cat-pill:hover{color:var(--text);border-color:rgba(255,255,255,.18);background:var(--glass)}
.cat-pill.active{
  background:var(--accent-soft);
  color:var(--accent);
  border-color:rgba(var(--accent-rgb),.3);
}
.cat-pill-child{font-size:.72rem;padding:.3rem .6rem}
.cat-pill-count{
  background:rgba(255,255,255,.06);
  color:var(--text-secondary);
  font-size:.65rem;
  padding:1px 5px;
  border-radius:99px;
  font-weight:600;
}
.cat-pill.active .cat-pill-count{
  background:rgba(var(--accent-rgb),.2);
  color:var(--accent);
}

/* Sort */
.cat-sort{
  display:flex;align-items:center;gap:6px;
  margin-top:.75rem;
  flex-wrap:wrap;
}
.cat-sort-label{
  font-size:.75rem;color:var(--text-secondary);
  margin-right:2px;
}
.cat-sort-btn{
  font-size:.72rem;
  padding:.25rem .55rem;
  border-radius:var(--radius-sm);
  color:var(--text-secondary);
  text-decoration:none;
  border:1px solid transparent;
  transition:var(--transition);
}
.cat-sort-btn:hover{color:var(--text);background:var(--surface)}
.cat-sort-btn.active{
  color:var(--text);
  background:var(--surface);
  border-color:var(--glass-border);
}

/* Grid section */
.cat-grid-section{
  padding:0 0 2rem;
  position:relative;z-index:1;
}

/* Product Card */
.pcard{
  display:flex;flex-direction:column;
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  text-decoration:none;
  color:var(--text);
  transition:var(--transition);
  height:100%;
}
.pcard:hover{
  color:var(--text);
  transform:translateY(-3px);
  border-color:rgba(var(--accent-rgb),.3);
  box-shadow:0 8px 32px rgba(0,0,0,.4),var(--accent-glow);
}
.pcard-img{
  position:relative;
  aspect-ratio:4/3;
  background:linear-gradient(135deg, rgba(var(--accent-rgb),.06), rgba(100,120,255,.04));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.pcard-img img{
  width:100%;height:100%;
  object-fit:contain;
  padding:12px;
  transition:transform .3s ease;
}
.pcard:hover .pcard-img img{transform:scale(1.04)}
.pcard-img-dimmed{opacity:.55}
.pcard-placeholder{
  display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;
  color:rgba(255,255,255,.12);
  font-size:3rem;
}
.pcard-oos-badge,.pcard-pre-badge,.pcard-stock-badge{
  position:absolute;top:10px;left:10px;
  font-size:.65rem;font-weight:600;
  padding:3px 8px;border-radius:var(--radius-sm);
}
.pcard-oos-badge{background:rgba(100,100,100,.85);color:#ccc}
.pcard-pre-badge{background:rgba(234,179,8,.85);color:#000}
.pcard-stock-badge{background:rgba(34,197,94,.85);color:#fff}

.pcard-body{
  padding:.85rem 1rem 1rem;
  display:flex;flex-direction:column;
  flex:1;
}
.pcard-cat{
  font-size:.68rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--accent);
  margin-bottom:.3rem;
}
.pcard-title{
  font-size:.9rem;font-weight:700;
  margin:0 0 .3rem;
  line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.pcard-desc{
  font-size:.78rem;color:var(--text-secondary);
  margin:0 0 auto;
  line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.pcard-addr{
  font-size:.72rem;color:var(--text-secondary);
  margin-top:.25rem;
  display:flex;align-items:center;gap:3px;
  opacity:.7;
}
.pcard-footer{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:.65rem;
  padding-top:.6rem;
  border-top:1px solid var(--glass-border);
}
.pcard-footer-main{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.pcard-price{
  font-size:1.05rem;font-weight:800;
  color:var(--accent);
}
.pcard-price-muted{color:var(--text-secondary);font-weight:600}
.pcard-stock-tag{
  display:inline-flex;align-items:center;gap:.25rem;
  font-size:.7rem;font-weight:700;line-height:1;
  white-space:nowrap;
}
.pcard-stock-tag.ok{color:var(--green)}
.pcard-stock-tag.pre{color:var(--yellow)}
.pcard-stock-tag.oos{color:var(--accent)}
.pcard-arrow{
  width:1.75rem;height:1.75rem;
  border-radius:50%;
  background:var(--surface);
  display:grid;place-items:center;
  color:var(--text-secondary);
  font-size:.75rem;
  transition:var(--transition);
}
.pcard:hover .pcard-arrow{
  background:var(--accent);color:#fff;
}

/* Empty state */
.cat-empty{
  text-align:center;
  padding:4rem 1rem;
}
.cat-empty-icon{
  font-size:3rem;color:var(--text-secondary);
  margin-bottom:1rem;
  opacity:.4;
}
.cat-empty h3{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}
.cat-empty p{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem}

/* CTA */
.cat-cta{
  padding:1rem 0 3rem;
  position:relative;z-index:1;
}

/* ===== Product Detail ===== */
.pd-section{
  padding:1rem 0 3rem;
  position:relative;z-index:1;
}

/* Gallery */
.pd-gallery{
  position:sticky;top:80px;
}
.pd-main-img{
  aspect-ratio:1/1;
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  margin-bottom:.75rem;
}
.pd-main-img img{
  max-width:100%;max-height:100%;
  object-fit:contain;
  padding:20px;
}
.pd-no-img{
  flex-direction:column;gap:.75rem;
  color:var(--text-secondary);
  font-size:.9rem;
}
.pd-no-img i{font-size:4rem;opacity:.15}
.pd-thumbs{
  display:flex;gap:8px;
  overflow-x:auto;
  padding-bottom:4px;
}
.pd-thumb{
  width:64px;height:64px;
  border-radius:var(--radius-sm);
  border:2px solid var(--glass-border);
  background:var(--surface);
  padding:4px;
  cursor:pointer;
  flex-shrink:0;
  transition:var(--transition);
}
.pd-thumb:hover{border-color:rgba(var(--accent-rgb),.3)}
.pd-thumb.active{border-color:var(--accent)}
.pd-thumb img{width:100%;height:100%;object-fit:contain}

/* Info */
.pd-info{padding-top:.25rem}
.pd-cat-link{
  display:inline-block;
  font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--accent);
  text-decoration:none;
  margin-bottom:.5rem;
}
.pd-cat-link:hover{text-decoration:underline;color:var(--accent)}
.pd-title{
  font-size:clamp(1.25rem,1rem + 1.5vw,1.6rem);
  font-weight:800;
  line-height:1.2;margin:0 0 .5rem;
}
.pd-desc{
  color:var(--text-secondary);
  font-size:.9rem;line-height:1.55;
  margin-bottom:1rem;
}
.pd-price-row{
  display:flex;align-items:center;gap:1rem;
  flex-wrap:wrap;
  margin-bottom:1.25rem;
}
.pd-price{
  font-size:clamp(1.4rem,1.1rem + 1.3vw,1.75rem);
  font-weight:800;
  color:var(--accent);
}
.pd-stock{
  font-size:.82rem;font-weight:600;
  display:inline-flex;align-items:center;gap:4px;
  padding:.35rem .7rem;
  border-radius:999px;
}
.pd-stock-in_stock{color:var(--green);background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2)}
.pd-stock-preorder{color:var(--yellow);background:rgba(234,179,8,.1);border:1px solid rgba(234,179,8,.2)}
.pd-stock-out_of_stock{color:var(--text-secondary);background:var(--surface);border:1px solid var(--glass-border)}

.pd-usps{
  list-style:none;margin:0 0 1.1rem;padding:0;
  display:flex;flex-direction:column;gap:.45rem;
}
.pd-usps li{
  display:flex;align-items:flex-start;gap:.5rem;
  font-size:.9rem;line-height:1.4;color:var(--text);
}
.pd-usps li i{color:var(--green);font-size:1rem;margin-top:.08rem;flex-shrink:0}

.pd-oos-note{
  display:flex;align-items:flex-start;gap:.5rem;
  margin:0 0 1rem;padding:.7rem .9rem;
  border-radius:var(--radius);
  background:var(--accent-soft);
  border:1px solid rgba(var(--accent-rgb),.25);
  color:var(--text);font-size:.85rem;line-height:1.45;
}
.pd-oos-note i{color:var(--accent);font-size:1rem;margin-top:.1rem;flex-shrink:0}

.pd-actions{
  display:flex;gap:.75rem;flex-wrap:wrap;
  margin-bottom:1.5rem;
}
.pd-actions .btn{
  font-weight:600;
  border-radius:var(--radius);
  padding:.65rem 1.5rem;
}
.pd-actions .btn-lg{font-size:.9rem}

/* Branches */
.pd-branches{
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  padding:1rem;
}
.pd-branches-title{
  font-size:.85rem;font-weight:700;
  margin:0 0 .75rem;
  display:flex;align-items:center;gap:6px;
}
.pd-branch-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:.4rem 0;
  font-size:.82rem;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.pd-branch-row:last-child{border-bottom:0}
.pd-branch-name{font-weight:600}
.pd-branch-addr{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:1px}
.pd-branch-status{font-weight:600}

/* Specs */
.pd-specs-block{
  margin-top:2.5rem;
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  padding:1.5rem;
}
.pd-specs-title{
  font-size:1.15rem;font-weight:700;
  margin:0 0 1rem;
}
.pd-specs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));
  gap:0 2rem;
}
.pd-spec-row{
  display:flex;align-items:baseline;
  gap:6px;
  padding:.55rem 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  font-size:.85rem;
}
.pd-spec-key{
  color:var(--text-secondary);
  white-space:nowrap;
  flex-shrink:0;
}
.pd-spec-dots{
  flex:1;min-width:20px;
  border-bottom:1px dotted rgba(255,255,255,.1);
  margin-bottom:4px;
}
.pd-spec-val{
  font-weight:600;
  text-align:right;
  white-space:nowrap;
  flex-shrink:0;
}

/* Description */
.pd-desc-block{
  margin-top:1.5rem;
}
.pd-description{
  color:var(--text-secondary);
  font-size:.9rem;line-height:1.7;
}

/* Related */
.pd-related{
  margin-top:2.5rem;
}

/* ===== Responsive catalog ===== */
@media(max-width:768px){
  .cat-sort{margin-top:.5rem}
  .cat-header-row{flex-direction:column;align-items:stretch;gap:.75rem}
  .pd-gallery{position:static}
  .pd-actions .btn{width:100%}
  .pd-specs-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .pcard-title{font-size:.85rem}
  .pcard-price{font-size:.98rem}
}

/* ===== Article (blog) ===== */
.article-body p{line-height:1.75;margin-bottom:.85rem}
.article-body h2{margin-top:1.6rem}
.article-body .check-list{margin-bottom:1rem}

/* ===== Branch 2GIS map ===== */
.branch-map{overflow:hidden}
.dgis-map{display:block;width:100%;height:600px;max-height:78vh;border:0;border-radius:var(--radius-sm);background:#fff}
@media(max-width:480px){.dgis-map{height:460px}}

/* ===== Online chat widget ===== */
.cchat{position:fixed;right:20px;bottom:20px;z-index:1000;font-family:var(--font)}
.cchat-launcher{width:56px;height:56px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:1.4rem;cursor:pointer;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;position:relative;transition:var(--transition)}
.cchat-launcher:hover{background:var(--accent-hover);transform:translateY(-2px)}
.cchat-bubble{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;border-radius:99px;background:#fff;color:var(--accent);font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid var(--accent)}
.cchat-panel{position:absolute;right:0;bottom:70px;width:360px;max-width:calc(100vw - 40px);height:520px;max-height:calc(100vh - 120px);background:var(--bg2);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}
.cchat-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:var(--accent);color:#fff}
.cchat-title{font-weight:700;font-size:.95rem}
.cchat-sub{font-size:.72rem;opacity:.85}
.cchat-close{background:none;border:none;color:#fff;font-size:1rem;cursor:pointer;opacity:.85;line-height:1}
.cchat-close:hover{opacity:1}
.cchat-body{flex:1;overflow-y:auto;padding:.85rem;display:flex;flex-direction:column;gap:.5rem}
.cchat-greeting{font-size:.82rem;color:var(--text-secondary);text-align:center;padding:.5rem 0}
.cchat-msg{max-width:82%;padding:.45rem .65rem;border-radius:.7rem;font-size:.85rem;line-height:1.45}
.cchat-msg-text{white-space:pre-wrap;word-break:break-word}
.cchat-msg-text a{color:inherit;text-decoration:underline}
.cchat-msg-meta{font-size:.65rem;opacity:.65;margin-top:.2rem}
.cchat-msg-visitor{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:.2rem}
.cchat-msg-operator{align-self:flex-start;background:var(--glass);color:var(--text);border:1px solid var(--glass-border);border-bottom-left-radius:.2rem}
.cchat-msg-system{align-self:center;font-size:.74rem;color:var(--text-secondary);text-align:center}
.cchat-att{display:block;margin-top:.3rem}
.cchat-att-img{max-width:200px;max-height:200px;border-radius:.4rem;display:block}
.cchat-att-file{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .45rem;border-radius:.4rem;background:rgba(255,255,255,.14);color:inherit;text-decoration:none;font-size:.76rem}
.cchat-att-file:hover{background:rgba(255,255,255,.24)}
.cchat-form{border-top:1px solid var(--glass-border);padding:.6rem;background:var(--bg3)}
.cchat-name{width:100%;margin-bottom:.4rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);padding:.4rem .6rem;font-size:.8rem}
.cchat-files{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.4rem}
.cchat-files:empty{display:none}
.cchat-file-chip{display:flex;align-items:center;gap:.25rem;font-size:.7rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:.3rem;padding:.12rem .4rem;color:var(--text-secondary)}
.cchat-file-chip button{background:none;border:none;color:inherit;cursor:pointer;padding:0;font-size:.85rem;line-height:1}
.cchat-file-input{display:none}
.cchat-attach{flex:none;width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--glass-border);background:var(--surface);color:var(--text-secondary);cursor:pointer;font-size:1rem}
.cchat-attach:hover{color:var(--text);border-color:var(--accent)}
.cchat-input-row{display:flex;gap:.4rem;align-items:flex-end}
.cchat-input{flex:1;resize:none;height:40px;max-height:96px;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);padding:.5rem .6rem;font-size:.85rem;font-family:var(--font)}
.cchat-input:focus,.cchat-name:focus{outline:none;border-color:var(--accent)}
.cchat-send{flex:none;width:40px;height:40px;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#fff;cursor:pointer;font-size:.95rem}
.cchat-send:hover{background:var(--accent-hover)}
.cchat-send:disabled{opacity:.5;cursor:default}
@media(max-width:480px){
  .cchat{right:12px;bottom:12px}
  .cchat-panel{bottom:66px}
}

/* ===== Адаптивность: общий проход по разрешениям ===== */
html{-webkit-text-size-adjust:100%}
img{max-width:100%}
.price-table{overflow-x:auto}
.table-responsive{-webkit-overflow-scrolling:touch}
@media(max-width:576px){
  .hero-subtitle{max-width:none}
  .feature-card{padding:1rem}
  /* плотнее карточки на узких экранах — больше места под контент */
  .glass.p-4{padding:1.15rem!important}
  /* поля ввода 16px: iOS не зумит страницу при фокусе */
  .form-control,.form-select,.cat-search-input,.lead-form .form-control,.cchat-input,.cchat-name{font-size:16px}
}
