/*
 * custom.css — page-specific and site-specific styles
 * Extracted from main.css. Edit freely via Admin → Settings → Custom CSS.
 */

/* Drivers block */
.home-drivers{background:linear-gradient(135deg,#fff8f0 0%,#fff 100%);border-radius:var(--radius-lg);padding:28px 32px;box-shadow:var(--shadow-sm);border-left:4px solid var(--primary)}
.home-drivers__inner{display:grid;grid-template-columns:1fr 380px;gap:32px;align-items:center}
.home-drivers__body{font-size:15px;line-height:1.7;color:var(--text-muted)}
.home-drivers__body p{margin-bottom:12px}
.home-drivers__body p:last-child{margin-bottom:0}
.home-drivers__body strong{color:var(--text)}
.home-drivers__video{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9}
.home-drivers__video iframe{width:100%;height:100%;border:none}
@media(max-width:800px){
  .home-drivers__inner{grid-template-columns:1fr}
  .home-drivers{padding:20px}
  .home-bottom-text__inner{flex-direction:column}
  .home-bottom-text__video{flex:none;width:100%}
}

/* Configurator */
.home-configurator{background:var(--white);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}
.home-configurator__subtitle{color:var(--text-muted);margin:-12px 0 24px;font-size:15px}
.cfg-widget{}
.cfg-steps{}
.cfg-step{display:none}
.cfg-step.is-active{display:block}
.cfg-step__q{font-size:17px;font-weight:600;color:var(--text);margin-bottom:18px}
.cfg-step__opts{display:flex;flex-wrap:wrap;gap:12px}
.cfg-opt-btn{display:flex;align-items:center;gap:10px;padding:12px 20px;border:2px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:border-color .2s,background .2s,color .2s;min-width:200px}
.cfg-opt-btn i{color:var(--primary);font-size:18px;width:22px;text-align:center}
.cfg-opt-btn:hover{border-color:var(--primary);background:var(--primary-light,#f0f7ff);color:var(--primary)}
.cfg-progress{display:flex;gap:8px;margin-top:24px;margin-bottom:8px}
.cfg-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:background .2s}
.cfg-dot.is-active{background:var(--primary)}
.cfg-result__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-top:8px}
.cfg-result__grid .product-card{flex-direction:column;padding:0;gap:0}
.cfg-result__grid .product-card__img-wrap{
  width:100%;height:220px;padding:16px;box-sizing:border-box;
  display:flex;align-items:center;justify-content:center;
  background:var(--white);border-bottom:1px solid var(--border-light);
  flex-shrink:0;overflow:hidden;
}
.cfg-result__grid .product-card__img{width:100%;height:100%;object-fit:contain;}
.cfg-result__grid .product-card{height:100%}
.cfg-result__grid .product-card__body{padding:10px 12px 6px;flex:1}
.cfg-result__grid .product-card__name{
  font-size:13px;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.cfg-result__grid .product-card__desc,
.cfg-result__grid .product-card__specs{display:none}
.cfg-result__grid .product-card__aside{
  width:100%;padding:8px 12px 12px;
  border-top:1px solid var(--border-light);gap:6px;
}
.cfg-result__grid .delivery-row,
.cfg-result__grid .product-card__cheaper,
.cfg-result__grid .qty-control,
.cfg-result__grid .card-actions{display:none}
.cfg-result__grid .product-card__price{font-size:18px}
.cfg-result__grid .btn-buy{padding:9px 10px;font-size:13px}
.cfg-reset-btn{margin-top:20px;display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:2px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text-muted);font-size:14px;cursor:pointer;transition:border-color .2s,color .2s}
.cfg-reset-btn:hover{border-color:var(--primary);color:var(--primary)}
@media(max-width:600px){
  .cfg-step__opts{flex-direction:column}
  .cfg-opt-btn{min-width:0;width:100%}
}

/* Bottom text */
.home-bottom-text{background:var(--white);border-radius:var(--radius-lg);padding:28px 32px;box-shadow:var(--shadow-sm)}
.home-bottom-text__inner{display:flex;gap:32px;align-items:flex-start}
.home-bottom-text__body{flex:1;min-width:0;font-size:15px;line-height:1.75;color:var(--text-muted)}
.home-bottom-text__video{flex:0 0 40%;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9}
.home-bottom-text__video iframe{width:100%;height:100%;border:none}
.home-bottom-text__body p{margin-bottom:12px}
.home-bottom-text__body ul{padding-left:20px;margin-bottom:12px}
.home-bottom-text__body li{margin-bottom:6px}
.home-bottom-text__body strong{color:var(--text)}

/* Home articles carousel */
.home-articles{overflow:hidden}
.art-carousel{position:relative;overflow:hidden;padding:0 44px;box-sizing:border-box;width:100%}
.art-carousel__track{display:flex;flex-wrap:nowrap;transition:transform .35s ease;will-change:transform}
.home-art-card{flex-shrink:0;box-sizing:border-box;padding:0 8px;width:25%;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.home-art-card__wrap{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;flex:1;transition:box-shadow .2s,transform .2s}
.home-art-card:hover .home-art-card__wrap{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.home-art-card__img{height:160px;overflow:hidden;background:var(--bg);flex-shrink:0}
.home-art-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.home-art-card:hover .home-art-card__img img{transform:scale(1.04)}
.home-art-card__img--empty{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:32px}
.home-art-card__body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:6px}
.home-art-card__title{font-size:15px;font-weight:600;color:var(--text);line-height:1.35;margin:0}
.home-art-card:hover .home-art-card__title{color:var(--primary)}
.home-art-card__desc{font-size:13px;color:var(--text-muted);line-height:1.5;flex:1;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.home-art-card__more{font-size:13px;color:var(--primary);font-weight:500;margin-top:6px}
.art-carousel__btn{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--white);box-shadow:var(--shadow);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);transition:background .2s,color .2s;z-index:2}
.art-carousel__btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.art-carousel__btn:disabled{opacity:.35;pointer-events:none}
.art-carousel__btn--prev{left:0}
.art-carousel__btn--next{right:0}
.art-carousel__dots{display:flex;justify-content:center;gap:6px;margin-top:14px}
.art-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--border);cursor:pointer;padding:0;transition:background .2s,transform .2s}
.art-dot.is-active{background:var(--primary);transform:scale(1.3)}
@media(max-width:960px){.home-art-card{width:33.333%}}
@media(max-width:640px){.home-art-card{width:50%}.art-carousel{padding:0 36px}}
@media(max-width:480px){
  .home-art-card{width:66.666%}
  .art-carousel{padding:0 0 48px}
  .art-carousel__btn{top:auto;bottom:0;transform:none}
  .art-carousel__btn--prev{left:calc(50% - 44px)}
  .art-carousel__btn--next{right:calc(50% - 44px)}
}

/* ── Guarantee page (gar-*) ──────────────────────────────────────────────── */
.gar-lead {
  background: var(--primary-light);
  border-left: 4px solid var(--primary);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 16px 20px;
  font-size: 14px;
  line-height: 1.65;
  margin-bottom: 24px;
  color: var(--text);
}
.gar-lead strong { color: var(--primary); }
.gar-promises {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 12px;
  margin-bottom: 28px;
}
.gar-promise {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 10px;
  box-shadow: var(--shadow-sm);
  font-size: 13px;
  line-height: 1.45;
  color: var(--text);
}
.gar-promise__icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.gar-promise__icon--blue  { background: var(--primary-light); color: var(--primary); }
.gar-promise__icon--green { background: #dcfce7; color: #16a34a; }
.gar-promise__icon--amber { background: #fef3c7; color: #d97706; }
.gar-promise__icon--red   { background: #fee2e2; color: #dc2626; }
.gar-promise__days {
  font-size: 28px;
  font-weight: 800;
  color: var(--primary);
  line-height: 1;
}
.gar-list {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  margin-bottom: 24px;
  box-shadow: var(--shadow-sm);
  counter-reset: gar-c;
  list-style: none;
}
.gar-list li {
  counter-increment: gar-c;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-light);
  font-size: 14px;
  line-height: 1.6;
  color: var(--text);
}
.gar-list li:last-child { border-bottom: none; }
.gar-list li > span { flex: 1; min-width: 0; }
.gar-list li::before {
  content: counter(gar-c);
  min-width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.gar-contacts {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px 24px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px 20px;
  margin-bottom: 28px;
  box-shadow: var(--shadow-sm);
  font-size: 14px;
}
.gar-contacts i { color: var(--primary); margin-right: 6px; }
.gar-contacts a { color: var(--primary); font-weight: 700; text-decoration: none; }
.gar-contacts a:hover { text-decoration: underline; }
.gar-section-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 12px;
}
.gar-accordion { display: flex; flex-direction: column; gap: 4px; }

@media(max-width:768px) {
  .gar-promises { grid-template-columns: repeat(2,1fr); }
}
@media(max-width:480px) {
  .gar-promises { grid-template-columns: 1fr 1fr; }
  .gar-promise { padding: 16px 12px; }
}

/* ─── Online Alkometer (alko1.php) ───────────────────────────────────────── */
.alko_online{
  background:var(--white);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);overflow:hidden;
  display:flex;flex-wrap:wrap;border:none!important
}
.alko_online>.row{border:none!important}

/* ── Form column ── */
.alko-form-col{
  padding:28px 24px !important;
  border-right:1px solid var(--border);
  background:var(--white)
}
.alko-form-col .row{
  display:flex;align-items:center;gap:8px;
  padding:10px 0;border-bottom:1px solid var(--border-light)!important;
  border-right:none!important
}
.alko-form-col .row:last-child{border-bottom:none!important}
.alko-form-col .col-6-sm{width:auto;flex:1;padding:0}
.alko-form-col .col-6-sm:last-child{flex:0 0 auto}

/* Selects */
.alko_online select,.alko_online .alk_online_select{
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:5px 8px;font-size:13px;background:var(--bg);
  color:var(--text);cursor:pointer;
  transition:border-color var(--transition),box-shadow var(--transition)
}
.alko_online select:focus,.alko_online .alk_online_select:focus{
  border-color:var(--primary);outline:none;
  box-shadow:0 0 0 3px rgba(26,86,219,.12)
}
.alko_online input[type=radio]{accent-color:var(--primary);width:15px;height:15px;cursor:pointer}
.alko-vol-num{font-size:18px;font-weight:700;color:var(--primary)}
.alko-sup{color:var(--danger);font-size:10px}
.meas{font-size:12px;color:var(--text-muted);margin-left:1px}

/* ── Result column ── */
.alko-result-col{
  background:linear-gradient(145deg,var(--primary-dark) 0%,var(--primary) 100%);
  color:#fff;padding:32px 28px !important;
  display:flex;flex-direction:column;justify-content:center;gap:10px;
  animation:alko-slide-in .45s cubic-bezier(.22,.61,.36,1) both
}
@keyframes alko-slide-in{
  from{opacity:0;transform:translateX(20px)}
  to  {opacity:1;transform:translateX(0)}
}
.alko-result-label{
  font-size:13px;font-weight:600;text-transform:uppercase;
  letter-spacing:.8px;opacity:.75
}
.alko-promille-val{
  font-size:60px;font-weight:800;line-height:1;
  text-shadow:0 3px 16px rgba(0,0,0,.25);
  animation:alko-pop .55s cubic-bezier(.36,.07,.19,.97) .15s both
}
@keyframes alko-pop{
  0%  {transform:scale(.75);opacity:0}
  65% {transform:scale(1.07)}
  100%{transform:scale(1);opacity:1}
}
.alko-permille-sign{font-size:36px;font-weight:400;opacity:.85}
.alko-mg{font-size:13px;opacity:.7;margin-top:-4px}
.alko-star-prom{
  font-size:13px;padding:8px 12px;
  background:rgba(255,255,255,.12);border-radius:var(--radius-sm);
  backdrop-filter:blur(4px)
}
.alko-sost{
  font-size:15px;font-weight:600;
  padding:10px 14px;
  background:rgba(255,255,255,.15);border-radius:var(--radius);
  border-left:3px solid rgba(255,255,255,.5)
}
.alko-za-rulj-wrap{font-size:14px;line-height:1.6}

/* Drive status classes */
.alko-drive{display:block;font-size:14px;line-height:1.6}
.alko-drive--ok{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:var(--radius);font-weight:700;
  background:rgba(5,150,105,.25);color:#6ee7b7;
  animation:alko-ok-glow 2s ease infinite alternate
}
.alko-drive--ok::before{content:'✓';font-size:16px}
@keyframes alko-ok-glow{
  from{box-shadow:0 0 0 0 rgba(110,231,183,.0)}
  to  {box-shadow:0 0 12px 2px rgba(110,231,183,.25)}
}
.alko-drive--warn{
  display:block;padding:10px 14px;border-radius:var(--radius);font-weight:600;
  background:rgba(217,119,6,.25);color:#fde68a;
  border-left:3px solid #fbbf24
}
.alko-drive-time{
  display:block;font-size:26px;font-weight:800;color:#fef3c7;margin-top:4px;
  animation:alko-pop .5s cubic-bezier(.36,.07,.19,.97) .3s both
}
.alko-drive--danger{
  display:block;padding:10px 14px;border-radius:var(--radius);font-weight:700;
  background:rgba(220,38,38,.25);color:#fca5a5;
  border-left:3px solid #f87171
}

/* ── Share block ── */
.share_alko{
  margin-top:4px;padding:14px;text-align:center;
  background:rgba(255,255,255,.1);border-radius:var(--radius);
  color:#fff;font-size:13px;backdrop-filter:blur(4px)
}
.dis_onl{
  display:inline-block;padding:3px 12px;margin:6px 0;
  background:#ef4444;color:#fff;font-size:16px;font-weight:800;
  border-radius:var(--radius-sm);
  animation:alko-discount 1.6s ease-in-out infinite alternate
}
@keyframes alko-discount{
  from{transform:scale(1);box-shadow:0 0 0 0 rgba(239,68,68,.4)}
  to  {transform:scale(1.06);box-shadow:0 0 10px 4px rgba(239,68,68,0)}
}

/* ── Submit row ── */
.alko-submit-row{
  padding:20px 24px;background:var(--border-light);
  border-top:1px solid var(--border);width:100%
}
.alko_but{
  width:100%;padding:14px;font-size:16px;font-weight:700;
  color:#fff;background:var(--primary);border:none;
  border-radius:var(--radius);cursor:pointer;letter-spacing:.3px;
  box-shadow:0 4px 14px rgba(26,86,219,.35);
  transition:background var(--transition),transform var(--transition),box-shadow var(--transition);
  position:relative;overflow:hidden
}
.alko_but::after{
  content:'';position:absolute;inset:0;border-radius:var(--radius);
  animation:alko-btn-pulse 2.8s ease infinite
}
@keyframes alko-btn-pulse{
  0%  {box-shadow:0 0 0 0 rgba(255,255,255,.35)}
  60% {box-shadow:0 0 0 12px rgba(255,255,255,0)}
  100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}
}
.alko_but:hover{
  background:var(--primary-hover);transform:translateY(-2px);
  box-shadow:0 7px 20px rgba(26,86,219,.45)
}
.alko_but:active{transform:translateY(0)}

/* ── Recommendations table ── */
#tab_alko_online_tovar{
  width:100%;border:none!important;border-radius:var(--radius-lg);
  overflow:hidden;margin-top:24px;
  background:var(--white);box-shadow:var(--shadow-sm)
}
#tab_alko_online_tovar td{
  padding:20px 24px!important;border:none!important;
  font-size:14px;line-height:1.7;vertical-align:top
}
#tab_alko_online_tovar img{
  width:50px;height:auto;border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);margin-right:8px;float:left
}

/* ── Responsive ── */
@media(max-width:640px){
  .alko-form-col,.alko-result-col{width:100%}
  .alko-form-col{border-right:none;border-bottom:1px solid var(--border)}
  .alko-promille-val{font-size:44px}
  .alko-form-col .col-6-sm{width:50%}
}

/* ─── Price list page (.price-page) ─────────────────────────────────────── */
.price-page{display:flex;flex-direction:column;gap:16px}

/* Category filter */
.price-cats{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.price-cat-form{display:contents}
.price-cat-btn{
  padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);
  background:#fff;font-size:13px;font-family:inherit;cursor:pointer;
  color:var(--text-muted);transition:all .15s;white-space:nowrap;
}
.price-cat-btn:hover{border-color:var(--primary);color:var(--primary)}
.price-cat-btn.is-active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}
.price-cat-link{
  font-size:13px;color:var(--text-muted);padding:6px 12px;
  border-radius:20px;border:1.5px dashed var(--border);
  text-decoration:none;white-space:nowrap;transition:all .15s;
}
.price-cat-link:hover{color:var(--primary);border-color:var(--primary)}

/* Sensor filter */
.price-sensors{display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.price-sensors__label{font-size:13px;color:var(--text-muted);flex-shrink:0}
.price-sensor-form{display:contents}
.price-sensor-btn{
  padding:5px 14px;border-radius:16px;border:1.5px solid var(--border);
  background:#fff;font-size:12px;font-family:inherit;cursor:pointer;
  color:var(--text-muted);transition:all .15s;
}
.price-sensor-btn.is-on{background:var(--success-light);border-color:var(--success);color:var(--success);font-weight:600}
.price-sensor-btn:hover{border-color:var(--primary)}

/* Table wrapper */
.price-table-wrap{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff}
.price-table{
  width:100%;border-collapse:collapse;font-size:14px;min-width:700px;
}
.price-table thead th{
  background:var(--primary-light);color:var(--text);font-weight:600;
  padding:10px 12px;border-bottom:2px solid var(--primary);
  white-space:nowrap;
}
.price-table tbody tr{border-bottom:1px solid var(--border-light)}
.price-table tbody tr:last-child{border-bottom:none}
.price-table tbody tr:hover{background:var(--bg-light,#f7f8fa)}
.price-table td{padding:8px 12px;vertical-align:middle}

/* Sort buttons in header */
.pt-sort{display:inline-flex;flex-direction:column;margin-left:6px;gap:1px;vertical-align:middle}
.pt-sort form{display:contents}
.pt-sort-btn{
  background:none;border:none;padding:0 2px;cursor:pointer;
  font-size:11px;line-height:1;color:var(--text-muted);opacity:.6;transition:opacity .1s;
}
.pt-sort-btn:hover,.pt-sort-btn.is-active{opacity:1;color:var(--primary)}
.pt-sort-btn.is-active{font-weight:700}

/* Column widths */
.pt-photo{width:70px;text-align:center}
.pt-col--name{min-width:180px}
.pt-col--price{white-space:nowrap}
.pt-col--price2,.pt-col--price3,.pt-col--price5{white-space:nowrap;color:var(--text-muted);font-size:13px;text-align:right}
.pt-buy{width:120px;text-align:center}

/* Photo cell */
td.pt-photo img{width:60px;height:60px;object-fit:contain;display:block;margin:0 auto;border-radius:4px}

/* Name cell */
.pt-name{color:var(--text);font-weight:500;text-decoration:none;line-height:1.35}
.pt-name:hover{color:var(--primary)}
.pt-strana{display:block;font-size:12px;color:var(--text-muted)}
.pt-badge{
  display:inline-block;font-size:11px;font-weight:700;
  padding:1px 7px;border-radius:10px;
  background:#fef9c3;color:#854d0e;margin-left:6px;
}

/* Price */
.pt-price{font-size:15px;color:var(--primary)}

/* Buy cell */
.pt-buy-form{display:flex;justify-content:center}
.pt-qty-wrap{display:flex;align-items:center;gap:4px}
.pt-qty{
  width:44px;padding:5px 6px;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);font-size:13px;font-family:inherit;
  text-align:center;outline:none;transition:border-color .15s;
}
.pt-qty:focus{border-color:var(--primary)}
.pt-add-btn{
  padding:6px 10px;background:var(--primary);color:#fff;
  border:none;border-radius:var(--radius-sm);cursor:pointer;
  font-size:14px;transition:opacity .15s;
}
.pt-add-btn:hover{opacity:.85}
.pt-incart{
  display:flex;align-items:center;justify-content:center;gap:5px;
  font-size:13px;color:var(--success);font-weight:600;
}
.pt-incart__del{
  color:var(--danger);text-decoration:none;font-size:14px;
  opacity:.7;transition:opacity .15s;
}
.pt-incart__del:hover{opacity:1}

@media(max-width:599px){
  .price-table{min-width:560px}
  .pt-col--price2,.pt-col--price3,.pt-col--price5{display:none}
}

/* ── 360° viewer ─────────────────────────────────────────────────────────── */
.pd-360-btn{display:inline-flex;align-items:center;gap:6px;margin-top:10px;
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  padding:7px 14px;font-size:.85rem;font-weight:500;color:var(--text);cursor:pointer;
  transition:border-color var(--transition),color var(--transition)}
.pd-360-btn:hover{border-color:var(--primary);color:var(--primary)}
.pd-360-btn .fa-rotate{color:var(--primary)}

.overlay360{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);
  z-index:1100;align-items:center;justify-content:center}
.overlay360.is-open{display:flex}
.modal360{background:var(--white);border-radius:var(--radius-lg);padding:24px;
  position:relative;max-width:540px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.modal360__close{position:absolute;top:12px;right:12px;width:32px;height:32px;
  border:none;background:var(--border-light);border-radius:50%;font-size:14px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}
.modal360__close:hover{background:var(--border);color:var(--text)}
.spin360-hint{text-align:center;font-size:.8rem;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;justify-content:center;gap:6px}
.spin360-wrap{width:100%;aspect-ratio:1/1;max-height:460px;cursor:grab;overflow:hidden;
  border-radius:var(--radius);border:1px solid var(--border-light);user-select:none}
.spin360-wrap:active{cursor:grabbing}
.spin360-img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none}

/* ── Vybor1 widget (characteristic selector) ───────────────────────────── */
.vybor1-toggle{margin:16px 0}
.vybor1-open-btn{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;
  border:none;border-radius:var(--radius);padding:10px 20px;font-size:.95rem;font-weight:500;
  cursor:pointer;transition:background var(--transition)}
.vybor1-open-btn:hover{background:var(--primary-hover)}

.vybor1-widget{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:20px;margin:20px 0;box-shadow:var(--shadow)}
.vybor1-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.vybor1-title{font-size:1rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}
.vybor1-close-btn{display:inline-flex;align-items:center;gap:6px;background:var(--border-light);color:var(--text-muted);
  border:1px solid var(--border);border-radius:var(--radius);padding:6px 14px;font-size:.85rem;
  cursor:pointer;transition:background var(--transition)}
.vybor1-close-btn:hover{background:var(--border);color:var(--text)}

.vybor1-filters{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.vybor1-filter-group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.vybor1-filter-label{font-size:.85rem;font-weight:600;color:var(--text-muted);white-space:nowrap}
.vybor1-chip{background:var(--border-light);border:1px solid var(--border);border-radius:20px;
  padding:5px 14px;font-size:.85rem;color:var(--text);cursor:pointer;transition:all var(--transition)}
.vybor1-chip:hover{border-color:var(--primary);color:var(--primary)}
.vybor1-chip.is-active{background:var(--primary);border-color:var(--primary);color:#fff}
.vybor1-chip--sensor.is-active{background:var(--success);border-color:var(--success);color:#fff}

.vybor1-table-wrap{overflow-x:auto}
.vybor1-table{width:100%;border-collapse:collapse;font-size:.9rem}
.vybor1-table thead tr{border-bottom:2px solid var(--border)}
.vybor1-table th{padding:10px 12px;text-align:left;font-weight:600;color:var(--text-muted);
  font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;background:var(--bg);
  vertical-align:middle}
.vybor1-table td{padding:10px 12px;border-bottom:1px solid var(--border-light);vertical-align:middle}
.vybor1-table tbody tr:hover{background:var(--border-light)}
.vybor1-table tbody tr:last-child td{border-bottom:none}

.vybor1-th-photo{width:80px}
.vybor1-td-photo img{width:60px;height:60px;object-fit:contain}
.vybor1-td-name a{color:var(--text);font-weight:500;text-decoration:none;line-height:1.4}
.vybor1-td-name a:hover{color:var(--primary)}
.vybor1-rec-badge{display:inline-block;background:var(--primary-light);color:var(--primary);
  font-size:.7rem;font-weight:600;padding:2px 7px;border-radius:10px;margin-top:4px}
.vybor1-nodata{color:var(--text-muted);font-size:.82rem}
.vybor1-td-price{font-weight:700;color:var(--primary);white-space:nowrap}

.vybor1-col-label{display:block;margin-bottom:4px}
.vybor1-sort-btns{display:flex;gap:2px}
.vybor1-sort-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:1px 5px;font-size:.8rem;cursor:pointer;color:var(--text-muted);transition:all var(--transition)}
.vybor1-sort-btn:hover{border-color:var(--primary);color:var(--primary)}
.vybor1-sort-btn.is-active{background:var(--primary);border-color:var(--primary);color:#fff}

.vybor1-buy-form{display:flex;align-items:center;gap:6px}
.vybor1-qty{width:44px;border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:4px 6px;text-align:center;font-size:.85rem}
.vybor1-add-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);
  padding:6px 10px;cursor:pointer;transition:background var(--transition);font-size:.9rem}
.vybor1-add-btn:hover{background:var(--primary-hover)}

@media(max-width:768px){
  .vybor1-table th:nth-child(3),.vybor1-table td:nth-child(3){display:none}
  .vybor1-widget{padding:14px}
}
/* ── zakaz.html (zk-*) ──────────────────────────────────────────────────── */
.zk-title{font-size:22px;font-weight:700;color:var(--text);margin:0 0 20px}
.zk-wrap{display:flex;gap:24px;align-items:flex-start}
.zk-form-col{flex:1 1 0;min-width:0}
.zk-summary{width:320px;flex-shrink:0;border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;background:var(--white)}
.zk-section-title{font-size:14px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.4px;margin:0 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.zk-field{margin-bottom:14px}
.zk-row{display:flex;gap:14px}
.zk-row .zk-field{flex:1 1 0}
.zk-label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:4px}
.zk-req{color:var(--danger)}
.zk-input,.zk-textarea{width:100%;box-sizing:border-box;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);font-family:inherit;background:var(--white);transition:border-color var(--transition)}
.zk-input:focus,.zk-textarea:focus{border-color:var(--primary);outline:none}
.zk-textarea{resize:vertical;min-height:64px}
.zk-msg{font-size:12px;color:var(--text-light);margin-top:4px}
.zk-pay-opts{display:flex;gap:12px;margin-bottom:18px}
.zk-pay-opt{flex:1;border:2px solid var(--border);border-radius:var(--radius);padding:12px 14px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:border-color var(--transition),background var(--transition);background:var(--white)}
.zk-pay-opt:hover{border-color:var(--primary)}
.zk-pay-opt--on{border-color:var(--primary);background:var(--primary-light)}
.zk-pay-icon{font-size:22px;color:var(--text-light);flex-shrink:0}
.zk-pay-opt--on .zk-pay-icon{color:var(--primary)}
.zk-pay-body{flex:1;min-width:0}
.zk-pay-body strong{display:block;font-size:14px;color:var(--text)}
.zk-pay-body span{font-size:12px;color:var(--text-muted)}
.zk-pay-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;position:relative;transition:border-color var(--transition),background var(--transition)}
.zk-pay-opt--on .zk-pay-check{border-color:var(--primary);background:var(--primary)}
.zk-pay-opt--on .zk-pay-check::after{content:'';position:absolute;top:3px;left:3px;width:8px;height:8px;border-radius:50%;background:#fff}
.zk-consent{font-size:12px;color:var(--text-light);margin-bottom:16px;line-height:1.5}
.zk-consent a{color:var(--primary)}
.zk-submit{display:inline-block;padding:11px 28px;background:var(--primary);color:#fff!important;font-size:15px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;text-decoration:none;transition:background var(--transition)}
.zk-submit:hover{background:var(--primary-hover)}
.zk-req-note{font-size:12px;color:var(--text-light);margin-top:10px}
.zk-summary__title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 14px}
.zk-summary__items{margin-bottom:14px}
@media(max-width:640px){
  .zk-wrap{flex-direction:column}
  .zk-summary{width:100%}
  .zk-row{flex-direction:column;gap:0}
  .zk-pay-opts{flex-direction:column}
}

/* ── Docs page (idoc-*) ────────────────────────────────────────────────── */
.idoc-page { margin-top: .5rem; }
.idoc-empty { color: var(--text-muted); }

.idoc-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1.5rem;
}
.idoc-chip {
  padding: .35rem .85rem;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: var(--white);
  color: var(--text-muted);
  font-size: .82rem;
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.idoc-chip:hover { border-color: var(--primary); color: var(--primary); }
.idoc-chip.is-active { background: var(--primary); border-color: var(--primary); color: #fff; }

.idoc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 1.25rem;
}
.idoc-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem 1rem .875rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  transition: box-shadow var(--transition);
}
.idoc-card:hover { box-shadow: var(--shadow-md); }

.idoc-card__head {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
}
.idoc-card__thumb {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.idoc-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.idoc-card__name {
  font-size: .875rem;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  line-height: 1.35;
}
.idoc-card__name:hover { color: var(--primary); }

.idoc-card__docs {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}
.idoc-doc-btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .3rem .7rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  font-size: .8rem;
  color: var(--text);
  text-decoration: none;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  max-width: 100%;
  min-width: 0;
}
.idoc-doc-btn span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
}
.idoc-doc-btn:hover {
  background: var(--primary-light);
  border-color: var(--primary);
  color: var(--primary);
}
.idoc-doc-btn:hover .idoc-ext { color: var(--primary); }
.idoc-ext {
  font-size: .7rem;
  font-style: normal;
  font-weight: 600;
  color: var(--text-light);
  text-transform: uppercase;
}

@media(max-width:600px) {
  .idoc-grid { grid-template-columns: 1fr; }
}

/* ── Service centers page (sc-*) ─────────────────────────────────────────── */
.sc-main {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  background: var(--white);
  border: 2px solid var(--primary);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-bottom: 32px;
  box-shadow: var(--shadow-md);
}
.sc-main__img {
  flex-shrink: 0;
  width: 220px;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
}
.sc-main__img img { width: 100%; display: block; }
.sc-main__info { flex: 1; min-width: 0; }
.sc-main__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--primary);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 4px 10px;
  border-radius: 20px;
  margin-bottom: 12px;
}
.sc-main__name {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}
.sc-main__addr {
  font-size: 14px;
  color: var(--text-muted);
  margin-bottom: 14px;
  line-height: 1.5;
}
.sc-main__row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}
.sc-main__row i { color: var(--primary); width: 16px; flex-shrink: 0; }
.sc-main__row a { color: var(--primary); font-weight: 600; text-decoration: none; }
.sc-main__row a:hover { text-decoration: underline; }
.sc-main__hours {
  margin-top: 12px;
  font-size: 13px;
  color: var(--text-muted);
  background: var(--bg);
  border-radius: var(--radius-sm);
  padding: 6px 12px;
  display: inline-block;
}

.sc-section-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.sc-section-title::after {
  content: '';
  flex: 1;
  height: 2px;
  background: var(--border);
  border-radius: 1px;
}

.sc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 28px;
}
.sc-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px;
  font-size: 13px;
  line-height: 1.55;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .18s, border-color .18s;
}
.sc-item:hover { box-shadow: var(--shadow-md); border-color: #bfdbfe; }
.sc-item__city {
  font-size: 14px;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  gap: 6px;
}
.sc-item__city i { font-size: 12px; opacity: .7; }
.sc-center { margin-bottom: 10px; }
.sc-center:last-child { margin-bottom: 0; }
.sc-center + .sc-center {
  padding-top: 10px;
  border-top: 1px dashed var(--border-light);
}
.sc-center__name {
  font-weight: 600;
  color: var(--text);
  margin-bottom: 2px;
}
.sc-center__addr {
  color: var(--text-muted);
  margin-bottom: 4px;
}
.sc-center__phone { color: var(--text); margin-bottom: 2px; }
.sc-center__phone a { color: var(--primary); text-decoration: none; }
.sc-center__phone a:hover { text-decoration: underline; }
.sc-center__email a { color: var(--primary); text-decoration: none; font-size: 12px; }
.sc-center__email a:hover { text-decoration: underline; }
.sc-center__note {
  font-size: 12px;
  color: #16a34a;
  margin-top: 3px;
}

.sc-filter {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 16px;
  box-shadow: var(--shadow-sm);
}
.sc-filter__search {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 7px 12px;
  margin-bottom: 12px;
}
.sc-filter__search i { color: var(--text-muted); font-size: 13px; flex-shrink: 0; }
.sc-filter__search input {
  border: none;
  background: transparent;
  outline: none;
  font-size: 14px;
  color: var(--text);
  width: 100%;
}
.sc-filter__search input::placeholder { color: var(--text-light); }
.sc-filter__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.sc-pill {
  padding: 4px 12px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--bg);
  font-size: 13px;
  color: var(--text-muted);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  white-space: nowrap;
}
.sc-pill:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-light); }
.sc-pill.is-active { background: var(--primary); color: #fff; border-color: var(--primary); }
.sc-filter__empty { color: var(--text-muted); padding: 24px 0; text-align: center; font-size: 14px; }

.sc-notice {
  display: flex;
  gap: 14px;
  background: #fefce8;
  border: 1px solid #fde68a;
  border-radius: var(--radius);
  padding: 16px 20px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--text);
}
.sc-notice i { font-size: 18px; color: #d97706; flex-shrink: 0; padding-top: 2px; }
.sc-notice p { margin: 0 0 8px; }
.sc-notice p:last-child { margin: 0; }

@media(max-width:900px) { .sc-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:600px) {
  .sc-grid { grid-template-columns: 1fr; }
  .sc-main { flex-direction: column; }
  .sc-main__img { width: 100%; }
}

/* ── Contact page ─────────────────────────────────────────────────────────── */
.cont_block {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  height: 100%;
  box-sizing: border-box;
  box-shadow: var(--shadow-sm);
  font-size: 14px;
  line-height: 1.7;
}
.cont_block h2 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
  line-height: 1.3;
}
.cont_block h2 i {
  font-size: 22px;
  color: var(--primary);
  width: 52px;
  height: 52px;
  background: var(--primary-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cont_block > i.fa {
  color: var(--primary);
  margin-right: 6px;
  font-size: 13px;
}
.cont_block a { color: var(--primary); font-weight: 600; }
.cont_block a:hover { text-decoration: underline; }
.cont_block span[style*="color: red"],
.cont_block span[style*="color:red"] { color: #dc2626 !important; font-weight: 600; }

.site-main > .row:first-child {
  margin-bottom: 28px;
}
.site-main > .row:first-child > [class*="col-"] {
  margin-bottom: 0;
}

.info_block {
  background: var(--primary-light);
  border: 1px solid #bfdbfe;
  border-radius: var(--radius);
  padding: 18px 20px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--text);
  margin: 20px 0;
}
.info_block p,
.info_block .MsoNormal {
  margin: 0 0 8px;
  padding: 0;
}
.info_block p:last-child,
.info_block .MsoNormal:last-child { margin-bottom: 0; }
.info_block b { color: #dc2626; }
.info_block span[style*="color: rgb(255, 0, 0)"],
.info_block span[style*="color:red"] { color: #dc2626 !important; }

.contact-map {
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin: 24px 0;
  border: 1px solid var(--border);
  line-height: 0;
  font-size: 0;
}
.contact-map iframe { display: block; width: 100%; }

.site-main > .row + .row .col-6 img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: var(--radius);
  display: block;
  border: 1px solid var(--border);
  margin-bottom: 0;
}
.site-main > .row + .row {
  gap: 10px 0;
  margin: 24px 0;
}

.site-main h2 { font-size: 18px; font-weight: 700; margin: 28px 0 8px; color: var(--text); }
.site-main h3 { font-size: 14px; font-weight: 700; color: var(--text-muted); margin: 16px 0 4px; text-transform: uppercase; letter-spacing: .03em; }
.site-main > p { font-size: 14px; line-height: 1.65; margin: 0 0 8px; }

.site-main > div:not([class]) {
  font-size: 14px;
  line-height: 2;
  color: var(--text);
}

.contact-requisites {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-top: 28px;
  font-size: 14px;
  line-height: 2;
  box-shadow: var(--shadow-sm);
}

@media(max-width:640px) {
  .site-main > .row:first-child > [class*="col-"] { width: 100%; }
  .site-main > .row + .row .col-6 { width: 50%; }
  .site-main > .row + .row .col-6 img { height: 130px; }
}

/* ── Contact page (ct-*) ──────────────────────────────────────────────────── */
.ct-cards {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
  margin-bottom: 28px;
}
.ct-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px 20px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  box-shadow: var(--shadow-sm);
  gap: 0;
}
.ct-card__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--primary-light);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin-bottom: 14px;
  flex-shrink: 0;
}
.ct-card__title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
  margin-bottom: 12px;
}
.ct-card__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  color: var(--text);
  line-height: 1.5;
  width: 100%;
}
.ct-phone {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  text-decoration: none;
  letter-spacing: .01em;
  white-space: nowrap;
}
.ct-phone:hover { color: var(--primary); text-decoration: none; }
.ct-messengers {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 4px;
}
.ct-msg {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: opacity .15s;
}
.ct-msg:hover { opacity: .85; text-decoration: none; }
.ct-msg--wa {
  background: #25d366;
  color: #fff;
}
.ct-msg--max {
  background: #0077ff;
  color: #fff;
}
.ct-max-ico {
  height: 14px;
  width: auto;
  filter: brightness(0) invert(1);
  vertical-align: middle;
}
.ct-email {
  color: var(--primary);
  font-size: 14px;
  font-weight: 600;
  word-break: break-all;
}
.ct-email:hover { text-decoration: underline; }
.ct-closed { color: #dc2626; font-weight: 600; }
.ct-pickup-note {
  margin-top: 8px;
  font-size: 12px;
  color: var(--text-muted);
  background: var(--bg);
  border-radius: var(--radius-sm);
  padding: 4px 10px;
}

/* map */
.ct-map {
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin: 0 0 24px;
  border: 1px solid var(--border);
  line-height: 0;
  font-size: 0;
}
.ct-map iframe { display: block; width: 100%; }
.ct-map--panorama { margin-top: 0; }

/* info block */
.ct-info {
  display: flex;
  gap: 16px;
  background: var(--primary-light);
  border: 1px solid #bfdbfe;
  border-radius: var(--radius);
  padding: 18px 20px;
  margin-bottom: 24px;
  font-size: 14px;
  line-height: 1.65;
}
.ct-info__icon {
  font-size: 20px;
  color: var(--primary);
  flex-shrink: 0;
  padding-top: 2px;
}
.ct-info__text p { margin: 0 0 8px; }
.ct-info__text p:last-child { margin-bottom: 0; }
.ct-warn { color: #dc2626; }

/* photo gallery carousel */
.ct-gallery {
  position: relative;
  margin-bottom: 28px;
  user-select: none;
}
.ct-gallery__viewport {
  overflow: hidden;
  border-radius: var(--radius-lg);
}
.ct-gallery__track {
  display: flex;
  transition: transform .32s cubic-bezier(.4,0,.2,1);
}
.ct-gallery__slide {
  min-width: calc(100% / 3);
  flex-shrink: 0;
  padding: 0 5px;
  box-sizing: border-box;
  cursor: pointer;
}
.ct-gallery__slide img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: var(--radius);
  display: block;
  transition: opacity .2s;
}
.ct-gallery__slide img:hover { opacity: .9; }
.ct-gallery__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--text);
  font-size: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow);
  transition: background .15s, color .15s;
  z-index: 2;
}
.ct-gallery__btn:hover:not(:disabled) { background: var(--primary); color: #fff; border-color: var(--primary); }
.ct-gallery__btn:disabled { opacity: .3; cursor: default; }
.ct-gallery__btn--prev { left: -14px; }
.ct-gallery__btn--next { right: -14px; }
.ct-gallery__dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
}
.ct-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: var(--border);
  cursor: pointer;
  padding: 0;
  transition: background .15s, width .15s;
}
.ct-dot.is-active { background: var(--primary); width: 20px; border-radius: 4px; }

/* lightbox */
.ct-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.85);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.ct-lightbox__inner {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
}
.ct-lightbox__inner img {
  max-width: 100%;
  max-height: 85vh;
  border-radius: var(--radius);
  display: block;
}
.ct-lightbox__close {
  position: absolute;
  top: -16px;
  right: -16px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #fff;
  border: none;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* nav section */
.ct-section-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 16px;
}
.ct-nav-wrap { margin-bottom: 28px; }
.ct-nav-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  border-bottom: 2px solid var(--border);
  padding-bottom: 0;
}
.ct-nav-tab {
  padding: 8px 18px;
  border: none;
  background: none;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  border-radius: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: color .15s;
}
.ct-nav-tab:hover { color: var(--primary); }
.ct-nav-tab.is-active { color: var(--primary); border-bottom-color: var(--primary); }
.ct-nav-panel { display: none; font-size: 14px; line-height: 1.7; }
.ct-nav-panel.is-active { display: block; }
.ct-nav-panel p { margin: 0 0 10px; }
.ct-nav-dir { margin-bottom: 14px; }
.ct-nav-dir__label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted);
  margin-bottom: 4px;
}

/* requisites */
.ct-requisites { margin-bottom: 24px; }
.ct-req-grid {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.ct-req-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 12px;
  padding: 10px 20px;
  font-size: 14px;
  border-bottom: 1px solid var(--border-light);
  align-items: start;
}
.ct-req-row:last-child { border-bottom: none; }
.ct-req-label {
  color: var(--text-muted);
  font-weight: 600;
  font-size: 13px;
  white-space: nowrap;
}
.ct-req-row a { color: var(--primary); }
.ct-req-row--full { grid-template-columns: 160px 1fr; }

@media(max-width:768px) {
  .ct-cards { grid-template-columns: 1fr; }
  .ct-gallery__slide { min-width: 50%; }
  .ct-gallery__btn--prev { left: 4px; }
  .ct-gallery__btn--next { right: 4px; }
}
@media(max-width:480px) {
  .ct-gallery__slide { min-width: 100%; }
  .ct-req-row { grid-template-columns: 110px 1fr; gap: 8px; padding: 9px 14px; }
  .ct-req-row--full { grid-template-columns: 110px 1fr; }
}

/* ── Requisites / documents page (rq-*) ──────────────────────────────────── */
.rq-edo {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: var(--radius);
  padding: 12px 16px;
  margin-bottom: 0;
  font-size: 13px;
  color: #166534;
}
.rq-edo i { font-size: 16px; color: #16a34a; flex-shrink: 0; }
.rq-edo strong { font-family: monospace; font-size: 14px; letter-spacing: .03em; }

.rq-docs-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin: 28px 0 14px;
}
.rq-docs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.rq-doc {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 14px 16px;
  text-decoration: none;
  color: var(--text);
  box-shadow: var(--shadow-sm);
  transition: box-shadow .18s, border-color .18s, transform .18s;
  gap: 10px;
}
.rq-doc:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--primary);
  transform: translateY(-2px);
  text-decoration: none;
  color: var(--text);
}
.rq-doc__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.rq-doc__icon--pdf { background: #fee2e2; color: #dc2626; }
.rq-doc__icon--doc { background: #dbeafe; color: #2563eb; }
.rq-doc__name {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.4;
  flex: 1;
}
.rq-doc__ext {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-light);
  background: var(--bg);
  padding: 2px 8px;
  border-radius: 20px;
}
.rq-doc:hover .rq-doc__ext { background: var(--primary-light); color: var(--primary); }

@media(max-width:768px) {
  .rq-docs { grid-template-columns: repeat(3,1fr); }
}
@media(max-width:480px) {
  .rq-docs { grid-template-columns: repeat(2,1fr); }
}

/* ── Price / service page (pp-*) ─────────────────────────────── */
.pp-sc-card {
  display: flex;
  gap: 24px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  margin-bottom: 28px;
  align-items: flex-start;
}
.pp-sc-imgs {
  flex-shrink: 0;
  width: 200px;
}
.pp-sc-imgs img {
  width: 100%;
  border-radius: var(--radius);
  object-fit: cover;
}
.pp-sc-info { flex: 1; min-width: 0; }
.pp-sc-name {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 10px;
  color: var(--text);
}
.pp-sc-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: 14px;
  color: var(--text);
  margin-bottom: 6px;
  flex-wrap: wrap;
}
.pp-sc-row i { color: var(--primary); flex-shrink: 0; font-size: 13px; }
.pp-sc-row a { color: var(--primary); text-decoration: none; }
.pp-sc-row a:hover { text-decoration: underline; }

.pp-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.pp-tab {
  padding: 7px 16px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: var(--white);
  color: var(--text);
  font-size: 13px;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  line-height: 1.4;
}
.pp-tab:hover { background: var(--bg); border-color: var(--primary); color: var(--primary); }
.pp-tab.is-active { background: var(--primary); border-color: var(--primary); color: #fff; }

.pp-panel { display: none; }
.pp-panel.is-active { display: block; }

.pp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin-bottom: 28px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.pp-table th {
  background: var(--bg);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted);
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.pp-table td {
  padding: 11px 14px;
  vertical-align: top;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  line-height: 1.5;
}
.pp-table tr:last-child td { border-bottom: none; }
.pp-table tr:hover td { background: var(--bg); }
.pp-col-price { width: 140px; white-space: nowrap; }
.pp-col-dur   { width: 110px; white-space: nowrap; color: var(--text-muted); }
.pp-col-note  { width: 200px; color: var(--text-muted); font-size: 13px; }

.pp-price { font-weight: 600; color: var(--text); }
.pp-price-note { font-size: 11px; color: var(--text-muted); display: block; margin-top: 2px; }
.pp-price-req { color: var(--text-muted); font-style: italic; }

.pp-notice {
  display: flex;
  gap: 14px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: var(--radius-lg);
  padding: 16px 20px;
  font-size: 13.5px;
  color: #1e3a5f;
  margin-top: 8px;
}
.pp-notice i { color: #3b82f6; flex-shrink: 0; font-size: 17px; margin-top: 2px; }
.pp-notice p { margin: 0 0 6px; }
.pp-notice p:last-child { margin-bottom: 0; }

@media(max-width:768px) {
  .pp-sc-card { flex-direction: column; }
  .pp-sc-imgs { width: 100%; max-width: 280px; }
  .pp-col-dur, .pp-col-note { display: none; }
  .pp-col-price { width: auto; }
}
@media(max-width:480px) {
  .pp-table th, .pp-table td { padding: 8px 10px; }
  .pp-tab { font-size: 12px; padding: 6px 12px; }
}

/* ══════════════════════════════════════════════════════════════════
   ABOUT PAGE
   ══════════════════════════════════════════════════════════════════ */
.about-wrap { max-width: 760px; }

.about-lead {
  font-size: 17px;
  line-height: 1.7;
  background: var(--primary-light);
  border-left: 4px solid var(--primary);
  padding: 20px 24px;
  border-radius: 0 var(--radius) var(--radius) 0;
  margin-bottom: 36px;
}

.about-section { margin-bottom: 36px; }
.about-section p { margin-bottom: 12px; }

.about-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 20px;
  margin-bottom: 16px;
  color: var(--text);
}
.about-title i { color: var(--primary); font-size: 18px; }

.about-values {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 14px;
  margin-top: 16px;
}
.about-value {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--white, #fff);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
}
.about-value__icon {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary-light);
  color: var(--primary);
  font-size: 16px;
}
.about-value__body { display: flex; flex-direction: column; gap: 3px; }
.about-value__body strong { font-size: 14px; color: var(--text); }
.about-value__body span { font-size: 13px; color: var(--text-muted); }

.about-list { list-style: none; padding: 0; margin: 12px 0 0; display: flex; flex-direction: column; gap: 10px; }
.about-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 15px; }
.about-list li i { color: var(--primary); margin-top: 3px; flex-shrink: 0; }

.about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 36px 0;
  padding: 28px;
  background: var(--primary);
  border-radius: var(--radius-lg);
  color: #fff;
  text-align: center;
}
.about-stat__num {
  font-size: 32px;
  font-weight: 700;
  line-height: 1.1;
}
.about-stat__label {
  font-size: 13px;
  opacity: .85;
  margin-top: 6px;
}

.about-cta {
  background: var(--white, #fff);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  margin-top: 36px;
}
.about-cta__title {
  font-size: 17px;
  font-weight: 600;
  margin-bottom: 14px;
  color: var(--text);
}
.about-cta__contacts { display: flex; flex-wrap: wrap; gap: 16px; }
.about-cta__item {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-size: 15px;
  text-decoration: none;
}
.about-cta__item i { color: var(--primary); }
a.about-cta__item:hover { color: var(--primary); }

@media (max-width: 600px) {
  .about-stats { grid-template-columns: 1fr; gap: 14px; padding: 20px; }
  .about-values { grid-template-columns: 1fr; }
  .about-cta__contacts { flex-direction: column; gap: 10px; }
}

/* ══════════════════════════════════════════════════════════════════
   CONTACTS PAGE
   ══════════════════════════════════════════════════════════════════ */
.cnt-lead{font-size:17px;color:var(--text-muted);margin-bottom:32px}
.cnt-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:8px}
.cnt-company{font-size:20px;font-weight:700;color:var(--text);margin-bottom:24px}
.cnt-items{display:flex;flex-direction:column;gap:20px;margin-bottom:28px}
.cnt-item{display:flex;gap:16px;align-items:flex-start}
.cnt-item__icon{width:42px;height:42px;border-radius:50%;background:var(--primary-light);
  color:var(--primary);display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0}
.cnt-item__label{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:3px;
  text-transform:uppercase;letter-spacing:.04em}
.cnt-item__value{font-size:15px;color:var(--text);line-height:1.5}
.cnt-item__value a{color:var(--primary-dark);text-decoration:none}
.cnt-item__value a:hover{color:var(--primary);text-decoration:underline}
.cnt-hours{background:var(--bg);border-radius:var(--radius-lg);padding:18px 20px;
  border:1px solid var(--border);display:flex;gap:14px;align-items:flex-start}
.cnt-hours__icon{color:var(--primary);font-size:18px;margin-top:2px;flex-shrink:0}
.cnt-hours__title{font-weight:600;color:var(--text);margin-bottom:4px}
.cnt-hours__text{font-size:14px;color:var(--text-muted);line-height:1.6}
.cnt-map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  margin-bottom:20px;border:1px solid var(--border)}
.cnt-map iframe{display:block;width:100%;height:340px;border:0}
.cnt-btns{display:flex;gap:12px}
.cnt-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 20px;border-radius:var(--radius-lg);font-size:15px;font-weight:600;
  text-decoration:none;transition:background .15s,transform .1s;cursor:pointer;border:2px solid transparent}
.cnt-btn:hover{transform:translateY(-1px);text-decoration:none}
.cnt-btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.cnt-btn--primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}
.cnt-btn--outline{background:var(--white);color:var(--primary);border-color:var(--primary)}
.cnt-btn--outline:hover{background:var(--primary-light);color:var(--primary-dark)}
@media(max-width:768px){
  .cnt-grid{grid-template-columns:1fr;gap:32px}
  .cnt-btns{flex-direction:column}
}

/* ── About landing block ── */
.about-lp__text p {
  line-height: 1.75;
  margin-bottom: 14px;
  font-size: 15px;
  color: var(--text);
}
.about-lp__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 32px 0 28px;
}
.about-lp__stat {
  background: var(--white);
  border: 1px solid var(--border);
  border-top: 3px solid var(--primary);
  border-radius: var(--radius);
  padding: 22px 16px 18px;
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.about-lp__stat--ozon {
  border-top-color: var(--warning);
}
.about-lp__stat-num {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 34px;
  font-weight: 700;
  color: var(--primary-dark);
  line-height: 1.1;
  margin-bottom: 4px;
}
.about-lp__stat--ozon .about-lp__stat-num {
  color: var(--warning);
}
.about-lp__stat-stars {
  color: #f5a623;
  font-size: 15px;
  letter-spacing: 1px;
  margin-bottom: 6px;
}
.about-lp__stat-label {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.4;
}
.about-lp__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--primary);
  color: #fff;
  padding: 11px 26px;
  border-radius: var(--radius);
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  transition: background .2s, transform .2s, box-shadow .2s;
}
.about-lp__cta:hover {
  background: var(--primary-hover);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
@media (max-width: 640px) {
  .about-lp__stats { grid-template-columns: 1fr; }
  .about-lp__stat-num { font-size: 28px; }
}

/* ─── Partnership Landing Page (slp-*) ─────────────────────────────────── */
.slp { font-size: 15px; }

/* Hero */
.slp-hero {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  border-radius: var(--radius-lg);
  padding: 56px 48px;
  color: #fff;
  text-align: center;
  margin-bottom: 40px;
}
.slp-hero__badge {
  display: inline-block;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 20px;
  padding: 5px 20px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.slp-hero__title {
  font-size: 38px;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 16px;
}
.slp-hero__sub {
  font-size: 16px;
  line-height: 1.7;
  opacity: .88;
  max-width: 660px;
  margin: 0 auto 36px;
}
.slp-kpi {
  display: flex;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
}
.slp-kpi__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.slp-kpi__num {
  font-size: 38px;
  font-weight: 800;
  line-height: 1;
}
.slp-kpi__label {
  font-size: 13px;
  opacity: .75;
  font-weight: 500;
}

/* Section generic */
.slp-section { margin-bottom: 40px; }
.slp-section__title {
  font-size: 22px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--primary);
}

/* Who grid */
.slp-who {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.slp-who__item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--white);
  border-radius: var(--radius);
  padding: 18px 16px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}
.slp-who__icon {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
  font-size: 15px;
}
.slp-who__text {
  font-size: 13.5px;
  color: var(--text);
  line-height: 1.5;
  padding-top: 9px;
}

/* Benefits */
.slp-benefits {
  background: #f0fdf4;
  border-radius: var(--radius-lg);
  padding: 36px 40px;
  margin-bottom: 40px;
  border: 1px solid #bbf7d0;
}
.slp-benefits .slp-section__title { border-bottom-color: #059669; }
.slp-checklist {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 32px;
  list-style: none;
  margin: 0; padding: 0;
}
.slp-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  font-size: 14px;
  color: var(--text);
  line-height: 1.55;
}
.slp-checklist li i {
  flex-shrink: 0;
  color: #059669;
  font-size: 16px;
  margin-top: 1px;
}

/* Format cards */
.slp-formats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.slp-format-card {
  background: var(--white);
  border-radius: var(--radius);
  padding: 24px 20px;
  box-shadow: var(--shadow);
  border-top: 3px solid var(--primary);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.slp-format-card__icon {
  font-size: 26px;
  color: var(--primary);
  margin-bottom: 6px;
}
.slp-format-card__title {
  font-size: 14.5px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.35;
}
.slp-format-card__text {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.55;
}

/* Why */
.slp-why {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
.slp-why__item {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  background: var(--white);
  border-radius: var(--radius);
  padding: 22px 20px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}
.slp-why__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: var(--radius);
  background: var(--primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
  font-size: 18px;
}
.slp-why__body strong {
  display: block;
  font-size: 14.5px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 5px;
  line-height: 1.3;
}
.slp-why__body span {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.5;
}

/* CTA */
.slp-cta {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  border-radius: var(--radius-lg);
  padding: 52px 48px;
  color: #fff;
  text-align: center;
}
.slp-cta__title {
  font-size: 28px;
  font-weight: 800;
  margin-bottom: 12px;
}
.slp-cta__sub {
  font-size: 15px;
  opacity: .88;
  max-width: 560px;
  margin: 0 auto 28px;
  line-height: 1.65;
}
.slp-cta__contacts {
  display: flex;
  justify-content: center;
  gap: 36px;
  flex-wrap: wrap;
  margin-bottom: 30px;
}
.slp-cta__contact {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14.5px;
  color: rgba(255,255,255,.85);
}
.slp-cta__contact i { font-size: 17px; opacity: .8; }
.slp-cta__contact a { color: #fff; font-weight: 600; }
.slp-cta__contact a:hover { opacity: .8; text-decoration: none; }
.slp-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  color: var(--primary);
  border-radius: var(--radius);
  padding: 14px 40px;
  font-size: 15.5px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  box-shadow: 0 4px 16px rgba(0,0,0,.18);
  transition: var(--transition);
}
.slp-cta__btn:hover {
  background: var(--primary-light);
  box-shadow: 0 6px 24px rgba(0,0,0,.22);
}

/* Responsive */
@media (max-width: 860px) {
  .slp-formats { grid-template-columns: repeat(2, 1fr); }
  .slp-who     { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .slp-hero    { padding: 36px 22px; }
  .slp-hero__title { font-size: 26px; }
  .slp-kpi     { gap: 24px; }
  .slp-kpi__num { font-size: 28px; }
  .slp-who     { grid-template-columns: 1fr; }
  .slp-checklist { grid-template-columns: 1fr; }
  .slp-formats { grid-template-columns: 1fr; }
  .slp-why     { grid-template-columns: 1fr; }
  .slp-benefits { padding: 24px 20px; }
  .slp-cta     { padding: 36px 22px; }
  .slp-cta__contacts { flex-direction: column; align-items: center; gap: 14px; }
  .slp-cta__title { font-size: 22px; }
}

