/* ============ PDP — Product Detail Page ============ */

/* breadcrumbs */
.crumbs{
  padding:24px 0 16px;
  font-family:var(--font-mono);font-size:11px;color:var(--ash);
  letter-spacing:0.14em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.crumbs a{color:var(--ash);transition:color .2s}
.crumbs a:hover{color:var(--ember)}
.crumbs__sep{color:var(--ember)}
.crumbs__current{color:var(--white)}

/* main split */
.pdp{
  display:grid;grid-template-columns:1.15fr 1fr;gap:64px;
  padding:32px 0 100px;align-items:start;
}
@media (max-width:980px){.pdp{grid-template-columns:1fr;gap:40px}}

/* ─────── GALLERY ─────── */
.gallery{position:sticky;top:96px;display:grid;grid-template-columns:84px 1fr;gap:18px;align-items:start}
@media (max-width:980px){.gallery{position:relative;top:auto;grid-template-columns:1fr;gap:14px}}

.gallery__thumbs{display:flex;flex-direction:column;gap:10px}
@media (max-width:980px){.gallery__thumbs{flex-direction:row;order:2}}
.gallery__thumb{
  width:84px;height:84px;border-radius:12px;
  background:var(--ink-2);border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;
  position:relative;overflow:hidden;
}
.gallery__thumb:hover{border-color:var(--line-strong)}
.gallery__thumb.active{border-color:var(--ember);box-shadow:0 0 0 1px var(--ember)}
.gallery__thumb .case{transform:scale(0.32);transform-origin:center}
.gallery__thumb .case__cam,.gallery__thumb .case__logo{display:none}

.gallery__main{
  position:relative;
  background:#F4EFE7 url("../images/case-bg-cream.svg") center/cover no-repeat;
  border:1px solid var(--line);
  border-radius:24px;
  aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.gallery__image{
  position:relative;z-index:2;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.gallery__case-fallback{position:relative;z-index:2;transform:scale(1.25)}

.gallery__chip{
  position:absolute;top:18px;left:18px;z-index:3;
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-size:14px;letter-spacing:0.12em;
  background:var(--ember);color:#fff;padding:7px 11px;border-radius:6px;
}
.gallery__chip--inverse{background:var(--white);color:var(--ink)}
.gallery__pager{
  position:absolute;bottom:18px;right:18px;z-index:3;
  display:flex;gap:6px;font-family:var(--font-mono);font-size:11px;color:var(--ash);
  letter-spacing:0.1em;
  background:rgba(0,0,0,0.5);backdrop-filter:blur(6px);padding:6px 10px;border-radius:8px;
}

/* ─────── INFO ─────── */
.info{padding-top:8px}
.info__cat{font-family:var(--font-mono);font-size:11px;color:var(--ember);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.info__cat .dash{display:inline-block;width:24px;height:1px;background:var(--ember)}
.info__name{font-family:var(--font-display);font-weight:700;font-size:clamp(38px,4.6vw,64px);letter-spacing:0.02em;line-height:0.95;text-transform:uppercase;margin-bottom:14px}
.info__name .ember{color:var(--ember)}
.info__rating{display:flex;align-items:center;gap:14px;margin-bottom:24px;font-family:var(--font-mono);font-size:12px;color:var(--ash);letter-spacing:0.12em;text-transform:uppercase}
.info__rating .stars{color:var(--ember);letter-spacing:2px}
.info__rating a{color:var(--white);text-decoration:underline;text-underline-offset:3px}

.info__price{
  display:flex;align-items:baseline;gap:16px;
  padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  margin-bottom:28px;flex-wrap:wrap;
}
.info__price b{font-family:var(--font-display);font-weight:700;font-size:54px;letter-spacing:0.02em;line-height:1;color:#fff}
.info__price s{font-size:16px;color:var(--ash);text-decoration:line-through}
.info__price .save{font-family:var(--font-display);font-size:16px;background:var(--ember);color:#fff;padding:5px 10px;border-radius:6px;letter-spacing:0.06em}
.info__price__split{font-family:var(--font-mono);font-size:11px;color:var(--ash);letter-spacing:0.1em;text-transform:uppercase;margin-left:auto}
.info__price__split b{font-family:var(--font-mono);font-size:11px;color:var(--white)}

/* selector blocks */
.field{margin-bottom:24px}
.field__label{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--font-mono);font-size:11px;color:var(--ash);letter-spacing:0.14em;text-transform:uppercase;margin-bottom:12px;
}
.field__label .val{font-family:var(--font-display);color:#fff;font-size:15px;letter-spacing:0.04em}

/* design swatches */
.swatches{display:flex;gap:10px;flex-wrap:wrap}
.swatch{
  width:60px;height:84px;border-radius:10px;
  position:relative;cursor:pointer;
  border:2px solid transparent;
  transition:transform .2s,border-color .2s;
  overflow:hidden;
}
.swatch:hover{transform:translateY(-2px)}
.swatch.active{border-color:var(--ember);box-shadow:0 0 0 2px rgba(255,90,31,0.25)}
.swatch__fill{position:absolute;inset:0;border-radius:8px}
.sw-k-ember{background:#0a0a0c;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:54px;color:var(--ember)}
.sw-k-white{background:#0a0a0c;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:54px;color:#fff}
.sw-exclaim{background:#0a0a0c;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:56px;color:var(--ember)}
.sw-icons{background:#0a0a0c;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 84'><g fill='%23FF5A1F'><path d='M14 14 L8 24 L13 24 L10 32 L18 22 L13 22 Z'/></g><g fill='%23FFFFFF'><path d='M40 50 L41 54 L45 55 L41 56 L40 60 L39 56 L35 55 L39 54 Z'/></g></svg>");background-size:100% 100%}
.sw-concrete{background:#1a1a1d}
.sw-bolts{background:#0a0a0c;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 42'><path d='M15 6 L9 21 L14 21 L11 35 L21 19 L16 19 Z' fill='%23FF5A1F'/></svg>");background-size:30px 42px}

/* phone model dropdown */
.model-pick{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
}
@media (max-width:560px){.model-pick{grid-template-columns:repeat(3,1fr)}}
.model-chip{
  background:var(--ink-2);border:1.5px solid var(--line);
  padding:11px 10px;border-radius:10px;
  font-family:var(--font-body);font-weight:600;font-size:12px;
  color:#D7D7DA;cursor:pointer;
  text-align:center;
  transition:all .2s;
  display:flex;flex-direction:column;align-items:center;gap:2px;
}
.model-chip small{font-family:var(--font-mono);font-size:9px;color:var(--ash);letter-spacing:0.1em;text-transform:uppercase}
.model-chip:hover{border-color:var(--line-strong)}
.model-chip.active{border-color:var(--ember);background:var(--ember-soft);color:#fff}
.model-chip.active small{color:#fff}

/* quantity + cta */
.cart-row{display:grid;grid-template-columns:130px 1fr;gap:12px;margin-bottom:18px}
@media (max-width:480px){.cart-row{grid-template-columns:1fr;gap:10px}}
.qty{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--ink-2);border:1.5px solid var(--line);
  border-radius:12px;padding:0 4px;height:60px;
}
.qty button{
  width:42px;height:42px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:20px;transition:background .2s;
}
.qty button:hover{background:rgba(255,255,255,0.06)}
.qty span{font-family:var(--font-display);font-size:24px;color:#fff;letter-spacing:0.04em;min-width:32px;text-align:center}

.cta-add{
  width:100%;height:60px;border-radius:12px;
  background:var(--ember);color:#fff;
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-body);font-weight:700;font-size:13px;
  letter-spacing:0.14em;text-transform:uppercase;
  box-shadow:0 8px 28px var(--ember-glow);
  transition:transform .2s,box-shadow .2s;
}
.cta-add:hover{transform:translateY(-2px);box-shadow:0 14px 36px var(--ember-glow)}
.cta-add__price{font-family:var(--font-display);font-size:18px;letter-spacing:0.06em;padding-left:12px;border-left:1px solid rgba(255,255,255,0.3);margin-left:4px}

.cta-secondary{
  display:flex;gap:10px;margin-bottom:24px;
}
.cta-secondary button{
  flex:1;height:48px;border-radius:11px;
  background:var(--ink-2);border:1.5px solid var(--line);
  color:#D7D7DA;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:600;font-size:12px;
  letter-spacing:0.1em;text-transform:uppercase;
  transition:all .2s;
}
.cta-secondary button:hover{border-color:var(--ember);color:var(--ember)}

/* highlights */
.highlights{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:24px 0;border-top:1px solid var(--line)}
@media (max-width:480px){.highlights{grid-template-columns:1fr}}
.highlight{display:flex;align-items:flex-start;gap:12px}
.highlight__icon{width:32px;height:32px;border-radius:8px;background:var(--ember-soft);color:var(--ember);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.highlight b{display:block;font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:0.04em;color:#fff;text-transform:uppercase;margin-bottom:2px}
.highlight span{font-size:12px;color:var(--ash);line-height:1.5}

/* ─────── UPSELL BLOCK ─────── */
.upsell{
  background:var(--ink-2);border:1px solid var(--line);border-radius:18px;
  padding:24px;margin-top:24px;
}
.upsell__head{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.upsell__head h4{font-family:var(--font-display);font-size:20px;letter-spacing:0.04em;font-weight:700;text-transform:uppercase;color:#fff;flex:1}
.upsell__head .save-pill{font-family:var(--font-display);font-size:13px;background:var(--ember);color:#fff;padding:4px 9px;border-radius:5px;letter-spacing:0.06em}

.addon{
  display:grid;grid-template-columns:48px 1fr auto auto;gap:14px;align-items:center;
  padding:14px;border-radius:12px;border:1.5px solid var(--line);
  background:rgba(0,0,0,0.2);margin-bottom:10px;cursor:pointer;
  transition:border-color .2s,background .2s;
}
.addon:last-child{margin-bottom:0}
.addon:hover{border-color:var(--line-strong)}
.addon.active{border-color:var(--ember);background:var(--ember-soft)}
.addon__icon{
  width:48px;height:48px;border-radius:10px;
  background:var(--ink);display:flex;align-items:center;justify-content:center;
  color:var(--ember);border:1px solid var(--line);
}
.addon.active .addon__icon{background:var(--ink-2);border-color:var(--ember)}
.addon__body b{display:block;font-family:var(--font-display);font-size:17px;letter-spacing:0.04em;font-weight:700;text-transform:uppercase;color:#fff;margin-bottom:2px}
.addon__body span{font-size:12px;color:var(--ash);line-height:1.4}
.addon__price{font-family:var(--font-display);font-size:20px;color:#fff;letter-spacing:0.04em}
.addon__price s{display:block;font-size:11px;color:var(--ash);text-decoration:line-through;font-family:var(--font-body);letter-spacing:0}
.addon__check{
  width:24px;height:24px;border-radius:7px;
  border:2px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  color:transparent;transition:all .2s;
}
.addon.active .addon__check{background:var(--ember);border-color:var(--ember);color:#fff}

/* ─────── TABS / DESCRIPTION ─────── */
.tabs{margin:80px 0 100px}
.tabs__nav{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:48px;overflow-x:auto;scrollbar-width:none}
.tabs__nav::-webkit-scrollbar{display:none}
.tabs__nav button{
  padding:18px 28px;
  font-family:var(--font-display);font-size:20px;letter-spacing:0.06em;
  color:var(--ash);text-transform:uppercase;
  border-bottom:2px solid transparent;
  white-space:nowrap;transition:all .2s;
}
.tabs__nav button:hover{color:#fff}
.tabs__nav button.active{color:#fff;border-bottom-color:var(--ember)}

.tab-content{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:start}
@media (max-width:980px){.tab-content{grid-template-columns:1fr;gap:40px}}
.tab-content h3{font-family:var(--font-display);font-size:36px;letter-spacing:0.02em;font-weight:700;text-transform:uppercase;margin-bottom:20px;line-height:1}
.tab-content p{font-size:15px;line-height:1.7;color:#C9C9CE;margin-bottom:18px;max-width:580px}
.tab-content p b{color:#fff;font-weight:600}

.specs{display:flex;flex-direction:column;gap:0}
.spec{display:grid;grid-template-columns:1fr auto;padding:18px 0;border-bottom:1px solid var(--line);gap:24px;align-items:baseline}
.spec:last-child{border-bottom:none}
.spec b{font-family:var(--font-mono);font-size:11px;color:var(--ash);letter-spacing:0.14em;text-transform:uppercase;font-weight:500}
.spec span{font-family:var(--font-body);font-size:14px;font-weight:500;color:#fff;text-align:right}

/* PDP tabs on light bg */
.section--light .tabs__nav,
.tabs--light .tabs__nav{border-bottom-color:rgba(14,14,16,0.1)}
.tabs__nav button{color:#8a8a8e}
.section--light .tabs__nav button:hover,
.tabs--light .tabs__nav button:hover{color:var(--ink)}
.section--light .tabs__nav button.active,
.tabs--light .tabs__nav button.active{color:var(--ink)}
.tab-content--light h3{color:var(--ink)}
.tab-content--light p{color:#3a3a40}
.tab-content--light p b{color:var(--ink)}
.tab-content--light .spec{border-bottom-color:rgba(14,14,16,0.1)}
.tab-content--light .spec b{color:#8a8a8e}
.tab-content--light .spec span{color:var(--ink)}
.sticky-cta{
  display:none;
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:rgba(14,14,16,0.95);backdrop-filter:blur(14px);
  border-top:1px solid var(--line-strong);
  padding:12px 16px;
  align-items:center;gap:12px;
}
.sticky-cta__price{font-family:var(--font-display);font-size:24px;letter-spacing:0.04em;color:#fff;line-height:1}
.sticky-cta__price small{display:block;font-family:var(--font-mono);font-size:9px;color:var(--ash);letter-spacing:0.12em;text-transform:uppercase;margin-top:2px}
.sticky-cta .cta-add{flex:1;height:52px;font-size:12px}
@media (max-width:720px){.sticky-cta{display:flex}.section{padding-bottom:80px !important}}

/* related */
.related{padding:100px 0}
.related .section__head{margin-bottom:40px}

/* shipping strip */
.ship-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:#070708;border:1px solid var(--line);border-radius:14px;
  margin-top:24px;
}
@media (max-width:560px){.ship-strip{grid-template-columns:1fr}}
.ship-strip__item{padding:18px;display:flex;align-items:center;gap:12px;border-right:1px solid var(--line)}
.ship-strip__item:last-child{border-right:none}
@media (max-width:560px){.ship-strip__item{border-right:none;border-bottom:1px solid var(--line)}.ship-strip__item:last-child{border-bottom:none}}
.ship-strip__icon{width:36px;height:36px;border-radius:9px;background:var(--ember-soft);color:var(--ember);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ship-strip__txt b{display:block;font-family:var(--font-display);font-size:14px;letter-spacing:0.06em;color:#fff;text-transform:uppercase;font-weight:700}
.ship-strip__txt span{font-size:11px;color:var(--ash)}

/* ════════════════════════════════════════════════════════════════
   WooCommerce native overrides — single product
   ═══════════════════════════════════════════════════════════════ */

/* The form WC outputs — use flex column so we can reorder children with CSS */
.info form.cart{
  display:flex;flex-direction:column;gap:18px;
  margin:0 0 22px;
}
/* Place variations table (model dropdown) at top */
.info form.cart .variations{order:1;margin:0}
.info form.cart .single_variation_wrap{order:2;margin:0}
/* Qty + button are inside .woocommerce-variation-add-to-cart — push to bottom */
.info form.cart .woocommerce-variation-add-to-cart,
.info form.cart > .quantity,
.info form.cart > button.single_add_to_cart_button{order:4}
/* Make qty + add-to-cart sit on one row inside the wrap */
.info form.cart .woocommerce-variation-add-to-cart{
  display:grid;grid-template-columns:160px 1fr;gap:12px;align-items:stretch;width:100%;
}
@media (max-width:520px){.info form.cart .woocommerce-variation-add-to-cart{grid-template-columns:1fr}}

/* Quantity wrapper */
.info form.cart .quantity{
  display:flex;align-items:center;justify-content:center;
  background:var(--ink-2);border:1.5px solid var(--line);
  border-radius:12px;height:60px;padding:0 6px;
  position:relative;
}
.info form.cart .quantity .screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* Hide WC's default qty number input look, restyle */
.info form.cart .quantity .qty,
.info form.cart input.qty{
  -moz-appearance:textfield;
  appearance:textfield;
  background:transparent;border:0;outline:0;
  font-family:var(--font-display);font-weight:700;font-size:22px;
  color:#fff;text-align:center;
  width:60px;height:48px;
  letter-spacing:0.02em;
  padding:0;
}
.info form.cart .quantity .qty::-webkit-inner-spin-button,
.info form.cart .quantity .qty::-webkit-outer-spin-button{
  -webkit-appearance:none;margin:0;
}

/* Real +/- buttons added via JS — actually clickable */
.info form.cart .quantity .kqty-btn{
  width:42px;height:48px;border-radius:8px;
  background:transparent;border:0;
  font-family:var(--font-display);font-size:22px;font-weight:300;color:var(--ash);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;user-select:none;
  transition:background .15s, color .15s;
  flex-shrink:0;
}
.info form.cart .quantity .kqty-btn:hover{background:rgba(255,255,255,0.06);color:#fff}
.info form.cart .quantity .kqty-btn:active{transform:scale(0.94)}

/* MAIN Add-to-cart button — override WC default purple */
.info form.cart button.single_add_to_cart_button,
.info form.cart button.button[name="add-to-cart"],
.info form.cart .single_add_to_cart_button{
  width:100%;min-height:60px;border-radius:12px;
  background:var(--ember) !important;color:#fff !important;
  border:0 !important;
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-body);font-weight:700;font-size:14px;
  letter-spacing:0.16em;text-transform:uppercase;
  box-shadow:0 8px 28px var(--ember-glow);
  cursor:pointer;
  transition:transform .2s, box-shadow .2s, background .2s;
  text-shadow:none;text-decoration:none;
  padding:0 24px;
}
.info form.cart button.single_add_to_cart_button:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 36px var(--ember-glow);
  background:#e84a10 !important;
}
.info form.cart button.single_add_to_cart_button.loading::after{
  border-color:#fff transparent #fff transparent !important;
}

/* Variation form — make model dropdown look premium */
.info .variations_form .variations{margin:0;width:100%}
.info .variations_form .variations table,
.info .variations_form .variations tbody,
.info .variations_form .variations tr{display:block;width:100%}
.info .variations_form .variations tr{
  display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:12px;
}
.info .variations_form .variations tr:last-child{margin-bottom:0}
.info .variations_form .variations td{display:block;padding:0;border:0}
.info .variations_form .variations td.label{padding:0}
.info .variations_form .variations td.label label{
  font-family:var(--font-body);font-size:11px;color:var(--ash);
  letter-spacing:0.14em;text-transform:uppercase;font-weight:700;margin:0;
}
.info .variations_form .variations td.value{position:relative}
.info .variations_form .variations td.value::after{
  content:"";position:absolute;right:18px;top:50%;
  width:8px;height:8px;border-right:2px solid var(--ash);border-bottom:2px solid var(--ash);
  transform:translateY(-70%) rotate(45deg);pointer-events:none;
}
.info .variations_form .variations select{
  -webkit-appearance:none;appearance:none;
  width:100%;padding:14px 40px 14px 16px;
  background:var(--ink-2);border:1.5px solid var(--line);border-radius:12px;
  color:#fff;font-family:var(--font-body);font-size:14px;font-weight:600;
  letter-spacing:0.02em;cursor:pointer;
  transition:border-color .2s, box-shadow .2s;
}
.info .variations_form .variations select:hover{border-color:var(--line-strong)}
.info .variations_form .variations select:focus{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px rgba(255,90,31,0.15)}
.info .variations_form .variations select option{background:var(--ink-2);color:#fff}
.info .variations_form .reset_variations{
  display:inline-block;margin-top:6px;
  color:var(--ash);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
}
.info .variations_form .reset_variations:hover{color:var(--ember)}
.info .variations_form .single_variation_wrap{margin:0}
.info .variations_form .single_variation{margin-bottom:0;min-height:0}
.info .variations_form .single_variation .price{display:none} /* hide duplicate price */


/* Stock badge */
.info__rating-stock.in{color:#22c55e}
.info__rating-stock.out{color:#ef4444}
.info__rating-sep{color:var(--ember);opacity:0.6}

/* ════════════════════════════════════════════════════════════════
   SHOP / ARCHIVE — sidebar, toolbar, sort
   ═══════════════════════════════════════════════════════════════ */
.shop-wrap{padding-bottom:100px}
.shop-grid{
  display:grid;grid-template-columns:260px 1fr;gap:40px;align-items:start;
}
@media (max-width:900px){.shop-grid{grid-template-columns:1fr;gap:24px}}

.shop-side{position:sticky;top:96px}
@media (max-width:900px){.shop-side{position:relative;top:auto}}

.filterbox{
  background:var(--ink-2);border:1px solid var(--line);border-radius:18px;
  padding:22px;
}
.filterbox__head{
  display:flex;align-items:center;gap:10px;
  padding-bottom:18px;margin-bottom:18px;
  border-bottom:1px solid var(--line);
}
.filterbox__head svg{color:var(--ember)}
.filterbox__head h4{
  font-family:var(--font-display);font-size:18px;font-weight:700;
  letter-spacing:0.06em;text-transform:uppercase;color:#fff;margin:0;
}

.teamlist{display:flex;flex-direction:column;gap:6px}
.teamchip{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 14px;border-radius:10px;
  background:transparent;border:1.5px solid var(--line);
  font-family:var(--font-body);font-weight:600;font-size:13px;color:#D7D7DA;
  letter-spacing:0.02em;
  cursor:pointer;text-decoration:none;
  transition:all .18s;
}
.teamchip:hover{border-color:var(--line-strong);background:rgba(255,255,255,0.02);color:#fff}
.teamchip.active{
  border-color:var(--ember);background:var(--ember-soft);color:#fff;
  box-shadow:0 0 0 1px var(--ember) inset;
}
.teamchip__count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:24px;height:22px;padding:0 7px;border-radius:11px;
  background:rgba(255,255,255,0.06);color:var(--ash);
  font-size:11px;font-weight:700;letter-spacing:0.04em;
}
.teamchip.active .teamchip__count{background:var(--ember);color:#fff}

/* TOOLBAR (count + sort) */
.shop-toolbar{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:28px;gap:16px;flex-wrap:wrap;
}
.shop-toolbar__count{
  font-family:var(--font-body);font-weight:600;font-size:12px;
  color:var(--ash);letter-spacing:0.14em;text-transform:uppercase;
}

/* Style WC's <form class="woocommerce-ordering"> */
.shop-toolbar__sort form.woocommerce-ordering{
  margin:0;position:relative;
}
.shop-toolbar__sort form.woocommerce-ordering::after{
  content:"";position:absolute;right:16px;top:50%;
  width:8px;height:8px;border-right:2px solid var(--ash);border-bottom:2px solid var(--ash);
  transform:translateY(-70%) rotate(45deg);pointer-events:none;
  transition:border-color .2s;
}
.shop-toolbar__sort form.woocommerce-ordering:hover::after{border-color:var(--ember)}
.shop-toolbar__sort select.orderby{
  -webkit-appearance:none;appearance:none;
  background:var(--ink-2);border:1.5px solid var(--line);border-radius:10px;
  color:#fff;font-family:var(--font-body);font-size:13px;font-weight:600;
  padding:11px 40px 11px 16px;cursor:pointer;
  letter-spacing:0.02em;
  min-width:240px;
  transition:border-color .2s;
}
.shop-toolbar__sort select.orderby:hover{border-color:var(--line-strong)}
.shop-toolbar__sort select.orderby:focus{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px rgba(255,90,31,0.15)}
.shop-toolbar__sort select.orderby option{background:var(--ink-2);color:#fff;font-family:var(--font-body)}

/* ════════════════════════════════════════════════════════════════
   SHOP + PDP — MOBILE OPTIMIZATIONS
   ═══════════════════════════════════════════════════════════════ */

/* SHOP — Collapsible filter on mobile + better toolbar */
@media (max-width:900px){
  .shop-toolbar{flex-direction:column;align-items:stretch;gap:12px;width:100%;max-width:100%}
  .shop-toolbar__sort,
  .shop-toolbar__sort form.woocommerce-ordering{display:block;width:100% !important;max-width:100% !important;min-width:0 !important;box-sizing:border-box}
  .shop-toolbar__sort select.orderby{width:100% !important;max-width:100% !important;min-width:0 !important;box-sizing:border-box;padding-right:40px}
  .shop-toolbar__count{text-align:center}
  /* Filter becomes a horizontal scrollable chip strip */
  .shop-side{position:relative;top:auto}
  .filterbox{padding:14px}
  .filterbox__head{padding-bottom:12px;margin-bottom:12px}
  .filterbox__head h4{font-size:14px}
  .teamlist{flex-direction:row;flex-wrap:nowrap;gap:8px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .teamlist::-webkit-scrollbar{display:none}
  .teamchip{flex-shrink:0;padding:10px 14px;font-size:12px}
}

/* PDP — gallery + info */
@media (max-width:980px){
  .gallery{position:relative;top:auto}
}
@media (max-width:560px){
  .crumbs{font-size:10px;gap:8px}
  .crumbs__current{max-width:60%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block;vertical-align:bottom}
  .info__name{font-size:clamp(30px,8vw,48px)}
  .info__price b{font-size:clamp(36px,9vw,54px)}
  .info__price{gap:10px;padding:18px 0;flex-wrap:wrap}
  .info__price__split{margin-left:0;width:100%;margin-top:8px;font-size:10px}
  .info form.cart{grid-template-columns:1fr;gap:12px}
  .info form.cart .quantity{height:54px}
  .info form.cart button.single_add_to_cart_button{min-height:54px;font-size:13px}
  .cta-secondary{flex-direction:column;gap:8px}
  .cta-secondary button,
  .cta-secondary a{height:46px;width:100%}
  .highlights{gap:14px;padding:20px 0}
  .highlight b{font-size:14px}
  .highlight span{font-size:11px;line-height:1.4}
  /* Upsell on PDP — keep readable */
  .addon{grid-template-columns:42px 1fr auto;gap:10px;padding:12px}
  .addon__check{display:none}
  .addon__body b{font-size:14px}
  .addon__body span{font-size:11px}
  .addon__price{font-size:16px}
  /* Tabs — smaller, scrollable */
  .tabs{margin:60px 0 80px}
  .tabs__nav{margin-bottom:32px;scroll-snap-type:x mandatory}
  .tabs__nav button{padding:14px 18px;font-size:14px;letter-spacing:0.04em;scroll-snap-align:start;white-space:nowrap}
  .specs{font-size:13px}
}

/* PDP related — replace inline grid */
.related .products{grid-template-columns:repeat(4,1fr) !important}
@media (max-width:1100px){.related .products{grid-template-columns:repeat(3,1fr) !important}}
@media (max-width:780px){.related .products{grid-template-columns:repeat(2,1fr) !important}}
@media (max-width:480px){.related .products{grid-template-columns:1fr !important}}

/* Sticky CTA — reserve space at bottom of body on mobile */
@media (max-width:720px){
  body{padding-bottom:0}
  .sticky-cta{padding-bottom:max(14px, env(safe-area-inset-bottom))}
}

/* ════════════════════════════════════════════════════════════════
   PDP — KEISOVE CUSTOM CART FORM (per-quantity phone model)
   ═══════════════════════════════════════════════════════════════ */

.km-form{
  display:flex;flex-direction:column;gap:18px;
  margin:0 0 28px;
}

/* Per-quantity model selectors */
.km-models{
  display:flex;flex-direction:column;gap:10px;
}
.km-model{
  display:flex;flex-direction:column;gap:8px;
}
.km-model__label{
  font-family:var(--font-body);font-size:11px;font-weight:700;
  color:var(--ash);letter-spacing:0.14em;text-transform:uppercase;
  margin:0;
}
.km-select{
  position:relative;display:block;
}
.km-select__field{
  -webkit-appearance:none;appearance:none;
  width:100%;height:52px;
  padding:0 44px 0 16px;
  background:var(--ink-2);
  border:1.5px solid var(--line);
  border-radius:12px;
  color:#fff;
  font-family:var(--font-body);font-size:14px;font-weight:600;
  letter-spacing:0.02em;
  cursor:pointer;outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.km-select__field:hover{border-color:var(--line-strong)}
.km-select__field:focus{border-color:var(--ember);box-shadow:0 0 0 3px rgba(255,90,31,0.15)}
.km-select__field option{background:var(--ink-2);color:#fff}
.km-select__chevron{
  position:absolute;right:18px;top:50%;
  width:8px;height:8px;
  border-right:2px solid var(--ash);
  border-bottom:2px solid var(--ash);
  transform:translateY(-70%) rotate(45deg);
  pointer-events:none;transition:border-color .2s;
}
.km-select:hover .km-select__chevron{border-color:#fff}

/* Qty + submit row */
.km-cart-row{
  display:grid;grid-template-columns:160px 1fr;gap:12px;
  align-items:stretch;width:100%;
}
@media (max-width:520px){.km-cart-row{grid-template-columns:1fr;gap:10px}}

.km-qty{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--ink-2);border:1.5px solid var(--line);
  border-radius:12px;padding:0 4px;height:60px;
  user-select:none;
}
.km-qty__btn{
  width:42px;height:48px;border-radius:9px;
  background:transparent;border:0;
  font-family:var(--font-display);font-size:22px;font-weight:300;
  color:var(--ash);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .15s, color .15s;
}
.km-qty__btn:hover{background:rgba(255,255,255,0.06);color:#fff}
.km-qty__btn:active{transform:scale(0.94)}
.km-qty__input{
  -moz-appearance:textfield;appearance:textfield;
  background:transparent;border:0;outline:0;
  width:56px;height:48px;
  font-family:var(--font-display);font-weight:700;font-size:22px;
  color:#fff;text-align:center;letter-spacing:0.02em;
  padding:0;
}
.km-qty__input::-webkit-inner-spin-button,
.km-qty__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}

.km-submit{
  position:relative;width:100%;min-height:60px;border-radius:12px;
  background:var(--ember);color:#fff;border:0;
  font-family:var(--font-body);font-weight:700;font-size:14px;
  letter-spacing:0.16em;text-transform:uppercase;
  box-shadow:0 8px 28px var(--ember-glow);
  cursor:pointer;padding:0 24px;
  transition:transform .2s, box-shadow .2s, background .2s;
  display:flex;align-items:center;justify-content:center;
}
.km-submit:hover:not(:disabled){
  transform:translateY(-2px);background:#e84a10;
  box-shadow:0 14px 36px var(--ember-glow);
}
.km-submit:disabled{cursor:not-allowed;opacity:.85}
.km-submit__idle,
.km-submit__loading{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
.km-submit__loading{display:none}
.km-submit--loading .km-submit__idle{display:none}
.km-submit--loading .km-submit__loading{display:inline-flex}
.km-spinner{
  width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(255,255,255,0.35);border-top-color:#fff;
  animation:km-spin .7s linear infinite;
}
@keyframes km-spin{to{transform:rotate(360deg)}}

.km-form__error{
  margin:0;padding:10px 14px;border-radius:10px;
  background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);
  color:#fecaca;font-family:var(--font-body);font-size:12px;font-weight:600;
  letter-spacing:0.04em;
}

/* ════════════════════════════════════════════════════════════════
   PDP — UPSELLS (redesigned)
   ═══════════════════════════════════════════════════════════════ */

.km-upsells{
  background:linear-gradient(180deg, rgba(255,90,31,0.04), transparent 60%), var(--ink-2);
  border:1px solid var(--line);border-radius:18px;
  padding:22px;margin-top:4px;
  display:flex;flex-direction:column;gap:14px;
}
.km-upsells__head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.km-upsells__title{display:flex;flex-direction:column;gap:4px}
.km-upsells__eyebrow{
  font-family:var(--font-body);font-size:10px;font-weight:700;
  color:var(--ember);letter-spacing:0.18em;text-transform:uppercase;
}
.km-upsells__head h3{
  margin:0;font-family:var(--font-display);font-weight:700;font-size:22px;
  letter-spacing:0.04em;text-transform:uppercase;color:#fff;line-height:1;
}
.km-pill{
  display:inline-flex;align-items:center;
  padding:6px 12px;border-radius:99px;
  font-family:var(--font-body);font-size:11px;font-weight:800;
  letter-spacing:0.08em;
}
.km-pill--ember{background:var(--ember);color:#fff}

.km-upsells__list{
  display:flex;flex-direction:column;gap:10px;
}
.km-upsell{
  display:grid;
  grid-template-columns:60px 1fr auto;
  gap:14px;align-items:center;
  padding:14px;border:1px solid var(--line);border-radius:14px;
  background:rgba(0,0,0,0.25);
  transition:border-color .2s, background .2s, transform .15s;
}
.km-upsell:hover{
  border-color:var(--line-orange);
  background:rgba(255,90,31,0.04);
}

/* Media */
.km-upsell__media{
  width:60px;height:60px;border-radius:11px;
  background:#070708;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
}
.km-upsell__media img,
.km-upsell__img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.km-upsell__icon{
  color:var(--ember);
  display:inline-flex;align-items:center;justify-content:center;
}

/* Body */
.km-upsell__body{
  display:flex;flex-direction:column;gap:4px;min-width:0;
}
.km-upsell__name{
  margin:0;font-family:var(--font-display);font-weight:700;
  font-size:15px;letter-spacing:0.03em;text-transform:uppercase;
  color:#fff;line-height:1.15;
}
.km-upsell__desc{
  margin:0;font-family:var(--font-body);font-size:12px;color:var(--ash);
  line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}
.km-upsell__price{
  display:flex;align-items:baseline;gap:8px;margin-top:2px;flex-wrap:wrap;
}
.km-upsell__price strong{
  font-family:var(--font-display);font-size:18px;font-weight:700;
  color:#fff;letter-spacing:0.02em;
}
.km-upsell__price strong .woocommerce-Price-currencySymbol{
  font-size:0.7em;color:var(--ash);margin-left:2px;
}
.km-upsell__price s{
  font-family:var(--font-body);font-size:12px;color:var(--ash);
  text-decoration:line-through;
}
.km-upsell__save{
  font-family:var(--font-body);font-size:10px;font-weight:800;
  background:rgba(255,90,31,0.18);color:var(--ember);
  padding:3px 7px;border-radius:99px;letter-spacing:0.06em;
}

/* CTA */
.km-upsell__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  min-height:38px;padding:0 14px;
  background:transparent;border:1.5px solid var(--ember);
  border-radius:99px;
  color:var(--ember);
  font-family:var(--font-body);font-size:11px;font-weight:800;
  letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;
  transition:background .15s, color .15s, transform .15s;
  white-space:nowrap;flex-shrink:0;
}
.km-upsell__cta:hover{background:var(--ember);color:#fff;transform:translateY(-1px)}
.km-upsell__cta-idle,
.km-upsell__cta-done{display:inline-flex;align-items:center;gap:6px}
.km-upsell__cta-done{display:none}

/* Loading + added states */
.km-addon--loading{opacity:.7;pointer-events:none}
.km-addon--loading .km-upsell__cta{background:var(--ember);color:#fff}
.km-addon--added .km-upsell__cta,
.km-cross__card.km-addon--added .km-cross__add{
  background:rgba(34,197,94,0.12);border-color:#22c55e;color:#22c55e;
}
.km-addon--added .km-upsell__cta-idle,
.km-addon--added .km-cross__add-idle{display:none}
.km-addon--added .km-upsell__cta-done,
.km-addon--added .km-cross__add-done{display:inline-flex}
.km-addon--added .km-upsell__cta:hover{background:rgba(34,197,94,0.18);color:#22c55e}
.km-addon--added{border-color:rgba(34,197,94,0.4);background:rgba(34,197,94,0.04)}

@media (max-width:560px){
  .km-upsell{grid-template-columns:54px 1fr;gap:12px;padding:12px}
  .km-upsell__media{width:54px;height:54px}
  .km-upsell__cta{grid-column:1 / -1;width:100%;min-height:36px}
}

/* ════════════════════════════════════════════════════════════════
   PDP — CROSS-SELLS
   ═══════════════════════════════════════════════════════════════ */

.km-cross{
  margin-top:8px;display:flex;flex-direction:column;gap:16px;
}
.km-cross__head{display:flex;flex-direction:column;gap:6px}
.km-cross__head h3{
  margin:0;font-family:var(--font-display);font-weight:700;
  font-size:20px;letter-spacing:0.04em;text-transform:uppercase;color:#fff;line-height:1;
}
.km-cross__head p{
  margin:0;font-family:var(--font-body);font-size:12px;color:var(--ash);
  letter-spacing:0.02em;
}
.km-cross__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
@media (max-width:560px){.km-cross__grid{grid-template-columns:repeat(2,1fr)}}

.km-cross__card{
  display:flex;flex-direction:column;
  border:1px solid var(--line);border-radius:14px;
  background:var(--ink-2);overflow:hidden;
  transition:border-color .2s, transform .15s;
  position:relative;
}
.km-cross__card:hover{
  border-color:var(--line-orange);transform:translateY(-2px);
}
.km-cross__media{
  position:relative;display:block;
  aspect-ratio:1/1;background:#070708;
  overflow:hidden;
}
.km-cross__media img,
.km-cross__img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .35s;
}
.km-cross__card:hover .km-cross__img{transform:scale(1.04)}
.km-cross__case{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  transform:scale(0.7);
}
.km-cross__badge{
  position:absolute;top:8px;left:8px;
  font-family:var(--font-body);font-size:10px;font-weight:800;
  background:var(--ember);color:#fff;
  padding:4px 8px;border-radius:99px;letter-spacing:0.06em;
}

.km-cross__body{
  display:flex;flex-direction:column;gap:6px;padding:12px;flex:1;
}
.km-cross__name{
  font-family:var(--font-display);font-weight:700;
  font-size:13px;letter-spacing:0.03em;text-transform:uppercase;
  color:#fff;text-decoration:none;line-height:1.2;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;min-height:32px;
}
.km-cross__name:hover{color:var(--ember)}
.km-cross__price{
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;
  margin-top:auto;
}
.km-cross__price strong{
  font-family:var(--font-display);font-size:16px;font-weight:700;
  color:#fff;letter-spacing:0.02em;
}
.km-cross__price s{
  font-family:var(--font-body);font-size:11px;color:var(--ash);
  text-decoration:line-through;
}

.km-cross__add{
  margin:0 12px 12px;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  min-height:36px;padding:0 12px;
  background:transparent;border:1.5px solid var(--line-strong);border-radius:10px;
  color:#fff;
  font-family:var(--font-body);font-size:11px;font-weight:800;
  letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;
  transition:background .15s, color .15s, border-color .15s, transform .15s;
}
.km-cross__add:hover{background:var(--ember);border-color:var(--ember);color:#fff;transform:translateY(-1px)}
.km-cross__add-idle,
.km-cross__add-done{display:inline-flex;align-items:center;gap:6px}
.km-cross__add-done{display:none}
.km-addon--loading.km-cross__card .km-cross__add{background:var(--ember);border-color:var(--ember);color:#fff}

/* ════════════════════════════════════════════════════════════════
   PDP — small-screen tweaks for the new form/sections
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:560px){
  .km-upsells{padding:16px;border-radius:14px}
  .km-upsells__head h3{font-size:18px}
  .km-cross__grid{gap:10px}
}

/* ════════════════════════════════════════════════════════════════
   CHECKOUT — FLAT brand-aligned (v2.0)
   No gradients, no glows, no blurs. Same flat ember/ink/cream
   palette + icons as the landing page.
   ═══════════════════════════════════════════════════════════════ */

:root{
  --cream:      #F4EFE7;
  --cream-2:    #EAE2D2;
  --cream-line: #D7CFBE;
  --cream-ink:  #3B342C;
  --cream-mute: #6E6258;
  --ink-paper:  #16161A;   /* solid card surface */
  --ink-input:  #1F1F23;   /* input surface */
  --ink-input-h:#26262B;   /* input hover */
}

/* ---- Page wrap ---- */
.km-checkout-wrap{padding:0 0 100px}

/* ---- Hero ---- */
.km-checkout-hero{
  padding:48px 0 36px;margin-bottom:28px;
  border-bottom:1px solid var(--line);
}
.km-checkout-hero__crumbs{
  font-family:var(--font-mono);font-size:11px;color:var(--ash);
  letter-spacing:0.18em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:22px;
}
.km-checkout-hero__crumbs a{color:var(--ash);transition:color .15s;text-decoration:none}
.km-checkout-hero__crumbs a:hover{color:var(--ember)}
.km-checkout-hero__crumbs span{color:var(--ember)}
.km-checkout-hero__current{color:#fff !important}
.km-checkout-hero__title{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(36px,4.6vw,60px);line-height:0.95;
  letter-spacing:0.01em;text-transform:uppercase;
  margin:0 0 14px;color:#fff;
}
.km-checkout-hero__title .ember{color:var(--ember)}
.km-checkout-hero__sub{
  margin:0;color:#C9C9CE;font-size:14px;line-height:1.6;max-width:580px;
  font-family:var(--font-body);
}
.km-checkout-hero__sub b{color:#fff;font-weight:700}
@media (max-width:560px){
  .km-checkout-hero{padding:24px 0 18px;margin-bottom:20px}
  .km-checkout-hero__title{font-size:clamp(28px,8vw,42px)}
  .km-checkout-hero__sub{font-size:13px}
}

/* ---- Grid ---- */
.km-checkout__grid{
  display:grid;grid-template-columns:minmax(0, 1fr) 460px;
  gap:32px;align-items:start;
}
@media (max-width:1240px){.km-checkout__grid{grid-template-columns:minmax(0, 1fr) 420px;gap:24px}}
@media (max-width:1024px){.km-checkout__grid{grid-template-columns:1fr;gap:24px}}
.km-checkout__main{display:flex;flex-direction:column;gap:16px;min-width:0}
.km-checkout__stack{display:flex;flex-direction:column;gap:16px;min-width:0}
.km-checkout__aside{
  position:sticky;top:24px;min-width:0;align-self:start;
  max-height:calc(100vh - 48px);overflow-y:auto;overscroll-behavior:contain;
  scrollbar-width:thin;scrollbar-color:var(--ember) transparent;
}
.km-checkout__aside::-webkit-scrollbar{width:5px}
.km-checkout__aside::-webkit-scrollbar-thumb{background:var(--ember);border-radius:99px}
@media (max-width:1024px){
  .km-checkout__aside{position:static;max-height:none;overflow:visible}
}

/* ════════════════════════════════════════════════════════════════
   LEFT — Billing card (flat dark)
   ═══════════════════════════════════════════════════════════════ */
.woocommerce-checkout .woocommerce-billing-fields{
  position:relative;
  background:var(--ink-paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:32px 28px 28px;
  margin:0;
  overflow:hidden;
}
@media (max-width:560px){
  .woocommerce-checkout .woocommerce-billing-fields{padding:24px 18px 20px;border-radius:14px}
}

/* Hide notes & shipping fields */
.woocommerce-checkout .woocommerce-additional-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout #ship-to-different-address{display:none !important}

/* Section title */
.woocommerce-checkout .woocommerce-billing-fields > h3{
  font-family:var(--font-display);font-weight:700;
  font-size:22px;letter-spacing:0.06em;text-transform:uppercase;
  color:#fff;line-height:1;
  margin:0 0 24px;padding:0;
  display:flex;align-items:center;gap:12px;
}
.woocommerce-checkout .woocommerce-billing-fields > h3::before{
  content:"";display:inline-block;width:24px;height:2px;background:var(--ember);flex-shrink:0;
}

/* Field grid */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper{
  display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:16px;
}
@media (max-width:640px){
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper{grid-template-columns:1fr;gap:12px}
}

.woocommerce-checkout .form-row{
  margin:0;padding:0;float:none;width:auto;
  display:flex;flex-direction:column;gap:6px;min-width:0;
}
.woocommerce-checkout .form-row-first{grid-column:1}
.woocommerce-checkout .form-row-last{grid-column:2}
.woocommerce-checkout .form-row-wide,
.woocommerce-checkout #billing_address_1_field,
.woocommerce-checkout #billing_postcode_field{grid-column:1 / -1}
@media (max-width:640px){
  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last{grid-column:1}
}

/* Hide country + address_1 (we collect address via Bulgarisation widget) */
.woocommerce-checkout #billing_country_field,
.woocommerce-checkout #billing_address_1_field,
.woocommerce-checkout #shipping_country_field,
.woocommerce-checkout #shipping_address_1_field{
  height:0;margin:0;padding:0;overflow:hidden;position:absolute;left:-9999px;
}

/* Labels */
.woocommerce-checkout .form-row label{
  font-family:var(--font-body);font-size:10px;font-weight:700;
  color:var(--ash);letter-spacing:0.16em;text-transform:uppercase;
  margin:0;line-height:1.2;
}
.woocommerce-checkout .form-row label .required{color:var(--ember);text-decoration:none;margin-left:3px;font-weight:900}
.woocommerce-checkout .form-row label .optional{display:none}

/* Inputs — flat, no shadow */
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout textarea,
.woocommerce-checkout select,
.woocommerce-checkout .select2-container--default .select2-selection--single{
  -webkit-appearance:none;appearance:none;
  width:100%;min-height:48px;padding:13px 16px;
  background:var(--ink-input);
  border:1.5px solid var(--line);
  border-radius:10px;
  color:#fff;
  font-family:var(--font-body);font-size:14px;font-weight:500;
  outline:none;box-shadow:none;
  transition:border-color .15s, background .15s;
}
.woocommerce-checkout textarea{min-height:88px;line-height:1.5;resize:vertical}
.woocommerce-checkout input:hover,
.woocommerce-checkout textarea:hover,
.woocommerce-checkout select:hover{
  background:var(--ink-input-h);border-color:var(--line-strong);
}
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus{
  background:var(--ink-input-h);
  border-color:var(--ember);
  box-shadow:none;
}
.woocommerce-checkout input::placeholder,
.woocommerce-checkout textarea::placeholder{color:rgba(255,255,255,0.28);opacity:1}

/* Select native arrow */
.woocommerce-checkout select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23FF5A1F' d='M6 8 0 0h12z'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;background-size:10px 6px;
  padding-right:40px;
}

/* Select2 */
.woocommerce-checkout .select2-container--default .select2-selection--single{
  height:48px;line-height:46px;padding:0 40px 0 16px;display:flex;align-items:center;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered{
  color:#fff;line-height:46px;padding:0;font-size:14px;font-weight:500;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow{
  height:46px;right:14px;top:0;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow b{
  border-color:var(--ember) transparent transparent transparent !important;
  border-width:6px 5px 0 5px !important;
}
.select2-dropdown{
  background:var(--ink-paper);border:1.5px solid var(--line-strong);
  border-radius:10px;color:#fff;overflow:hidden;margin-top:6px;
}
.select2-search--dropdown .select2-search__field{
  background:var(--ink-input);border:1.5px solid var(--line);border-radius:8px;
  color:#fff;padding:9px 12px;
}
.select2-results__option{padding:11px 14px;color:#D7D7DA;font-size:13px}
.select2-results__option[aria-selected="true"]{background:rgba(255,90,31,0.12);color:#fff}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--ember) !important;color:#fff !important}

/* Validation */
.woocommerce-checkout .woocommerce-invalid input,
.woocommerce-checkout .woocommerce-invalid select,
.woocommerce-checkout .woocommerce-invalid textarea{
  border-color:#ef4444 !important;
}

/* ════════════════════════════════════════════════════════════════
   RIGHT — Cream receipt card (flat)
   ═══════════════════════════════════════════════════════════════ */
.km-checkout__summary{
  background:var(--cream);color:var(--ink);
  border:1px solid var(--cream-line);
  border-radius:18px;
  padding:0;overflow:hidden;position:relative;
}

/* Solid ember accent strip at top (flat dashes, not a gradient fade) */
.km-checkout__summary::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background-image:linear-gradient(90deg, var(--ember) 50%, transparent 50%);
  background-size:18px 5px;background-repeat:repeat-x;
}

/* K monogram chip in top-right (flat) */
.km-checkout__summary::after{
  content:"K";
  position:absolute;top:22px;right:22px;
  font-family:var(--font-display);font-weight:700;font-size:18px;
  color:var(--ember);
  width:36px;height:36px;
  border:2px solid var(--ember);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  line-height:1;letter-spacing:0;
}

.km-checkout__summary-title{
  font-family:var(--font-display);font-weight:700;
  font-size:20px;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--ink);margin:0;padding:32px 24px 14px;line-height:1;
  display:flex;align-items:center;gap:12px;
}
.km-checkout__summary-title::before{
  content:"";display:inline-block;width:24px;height:2px;background:var(--ember);flex-shrink:0;
}

#order_review.woocommerce-checkout-review-order{padding:8px 24px 0}

/* ---- Order review table ---- */
.woocommerce-checkout-review-order-table,
.woocommerce-checkout-review-order table.shop_table{
  width:100%;background:transparent;border:0;border-collapse:collapse;
  font-family:var(--font-body);color:var(--ink);margin:0;
  table-layout:fixed;
}
.woocommerce-checkout-review-order-table thead{display:none}
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td{
  background:transparent !important;border:0 !important;
  padding:14px 0;color:var(--ink);vertical-align:middle;text-align:left;
}

/* Product rows */
.woocommerce-checkout-review-order-table tbody td{
  border-bottom:1px solid var(--cream-line) !important;
}
.woocommerce-checkout-review-order-table tbody tr:last-child td{border-bottom:1px solid var(--ink) !important}

.woocommerce-checkout-review-order-table tbody td.product-name{
  width:68%;padding:14px 8px 14px 0 !important;
  display:grid;grid-template-columns:48px minmax(0, 1fr);gap:4px 12px;
}
.woocommerce-checkout-review-order-table tbody td.product-total{
  width:32%;padding:14px 0 !important;text-align:right;
  font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--ink);
  white-space:nowrap;
}

/* Thumb + line */
.woocommerce-checkout-review-order-table .km-co-thumb{
  width:48px;height:48px;border-radius:9px;
  background:#fff;border:1px solid var(--cream-line);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
  grid-row:1 / span 3;
}
.woocommerce-checkout-review-order-table .km-co-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.woocommerce-checkout-review-order-table .km-co-line{display:flex;flex-direction:column;gap:2px;min-width:0}
.woocommerce-checkout-review-order-table .km-co-line__name{
  font-family:var(--font-display);font-weight:700;font-size:12px;
  letter-spacing:0.04em;text-transform:uppercase;
  color:var(--ink);line-height:1.2;word-break:break-word;
}
.woocommerce-checkout-review-order-table .km-co-line__qty{
  font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--cream-mute);
  letter-spacing:0.14em;text-transform:uppercase;
}
.woocommerce-checkout-review-order-table .product-name dl{
  margin:2px 0 0;font-family:var(--font-body);font-size:11px;color:var(--cream-mute);
  font-weight:500;
}
.woocommerce-checkout-review-order-table .product-name dl dt{display:inline;font-weight:700;color:var(--cream-ink)}
.woocommerce-checkout-review-order-table .product-name dl dd{display:inline;margin:0 0 0 4px}
.woocommerce-checkout-review-order-table .product-name dl dd p{margin:0;display:inline}
.woocommerce-checkout-review-order-table .product-name > .product-quantity{display:none}

/* Subtotal row */
.woocommerce-checkout-review-order-table tfoot tr.cart-subtotal{
  display:flex;justify-content:space-between;padding:14px 0 0;
}
.woocommerce-checkout-review-order-table tfoot tr.cart-subtotal th,
.woocommerce-checkout-review-order-table tfoot tr.cart-subtotal td{
  padding:0 !important;font-family:var(--font-mono);font-size:11px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--cream-mute);
}
.woocommerce-checkout-review-order-table tfoot tr.cart-subtotal td{color:var(--ink)}

/* ---- Shipping section ---- */
.woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals,
.woocommerce-checkout-review-order-table tr.woo-bg--shipping-methods{
  display:block;width:100%;
}
.woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals th,
.woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals td,
.woocommerce-checkout-review-order-table tr.woo-bg--shipping-methods th,
.woocommerce-checkout-review-order-table tr.woo-bg--shipping-methods td{
  display:block;width:100%;text-align:left;padding:0 !important;border:0 !important;
}
.woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals th{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--cream-mute);
  padding:18px 0 12px !important;margin-top:8px;
  border-top:1px solid var(--cream-line) !important;
  display:flex !important;align-items:center;gap:10px;
}
.woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals th::before{
  content:"";display:inline-block;width:18px;height:2px;background:var(--ember);
}
.woocommerce-checkout-review-order-table tr.woocommerce-shipping-totals td{padding-bottom:14px !important}

/* Each shipping method = its own card */
.woocommerce-checkout-review-order #shipping_method{
  display:flex;flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;
}
.woocommerce-checkout-review-order #shipping_method li{
  display:block;padding:14px 16px;
  background:#fff;
  border:1.5px solid var(--cream-line);
  border-radius:12px;
  transition:border-color .15s, background .15s;
  border-bottom:none !important;
}
.woocommerce-checkout-review-order #shipping_method li:has(input:checked){
  border-color:var(--ember);background:#fff;
}
.woocommerce-checkout-review-order #shipping_method li:hover{border-color:#A89C8A}
.woocommerce-checkout-review-order #shipping_method li input[type="radio"]{
  width:18px;height:18px;accent-color:var(--ember);margin:0 10px 0 0;
  vertical-align:-4px;
}
.woocommerce-checkout-review-order #shipping_method li label{
  display:inline;
  font-family:var(--font-display);font-weight:700;font-size:13px;
  color:var(--ink);letter-spacing:0.04em;text-transform:uppercase;line-height:1.3;
  cursor:pointer;
}
.woocommerce-checkout-review-order #shipping_method li label .amount,
.woocommerce-checkout-review-order #shipping_method li label .woocommerce-Price-amount{
  display:inline;margin-left:6px;color:var(--ember);font-weight:700;
}

/* ════════════════════════════════════════════════════════════════
   Bulgarisation Econt widgets — readable on cream
   ═══════════════════════════════════════════════════════════════ */
.woocommerce-checkout .woo-bg-additional-fields{
  display:block;margin:12px 0 0;padding:12px 0 0;
  background:transparent;border:0;
  border-top:1px dashed var(--cream-line);
  color:var(--ink);
}
.woocommerce-checkout .woo-bg-additional-fields .woo-bg-label,
.woocommerce-checkout .woo-bg-additional-fields label{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--cream-mute);
  margin:0 0 8px;display:block;
}

/* All input/select widgets inside */
.woocommerce-checkout .woo-bg-additional-fields input,
.woocommerce-checkout .woo-bg-additional-fields select,
.woocommerce-checkout .woo-bg-additional-fields .react-select__control{
  background:var(--cream-2);
  border:1.5px solid var(--cream-line);
  color:var(--ink);
  border-radius:10px;min-height:46px;padding:10px 14px;
  font-family:var(--font-body);font-size:13px;font-weight:600;
  box-shadow:none !important;
  white-space:normal;
}
.woocommerce-checkout .woo-bg-additional-fields input:focus,
.woocommerce-checkout .woo-bg-additional-fields select:focus,
.woocommerce-checkout .woo-bg-additional-fields .react-select__control--is-focused{
  border-color:var(--ember) !important;background:#fff !important;
}

/* React-select widget */
.woocommerce-checkout .woo-bg-additional-fields .react-select__control{
  padding:0 6px;min-height:46px;cursor:pointer;
}
.woocommerce-checkout .woo-bg-additional-fields .react-select__value-container{padding:2px 8px}
.woocommerce-checkout .woo-bg-additional-fields .react-select__single-value{
  color:var(--ink) !important;
  font-family:var(--font-body);font-weight:600;font-size:13px;
  white-space:normal;overflow:visible;text-overflow:clip;line-height:1.3;
}
.woocommerce-checkout .woo-bg-additional-fields .react-select__placeholder{color:var(--cream-mute)}
.woocommerce-checkout .woo-bg-additional-fields .react-select__menu{
  background:#fff;border:1.5px solid var(--cream-line);border-radius:10px;
  margin-top:6px;z-index:100;
}
.woocommerce-checkout .woo-bg-additional-fields .react-select__option{
  color:var(--ink);font-size:13px;padding:10px 14px;cursor:pointer;
}
.woocommerce-checkout .woo-bg-additional-fields .react-select__option--is-focused{background:var(--cream)}
.woocommerce-checkout .woo-bg-additional-fields .react-select__option--is-selected{background:var(--ember) !important;color:#fff !important}
.woocommerce-checkout .woo-bg-additional-fields .react-select__indicator{color:var(--ember);padding:0 8px}
.woocommerce-checkout .woo-bg-additional-fields .react-select__indicator-separator{background:var(--cream-line)}

.woocommerce-checkout .woo-bg-additional-fields > div + div{margin-top:10px}

/* ════════════════════════════════════════════════════════════════
   Order TOTAL (final big number)
   ═══════════════════════════════════════════════════════════════ */
.woocommerce-checkout-review-order-table tfoot tr.order-total{
  border-top:2px solid var(--ink) !important;display:flex;
  justify-content:space-between;align-items:center;padding:18px 0 14px;
}
.woocommerce-checkout-review-order-table tfoot tr.order-total th,
.woocommerce-checkout-review-order-table tfoot tr.order-total td{
  padding:0 !important;border:0 !important;
}
.woocommerce-checkout-review-order-table tfoot tr.order-total th{
  font-family:var(--font-display);font-size:14px;font-weight:700;
  color:var(--ink);letter-spacing:0.14em;text-transform:uppercase;
}
.woocommerce-checkout-review-order-table tfoot tr.order-total td{
  font-family:var(--font-display);font-size:26px;font-weight:700;
  color:var(--ember);text-align:right;line-height:1;
}

/* ════════════════════════════════════════════════════════════════
   Payment methods — full-width, flat
   ═══════════════════════════════════════════════════════════════ */
.woocommerce-checkout #payment{
  background:transparent;border-radius:0;padding:18px 24px 24px;margin:0;
  width:100%;box-sizing:border-box;
}
.woocommerce-checkout #payment ul.payment_methods{
  list-style:none;padding:0;margin:0 0 16px;border:0;background:transparent;
  display:flex;flex-direction:column;gap:8px;width:100%;
}
.woocommerce-checkout #payment ul.payment_methods li{
  width:100%;
  background:#fff;
  border:1.5px solid var(--cream-line);border-radius:12px;
  padding:16px 18px;
  transition:border-color .15s, background .15s;
  box-sizing:border-box;
}
.woocommerce-checkout #payment ul.payment_methods li:has(input:checked){
  border-color:var(--ember);background:#fff;
}
.woocommerce-checkout #payment ul.payment_methods li:hover{border-color:#A89C8A}
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"]{
  width:18px;height:18px;accent-color:var(--ember);margin:0 10px 0 0;vertical-align:-4px;
}
.woocommerce-checkout #payment ul.payment_methods li label{
  display:inline;cursor:pointer;color:var(--ink);
  font-family:var(--font-display);font-weight:700;font-size:14px;
  letter-spacing:0.06em;text-transform:uppercase;margin:0;
}
.woocommerce-checkout #payment ul.payment_methods li img{max-height:24px;width:auto;margin-left:6px;vertical-align:middle}
.woocommerce-checkout #payment ul.payment_methods .payment_box{
  background:transparent !important;color:var(--cream-mute) !important;
  font-size:12px;line-height:1.5;padding:12px 0 0;margin:12px 0 0;
  border:0 !important;border-top:1px dashed var(--cream-line) !important;
}
.woocommerce-checkout #payment ul.payment_methods .payment_box::before{display:none}
.woocommerce-checkout #payment ul.payment_methods .payment_box p{margin:0;color:var(--cream-ink)}

/* Terms */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper{margin:0 0 14px;font-size:12px;color:var(--cream-mute)}
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;font-weight:600}
.woocommerce-checkout #payment input#terms{width:18px;height:18px;accent-color:var(--ember);margin-right:8px;vertical-align:-3px}

/* Place order — flat ember slab */
.woocommerce-checkout #payment .place-order,
.woocommerce-checkout #payment > .form-row{margin:0;padding:0;background:transparent;border:0}
.woocommerce-checkout button#place_order{
  width:100%;min-height:56px;border-radius:12px;
  background:var(--ember) !important;color:#fff !important;
  border:0 !important;
  font-family:var(--font-display);font-weight:700;font-size:16px;
  letter-spacing:0.14em;text-transform:uppercase;
  cursor:pointer;
  transition:background .15s;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.woocommerce-checkout button#place_order::after{content:"→";font-size:20px;line-height:1}
.woocommerce-checkout button#place_order:hover{background:#FF6F38 !important}

/* Trust strip */
.km-checkout__trust{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  padding:18px 24px 22px;
  border-top:1px solid var(--cream-line);background:transparent;
}
.km-checkout__trust-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  color:var(--cream-mute);font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;
  text-align:center;text-transform:uppercase;font-weight:700;
}
.km-checkout__trust-item svg{color:var(--ember);flex-shrink:0}
@media (max-width:480px){
  .km-checkout__trust{grid-template-columns:1fr;gap:10px;padding:14px 18px 18px}
  .km-checkout__trust-item{flex-direction:row;justify-content:flex-start;gap:10px}
}

/* Coupon / messages — flat */
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-error{
  background:var(--ink-paper);border:1px solid var(--line-orange);
  color:#fff;border-radius:12px;padding:14px 18px;margin:0 0 20px;font-size:13px;
}
.woocommerce-checkout .woocommerce-info::before,
.woocommerce-checkout .woocommerce-message::before,
.woocommerce-checkout .woocommerce-error::before{color:var(--ember) !important}
.woocommerce-checkout .woocommerce-info a,
.woocommerce-checkout .woocommerce-message a,
.woocommerce-checkout .woocommerce-error a{color:var(--ember);text-decoration:underline}
.woocommerce-checkout .checkout_coupon{
  background:var(--ink-paper);border:1px dashed rgba(255,255,255,0.12);
  border-radius:14px;padding:18px;margin:0 0 20px;
}
.woocommerce-checkout .checkout_coupon .form-row-first,
.woocommerce-checkout .checkout_coupon .form-row-last{display:inline-block;width:auto;vertical-align:top}
.woocommerce-checkout .checkout_coupon button{
  background:var(--ember) !important;color:#fff !important;border:0 !important;
  padding:13px 22px !important;border-radius:10px !important;
  font-family:var(--font-display);font-weight:700;letter-spacing:0.06em;text-transform:uppercase;font-size:12px;
}

/* Loading overlay */
.woocommerce-checkout .blockUI.blockOverlay,
.woocommerce-checkout .blockUI.blockMsg{background:rgba(14,14,16,0.85) !important;border:0 !important;color:#fff !important}

.woocommerce-checkout .woocommerce-privacy-policy-text{color:var(--cream-mute);font-size:11px;margin:14px 0 0;line-height:1.5}
.woocommerce-checkout .woocommerce-privacy-policy-text a{color:var(--ink);font-weight:600}

/* Hide blocks-only leftovers if any */
.wp-block-woocommerce-checkout,
.wc-block-checkout{display:none !important}

/* Wrap max-width */
.km-checkout-wrap.wrap{max-width:1280px;margin:0 auto;padding-left:32px;padding-right:32px}
@media (max-width:560px){.km-checkout-wrap.wrap{padding-left:18px;padding-right:18px}}

/* ════════════════════════════════════════════════════════════════
   CHECKOUT v2.0.1 — autofill fix + widget polish
   ═══════════════════════════════════════════════════════════════ */

/* Safari/Chrome autofill paints inputs white. Override with our dark theme. */
.woocommerce-checkout input:-webkit-autofill,
.woocommerce-checkout input:-webkit-autofill:hover,
.woocommerce-checkout input:-webkit-autofill:focus,
.woocommerce-checkout input:-webkit-autofill:active,
.woocommerce-checkout textarea:-webkit-autofill,
.woocommerce-checkout select:-webkit-autofill{
  -webkit-text-fill-color:#fff !important;
  -webkit-box-shadow:0 0 0 1000px var(--ink-input) inset !important;
  box-shadow:0 0 0 1000px var(--ink-input) inset !important;
  caret-color:#fff !important;
  border:1.5px solid var(--line) !important;
  transition:background-color 5000s ease-in-out 0s, color 5000s ease-in-out 0s !important;
  font-family:var(--font-body) !important;
}
.woocommerce-checkout input:-webkit-autofill:focus{
  border-color:var(--ember) !important;
}

/* Same for Bulgarisation inputs on cream background */
.woocommerce-checkout .woo-bg-additional-fields input:-webkit-autofill,
.woocommerce-checkout .woo-bg-additional-fields input:-webkit-autofill:focus,
.woocommerce-checkout .woo-bg-additional-fields input:-webkit-autofill:hover{
  -webkit-text-fill-color:var(--ink) !important;
  -webkit-box-shadow:0 0 0 1000px var(--cream-2) inset !important;
  box-shadow:0 0 0 1000px var(--cream-2) inset !important;
  caret-color:var(--ink) !important;
  border:1.5px solid var(--cream-line) !important;
}

/* Empty input state — be explicit about background (some browsers reset) */
.woocommerce-checkout input,
.woocommerce-checkout select,
.woocommerce-checkout textarea{
  background-color:var(--ink-input) !important;
  color:#fff !important;
}
.woocommerce-checkout input::placeholder,
.woocommerce-checkout textarea::placeholder{color:rgba(255,255,255,0.32) !important;opacity:1}
/* Re-allow Bulgarisation inputs on cream to keep cream styling */
.woocommerce-checkout .woo-bg-additional-fields input,
.woocommerce-checkout .woo-bg-additional-fields select{
  background-color:var(--cream-2) !important;
  color:var(--ink) !important;
}
.woocommerce-checkout .woo-bg-additional-fields input::placeholder{color:var(--cream-mute) !important}

/* Make sure Bulgarisation street number / extra inputs follow cream style */
.woocommerce-checkout .woo-bg-additional-fields input[type="text"],
.woocommerce-checkout .woo-bg-additional-fields input[type="number"],
.woocommerce-checkout .woo-bg-additional-fields input[type="search"],
.woocommerce-checkout .woo-bg-additional-fields .woo-bg-input,
.woocommerce-checkout .woo-bg-additional-fields .woo-bg-input-text,
.woocommerce-checkout [class*="woo-bg-econt"] input{
  background:var(--cream-2) !important;
  border:1.5px solid var(--cream-line) !important;
  color:var(--ink) !important;
  border-radius:10px !important;
  min-height:42px !important;
  padding:10px 14px !important;
  font-family:var(--font-body) !important;font-size:13px !important;
  font-weight:600 !important;
  box-shadow:none !important;
  margin-top:8px !important;
  width:100% !important;box-sizing:border-box !important;
}
.woocommerce-checkout .woo-bg-additional-fields input[type="text"]:focus,
.woocommerce-checkout .woo-bg-additional-fields input[type="number"]:focus{
  border-color:var(--ember) !important;background:#fff !important;
}

/* Bulgarisation labels above each picker input */
.woocommerce-checkout .woo-bg-additional-fields > label,
.woocommerce-checkout .woo-bg-additional-fields > strong{
  font-family:var(--font-mono) !important;font-size:10px !important;
  font-weight:700 !important;letter-spacing:0.16em !important;
  text-transform:uppercase !important;color:var(--cream-mute) !important;
  display:block !important;margin:10px 0 6px !important;
}

/* Cream summary title — guarantee visibility above the K stamp */
.km-checkout__summary-title{
  padding-top:36px !important;
  padding-right:80px !important; /* leave room for K stamp */
  position:relative;
  z-index:2;
}
.km-checkout__summary::after{
  z-index:1;
}

/* Section title in left billing card — match cream side spacing */
.woocommerce-checkout .woocommerce-billing-fields > h3{
  padding-right:0;
}

/* Wider page padding for huge desktops */
@media (min-width:1440px){
  .km-checkout-wrap.wrap{max-width:1360px;padding-left:40px;padding-right:40px}
}

/* Fix the product thumb sizing if image missing */
.woocommerce-checkout-review-order-table .km-co-thumb img,
.woocommerce-checkout-review-order-table .km-co-thumb{
  width:48px !important;height:48px !important;
}
.woocommerce-checkout-review-order-table .km-co-thumb .attachment-shop_thumbnail,
.woocommerce-checkout-review-order-table .km-co-thumb .woocommerce-placeholder{
  width:48px !important;height:48px !important;object-fit:cover !important;
}

/* ════════════════════════════════════════════════════════════════
   CHECKOUT v2.1 — product row restructure + input consistency
   ═══════════════════════════════════════════════════════════════ */

/* Product row layout — grid: [thumb] [name / meta / qty stacked] */
.woocommerce-checkout-review-order-table tbody td.product-name{
  display:grid !important;
  grid-template-columns:48px minmax(0, 1fr) !important;
  grid-auto-rows:auto !important;
  gap:3px 14px !important;
  align-items:start !important;
  padding:14px 8px 14px 0 !important;
}
.woocommerce-checkout-review-order-table .km-co-thumb{
  grid-column:1;
  grid-row:1 / span 3;
  align-self:start;
  width:48px;height:48px;
  border-radius:9px;
  background:#fff;border:1px solid var(--cream-line);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.woocommerce-checkout-review-order-table .km-co-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.woocommerce-checkout-review-order-table .km-co-line__name{
  grid-column:2;grid-row:1;
  font-family:var(--font-display);font-weight:700;font-size:13px;
  letter-spacing:0.04em;text-transform:uppercase;
  color:var(--ink);line-height:1.2;
  word-break:break-word;
}
.woocommerce-checkout-review-order-table .km-co-line__meta{
  grid-column:2;grid-row:2;
  font-family:var(--font-body);font-size:11px;font-weight:500;
  color:var(--cream-mute);line-height:1.35;
  margin-top:2px;
}
.woocommerce-checkout-review-order-table .km-co-line__meta-label{
  font-weight:700;color:var(--cream-ink);
}
.woocommerce-checkout-review-order-table .km-co-line__meta-value{
  color:var(--ink);font-weight:600;
}
.woocommerce-checkout-review-order-table .km-co-line__qty{
  grid-column:2;grid-row:3;
  font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--cream-mute);
  letter-spacing:0.14em;text-transform:uppercase;
  margin-top:4px;
}

/* Remove any stray dl from Woo (we suppressed it but be defensive) */
.woocommerce-checkout-review-order-table .product-name dl,
.woocommerce-checkout-review-order-table .product-name .wc-item-meta{display:none}

/* ════════════════════════════════════════════════════════════════
   INPUT CONSISTENCY — all inputs match the Област dropdown
   ═══════════════════════════════════════════════════════════════ */

/* Reset and unify every input field */
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout input[type="url"],
.woocommerce-checkout input[type="search"],
.woocommerce-checkout textarea,
.woocommerce-checkout select,
.woocommerce-checkout .select2-container--default .select2-selection--single{
  -webkit-appearance:none !important;appearance:none !important;
  width:100% !important;
  height:52px !important;min-height:52px !important;
  padding:14px 16px !important;
  background-color:var(--ink-input) !important;
  background-image:none;
  border:1.5px solid var(--line) !important;
  border-radius:10px !important;
  color:#fff !important;
  font-family:var(--font-body) !important;
  font-size:14px !important;
  font-weight:500 !important;
  letter-spacing:0.01em !important;
  line-height:1.4 !important;
  outline:none !important;
  box-shadow:none !important;
  transition:border-color .15s, background-color .15s !important;
  box-sizing:border-box !important;
}
.woocommerce-checkout textarea{
  height:auto !important;min-height:96px !important;
  padding:14px 16px !important;line-height:1.5 !important;resize:vertical !important;
}

/* Select chevron — same on native and Select2 */
.woocommerce-checkout select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23FF5A1F' d='M6 8 0 0h12z'/></svg>") !important;
  background-repeat:no-repeat !important;
  background-position:right 18px center !important;
  background-size:10px 6px !important;
  padding-right:42px !important;
  cursor:pointer;
}

/* Select2 (single) — match select exactly */
.woocommerce-checkout .select2-container,
.woocommerce-checkout .select2-container--default{width:100% !important;display:block}
.woocommerce-checkout .select2-container--default .select2-selection--single{
  display:flex !important;align-items:center !important;
  padding:0 42px 0 16px !important;cursor:pointer !important;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered{
  color:#fff !important;line-height:1.4 !important;padding:0 !important;
  font-size:14px !important;font-weight:500 !important;font-family:var(--font-body) !important;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow{
  height:50px !important;right:14px !important;top:0 !important;width:24px !important;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow b{
  border-color:var(--ember) transparent transparent transparent !important;
  border-width:6px 5px 0 5px !important;
  margin-left:-5px !important;margin-top:-3px !important;
}

/* Hover state */
.woocommerce-checkout input:hover,
.woocommerce-checkout textarea:hover,
.woocommerce-checkout select:hover,
.woocommerce-checkout .select2-container--default .select2-selection--single:hover{
  background-color:var(--ink-input-h) !important;
  border-color:var(--line-strong) !important;
}

/* Focus state — ember border, no glow */
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single{
  background-color:var(--ink-input-h) !important;
  border-color:var(--ember) !important;
  box-shadow:none !important;
}

/* Placeholder */
.woocommerce-checkout input::placeholder,
.woocommerce-checkout textarea::placeholder{
  color:rgba(255,255,255,0.32) !important;
  font-family:var(--font-body) !important;
  font-weight:500 !important;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__placeholder{
  color:rgba(255,255,255,0.32) !important;
}

/* Re-apply CREAM-side overrides for Bulgarisation widgets (lighter) */
.woocommerce-checkout .woo-bg-additional-fields input,
.woocommerce-checkout .woo-bg-additional-fields select,
.woocommerce-checkout .woo-bg-additional-fields .react-select__control{
  height:48px !important;min-height:48px !important;
  background-color:var(--cream-2) !important;
  border:1.5px solid var(--cream-line) !important;
  color:var(--ink) !important;
  border-radius:10px !important;
  padding:0 16px !important;
  font-family:var(--font-body) !important;
  font-size:14px !important;font-weight:500 !important;
}
.woocommerce-checkout .woo-bg-additional-fields input::placeholder{
  color:var(--cream-mute) !important;
}

/* Field label clarity — uniform font, sizing, spacing */
.woocommerce-checkout .form-row{
  gap:8px !important;
}
.woocommerce-checkout .form-row > label,
.woocommerce-checkout .form-row > label:first-child{
  font-family:var(--font-body) !important;
  font-size:10px !important;font-weight:700 !important;
  color:var(--ash) !important;
  letter-spacing:0.18em !important;
  text-transform:uppercase !important;
  margin:0 !important;line-height:1.2 !important;
  display:block !important;
}
.woocommerce-checkout .form-row > label .required{
  color:var(--ember) !important;text-decoration:none !important;
  margin-left:3px;font-weight:900;
}
.woocommerce-checkout .form-row > label .optional{display:none !important}

/* ════════════════════════════════════════════════════════════════
   CHECKOUT v2.1.1 — single-column form (full-width, stacked)
   ═══════════════════════════════════════════════════════════════ */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .woocommerce-additional-fields__field-wrapper{
  display:flex !important;
  flex-direction:column !important;
  gap:14px !important;
}
.woocommerce-checkout .form-row,
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last,
.woocommerce-checkout .form-row-wide,
.woocommerce-checkout .form-row-full{
  width:100% !important;
  max-width:none !important;
  flex:0 0 100% !important;
  grid-column:1 / -1 !important;
}
