/* solutions.css — раздел «Купить готовые решения». Опирается на токены сайта. */

/* ── каталог ── */
.sol-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--sp-5);
}
.sol-card {
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  border: 1px solid var(--color-grey-200);
  border-radius: var(--radius-lg, 18px);
  overflow: hidden;
  transition: border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);
}
@media (hover: hover) { .sol-card:hover { border-color: var(--color-grey-300); box-shadow: 0 12px 30px rgba(20,18,16,0.08); } }
.sol-card__body { display: flex; flex-direction: column; gap: var(--sp-2); padding: var(--sp-4); flex: 1; }
.sol-card__cat {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.07em;
  color: var(--color-accent-text, var(--color-accent)); font-weight: var(--fw-semibold);
}
.sol-card__title { font-size: var(--fs-lg); font-weight: var(--fw-semibold); line-height: 1.2; margin: 0; }
.sol-card__title a { color: var(--color-text); text-decoration: none; }
@media (hover: hover) { .sol-card__title a:hover { color: var(--color-accent-text, var(--color-accent)); } }
.sol-card__summary { font-size: var(--fs-sm); color: var(--color-text-secondary); line-height: var(--lh-relaxed); margin: 0; }
.sol-card__color { font-size: var(--fs-sm); color: var(--color-text-secondary); margin: 0; }
.sol-card__color span { color: var(--color-text); font-weight: var(--fw-medium); }
.sol-card__foot { margin-top: auto; padding-top: var(--sp-2); display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.sol-card__price { display: flex; flex-direction: column; }
.sol-card__price-val { font-size: var(--fs-xl); font-weight: var(--fw-semibold); letter-spacing: -0.01em; }
.sol-card__price-note { font-size: 11px; color: var(--color-text-secondary); }
.sol-card__cta { white-space: nowrap; }

/* ── медиа: галерея + цвета ── */
.sol-media { position: relative; }
.sol-gallery {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--color-grey-100);
  overflow: hidden;
}
.sol-gallery__track { position: absolute; inset: 0; }
.sol-slide {
  position: absolute; inset: 0; margin: 0;
  opacity: 0; visibility: hidden;
  transition: opacity var(--duration-normal) var(--ease-out);
  display: grid; place-items: center;
}
.sol-slide.is-active { opacity: 1; visibility: visible; }
.sol-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sol-slide--3d { background: linear-gradient(135deg, #2a2622, #14110f); }
.sol-3d-load {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 18px; border-radius: 999px; cursor: pointer;
  background: rgba(255,255,255,0.12); color: #fff; border: 1px solid rgba(255,255,255,0.4);
  font-size: var(--fs-sm); font-weight: var(--fw-medium); backdrop-filter: blur(4px);
}
@media (hover: hover) { .sol-3d-load:hover { background: var(--color-accent); border-color: var(--color-accent); } }
.sol-modelviewer { width: 100%; height: 100%; display: block; --poster-color: transparent; background: #14110f; }

.sol-gallery__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 38px; height: 38px; border-radius: 50%;
  border: none; cursor: pointer; z-index: 3;
  background: rgba(255,255,255,0.82); color: var(--color-text);
  font-size: 22px; line-height: 1; display: grid; place-items: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  transition: background var(--duration-fast) var(--ease-out);
}
.sol-gallery__nav--prev { left: 10px; }
.sol-gallery__nav--next { right: 10px; }
@media (hover: hover) { .sol-gallery__nav:hover { background: #fff; } }
.sol-gallery__badge {
  position: absolute; left: 10px; bottom: 10px; z-index: 3;
  font-size: 11px; font-weight: var(--fw-medium); color: #fff;
  background: rgba(20,18,16,0.6); padding: 3px 9px; border-radius: 999px;
  backdrop-filter: blur(3px); pointer-events: none;
}
/* ── выбор цвета (свотчи) ── */
.sol-picker {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px 14px;
  padding: var(--sp-3) var(--sp-4);
}
.sol-picker__label { font-size: var(--fs-sm); color: var(--color-text-secondary); white-space: nowrap; }
.sol-picker__label b { color: var(--color-text); font-weight: var(--fw-semibold); }
.sol-colors { display: flex; flex-wrap: wrap; gap: 11px; padding: 0; }
.sol-color {
  width: 27px; height: 27px; border-radius: 50%; padding: 0; cursor: pointer;
  background: none; border: none; position: relative; display: grid; place-items: center;
}
.sol-color__dot {
  width: 25px; height: 25px; border-radius: 50%; display: block;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.14);
  transition: transform var(--duration-fast) var(--ease-out);
}
/* кольцо-обводка активного цвета (iOS-стиль) */
.sol-color::after {
  content: ''; position: absolute; inset: -4px; border-radius: 50%;
  border: 2px solid transparent; transition: border-color var(--duration-fast) var(--ease-out);
}
.sol-color.is-active::after { border-color: var(--color-text); }
.sol-color.is-active .sol-color__dot { transform: scale(0.9); }
@media (hover: hover) {
  .sol-color:hover .sol-color__dot { transform: scale(1.07); }
  .sol-color.is-active:hover .sol-color__dot { transform: scale(0.9); }
}

/* ── точки-листалка карточки (кол-во = кол-во цветов/материалов) ── */
.sol-dots {
  position: absolute; left: 50%; bottom: 12px; transform: translateX(-50%);
  z-index: 3; display: flex; gap: 8px; align-items: center;
  padding: 7px 11px; border-radius: 999px;
  background: rgba(255,255,255,0.72); backdrop-filter: blur(8px);
  box-shadow: 0 2px 10px rgba(20,18,16,0.14);
}
.sol-dot {
  width: 8px; height: 8px; border-radius: 50%; padding: 0; cursor: pointer;
  background: transparent; border: 1.5px solid rgba(20,18,16,0.4);
  transition: background var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}
@media (hover: hover) { .sol-dot:hover { border-color: var(--color-text); } }
.sol-dot.is-active { background: var(--color-text); border-color: var(--color-text); transform: scale(1.18); }

/* подпись цвета на деталке */
.sol-detail__color { font-size: var(--fs-sm); color: var(--color-text-secondary); margin: 0 0 var(--sp-3); }
.sol-detail__color span { color: var(--color-text); font-weight: var(--fw-medium); }

/* ── деталка ── */
.sol-crumbs { display: flex; gap: 8px; align-items: center; font-size: var(--fs-sm); color: var(--color-text-secondary); margin-bottom: var(--sp-4); flex-wrap: wrap; }
.sol-crumbs a { color: var(--color-text-secondary); text-decoration: none; }
@media (hover: hover) { .sol-crumbs a:hover { color: var(--color-accent-text, var(--color-accent)); } }

.sol-detail__grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); gap: var(--sp-7); align-items: start; }
.sol-detail__media .sol-gallery { aspect-ratio: 4 / 3; border-radius: var(--radius-lg, 18px); }
/* деталка: выбор цвета вынесен в колонку с характеристиками */
.sol-detail__colorpick {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px 14px;
  margin-top: var(--sp-5); padding-top: var(--sp-4);
  border-top: 1px solid var(--color-grey-200);
}
.sol-detail__colorpick-label { font-size: var(--fs-sm); color: var(--color-text-secondary); white-space: nowrap; }
.sol-detail__colorpick-label b { color: var(--color-text); font-weight: var(--fw-semibold); }

/* деталка: лента превью под основным фото (метки Эскиз / 3D) */
.sol-thumbs {
  display: flex; gap: 10px; margin-top: var(--sp-3);
  overflow-x: auto; padding-bottom: 4px; scrollbar-width: thin;
}
.sol-thumb {
  position: relative; flex: 0 0 auto;
  width: 84px; height: 64px; border-radius: 10px; overflow: hidden;
  border: 2px solid transparent; background: var(--color-grey-100);
  padding: 0; cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-out);
}
.sol-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sol-thumb.is-active { border-color: var(--color-text); }
@media (hover: hover) { .sol-thumb:hover { border-color: var(--color-grey-400); } }
.sol-thumb__badge {
  position: absolute; left: 0; bottom: 0;
  font-size: 9px; font-weight: var(--fw-semibold); letter-spacing: 0.04em; text-transform: uppercase;
  color: #fff; background: rgba(20, 18, 16, 0.8);
  padding: 2px 6px; border-top-right-radius: 6px;
}
.sol-thumb--3d { background: linear-gradient(135deg, #2b2b2b, #4a4a4a); }
.sol-thumb__ic {
  position: absolute; inset: 0; display: grid; place-items: center;
  color: #fff; font-size: 13px; font-weight: 700; letter-spacing: 0.05em;
}
.sol-detail__title { font-size: clamp(1.6rem, 1.2rem + 1.6vw, 2.4rem); font-weight: var(--fw-semibold); line-height: 1.1; margin: var(--sp-1) 0 var(--sp-3); }
.sol-detail__summary { font-size: var(--fs-base); color: var(--color-text-secondary); line-height: var(--lh-relaxed); margin: 0 0 var(--sp-4); }
.sol-detail__priceblock { display: flex; align-items: baseline; gap: 10px; margin-bottom: var(--sp-4); }
.sol-detail__price { font-size: clamp(1.8rem, 1.4rem + 1.4vw, 2.6rem); font-weight: var(--fw-semibold); letter-spacing: -0.02em; }
.sol-detail__pricenote { font-size: var(--fs-sm); color: var(--color-text-secondary); }
.sol-order-btn { width: 100%; justify-content: center; }
.sol-detail__reassure { font-size: var(--fs-sm); color: var(--color-text-secondary); margin: var(--sp-2) 0 var(--sp-5); }
.sol-detail__h { font-size: var(--fs-md); font-weight: var(--fw-semibold); margin: var(--sp-5) 0 var(--sp-3); }
.sol-specs { width: 100%; border-collapse: collapse; }
.sol-specs th, .sol-specs td { text-align: left; padding: 9px 0; border-bottom: 1px solid var(--color-grey-200); font-size: var(--fs-sm); vertical-align: top; }
.sol-specs th { color: var(--color-text-secondary); font-weight: var(--fw-regular); width: 46%; padding-right: var(--sp-3); }
.sol-specs td { font-weight: var(--fw-medium); }
.sol-detail__desc p { font-size: var(--fs-base); line-height: var(--lh-relaxed); margin: 0 0 var(--sp-2); color: var(--color-text); }

@media (max-width: 860px) {
  .sol-detail__grid { grid-template-columns: 1fr; gap: var(--sp-5); }
}

/* ── оформление ── */
.sol-order__wrap { max-width: 1000px; }
.sol-order__title { font-size: clamp(1.6rem, 1.2rem + 1.4vw, 2.2rem); font-weight: var(--fw-semibold); margin: 0 0 var(--sp-2); }
.sol-order__lead { color: var(--color-text-secondary); margin: 0 0 var(--sp-5); max-width: 60ch; }
.sol-order__grid { display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr); gap: var(--sp-5); align-items: start; }
.sol-order__preview { background: var(--color-white); border: 1px solid var(--color-grey-200); border-radius: var(--radius-lg, 18px); overflow: hidden; position: sticky; top: var(--sp-4); }
.sol-order__preview-img { aspect-ratio: 4 / 3; background-size: cover; background-position: center; background-color: var(--color-grey-100); }
.sol-order__preview-body { padding: var(--sp-4); display: flex; flex-direction: column; gap: 6px; }
.sol-order__preview-title { font-size: var(--fs-lg); font-weight: var(--fw-semibold); margin: 2px 0; }
.sol-order__preview-color { display: flex; align-items: center; gap: 8px; font-size: var(--fs-sm); color: var(--color-text-secondary); margin: 0; }
.sol-order__preview-price { font-size: var(--fs-xl); font-weight: var(--fw-semibold); margin: 4px 0 2px; }
.sol-order__change { font-size: var(--fs-sm); color: var(--color-accent-text, var(--color-accent)); text-decoration: none; }

.sol-order__form { background: var(--color-white); border: 1px solid var(--color-grey-200); border-radius: var(--radius-lg, 18px); padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-4); }
.sol-form__summary { color: var(--color-accent); font-size: var(--fs-sm); }
.sol-form__summary ul { margin: 0; padding-left: 18px; }
.sol-field { display: flex; flex-direction: column; gap: 6px; }
.sol-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.sol-field__label { font-size: var(--fs-sm); font-weight: var(--fw-medium); }
.sol-field__label .req { color: var(--color-accent); }
.sol-field__input {
  width: 100%; padding: 11px 13px; border: 1px solid var(--color-grey-300); border-radius: var(--radius-sm, 8px);
  font: inherit; font-size: var(--fs-base); background: var(--color-white); color: var(--color-text);
}
.sol-field__input:focus-visible { outline: 2px solid var(--color-text); outline-offset: 1px; border-color: var(--color-text); }
.sol-field__err { color: var(--color-accent); font-size: var(--fs-xs); display: block; margin-top: 4px; }
.sol-field__err:empty { display: none; }
.sol-field__input.is-invalid { border-color: var(--color-accent); }
.sol-field__input.is-invalid:focus-visible { outline-color: var(--color-accent); border-color: var(--color-accent); }
.sol-channels { display: flex; flex-wrap: wrap; gap: 8px; }
.sol-channel { display: inline-flex; align-items: center; gap: 6px; padding: 8px 13px; border: 1px solid var(--color-grey-300); border-radius: 999px; font-size: var(--fs-sm); cursor: pointer; }
.sol-channel input { accent-color: var(--color-accent); }
.sol-consent { display: flex; gap: 10px; align-items: flex-start; font-size: var(--fs-sm); line-height: var(--lh-relaxed); color: var(--color-text-secondary); }
.sol-consent input { margin-top: 3px; flex: none; accent-color: var(--color-accent); width: 18px; height: 18px; }
.sol-consent a { color: var(--color-accent-text, var(--color-accent)); }
.sol-order__submit { width: 100%; justify-content: center; margin-top: var(--sp-1); }
.honeypot { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; }

@media (max-width: 760px) {
  .sol-order__grid { grid-template-columns: 1fr; }
  .sol-order__preview { position: static; }
  .sol-field-row { grid-template-columns: 1fr; }
}

.sol-success__icon { display: inline-flex; }
