/* ===================================================================
   TRUSTOLD · Страница КОРЗИНЫ (cart)
   Лейаут: две колонки — список позиций + липкая карточка «Итого».
   Использует токены design.css. Палитру/шрифты не переопределяет.
   =================================================================== */

.cart-page{padding-top:30px;padding-bottom:120px;min-height:60vh}

/* заголовок страницы (page-title уже в design.css) */
.cart-page .page-title{margin-bottom:0}

/* ── пустое состояние ─────────────────────────────────────────── */
.cart-empty{text-align:center;padding:80px 0 40px}
.cart-empty-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:84px;height:84px;border:1px solid var(--gold-42);border-radius:50%;
  margin-bottom:28px;
}
.cart-empty-icon svg{width:32px;height:32px}
.cart-empty-title{font-family:var(--serif);font-weight:600;font-size:28px;color:var(--ink)}
.cart-empty-lead{
  font-family:var(--sans);font-weight:300;font-size:16px;color:var(--muted);
  margin:14px auto 32px;max-width:420px;
}

/* ── двухколоночный лейаут ────────────────────────────────────── */
.cart-grid{
  display:grid;grid-template-columns:1fr 380px;gap:60px;align-items:start;
  margin-top:40px;
}

/* ── список позиций ───────────────────────────────────────────── */
.cart-items{display:block}
.cart-row{
  display:grid;grid-template-columns:124px 1fr auto;gap:26px;
  padding:28px 0;border-bottom:1px solid var(--gold-22);align-items:center;
}
.cart-row:first-child{padding-top:0}

/* фото в золотой рамке (.framed + .dia из design.css дают внутр. рамку и ромбы) */
.cart-thumb-wrap{position:relative;aspect-ratio:1/1;background:#E8E6E0;border:1px solid var(--gold-30);display:block;overflow:visible}
.cart-thumb-wrap.framed::after{inset:9px}
.cart-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cart-thumb-ph{position:absolute;inset:0;background:linear-gradient(135deg,#EDEAE2,#E2DED5)}

/* центр: бренд·тип, название, цена/шт, степпер */
.cart-info-brand{
  font-family:var(--sans);font-size:10.5px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold-2);
}
.cart-info-title{
  font-family:var(--serif);font-weight:600;font-size:24px;color:var(--ink);
  margin:7px 0 0;display:inline-block;transition:color .35s;
}
a.cart-info-title:hover{color:var(--gold)}
.cart-info-unit{font-family:var(--sans);font-size:13px;color:var(--muted-2);margin-top:5px}

/* степпер количества */
.cart-stepper{
  display:flex;align-items:center;border:1px solid var(--gold-42);
  width:-moz-fit-content;width:fit-content;margin-top:14px;
}
.cart-step-btn{
  width:38px;height:40px;background:none;border:none;color:var(--gold);
  font-size:18px;cursor:pointer;line-height:1;transition:background .25s;
}
.cart-step-btn:hover{background:var(--gold-12)}
.qty-input{
  width:48px;height:40px;text-align:center;border:none;background:none;
  font-family:var(--sans);font-size:15px;color:var(--ink);padding:0;
  -moz-appearance:textfield;
}
.qty-input::-webkit-outer-spin-button,
.qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.qty-input:focus{outline:none}

/* правая колонка строки: сумма + удалить */
.cart-row-right{text-align:right}
.cart-cell-sum{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--ink)}
.cart-cell-sum .price-rub{font-size:22px}
.btn-remove{
  font-family:var(--sans);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;background:none;border:none;color:var(--muted-2);
  cursor:pointer;margin-top:14px;padding:0;transition:color .3s;
}
.btn-remove:hover{color:var(--wine)}

/* ── карточка «Итого» (липкая) ────────────────────────────────── */
.cart-summary{
  background:var(--surface);border:1px solid var(--gold-30);
  padding:38px;position:sticky;top:110px;
}
.cart-summary-title{
  font-family:var(--serif);font-weight:600;font-size:24px;color:var(--ink);
  margin:0 0 26px;
}
.cart-summary-row{
  display:flex;justify-content:space-between;padding:11px 0;
  font-family:var(--sans);font-size:14px;color:var(--ink-2);
}
.cart-summary-row .summary-val{color:var(--ink)}
.cart-summary-row .summary-free{color:var(--gold)}
.cart-summary-total{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:22px 0 0;margin-top:14px;border-top:1px solid var(--gold-30);
}
.cart-summary-total .total-label{
  font-family:var(--sans);font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);
}
.cart-summary-total .cart-total-strong{font-family:var(--serif);font-weight:700;font-size:28px;color:var(--ink)}
.cart-summary-total .cart-total-strong .price-rub{font-size:28px;font-weight:700}
.cart-summary .btn-checkout{width:100%;margin-top:28px}
.cart-summary-note{
  font-family:var(--sans);font-size:11.5px;line-height:1.6;color:var(--faint);
  margin:18px 0 0;text-align:center;
}

/* ── модалки ──────────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:200;background:rgba(28,26,22,.55);
  display:flex;align-items:center;justify-content:center;padding:24px;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
.modal-overlay[hidden]{display:none}
.modal{
  position:relative;background:var(--surface);border:1px solid var(--gold-30);
  width:100%;max-width:420px;padding:42px 40px 40px;
  box-shadow:var(--shadow-card);
}
.modal-close{
  position:absolute;top:16px;right:18px;background:none;border:none;
  color:var(--muted-2);font-size:18px;cursor:pointer;line-height:1;transition:color .3s;
}
.modal-close:hover{color:var(--wine)}
.modal-title{
  font-family:var(--serif);font-weight:600;font-size:26px;color:var(--ink);
  margin:0 0 22px;
}
.field-label{
  display:block;font-family:var(--sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);margin-bottom:9px;
}
.modal .input{width:100%}
.modal-error{
  font-family:var(--sans);font-size:12.5px;color:var(--wine);margin:12px 0 0;
}
.modal-submit{width:100%;margin-top:22px}
.modal-success{text-align:center}
.modal-success .modal-title{margin-bottom:14px}
.modal-success p{font-family:var(--sans);font-weight:300;font-size:15px;color:var(--muted);margin:0 0 26px;line-height:1.6}
.modal-actions{display:flex;flex-direction:column;gap:.5rem}
.modal-actions .btn{width:100%}

/* ── адаптив ──────────────────────────────────────────────────── */
@media (max-width:900px){
  .cart-grid{grid-template-columns:1fr;gap:36px}
  .cart-summary{position:static}
}
@media (max-width:560px){
  .cart-row{grid-template-columns:90px 1fr;gap:18px}
  .cart-row-right{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;text-align:left;margin-top:4px}
  .btn-remove{margin-top:0}
}
