/* ============================================================
   ONZE — components.css  (buttons, cards, forms, filters,
   product page, cookie bar, breadcrumbs, badges)
   ============================================================ */

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--sans);font-size:.8rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  padding:1rem 2rem;border:1px solid var(--graphite);
  background:var(--graphite);color:var(--milk);
  cursor:pointer;transition:.3s ease;border-radius:var(--radius);
  text-align:center;line-height:1;
}
.btn:hover{background:var(--accent);border-color:var(--accent)}
.btn--ghost{background:transparent;color:var(--graphite)}
.btn--ghost:hover{background:var(--graphite);color:var(--milk);border-color:var(--graphite)}
.btn--accent{background:var(--accent);border-color:var(--accent)}
.btn--accent:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn--block{width:100%}
.btn--sm{padding:.7rem 1.3rem;font-size:.72rem}

.link-arrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  color:var(--graphite);border-bottom:1px solid var(--graphite);padding-bottom:3px;
  transition:.3s;
}
.link-arrow:hover{color:var(--accent);border-color:var(--accent);gap:.85rem}

/* ---- product card ---- */
.card{display:flex;flex-direction:column;background:transparent}
.card-media{
  position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--paper);
  border:1px solid var(--line);
}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.card:hover .card-media img{transform:scale(1.05)}
.card-tag{
  position:absolute;top:.9rem;left:.9rem;z-index:2;
  background:var(--accent);color:var(--milk);
  font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  padding:.32rem .6rem;border-radius:var(--radius);
}
.card-tag--neutral{background:var(--graphite)}
.card-quick{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  background:var(--graphite);color:var(--milk);
  text-align:center;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:.85rem;transform:translateY(101%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
  cursor:pointer;
}
.card:hover .card-quick{transform:none}
.card-body{padding:1.1rem .1rem 0;display:flex;flex-direction:column;gap:.35rem}
.card-cat{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.card-title{font-family:var(--serif);font-size:1.3rem;line-height:1.15}
.card-title a:hover{color:var(--accent)}
.card-price{display:flex;align-items:baseline;gap:.6rem;margin-top:.2rem}
.card-price .now{font-size:1.02rem;font-weight:600;letter-spacing:.02em}
.card-price .was{font-size:.86rem;color:var(--muted);text-decoration:line-through}
.swatches{display:flex;gap:.35rem;margin-top:.55rem}
.swatch{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.18)}

/* ---- breadcrumb ---- */
.crumbs{display:flex;gap:.6rem;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding-block:1.6rem}
.crumbs a:hover{color:var(--accent)}
.crumbs span{color:var(--line)}

/* ---- page intro ---- */
.page-head{border-bottom:1px solid var(--line);padding-bottom:clamp(1.6rem,3vw,2.4rem)}
.page-head h1{font-size:clamp(2.4rem,5.5vw,4rem)}
.page-head p{max-width:60ch;margin-top:1rem}

/* ---- catalog toolbar / filters ---- */
.shop-layout{display:grid;grid-template-columns:260px 1fr;gap:clamp(1.8rem,3vw,3rem);align-items:start}
.filters{position:sticky;top:96px;display:flex;flex-direction:column;gap:1.8rem}
.filter-block{border-top:1px solid var(--line);padding-top:1.3rem}
.filter-block h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;margin-bottom:1rem}
.filter-opt{display:flex;align-items:center;gap:.65rem;margin-bottom:.6rem;cursor:pointer;font-size:.92rem;color:var(--graphite-2)}
.filter-opt input{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}
.filter-opt:hover{color:var(--graphite)}
.size-row{display:flex;flex-wrap:wrap;gap:.5rem}
.size-chip{border:1px solid var(--line);padding:.45rem .7rem;font-size:.78rem;letter-spacing:.06em;cursor:pointer;border-radius:var(--radius);transition:.2s;min-width:42px;text-align:center}
.size-chip.is-active,.size-chip:hover{background:var(--graphite);color:var(--milk);border-color:var(--graphite)}
.color-row{display:flex;flex-wrap:wrap;gap:.6rem}
.color-chip{width:26px;height:26px;border-radius:50%;border:1px solid rgba(0,0,0,.18);cursor:pointer;position:relative;transition:.2s}
.color-chip.is-active{box-shadow:0 0 0 2px var(--milk),0 0 0 3.5px var(--accent)}
.price-range{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:var(--muted)}
.price-range input[type=range]{width:100%;accent-color:var(--accent)}
.filter-reset{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);cursor:pointer;background:none;border:0;text-decoration:underline;text-underline-offset:3px;padding:0}

.toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.toolbar .count{font-size:.82rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.toolbar select{border:1px solid var(--line);background:var(--paper);padding:.6rem 2.2rem .6rem .9rem;font-size:.82rem;letter-spacing:.06em;cursor:pointer;border-radius:var(--radius);
  appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237d1128' fill='none' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9rem center}
.filter-toggle{display:none}
.no-results{padding:3rem 0;text-align:center;color:var(--muted)}
.card.is-hidden{display:none}

/* active filter pills */
.active-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.4rem}
.pill{display:inline-flex;align-items:center;gap:.45rem;background:var(--accent-soft);color:var(--accent);font-size:.72rem;letter-spacing:.08em;padding:.35rem .7rem;border-radius:999px;text-transform:uppercase;font-weight:600}
.pill button{background:none;border:0;cursor:pointer;color:var(--accent);font-size:.9rem;line-height:1}

/* ---- product detail page ---- */
.product{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.gallery{display:flex;flex-direction:column;gap:1rem}
.gallery-main{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:var(--paper)}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.thumbs{display:flex;gap:.8rem}
.thumb{flex:1;aspect-ratio:1;overflow:hidden;border:1px solid var(--line);background:var(--paper);cursor:pointer;opacity:.6;transition:.25s}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.is-active,.thumb:hover{opacity:1;border-color:var(--graphite)}

.product-info{display:flex;flex-direction:column;gap:1.2rem}
.product-info .rating{display:flex;align-items:center;gap:.6rem;font-size:.82rem;color:var(--muted)}
.product-info .rating .stars{margin:0}
.product-info h1{font-size:clamp(2.1rem,4vw,3.2rem)}
.product-price{display:flex;align-items:baseline;gap:.9rem}
.product-price .now{font-family:var(--serif);font-size:2rem;font-weight:500}
.product-price .was{font-size:1.1rem;color:var(--muted);text-decoration:line-through}
.product-price .save{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600}
.product-desc{color:var(--graphite-2);max-width:54ch}

.opt-group{display:flex;flex-direction:column;gap:.7rem}
.opt-group .opt-label{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--graphite)}
.opt-group .opt-label .sel{color:var(--muted);font-weight:400;letter-spacing:.04em;text-transform:none;margin-left:.4rem}

.qty{display:flex;align-items:center;border:1px solid var(--line);width:max-content;border-radius:var(--radius)}
.qty button{width:44px;height:44px;background:none;border:0;cursor:pointer;font-size:1.1rem}
.qty button:hover{color:var(--accent)}
.qty input{width:46px;height:44px;text-align:center;border:0;border-inline:1px solid var(--line);font-weight:600}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.buy-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:.4rem}
.buy-row .btn{flex:1;min-width:200px}

.product-meta{border-top:1px solid var(--line);padding-top:1.3rem;display:flex;flex-direction:column;gap:.55rem;font-size:.9rem;color:var(--graphite-2)}
.product-meta .row{display:flex;gap:.6rem}
.product-meta .row span:first-child{color:var(--muted);min-width:120px}

.specs{width:100%;border-collapse:collapse;margin-top:1.4rem}
.specs th,.specs td{text-align:left;padding:.85rem 0;border-bottom:1px solid var(--line);font-size:.92rem;vertical-align:top}
.specs th{color:var(--muted);font-weight:500;width:42%;letter-spacing:.04em}

.tab-head{display:flex;gap:2rem;border-bottom:1px solid var(--line);margin-bottom:1.6rem;flex-wrap:wrap}
.tab-head button{background:none;border:0;padding:0 0 1rem;cursor:pointer;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--muted);position:relative}
.tab-head button.is-active{color:var(--graphite)}
.tab-head button.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent)}
.tab-panel{display:none}
.tab-panel.is-active{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.field{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.3rem}
.field label{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--graphite)}
.field input,.field textarea,.field select{
  border:1px solid var(--line);background:var(--paper);padding:.85rem 1rem;
  border-radius:var(--radius);transition:.2s;font-size:.95rem;
}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--accent);background:#fff}
.field textarea{resize:vertical;min-height:140px}
.field .err{color:var(--accent);font-size:.78rem;display:none}
.field.invalid input,.field.invalid textarea{border-color:var(--accent);background:#fff}
.field.invalid .err{display:block}
.form-note{font-size:.82rem;color:var(--muted);margin-top:.4rem}
.form-success{display:none;background:var(--accent-soft);border:1px solid #e2c4ca;color:var(--accent);padding:1rem 1.2rem;border-radius:var(--radius);margin-bottom:1.2rem;font-size:.92rem}
.form-success.show{display:block}

.info-card{border:1px solid var(--line);padding:1.5rem;display:flex;flex-direction:column;gap:.35rem;background:var(--paper)}
.info-card h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--muted);margin-bottom:.3rem}
.info-card a{font-size:1.1rem;font-family:var(--serif)}
.info-card a:hover{color:var(--accent)}
.info-stack{display:flex;flex-direction:column;gap:1rem}
.map-frame{border:1px solid var(--line);overflow:hidden;aspect-ratio:16/10;margin-top:1.4rem}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.02)}

/* ---- legal / prose ---- */
.prose{max-width:760px}
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-top:2.6rem;margin-bottom:.9rem}
.prose h3{font-size:1.2rem;margin-top:1.6rem;margin-bottom:.6rem;font-family:var(--sans);font-weight:700;letter-spacing:.01em}
.prose p,.prose li{color:var(--graphite-2);margin-bottom:.9rem;font-size:1rem}
.prose ul,.prose ol{margin-left:1.3rem;margin-bottom:1rem}
.prose li{margin-bottom:.5rem}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.prose .updated{font-size:.82rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}

/* ---- cookie bar ---- */
.cookie{
  position:fixed;left:0;right:0;bottom:0;z-index:80;
  background:var(--graphite);color:var(--milk);
  padding:1.1rem clamp(1.2rem,5vw,3rem);
  display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;justify-content:center;
  transform:translateY(120%);transition:transform .5s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 -10px 40px -20px rgba(0,0,0,.6);
}
.cookie.show{transform:none}
.cookie p{color:#cdc8bd;font-size:.88rem;max-width:62ch}
.cookie p a{color:var(--milk);text-decoration:underline;text-underline-offset:3px}
.cookie .actions{display:flex;gap:.8rem;flex-wrap:wrap}
.cookie .btn{padding:.7rem 1.4rem;font-size:.72rem}
.cookie .btn--mini-ghost{background:transparent;color:var(--milk);border-color:#55534d}
.cookie .btn--mini-ghost:hover{background:var(--milk);color:var(--graphite);border-color:var(--milk)}

/* toast */
.toast{
  position:fixed;top:90px;right:24px;z-index:90;
  background:var(--graphite);color:var(--milk);padding:.9rem 1.3rem;border-radius:var(--radius);
  font-size:.85rem;letter-spacing:.04em;box-shadow:var(--shadow-lift);
  transform:translateX(140%);transition:transform .45s cubic-bezier(.2,.7,.2,1);max-width:300px;
}
.toast.show{transform:none}
.toast b{color:#e7c7cd}

/* ---- small qty stepper (cart) ---- */
.qty--sm{border:1px solid var(--line)}
.qty--sm button{width:32px;height:32px;font-size:1rem}
.qty--sm input{width:36px;height:32px}

/* ---- cart drawer ---- */
.cart-backdrop{
  position:fixed;inset:0;z-index:95;background:rgba(20,20,19,.42);
  opacity:0;visibility:hidden;transition:.35s;
}
.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:96;
  width:min(94vw,420px);background:var(--milk);
  display:flex;flex-direction:column;
  transform:translateX(101%);transition:transform .42s cubic-bezier(.2,.7,.2,1);
  box-shadow:var(--shadow-lift);border-left:1px solid var(--line);
}
body.cart-open .cart-backdrop{opacity:1;visibility:visible}
body.cart-open .cart-drawer{transform:none}
.cart-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:1.4rem clamp(1.2rem,3vw,1.6rem);border-bottom:1px solid var(--line)}
.cart-drawer-head h3{font-size:1.5rem}
.cart-close{background:none;border:0;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--graphite);transition:.2s}
.cart-close:hover{color:var(--accent)}
.cart-drawer-body{flex:1;overflow-y:auto;padding:.4rem clamp(1.2rem,3vw,1.6rem)}
.cart-drawer-foot{padding:1.2rem clamp(1.2rem,3vw,1.6rem);border-top:1px solid var(--line);display:flex;flex-direction:column;gap:.9rem}

.cart-line{display:grid;grid-template-columns:64px 1fr auto;gap:.9rem;padding:1.1rem 0;border-bottom:1px solid var(--line);align-items:start}
.cart-line-media{width:64px;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:var(--paper)}
.cart-line-media img{width:100%;height:100%;object-fit:cover}
.cart-line-info{display:flex;flex-direction:column;gap:.4rem;min-width:0}
.cart-line-name{font-family:var(--serif);font-size:1.05rem;line-height:1.2}
.cart-line-name:hover{color:var(--accent)}
.cart-line-opt{font-size:.74rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.cart-line-bottom{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:.2rem}
.cart-line-price{font-weight:600;font-size:.95rem}
.cart-line-del{background:none;border:0;cursor:pointer;font-size:1.3rem;line-height:1;color:var(--muted);transition:.2s}
.cart-line-del:hover{color:var(--accent)}

.cart-sum{display:flex;align-items:baseline;justify-content:space-between}
.cart-sum span{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.cart-sum strong{font-family:var(--serif);font-size:1.6rem;font-weight:500}
.cart-foot-link{text-align:center;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite-2);text-decoration:underline;text-underline-offset:3px}
.cart-foot-link:hover{color:var(--accent)}

.cart-empty{display:flex;flex-direction:column;align-items:center;gap:1.2rem;text-align:center;padding:3rem 1rem;color:var(--graphite-2)}
.cart-empty--page{padding:5rem 1rem}
.cart-empty--page h2{margin-top:.4rem}

/* ---- cart page (koshyk.html) ---- */
.cart-grid{display:grid;grid-template-columns:1fr 340px;gap:clamp(1.8rem,4vw,3.5rem);align-items:start}
.cart-list{display:flex;flex-direction:column}
.cart-row{display:grid;grid-template-columns:84px 1fr auto auto auto;gap:1.1rem;align-items:center;padding:1.3rem 0;border-bottom:1px solid var(--line)}
.cart-row:first-child{border-top:1px solid var(--line)}
.cart-row-media{width:84px;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:var(--paper)}
.cart-row-media img{width:100%;height:100%;object-fit:cover}
.cart-row-main{display:flex;flex-direction:column;gap:.3rem;min-width:0}
.cart-row-name{font-family:var(--serif);font-size:1.2rem;line-height:1.2}
.cart-row-name:hover{color:var(--accent)}
.cart-row-opt{font-size:.74rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.cart-row-unit{font-size:.82rem}
.cart-row-sum{font-weight:600;min-width:84px;text-align:right}
.cart-row-del{background:none;border:0;cursor:pointer;font-size:1.4rem;line-height:1;color:var(--muted);transition:.2s}
.cart-row-del:hover{color:var(--accent)}

.cart-summary{border:1px solid var(--line);background:var(--paper);padding:1.6rem;display:flex;flex-direction:column;gap:.9rem;position:sticky;top:96px}
.cart-summary h3{font-size:1.4rem;margin-bottom:.3rem}
.cart-summary-row{display:flex;justify-content:space-between;font-size:.92rem;color:var(--graphite-2)}
.cart-summary-total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);padding-top:.9rem;margin-top:.3rem}
.cart-summary-total strong{font-family:var(--serif);font-size:1.5rem;font-weight:500}
.cart-summary .btn{margin-top:.5rem}

/* ---- checkout (oformlennya.html) ---- */
.checkout-grid{display:grid;grid-template-columns:1fr 360px;gap:clamp(1.8rem,4vw,3.5rem);align-items:start}
.checkout-form .field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.pay-opts{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.3rem}
.pay-opt{display:flex;align-items:flex-start;gap:.7rem;border:1px solid var(--line);background:var(--paper);padding:.9rem 1rem;border-radius:var(--radius);cursor:pointer;transition:.2s}
.pay-opt:hover{border-color:var(--accent)}
.pay-opt input{accent-color:var(--accent);margin-top:.2rem;width:16px;height:16px;cursor:pointer}
.pay-opt .pay-opt-t{font-weight:600;font-size:.92rem}
.pay-opt .pay-opt-d{font-size:.8rem;color:var(--muted)}
.pay-opt:has(input:checked){border-color:var(--accent);background:var(--accent-soft)}

.checkout-summary{border:1px solid var(--line);background:var(--paper);padding:1.6rem;position:sticky;top:96px;display:flex;flex-direction:column;gap:.4rem}
.checkout-summary h3{font-size:1.4rem;margin-bottom:.8rem}
.sum-line{display:grid;grid-template-columns:48px 1fr auto;gap:.8rem;align-items:center;padding:.7rem 0;border-bottom:1px solid var(--line)}
.sum-line img{width:48px;aspect-ratio:4/5;object-fit:cover;border:1px solid var(--line);background:var(--paper)}
.sum-line-info{display:flex;flex-direction:column;min-width:0}
.sum-line-name{font-size:.9rem;line-height:1.2}
.sum-line-opt{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.sum-line-price{font-weight:600;font-size:.9rem}
.sum-foot{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.sum-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--graphite-2)}
.sum-total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);padding-top:.8rem;margin-top:.3rem}
.sum-total strong{font-family:var(--serif);font-size:1.5rem;font-weight:500}

.order-success{display:none;text-align:center;border:1px solid #e2c4ca;background:var(--accent-soft);padding:clamp(2rem,5vw,3.5rem);border-radius:var(--radius)}
.order-success.show{display:block;animation:fade .4s ease}
.order-success .ok-ico{width:56px;height:56px;color:var(--accent);margin:0 auto 1rem}
.order-success h2{color:var(--accent);margin-bottom:.6rem}
.order-success p{color:var(--graphite-2);max-width:46ch;margin:0 auto 1.4rem}

/* ---- missing product ---- */
.product-missing{text-align:center;padding:clamp(3rem,8vw,6rem) 1rem;display:flex;flex-direction:column;align-items:center;gap:1rem}
.product-missing p{max-width:48ch}
.product-missing .btn{margin-top:.6rem}

@media (max-width:900px){
  .product{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .shop-layout{grid-template-columns:1fr}
  .filters{position:static;border:1px solid var(--line);padding:1.4rem;display:none}
  .filters.open{display:flex}
  .filter-toggle{display:inline-flex}
  .cart-grid{grid-template-columns:1fr}
  .cart-summary{position:static}
  .checkout-grid{grid-template-columns:1fr}
  .checkout-summary{position:static;order:-1}
}
@media (max-width:520px){
  .buy-row .btn{min-width:0;flex:1 1 100%}
  .cookie{justify-content:flex-start}
  .cart-row{grid-template-columns:64px 1fr auto;grid-template-areas:"media main del" "media qty sum";row-gap:.7rem}
  .cart-row-media{grid-area:media}
  .cart-row-main{grid-area:main}
  .cart-row .qty{grid-area:qty}
  .cart-row-sum{grid-area:sum;text-align:right;align-self:center}
  .cart-row-del{grid-area:del;align-self:start;justify-self:end}
  .checkout-form .field-row{grid-template-columns:1fr}
}
