/*
 Theme Name:  Low 12 Leather — Child
 Template:    leather-house
 Description: Modern luxury child theme for Low 12 Leather (WooCommerce-focused).
 Version:     1.0.0
 Author:      PC Guys LLC
 Text Domain: low12
*/

/* =======================================
   DESIGN TOKENS
   ======================================= */
:root{
  --l12-bg:#0b0a09;          /* deep espresso */
  --l12-bg-2:#12110f;        /* slightly lighter */
  --l12-ink:#eae7e1;         /* bone/ivory text */
  --l12-ink-2:#cfc9bf;       /* muted text */
  --l12-accent:#c9a66b;      /* warm gold */
  --l12-accent-2:#b48f53;    /* deeper gold */
  --l12-line:rgba(255,255,255,.08);
  --l12-card:#171512;        /* card surface */
  --l12-success:#4caf50;
  --l12-danger:#e74c3c;

  --l12-max:1200px;
  --l12-radius:18px;
  --l12-radius-lg:26px;
  --l12-shadow:0 8px 30px rgba(0,0,0,.35);

  --l12-h1:clamp(40px,6vw,64px);
  --l12-h2:clamp(28px,4vw,40px);
  --l12-h3:clamp(22px,3vw,28px);
  --l12-lead:clamp(16px,2.2vw,19px);
}

/* =======================================
   BASE
   ======================================= */
html,body{
  background:var(--l12-bg);
  color:var(--l12-ink);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  line-height:1.55;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{
  font-family:"Playfair Display",Georgia,"Times New Roman",serif;
  line-height:1.15;
  letter-spacing:.2px;
}

a{ color:var(--l12-accent); text-decoration:none; }
a:hover{ color:var(--l12-accent-2); }

/* Helpers */
.l12-container{ width:100%; max-width:var(--l12-max); margin:0 auto; padding:0 22px; }
.l12-pill{ border-radius:999px; }
.l12-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.9rem 1.25rem; border-radius:999px; border:1px solid var(--l12-line);
  background:linear-gradient(180deg,#1a1815,#12110f); color:var(--l12-ink);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 6px 20px rgba(0,0,0,.35);
  transition:transform .18s ease, background .2s ease, border-color .2s ease;
  font-weight:600;
}
.l12-btn:hover{ transform:translateY(-1px); border-color:rgba(201,166,107,.45); }
.l12-btn--gold{ background:linear-gradient(180deg,var(--l12-accent),var(--l12-accent-2)); color:#1a1206; border-color:rgba(0,0,0,.15); }
.l12-btn--ghost{ background:transparent; border-color:var(--l12-line); color:var(--l12-ink); }
.l12-badge{ display:inline-block; padding:.35rem .7rem; font-size:.78rem; border:1px solid var(--l12-line); border-radius:999px; color:var(--l12-ink-2); }

:focus-visible{ outline:2px solid var(--l12-accent); outline-offset:2px; }
.hide{ display:none !important; }
.center{ text-align:center; }
.space{ height:50px; }

/* =======================================
   HEADER
   ======================================= */
.l12-header{
  position:sticky; top:0; z-index:1000; backdrop-filter:blur(10px);
  background:linear-gradient(180deg,rgba(11,10,9,.85),rgba(11,10,9,.65));
  border-bottom:1px solid var(--l12-line);
  transition:padding .25s ease, background .25s ease, border-color .25s ease;
  padding:14px 0;
}
.l12-header.scrolled{ padding:8px 0; background:rgba(11,10,9,.9); }

.l12-nav{ display:flex; align-items:center; justify-content:space-between; gap:16px; }

.l12-brand{ display:flex; align-items:center; gap:12px; min-width:0; }
.l12-wordmark{ font-family:"Playfair Display",serif; font-weight:900; letter-spacing:.6px; font-size:1.15rem; white-space:nowrap; color:var(--l12-ink); }
@media (max-width:520px){ .l12-wordmark{ display:none; } }

/* Circle logo (image contained, no crop) */
.l12-logo{
  width:72px; height:72px; border-radius:50%;
  display:grid; place-items:center; overflow:hidden;
  background:radial-gradient(120% 120% at 30% 20%, rgba(201,166,107,.18), transparent) #151311;
  border:1px solid var(--l12-line);
}
.l12-logo img{
  width:100% !important; height:100% !important; object-fit:contain; object-position:center; display:block;
  transform:scale(1.04); /* tiny optical fill */
}
@media (max-width:600px){ .l12-logo{ width:64px; height:64px; } }

/* Desktop menu */
.l12-menu{ display:flex; align-items:center; gap:22px; }
.l12-menu a{
  position:relative; padding:.35rem .12rem; color:var(--l12-ink-2); font-weight:600;
  transition:color .2s ease;
}
.l12-menu a::before{
  content:""; position:absolute; inset:-6px -10px; border-radius:12px;
  background:rgba(201,166,107,.08); transform:translateY(6px); opacity:0; transition:.25s ease;
}
.l12-menu a::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:linear-gradient(90deg,transparent,var(--l12-accent),transparent);
  transform:scaleX(0); transform-origin:center; opacity:0; transition:transform .25s ease, opacity .25s ease;
}
.l12-menu a:hover{ color:var(--l12-ink); }
.l12-menu a:hover::before{ transform:translateY(0); opacity:1; }
.l12-menu a:hover::after{ transform:scaleX(1); opacity:1; }
.l12-menu .current-menu-item>a{ color:var(--l12-accent); }
.l12-menu .current-menu-item>a::after{ transform:scaleX(1); opacity:1; }

/* Header actions */
.l12-actions{ display:flex; align-items:center; gap:10px; }
.l12-iconbtn{
  width:40px; height:40px; display:grid; place-items:center; line-height:0; box-sizing:border-box;
  border-radius:999px; border:1px solid var(--l12-line); background:#141310; cursor:pointer;
  transition:transform .15s ease, border-color .2s ease; -webkit-tap-highlight-color:transparent;
}
.l12-iconbtn:hover{ transform:translateY(-1px); border-color:rgba(201,166,107,.5); }
.l12-iconbtn svg{ width:18px; height:18px; display:block; }
#l12-burger{ display:none; }
@media (max-width:980px){ .l12-menu-wrap{ display:none; } #l12-burger{ display:grid; place-items:center; } }

/* Cart pill */
.l12-cart{ position:relative; }
.l12-cart-count{
  position:absolute; top:-6px; right:-6px; min-width:20px; height:20px;
  border-radius:999px; display:grid; place-items:center; background:var(--l12-accent); color:#1a1206;
  font-size:.72rem; font-weight:800; border:1px solid rgba(0,0,0,.25);
}

/* Drawer (mobile menu) */
.l12-drawer{
  position:fixed; inset:0 0 0 auto; width:min(86%,420px); background:#0f0e0d;
  transform:translateX(102%); transition:transform .28s ease; border-left:1px solid var(--l12-line);
  z-index:1001; display:flex; flex-direction:column; overscroll-behavior:contain;
}
.l12-drawer.open{ transform:translateX(0); }
.l12-drawer-head{ padding:18px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--l12-line); }
.l12-drawer-nav{ padding:12px 18px 28px; display:flex; flex-direction:column; gap:6px; max-height:calc(100dvh - 60px); overflow:auto; }
.l12-drawer-nav .menu, .l12-drawer-nav ul{ list-style:none; margin:0; padding:0; }
.l12-drawer-nav .menu>li{ margin:0 0 10px; }
.l12-drawer-nav a{
  display:block; width:100%; box-sizing:border-box; padding:14px 16px; border-radius:14px;
  background:#151311; border:1px solid var(--l12-line); color:var(--l12-ink); line-height:1.25; white-space:normal;
}
.l12-drawer-nav a:hover{ background:#191714; }
.l12-drawer-nav .sub-menu{ margin:8px 0 0; padding-left:12px; border-left:1px dashed var(--l12-line); display:grid; gap:8px; }
.l12-drawer-nav .sub-menu a{ padding:10px 12px; border-radius:12px; }

/* Search overlay (wide input) */
.l12-search{ position:fixed; inset:0; background:rgba(11,10,9,.9); backdrop-filter:blur(8px); display:none; z-index:1002; }
.l12-search.open{ display:block; }
.l12-search-inner{ max-width:1320px; margin:12vh auto 0; padding:0 22px; }
.l12-search form{ display:flex; gap:10px; }
.l12-search .search-field{
  flex:1; padding:22px; font-size:1.15rem; border-radius:16px; border:1px solid var(--l12-line); background:#141310; color:var(--l12-ink); min-width:0;
}
.l12-search [type="submit"]{
  padding:0 18px; border-radius:14px; border:1px solid var(--l12-line);
  background:linear-gradient(180deg,#1a1815,#12110f); color:var(--l12-ink); font-weight:700;
}

/* =======================================
   HERO
   ======================================= */
.l12-hero{
  position:relative; isolation:isolate; overflow:hidden; border-bottom:1px solid var(--l12-line);
  background:radial-gradient(1200px 600px at 60% -20%, rgba(201,166,107,.18), transparent 60%), #0b0a09;
}
.l12-hero-wrap{ display:grid; grid-template-columns:1.1fr .9fr; gap:30px; align-items:center; min-height:72vh; }
@media (max-width:980px){ .l12-hero-wrap{ grid-template-columns:1fr; gap:16px; padding:18vh 0 12vh; } }
.l12-hero .eyebrow{ text-transform:uppercase; letter-spacing:.22em; color:var(--l12-accent); font-weight:800; font-size:.82rem; }
.l12-hero h1{ font-size:var(--l12-h1); margin:.5rem 0; }
.l12-hero p{ color:var(--l12-ink-2); font-size:var(--l12-lead); max-width:62ch; }
.l12-hero-cta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:18px; }
.l12-hero-card{ border-radius:var(--l12-radius-lg); background:#141310; border:1px solid var(--l12-line); box-shadow:var(--l12-shadow); overflow:hidden; aspect-ratio:5/3; position:relative; }
.l12-hero-card img{ width:100%; height:100%; object-fit:cover; display:block; opacity:.88; }

/* =======================================
   WOOCOMMERCE — PRODUCT CARDS / BUTTONS
   ======================================= */
.woocommerce ul.products li.product, .products .product{
  background:var(--l12-card); border:1px solid var(--l12-line); border-radius:18px; overflow:hidden; padding-bottom:14px;
  transition:transform .18s ease, box-shadow .22s ease, border-color .22s ease;
}
.woocommerce ul.products li.product:hover{ transform:translateY(-3px); box-shadow:0 14px 36px rgba(0,0,0,.45); border-color:rgba(201,166,107,.35); }
.woocommerce ul.products li.product .woocommerce-loop-product__title{ font-family:"Playfair Display",serif; font-size:1.05rem; padding:0 14px; margin:6px 0 0; }
.woocommerce ul.products li.product .price{ padding:0 14px; color:var(--l12-accent); font-weight:700; }

.woocommerce a.button, .woocommerce button.button, .woocommerce input.button{
  border-radius:999px; border:1px solid var(--l12-line);
  background:linear-gradient(180deg,#1a1815,#12110f); color:var(--l12-ink);
  padding:.7rem 1.1rem; font-weight:700;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover{ border-color:rgba(201,166,107,.45); }
.woocommerce span.onsale{ background:var(--l12-accent); color:#1a1206; border-radius:999px; padding:.2rem .5rem; top:12px; left:12px; }

/* Normalize “Return to shop / Back” buttons */
.woocommerce .return-to-shop .button,
.woocommerce a.wc-backward,
.woocommerce .woocommerce-info .button,
.woocommerce .woocommerce-message .button{
  min-height:44px; padding:.7rem 1.1rem !important; border-radius:999px !important;
  border:1px solid var(--l12-line) !important; background:linear-gradient(180deg,#1a1815,#12110f) !important;
  color:var(--l12-ink) !important; font-weight:700 !important; font-size:.95rem !important; box-shadow:none !important;
}

/* =======================================
   FOOTER
   ======================================= */
.l12-footer{ border-top:1px solid var(--l12-line); background:var(--l12-bg-2); margin-top:60px; }
.l12-foot-grid{ display:grid; grid-template-columns:1.2fr 1fr 1fr 1.2fr; gap:28px; padding:50px 0; }
@media (max-width:980px){ .l12-foot-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .l12-foot-grid{ grid-template-columns:1fr; } }
.l12-foot h4{ font-size:1rem; text-transform:uppercase; letter-spacing:.12em; color:var(--l12-ink-2); margin-bottom:12px; }
.l12-foot a{ color:var(--l12-ink-2); } .l12-foot a:hover{ color:var(--l12-ink); }
.l12-copy{ border-top:1px solid var(--l12-line); padding:16px 0; font-size:.92rem; color:var(--l12-ink-2); display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.l12-pay{ display:flex; gap:10px; opacity:.8; }

/* =======================================
   RESPONSIVE POLISH (header/hero/shop/forms)
   ======================================= */
@media (max-width:980px){
  .l12-header{ padding:10px 0; }
  .l12-actions{ gap:8px; }
  .l12-iconbtn{ width:44px; height:44px; }
  .l12-cart-count{ top:-4px; right:-4px; min-width:18px; height:18px; font-size:.7rem; }
  .l12-brand{ gap:10px; }
  .woocommerce ul.products{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px !important; }
  .woocommerce ul.products li.product{ margin:0 !important; width:auto !important; }
}
@media (max-width:600px){
  .l12-search-inner{ margin-top:10vh; padding:0 16px; max-width:94vw; }
  .l12-search .search-field{ font-size:1.05rem; padding:18px; }
  .l12-hero h1{ font-size:clamp(28px,8vw,40px); }
}
@media (max-width:480px){
  .woocommerce ul.products{ grid-template-columns:1fr; }
}

/* =======================================
   WOOCOMMERCE — MY ACCOUNT (GLOBAL NORMALIZE)
   ======================================= */
/* Remove theme sidebars/columns on account pages */
body.woocommerce-account .sidebar, body.woocommerce-account .widget-area{ display:none !important; }
body.woocommerce-account #av-primary-content{ width:auto !important; max-width:none !important; float:none !important; margin:0 auto !important; }
body.woocommerce-account .av-columns-area,
body.woocommerce-account .container-full,
body.woocommerce-account .l12-container{
  max-width:1200px !important; margin:0 auto !important; padding-left:22px !important; padding-right:22px !important;
}

/* =======================================
   MY ACCOUNT — LOGGED IN (WIDE CONTENT RIGHT)
   ======================================= */
body.logged-in.woocommerce-account #av-primary-content > .woocommerce{
  /* centered wide track */
  width:min(1320px,96vw) !important;
  margin:28px auto 44px !important;
  display:grid !important;
  grid-template-columns:240px minmax(0,1fr) !important; /* small nav | big content */
  gap:34px !important;
  align-items:start; justify-content:center;
  color:var(--l12-ink); background:transparent;
}

/* Kill floats from parent theme on the two panels */
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content{
  float:none !important; width:auto !important; max-width:none !important; margin:0 !important; clear:none !important; order:0 !important;
}
.woocommerce-account nav.woocommerce-MyAccount-navigation{ grid-column:1 !important; }
.woocommerce-account div.woocommerce-MyAccount-content{ grid-column:2 !important; }

/* Nav panel visuals */
.woocommerce-account .woocommerce-MyAccount-navigation{
  background:#141310; border:1px solid var(--l12-line); border-radius:14px; overflow:hidden;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul{ list-style:none; margin:0; padding:8px; display:grid; gap:8px; }
.woocommerce-account .woocommerce-MyAccount-navigation li a{
  display:block; padding:12px 14px; border-radius:12px; background:#151311; border:1px solid var(--l12-line);
  color:var(--l12-ink-2); line-height:1.25;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a::before,
.woocommerce-account .woocommerce-MyAccount-navigation li a::after{ content:none !important; }
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover{ background:#191714; color:var(--l12-ink); }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a{ background:#191714; color:var(--l12-ink); box-shadow:inset 2px 0 0 var(--l12-accent); }

/* Content panel visuals */
.woocommerce-account .woocommerce-MyAccount-content{
  background:#141310; border:1px solid var(--l12-line); border-radius:18px; padding:22px; color:var(--l12-ink);
}
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3{
  color:var(--l12-ink); font-family:"Playfair Display",serif;
}

/* Links and notices in content */
.woocommerce-account .woocommerce-MyAccount-content a{ color:var(--l12-accent); }
.woocommerce-account .woocommerce-MyAccount-content a:hover{ color:var(--l12-accent-2); }
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info,
.woocommerce-account .woocommerce-error{
  background:#151311; color:var(--l12-ink); border:1px solid var(--l12-line);
}

/* Tables */
.woocommerce-account table.shop_table{ background:transparent; color:var(--l12-ink); border-color:var(--l12-line); }
.woocommerce-account table.shop_table th{ background:#151311; color:var(--l12-ink); }
.woocommerce-account table.shop_table td{ background:transparent; color:var(--l12-ink-2); border-top:1px solid var(--l12-line); }

/* Forms/inputs/buttons inside account content */
.woocommerce-account .woocommerce input[type="text"],
.woocommerce-account .woocommerce input[type="email"],
.woocommerce-account .woocommerce input[type="password"],
.woocommerce-account .woocommerce textarea,
.woocommerce-account .woocommerce select{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid var(--l12-line); background:#0f0e0d; color:var(--l12-ink);
}
.woocommerce-account .woocommerce button.button,
.woocommerce-account .woocommerce a.button{
  border-radius:999px; border:1px solid var(--l12-line);
  background:linear-gradient(180deg,var(--l12-accent),var(--l12-accent-2)); color:#1a1206; font-weight:800; padding:.8rem 1.2rem;
}
.woocommerce-account .woocommerce button.button:hover,
.woocommerce-account .woocommerce a.button:hover{ filter:brightness(.98); }

/* Addresses grid (two cards) + title row fix */
.woocommerce-account .woocommerce-MyAccount-content .addresses{
  display:grid !important; grid-template-columns:repeat(2, minmax(320px,1fr)); gap:24px; align-items:start;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address{
  background:#141310; border:1px solid var(--l12-line); border-radius:12px; padding:18px; color:var(--l12-ink);
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address header.title{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  position:static !important; margin:0 0 12px !important;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address header.title h3{
  margin:0 !important; font-size:1.15rem !important; line-height:1.2 !important;
  writing-mode:horizontal-tb !important; text-orientation:mixed !important; transform:none !important;
  letter-spacing:normal !important; white-space:normal !important;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address header.title .edit{
  position:static !important; margin-left:auto; border:1px solid var(--l12-line); border-radius:999px; padding:6px 10px;
  background:#151311; color:var(--l12-ink); font-size:.85rem; line-height:1; white-space:nowrap;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address address,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address p{ margin:0; color:var(--l12-ink-2); }

/* =======================================
   MY ACCOUNT — LOGGED OUT (LOGIN/REGISTER)
   ======================================= */
body.woocommerce-account:not(.logged-in) .woocommerce{
  width:min(820px,96vw) !important; margin:40px auto !important;
  display:grid !important; grid-template-columns:1fr !important; gap:24px !important; align-items:start; justify-items:center;
}
body.woocommerce-account:not(.logged-in) .woocommerce > h2{
  /* sometimes Woo prints a top H2 outside columns: keep centered above */
  width:100%; order:-1; text-align:center; margin:0 0 14px !important; float:none !important;
  color:var(--l12-ink); font-family:"Playfair Display",serif;
}

/* If Woo prints two columns (Login / Register), stack vertically */
body.woocommerce-account:not(.logged-in) .u-columns.col2-set{
  display:grid !important; grid-template-columns:1fr !important; gap:24px !important; width:100%;
}
body.woocommerce-account:not(.logged-in) .u-column1,
body.woocommerce-account:not(.logged-in) .u-column2{ width:auto !important; float:none !important; margin:0 !important; }

/* Card visuals for login/register forms */
body.woocommerce-account:not(.logged-in) .woocommerce form.login,
body.woocommerce-account:not(.logged-in) .woocommerce form.register{
  width:min(560px,92vw); margin:0 auto; background:#141310; border:1px solid var(--l12-line); border-radius:16px; padding:22px; color:var(--l12-ink);
}
body.woocommerce-account:not(.logged-in) .woocommerce .u-column1 h2,
body.woocommerce-account:not(.logged-in) .woocommerce .u-column2 h2{
  width:100%; text-align:center; margin:0 0 14px !important; float:none !important;
}

/* =======================================
   MY ACCOUNT — RESPONSIVE
   ======================================= */
@media (max-width:899px){
  body.logged-in.woocommerce-account #av-primary-content > .woocommerce{
    grid-template-columns:1fr !important; width:94vw !important; gap:16px !important; margin:20px auto 32px !important;
  }
  .woocommerce-account .woocommerce-MyAccount-content{ padding:18px; }
  .woocommerce-account .woocommerce-MyAccount-navigation ul{ grid-auto-rows:minmax(44px,auto); }
  .woocommerce-account .woocommerce-MyAccount-content .addresses{ grid-template-columns:1fr; }
}

/* =======================================
   FORMS/CHECKOUT RESPONSIVE NORMALIZE
   ======================================= */
@media (max-width:900px){
  .woocommerce .col2-set,
  .woocommerce .col2-set .col-1,
  .woocommerce .col2-set .col-2{ width:100% !important; float:none !important; }
  .woocommerce form .form-row-first,
  .woocommerce form .form-row-last{ width:100% !important; float:none !important; }
}
.woocommerce table.shop_table{ width:100%; display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; }
/* ===== Woo My Account — Addresses: horizontal titles + 2-column grid ===== */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
  display:grid !important;
  grid-template-columns:repeat(2, minmax(320px,1fr)) !important; /* side by side */
  gap:24px !important;
  align-items:start !important;
}

/* kill theme floats/widths that break the grid */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address{
  float:none !important;
  width:auto !important;
  background:#141310; border:1px solid var(--l12-line); border-radius:12px; padding:18px;
}

/* title row: keep on one line with edit link to the right */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header.title{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;
  margin:0 0 12px !important;
  position:static !important;
}

/* horizontal headings — match both classic & new Woo classnames */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header.title h3,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address .woocommerce-column__title{
  margin:0 !important;
  font-size:1.15rem !important;
  line-height:1.2 !important;
  /* nuke vertical styles from parent theme */
  writing-mode:horizontal-tb !important;
  text-orientation:mixed !important;
  transform:none !important;
  white-space:normal !important;
  letter-spacing:normal !important;
  width:auto !important;
  max-width:none !important;
  display:block !important;
}

/* "Edit/Add" button */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header.title .edit{
  position:static !important;
  margin-left:auto !important;
  border:1px solid var(--l12-line) !important;
  border-radius:999px !important;
  padding:6px 10px !important;
  background:#151311 !important;
  color:var(--l12-ink) !important;
  font-size:.85rem !important;
  line-height:1 !important;
  white-space:nowrap !important;
}

/* mobile: stack the two cards */
@media (max-width:680px){
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
    grid-template-columns:1fr !important;
  }
}
/* ===== Woo My Account — Addresses: lock into one row, no diagonal ===== */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;  /* side-by-side */
  gap: 24px !important;
  align-items: start !important;
}

/* kill floats/widths/margins that push one box down */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .u-column1,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .u-column2,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .col-1,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .col-2{
  float: none !important;
  clear: none !important;
  width: auto !important;
  margin: 0 !important;            /* remove top margin causing the drop */
}

/* explicitly place them on the same row (left = billing, right = shipping) */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .u-column1,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .col-1{
  grid-column: 1 !important;
  grid-row: 1 !important;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .u-column2,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .col-2{
  grid-column: 2 !important;
  grid-row: 1 !important;
}

/* titles stay horizontal (keep from earlier, repeated here for certainty) */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address header.title{
  display:flex !important; align-items:center !important; justify-content:space-between !important;
  gap:12px !important; margin:0 0 12px !important; position:static !important;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address header.title h3,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address .woocommerce-column__title{
  writing-mode: horizontal-tb !important; text-orientation: mixed !important; transform: none !important;
  letter-spacing: normal !important; white-space: normal !important; margin:0 !important; line-height:1.2 !important;
}

/* mobile: stack neatly */
@media (max-width: 680px){
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
    grid-template-columns: 1fr !important;
  }
}
/* === My Account — Addresses: keep the two cards the same height === */
.woocommerce-account .woocommerce-MyAccount-content .addresses{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;                 /* makes both items fill the row height */
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address{
  background: #141310;
  border: 1px solid var(--l12-line);
  border-radius: 12px;
  padding: 18px;
  height: 100%;                         /* stretch to the track height */
  display: flex;                        /* keeps content tidy inside */
  flex-direction: column;
  justify-content: space-between;
  min-height: 190px;                    /* consistent minimum */
}

/* header row inside each card */
.woocommerce-account .woocommerce-MyAccount-content .addresses .title{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 10px;
}

/* === My Account — Left menu: kill any white background, keep it dark === */
.woocommerce-account nav.woocommerce-MyAccount-navigation{
  background: #0f0e0d !important;
  border: 1px solid var(--l12-line) !important;
  box-shadow: none !important;
}

.woocommerce-account nav.woocommerce-MyAccount-navigation::before,
.woocommerce-account nav.woocommerce-MyAccount-navigation::after{
  content: none !important;             /* some themes draw white halos here */
}

.woocommerce-account nav.woocommerce-MyAccount-navigation ul{
  background: transparent !important;   /* remove white list background */
}

.woocommerce-account nav.woocommerce-MyAccount-navigation li{
  background: transparent !important;   /* ensure no white behind items */
}

.woocommerce-account nav.woocommerce-MyAccount-navigation li a{
  background: #151311 !important;
  border: 1px solid var(--l12-line) !important;
}
/* ----------------------------------------
   Mobile hero layout
---------------------------------------- */
@media (max-width: 768px) {

  .l12-hero {
    padding-top: 72px;       /* room below header */
    padding-bottom: 32px;
  }

  .l12-hero-wrap {
    display: flex;
    flex-direction: column;  /* stack text over image */
    align-items: center;
    text-align: center;
    gap: 20px;
  }

  /* constrain the text width a bit so it’s readable */
  .l12-hero-wrap > div:first-child {
    max-width: 520px;
    margin: 0 auto;
  }

  .l12-hero-cta {
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
  }

  .l12-hero-card {
    width: 100%;
    max-width: 540px;
  }

  .l12-hero-card img {
    width: 100%;
    height: auto;
    display: block;
  }
}
/* ----------------------------------------
   Mobile footer layout
---------------------------------------- */
@media (max-width: 768px) {

  .l12-footer {
    padding-top: 32px;
    padding-bottom: 24px;
  }

  .l12-foot-grid {
    display: grid;
    grid-template-columns: 1fr;   /* single column */
    gap: 24px;
    text-align: center;
  }

  .l12-foot {
    margin: 0 auto;
  }

  .l12-foot p {
    margin-left: auto;
    margin-right: auto;
  }

  .l12-foot ul {
    margin-left: auto;
    margin-right: auto;
    padding-left: 0;
    list-style: none;
  }

  .l12-foot ul li {
    margin: 2px 0;
  }

  /* social + payment icons centered */
  .l12-foot div[style*="display:flex"] {
    justify-content: center;
  }

  .l12-copy {
    padding-top: 16px;
    border-top: 1px solid var(--l12-line);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    text-align: center;
  }
}
/* -------------------------------------------------
   WooCommerce My Account layout – desktop base
------------------------------------------------- */

.woocommerce-account .woocommerce {
  display: flex;
  align-items: flex-start;
  gap: 32px;
  max-width: 100%;
  overflow-x: hidden;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
  flex: 0 0 260px;
  max-width: 260px;
}

.woocommerce-account .woocommerce-MyAccount-content {
  flex: 1;
  min-width: 0;           /* prevents horizontal overflow */
  box-sizing: border-box;
}

/* Remove the white border around the navigation block */

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  border: none !important;
  box-shadow: none;
}

/* -------------------------------------------------
   Mobile: show nav, stack, and prevent cut-off
------------------------------------------------- */

@media (max-width: 768px) {

  .woocommerce-account .woocommerce {
    flex-direction: column;
    gap: 20px;
  }

  /* make sure the nav is visible on mobile */
  .woocommerce-account .woocommerce-MyAccount-navigation {
    display: block !important;
    width: 100%;
    max-width: 100%;
  }

  .woocommerce-account .woocommerce-MyAccount-content {
    width: 100%;
  }

  /* center the nav buttons a bit on small screens */
  .woocommerce-account .woocommerce-MyAccount-navigation ul {
    padding-left: 0;
    margin: 0 auto;
    list-style: none;
  }
}
/* ===========================
   WooCommerce account + login
   — mobile fixes
   =========================== */

@media (max-width: 768px) {

  /* 1. Make the whole account wrapper a simple block layout,
        remove any flex/grid that might push nav off-screen. */
  .woocommerce-account .woocommerce {
    display: block !important;
    max-width: 100%;
    padding: 0 16px;
    box-sizing: border-box;
    overflow-x: visible !important;
  }

  /* 2. Navigation: force it to be full-width, visible, stacked on top. */
  .woocommerce-account .woocommerce-MyAccount-navigation {
    float: none !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 20px 0;
  }

  .woocommerce-account .woocommerce-MyAccount-navigation ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }

  /* 3. Content: make sure it cannot be wider than the viewport. */
  .woocommerce-account .woocommerce-MyAccount-content {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  .woocommerce-account .woocommerce-MyAccount-content > * {
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
  }

  /* 4. Login / register / coupon forms: also prevent cut-off. */
  .woocommerce form.login,
  .woocommerce form.register,
  .woocommerce form.checkout_coupon {
    max-width: 100% !important;
    width: 100% !important;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 0 0 24px 0;
  }
}

/* Remove any remaining border/shadow around the account navigation */
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  border: none !important;
  box-shadow: none !important;
}
/* =======================================
   FIX: My Account below 900px
   - remove 2-col grid placement
   - force nav + content stacked
   - prevent horizontal cut-off
   ======================================= */
@media (max-width: 899px){

  /* Keep the wrapper as a single column grid (or block), but sane */
  body.logged-in.woocommerce-account #av-primary-content > .woocommerce{
    display: block !important;          /* simplest: stack */
    width: 94vw !important;
    max-width: 94vw !important;
    margin: 20px auto 32px !important;
    padding: 0 14px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  /* Force nav visible and full width */
  body.logged-in.woocommerce-account #av-primary-content > .woocommerce
  .woocommerce-MyAccount-navigation{
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 16px 0 !important;
    float: none !important;
  }

  /* Kill the grid-column forcing that breaks in 1-col layouts */
  .woocommerce-account nav.woocommerce-MyAccount-navigation{
    grid-column: auto !important;
    grid-row: auto !important;
  }
  .woocommerce-account div.woocommerce-MyAccount-content{
    grid-column: auto !important;
    grid-row: auto !important;
  }

  /* Content full width, no cut-off */
  body.logged-in.woocommerce-account #av-primary-content > .woocommerce
  .woocommerce-MyAccount-content{
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }
}
@media (max-width: 899px){
  body.woocommerce-account:not(.logged-in) .woocommerce{
    width: 94vw !important;
    max-width: 94vw !important;
    padding: 0 14px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  body.woocommerce-account:not(.logged-in) .woocommerce form.login,
  body.woocommerce-account:not(.logged-in) .woocommerce form.register{
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
}
/* =======================================
   FINAL: Center + equal padding (Account + Login)
   ======================================= */
@media (max-width: 900px){

  /* Shared: keep the Woo wrapper centered with equal gutters */
  body.woocommerce-account #av-primary-content{
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  /* Logged-in My Account wrapper */
  body.logged-in.woocommerce-account #av-primary-content > .woocommerce{
    width: min(640px, calc(100vw - 32px)) !important; /* equal 16px gutters */
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  /* Logged-out (Login/Register) wrapper */
  body.woocommerce-account:not(.logged-in) #av-primary-content > .woocommerce{
    width: min(640px, calc(100vw - 32px)) !important; /* equal 16px gutters */
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  /* Ensure inner panels cannot force overflow */
  .woocommerce-account .woocommerce-MyAccount-navigation,
  .woocommerce-account .woocommerce-MyAccount-content,
  .woocommerce-account form.login,
  .woocommerce-account form.register{
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  /* If any parent theme adds left margin/padding to Woo wrappers, kill it */
  body.woocommerce-account .woocommerce,
  body.woocommerce-account .woocommerce-page .woocommerce{
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
/* =======================================
   MY ACCOUNT: Addresses + Account details fixes
   ======================================= */

/* 1) Address page headings: responsive sizing + prevent weird wrapping */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header.title h3,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address .woocommerce-column__title{
  font-size: clamp(20px, 4.6vw, 34px) !important;
  line-height: 1.05 !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  letter-spacing: 0 !important;
}

/* If the theme is forcing very narrow titles, give them room */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header.title h3{
  max-width: 70% !important;
}

/* 2) Addresses cards: side-by-side on larger screens, stacked on small */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 24px !important;
}

@media (max-width: 720px){
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
    grid-template-columns: 1fr !important;   /* stack */
  }

  /* let heading use full width when stacked */
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header.title h3{
    max-width: 100% !important;
  }
}

/* 3) Account details: make the helper/description text readable */
.woocommerce-account .woocommerce-MyAccount-content em,
.woocommerce-account .woocommerce-MyAccount-content small,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-form-row span.description,
.woocommerce-account .woocommerce-MyAccount-content .description,
.woocommerce-account .woocommerce-MyAccount-content p.form-row span em{
  color: var(--l12-ink-2) !important;   /* muted white */
  opacity: 1 !important;
}

/* If theme is setting a link-like blue on that helper text */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-form-row span.description a{
  color: var(--l12-accent) !important;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header.title h3{
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  transform: none !important;
}
/* =======================================
   ADDRESSES PAGE: FIX WRAPPING + STACKING
   (paste at very bottom)
   ======================================= */

/* A) Stop "Billing address" from breaking into stacked letters */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address header.title h3,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address .woocommerce-column__title{
  font-size: clamp(18px, 3.2vw, 28px) !important; /* smaller than before */
  line-height: 1.1 !important;
  white-space: nowrap !important;      /* keep "Billing address" on one line */
  overflow: hidden !important;
  text-overflow: ellipsis !important;  /* if it ever gets too tight */
  max-width: none !important;
  width: auto !important;
}

/* Ensure the title row can actually give the h3 space */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address header.title{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  flex-wrap: wrap !important;          /* button can drop below if needed */
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address header.title h3{
  flex: 1 1 auto !important;           /* take remaining space */
  min-width: 180px !important;         /* prevents ultra-narrow column */
}

/* B) Keep 2 columns at ~790 widths, but allow stacking at small widths */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 24px !important;
}

/* C) IMPORTANT: remove the "force to column 2" rules on small screens */
@media (max-width: 520px){

  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses{
    grid-template-columns: 1fr !important; /* stack */
  }

  /* undo earlier pinned placement that prevents stacking */
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .u-column1,
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .col-1,
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .u-column2,
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .col-2{
    grid-column: auto !important;
    grid-row: auto !important;
  }

  /* on very small screens, allow heading to wrap (two lines max) */
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses.addresses .woocommerce-Address header.title h3{
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    min-width: 0 !important;
  }
}
/* =======================================
   ICON BUTTON ALIGNMENT + SEARCH INPUT COLORS
   ======================================= */

/* 1) Any icon button (including close "X") should truly center its content */
.l12-iconbtn,
.l12-iconbtn *{
  box-sizing: border-box;
}

.l12-iconbtn{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
}

/* If the "X" is text (not SVG), center it */
.l12-iconbtn{
  line-height: 1 !important;
  text-align: center !important;
}

/* If the "X" is an SVG, ensure it has no weird margins */
.l12-iconbtn svg{
  display: block !important;
  margin: 0 !important;
}

/* 2) Search overlay input: keep text readable in all states */
.l12-search .search-field{
  background: #141310 !important;
  color: var(--l12-ink) !important;         /* typed text */
  caret-color: var(--l12-ink) !important;   /* caret */
}

/* Placeholder color */
.l12-search .search-field::placeholder{
  color: var(--l12-ink-2) !important;
  opacity: 1 !important;
}

/* Prevent browser autofill from turning it white/yellow and changing text color */
.l12-search .search-field:-webkit-autofill,
.l12-search .search-field:-webkit-autofill:hover,
.l12-search .search-field:-webkit-autofill:focus{
  -webkit-text-fill-color: var(--l12-ink) !important;
  box-shadow: 0 0 0px 1000px #141310 inset !important;
  transition: background-color 9999s ease-out 0s;
}

/* 3) Header search icon alignment (force exact centering) */
#l12-search-open{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

#l12-search-open svg{
  margin: 0 !important;
  transform: none !important;
}

/* =======================================
   PRODUCT PAGE (Single Product) — Luxury polish
   ======================================= */
.single-product .woocommerce{
  color: var(--l12-ink);
}

/* Layout breathing room */
.single-product div.product{
  width: min(1200px, calc(100vw - 44px));
  margin: 34px auto 60px;
}

/* Image + summary cards */
.single-product div.product .woocommerce-product-gallery,
.single-product div.product .summary{
  background: transparent;
}

.single-product div.product .woocommerce-product-gallery .woocommerce-product-gallery__wrapper{
  border-radius: var(--l12-radius-lg);
  overflow: hidden;
  border: 1px solid var(--l12-line);
  box-shadow: var(--l12-shadow);
}

.single-product div.product .summary{
  background: #141310;
  border: 1px solid var(--l12-line);
  border-radius: var(--l12-radius-lg);
  padding: 22px;
  box-shadow: var(--l12-shadow);
}

/* Title/price readability */
.single-product .product_title{
  font-family: "Playfair Display", serif;
  letter-spacing: .2px;
  margin: 0 0 10px;
}
.single-product p.price,
.single-product span.price{
  color: var(--l12-accent);
  font-weight: 800;
  font-size: 1.15rem;
}

/* Short description */
.single-product .woocommerce-product-details__short-description{
  color: var(--l12-ink-2);
  line-height: 1.65;
}

/* Variations (dropdown row) */
.variations{
  width: 100%;
  border-collapse: separate !important;
  border-spacing: 0 12px !important;
}
.variations td,
.variations th{
  padding: 0 !important;
}
.variations label{
  display: inline-block;
  color: var(--l12-ink);
  font-weight: 700;
  margin-bottom: 6px;
}
.variations select{
  width: 100% !important;
  padding: 12px 14px !important;
  border-radius: 12px !important;
  border: 1px solid var(--l12-line) !important;
  background: #0f0e0d !important;
  color: var(--l12-ink) !important;
  min-height: 46px;
}

/* “Clear” link + variation message */
.woocommerce-variation-description,
.woocommerce-variation-availability{
  color: var(--l12-ink-2);
}
a.reset_variations{
  color: var(--l12-accent) !important;
  font-weight: 700;
}

/* Quantity + add to cart row */
.single-product form.cart{
  margin-top: 16px;
}
.single-product form.cart .quantity input.qty{
  width: 88px !important;
  padding: 10px 10px !important;
  border-radius: 12px !important;
  border: 1px solid var(--l12-line) !important;
  background: #0f0e0d !important;
  color: var(--l12-ink) !important;
}
.single-product form.cart button.single_add_to_cart_button{
  border-radius: 999px !important;
  border: 1px solid rgba(0,0,0,.15) !important;
  background: linear-gradient(180deg, var(--l12-accent), var(--l12-accent-2)) !important;
  color: #1a1206 !important;
  font-weight: 900 !important;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .95rem 1.4rem !important;
  min-height: 48px;
}

/* Tabs -> make them look modern */
.woocommerce-tabs{
  margin-top: 28px;
  background: #141310;
  border: 1px solid var(--l12-line);
  border-radius: var(--l12-radius-lg);
  box-shadow: var(--l12-shadow);
  overflow: hidden;
}
.woocommerce-tabs ul.tabs{
  margin: 0 !important;
  padding: 12px 12px 0 !important;
  border: 0 !important;
  background: transparent !important;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.woocommerce-tabs ul.tabs li{
  border: 0 !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
}
.woocommerce-tabs ul.tabs li a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  border: 1px solid var(--l12-line) !important;
  background: #151311 !important;
  color: var(--l12-ink-2) !important;
  font-weight: 800 !important;
}
.woocommerce-tabs ul.tabs li.active a{
  color: #1a1206 !important;
  background: linear-gradient(180deg, var(--l12-accent), var(--l12-accent-2)) !important;
  border-color: rgba(0,0,0,.15) !important;
}
.woocommerce-tabs .panel{
  margin: 0 !important;
  padding: 18px 18px 22px !important;
  color: var(--l12-ink-2);
}
.woocommerce-tabs .panel h2{
  color: var(--l12-ink);
  font-family: "Playfair Display", serif;
  margin-top: 0;
}

/* Additional information table (kill the white strip look) */
.woocommerce table.shop_attributes{
  width: 100% !important;
  border: 1px solid var(--l12-line) !important;
  border-radius: 14px;
  overflow: hidden;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  background: #0f0e0d;
}
.woocommerce table.shop_attributes th{
  background: #151311 !important;
  color: var(--l12-ink) !important;
  font-weight: 800;
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--l12-line) !important;
}
.woocommerce table.shop_attributes td{
  background: #0f0e0d !important;
  color: var(--l12-ink-2) !important;
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--l12-line) !important;
}
.woocommerce table.shop_attributes tr:last-child th,
.woocommerce table.shop_attributes tr:last-child td{
  border-bottom: 0 !important;
}

/* Mobile: stack image + summary nicely */
@media (max-width: 900px){
  .single-product div.product{
    width: min(680px, calc(100vw - 32px));
  }
  .single-product div.product .summary{
    padding: 18px;
  }
}
/* =========================================================
   PRODUCT VARIATIONS (dropdown) — dark UI + remove white lines
   Put at VERY BOTTOM of style.css
   ========================================================= */

/* 1) Kill the white table styling Woo uses in the variations area */
.woocommerce div.product form.cart .variations,
.woocommerce div.product form.cart .variations tbody,
.woocommerce div.product form.cart .variations tr,
.woocommerce div.product form.cart .variations th,
.woocommerce div.product form.cart .variations td{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Reduce odd separator lines around the variations block */
.woocommerce div.product form.cart .variations{
  border: 1px solid var(--l12-line) !important;
  border-radius: 14px !important;
  overflow: hidden !important;
}

/* 2) Make label + value cells match your dark card look */
.woocommerce div.product form.cart .variations th{
  color: var(--l12-ink) !important;
  font-weight: 800 !important;
  letter-spacing: .02em !important;
  padding: 16px 14px !important;
  width: 160px;
}

.woocommerce div.product form.cart .variations td{
  padding: 12px 14px !important;
  border-left: 1px solid var(--l12-line) !important;
}

/* 3) The actual select: force dark background + readable text */
.woocommerce div.product form.cart .variations select,
.woocommerce div.product form.cart .variations .value select,
.woocommerce div.product form.cart select{
  background: #0f0e0d !important;
  color: var(--l12-ink) !important;
  border: 1px solid var(--l12-line) !important;
  border-radius: 12px !important;
  padding: 12px 14px !important;
  height: auto !important;
  box-shadow: none !important;
  outline: none !important;
}

/* When focused, keep it dark (no white flash) */
.woocommerce div.product form.cart .variations select:focus{
  background: #0f0e0d !important;
  color: var(--l12-ink) !important;
  border-color: rgba(201,166,107,.55) !important;
  box-shadow: 0 0 0 2px rgba(201,166,107,.18) !important;
}

/* 4) Dropdown list items (browser-dependent, but helps where supported) */
.woocommerce div.product form.cart .variations select option{
  background: #0f0e0d !important;
  color: var(--l12-ink) !important;
}

/* 5) “Clear” link */
.woocommerce div.product form.cart .reset_variations{
  color: var(--l12-accent) !important;
  font-weight: 700 !important;
}
.woocommerce div.product form.cart .reset_variations:hover{
  color: var(--l12-accent-2) !important;
}

/* 6) Remove other random white rules inside product summary/tabs */
.woocommerce div.product .product_meta,
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .woocommerce-tabs .panel,
.woocommerce div.product .woocommerce-tabs ul.tabs:before,
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  border-color: var(--l12-line) !important;
}

/* If your theme outputs <hr> in product areas, make them subtle */
.woocommerce div.product hr,
.woocommerce div.product .hr,
.woocommerce div.product .separator{
  border-color: var(--l12-line) !important;
  opacity: .6 !important;
}
/* =======================================
   SINGLE PRODUCT — remove tab artifacts (dots/lines)
   ======================================= */

/* Kill default Woo tab bar borders */
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after,
.woocommerce div.product .woocommerce-tabs ul.tabs li a::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li a::after{
  content: none !important;
}

/* Remove focus outline “dots” on tabs/buttons (keep accessibility with a clean ring) */
.woocommerce div.product .woocommerce-tabs ul.tabs li a:focus,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:focus-visible,
.woocommerce div.product .woocommerce-tabs ul.tabs li a{
  outline: none !important;
  box-shadow: none !important;
}

/* Optional: if you want a nice consistent focus ring instead of dots */
.woocommerce a:focus-visible,
.woocommerce button:focus-visible,
.woocommerce input:focus-visible,
.woocommerce select:focus-visible,
.woocommerce textarea:focus-visible{
  outline: 2px solid var(--l12-accent) !important;
  outline-offset: 2px !important;
  box-shadow: none !important;
}
/* =======================================
   REVIEWS — remove weird strike/decoration
   ======================================= */

.woocommerce #reviews,
.woocommerce #reviews *{
  text-decoration: none !important;
}

.woocommerce #reviews .woocommerce-noreviews,
.woocommerce #reviews .comment-reply-title,
.woocommerce #reviews .comment-form-rating label{
  text-decoration: none !important;
}

/* =======================================
   PRODUCT ACCORDION (replaces tabs)
   ======================================= */
.l12-acc{
  width:min(1200px, 96vw);
  margin: 26px auto 0;
  background:#141310;
  border:1px solid var(--l12-line);
  border-radius:18px;
  overflow:hidden;
  box-shadow: var(--l12-shadow);
}

.l12-acc-item + .l12-acc-item{ border-top:1px solid var(--l12-line); }

.l12-acc-btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 18px;
  background:linear-gradient(180deg,#171512,#141310);
  color:var(--l12-ink);
  border:0;
  cursor:pointer;
  text-align:left;
}

.l12-acc-title{
  font-family:"Playfair Display", Georgia, serif;
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 800;
}

.l12-acc-icon{
  transition: transform .18s ease;
  opacity:.9;
}
.l12-acc-btn[aria-expanded="true"] .l12-acc-icon{ transform: rotate(180deg); }

.l12-acc-panel{
  padding: 18px;
  color: var(--l12-ink-2);
}

.l12-acc-panel p, .l12-acc-panel li{ color: var(--l12-ink-2); }
/* =======================================
   PRODUCT ACCORDION — remove duplicate inner titles
   (Keeps the clickable accordion header only)
   ======================================= */

/* Description tab usually prints an H2 "Description" */
.l12-acc .l12-acc-panel > h2:first-child{
  display:none !important;
}

/* Additional information / Reviews often print H2/H3 titles */
.l12-acc .l12-acc-panel .woocommerce-Reviews-title,
.l12-acc .l12-acc-panel #tab-description > h2,
.l12-acc .l12-acc-panel #tab-additional_information > h2{
  display:none !important;
}

/* Some themes wrap the tab content in .woocommerce-Tabs-panel */
.l12-acc .l12-acc-panel.woocommerce-Tabs-panel > h2:first-child,
.l12-acc .l12-acc-panel.woocommerce-Tabs-panel > h3:first-child{
  display:none !important;
}

/* Tighten top spacing since the title is gone */
.l12-acc .l12-acc-panel > :first-child{
  margin-top:0 !important;
}
/* =======================================
   PRODUCT REVIEWS — remove orange strike/underline line
   ======================================= */

/* Kill any inherited underline/line-through that shows as an orange line */
.woocommerce #review_form,
.woocommerce #review_form *,
.woocommerce .woocommerce-Reviews,
.woocommerce .woocommerce-Reviews *{
  text-decoration: none !important;
  text-decoration-thickness: initial !important;
  text-underline-offset: initial !important;
  text-decoration-color: currentColor !important;
}

/* Also remove any pseudo-element line some themes add */
.woocommerce #review_form p::before,
.woocommerce #review_form p::after,
.woocommerce .woocommerce-Reviews p::before,
.woocommerce .woocommerce-Reviews p::after{
  content: none !important;
  display: none !important;
}
.woocommerce .woocommerce-Reviews-title,
.woocommerce .comment-respond p,
.woocommerce #review_form_wrapper p{
  text-decoration: none !important;
}
/* =======================================
   REVIEWS: remove orange line + force stars gold (hover/focus/selected)
   ======================================= */

/* 1) Remove any orange rule line coming from borders/after-elements on rating row */
.woocommerce #reviews .comment-form-rating,
.woocommerce #reviews .comment-form-rating label,
.woocommerce #review_form .comment-form-rating,
.woocommerce #review_form .comment-form-rating label{
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  text-decoration: none !important;
}

.woocommerce #reviews .comment-form-rating::before,
.woocommerce #reviews .comment-form-rating::after,
.woocommerce #reviews .comment-form-rating label::before,
.woocommerce #reviews .comment-form-rating label::after,
.woocommerce #review_form .comment-form-rating::before,
.woocommerce #review_form .comment-form-rating::after,
.woocommerce #review_form .comment-form-rating label::before,
.woocommerce #review_form .comment-form-rating label::after{
  content: none !important;
  display: none !important;
}

/* 2) Some themes add a "rule" via background-image gradient on form rows */
.woocommerce #reviews .comment-form-rating,
.woocommerce #review_form .comment-form-rating,
.woocommerce #reviews .comment-respond p,
.woocommerce #review_form .comment-respond p{
  background-image: none !important;
}

/* 3) Stars: make every state use your gold, not bootstrap blue */
.woocommerce p.stars a,
.woocommerce p.stars a:visited{
  color: var(--l12-accent) !important;
  text-decoration: none !important;
}

.woocommerce p.stars a:hover,
.woocommerce p.stars a:focus,
.woocommerce p.stars a:active{
  color: var(--l12-accent) !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Selected/hovered star states (Woo uses these) */
.woocommerce p.stars.selected a,
.woocommerce p.stars.selected a:hover,
.woocommerce p.stars:hover a{
  color: var(--l12-accent) !important;
}

/* If theme sets focus ring on links, keep it subtle but not blue */
.woocommerce p.stars a:focus-visible{
  outline: 2px solid rgba(201,166,107,.45) !important;
  outline-offset: 2px !important;
}
/* =======================================
   REVIEWS: kill orange "rule" on Your rating
   ======================================= */

/* The row that contains "Your rating" + stars */
.woocommerce #reviews p.comment-form-rating,
.woocommerce #review_form p.comment-form-rating,
.woocommerce #reviews .comment-form-rating,
.woocommerce #review_form .comment-form-rating{
  border: 0 !important;
  border-bottom: 0 !important;
  box-shadow: none !important;              /* removes inset underline rules */
  background: transparent !important;
  background-image: none !important;
  text-decoration: none !important;
}

/* The actual "Your rating" label */
.woocommerce #reviews p.comment-form-rating > label,
.woocommerce #review_form p.comment-form-rating > label,
.woocommerce #reviews .comment-form-rating > label,
.woocommerce #review_form .comment-form-rating > label{
  border: 0 !important;
  border-bottom: 0 !important;
  box-shadow: none !important;              /* common culprit */
  background: transparent !important;
  background-image: none !important;
  text-decoration: none !important;
  padding-bottom: 0 !important;
}

/* Nuclear option: some themes draw the rule via hr/after on p.form-row */
.woocommerce #reviews p.comment-form-rating::before,
.woocommerce #reviews p.comment-form-rating::after,
.woocommerce #review_form p.comment-form-rating::before,
.woocommerce #review_form p.comment-form-rating::after{
  content: none !important;
  display: none !important;
}
/* =======================================
   REVIEWS: remove orange rule from reply title (::after)
   ======================================= */

.woocommerce #reviews .comment-reply-title::after,
.woocommerce #reviews span.comment-reply-title::after,
.woocommerce #review_form_wrapper .comment-reply-title::after,
.woocommerce #review_form_wrapper span.comment-reply-title::after,
.woocommerce .comment-respond .comment-reply-title::after,
.woocommerce .comment-respond span.comment-reply-title::after{
  content: none !important;
  display: none !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}
/* =======================================
   PRODUCT ACCORDION — mobile gutters (equal L/R)
   ======================================= */
@media (max-width: 680px){
  .l12-acc{
    width: calc(100vw - 32px) !important; /* 16px left + 16px right */
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* safety: prevent inner content from touching edges */
  .l12-acc-btn,
  .l12-acc-panel{
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}
/* =========================================================
   SHOP / HOMEPAGE PRODUCT CARDS
   - Remove bulky white title box
   - Keep rounded container clean (no visible white border)
   - Hide "Select options" button (and all loop buttons)
   - Show title/price only on hover (desktop)
   - On mobile (no hover), show title/price neatly BELOW image
   ========================================================= */

/* Card shell: no visible border line, keep luxury shadow */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{
  position: relative !important;
  overflow: hidden !important;
  border: 0 !important;                     /* removes the faint white outline */
  background: transparent !important;       /* prevents any theme white panels */
  box-shadow: 0 14px 36px rgba(0,0,0,.40) !important;
  border-radius: 18px !important;
  padding: 0 !important;
}

/* Make the entire image area clipped to rounded corners */
.woocommerce ul.products li.product a,
.woocommerce-page ul.products li.product a{
  text-decoration: none !important;
}

.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img{
  display: block !important;
  width: 100% !important;
  border-radius: 18px !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* Hide ALL loop buttons (Select options / Add to cart / etc.) */
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product a.button,
.woocommerce-page ul.products li.product .button{
  display: none !important;
}

/* Title + price base: convert into a subtle overlay (desktop hover) */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title{
  position: absolute !important;
  left: 14px !important;
  right: 92px !important; /* leaves room for price pill on the right */
  bottom: 14px !important;

  margin: 0 !important;
  padding: 10px 12px !important;

  background: rgba(11,10,9,.72) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  border: 1px solid var(--l12-line) !important;
  border-radius: 14px !important;

  color: var(--l12-ink) !important;
  font-family: "Playfair Display", Georgia, serif !important;
  font-weight: 800 !important;
  font-size: 1.02rem !important;
  line-height: 1.2 !important;

  /* clamp to 2 lines */
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;

  /* hidden until hover */
  opacity: 0 !important;
  transform: translateY(10px) !important;
  transition: opacity .18s ease, transform .18s ease !important;
  pointer-events: none !important;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price{
  position: absolute !important;
  right: 14px !important;
  bottom: 14px !important;

  margin: 0 !important;
  padding: 10px 12px !important;

  background: rgba(11,10,9,.72) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  border: 1px solid var(--l12-line) !important;
  border-radius: 14px !important;

  color: var(--l12-accent) !important;
  font-weight: 900 !important;
  font-size: 1.02rem !important;
  line-height: 1.1 !important;

  opacity: 0 !important;
  transform: translateY(10px) !important;
  transition: opacity .18s ease, transform .18s ease !important;
  pointer-events: none !important;
}

/* Show title + price ONLY on hover (desktop) */
.woocommerce ul.products li.product:hover .woocommerce-loop-product__title,
.woocommerce ul.products li.product:hover .price,
.woocommerce-page ul.products li.product:hover .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product:hover .price{
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* On touch devices (no hover): show neatly BELOW the image (no bulky overlay box) */
@media (hover: none) and (pointer: coarse){
  .woocommerce ul.products li.product,
  .woocommerce-page ul.products li.product{
    overflow: visible !important; /* allow below-content layout */
    background: transparent !important;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title,
  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .price{
    position: static !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;

    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;

    padding: 8px 2px 0 !important;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title{
    color: var(--l12-ink) !important;
    font-size: 1.05rem !important;
    -webkit-line-clamp: 2 !important;
  }

  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .price{
    color: var(--l12-accent) !important;
    font-size: 1rem !important;
    padding-top: 4px !important;
  }
}
/* =========================================================
   FINAL: Shop card fixes
   - remove orange hover bar
   - switch white card area to charcoal
   (paste at VERY BOTTOM)
   ========================================================= */

/* 1) Kill the orange bar/stripe that appears on hover (theme pseudo-elements) */
.woocommerce ul.products li.product::before,
.woocommerce ul.products li.product::after,
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link::before,
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link::after,
.woocommerce ul.products li.product a.woocommerce-loop-product__link::before,
.woocommerce ul.products li.product a.woocommerce-loop-product__link::after,
.woocommerce-page ul.products li.product::before,
.woocommerce-page ul.products li.product::after,
.woocommerce-page ul.products li.product a.woocommerce-LoopProduct-link::before,
.woocommerce-page ul.products li.product a.woocommerce-LoopProduct-link::after,
.woocommerce-page ul.products li.product a.woocommerce-loop-product__link::before,
.woocommerce-page ul.products li.product a.woocommerce-loop-product__link::after{
  content: none !important;
  display: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* Also remove any top/bottom borders that might look like a bar on hover */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
.woocommerce ul.products li.product a.woocommerce-loop-product__link,
.woocommerce-page ul.products li.product a.woocommerce-LoopProduct-link,
.woocommerce-page ul.products li.product a.woocommerce-loop-product__link{
  border: 0 !important;
  box-shadow: none !important;
}

/* 2) Replace the bright white card background with charcoal */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{
  background: #141310 !important; /* charcoal */
  border: 1px solid var(--l12-line) !important;
}

/* If your theme is putting white on inner wrappers, force charcoal there too */
.woocommerce ul.products li.product .inner_product,
.woocommerce ul.products li.product .product-inner,
.woocommerce ul.products li.product .product-wrap,
.woocommerce-page ul.products li.product .inner_product,
.woocommerce-page ul.products li.product .product-inner,
.woocommerce-page ul.products li.product .product-wrap{
  background: #141310 !important;
}
/* =========================================================
   FINAL OVERRIDES: shop card orange bar + white title block
   - Kills .product-action (orange bar)
   - Makes the info area charcoal (not white)
   - Keeps title/price hidden until hover on desktop
   ========================================================= */

/* 1) Kill the orange action bar entirely */
.woocommerce ul.products li.product .product-action,
.woocommerce-page ul.products li.product .product-action{
  display: none !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

/* 2) Some themes render the orange as a pseudo element */
.woocommerce ul.products li.product .product-action::before,
.woocommerce ul.products li.product .product-action::after,
.woocommerce-page ul.products li.product .product-action::before,
.woocommerce-page ul.products li.product .product-action::after{
  content: none !important;
  display: none !important;
}

/* 3) Force the “white block” under the image to charcoal */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price{
  background: #1a1815 !important;              /* charcoal */
  border-color: rgba(255,255,255,.08) !important;
}

/* 4) If the theme wraps title/price in a white container, darken it */
.woocommerce ul.products li.product .product-details,
.woocommerce ul.products li.product .product-content,
.woocommerce ul.products li.product .product-info,
.woocommerce ul.products li.product .product-inner,
.woocommerce ul.products li.product .entry-wrap,
.woocommerce ul.products li.product .entry-content,
.woocommerce-page ul.products li.product .product-details,
.woocommerce-page ul.products li.product .product-content,
.woocommerce-page ul.products li.product .product-info,
.woocommerce-page ul.products li.product .product-inner,
.woocommerce-page ul.products li.product .entry-wrap,
.woocommerce-page ul.products li.product .entry-content{
  background: transparent !important;
}

/* 5) Ensure nothing “button-like” flashes in that area */
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.product_type_variable,
.woocommerce ul.products li.product a.product_type_grouped,
.woocommerce ul.products li.product a.product_type_external,
.woocommerce-page ul.products li.product a.add_to_cart_button,
.woocommerce-page ul.products li.product a.product_type_variable,
.woocommerce-page ul.products li.product a.product_type_grouped,
.woocommerce-page ul.products li.product a.product_type_external{
  display: none !important;
}

/* 6) Desktop: keep hidden until hover (redundant safety) */
@media (hover: hover) and (pointer: fine){
  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .price{
    opacity: 0 !important;
    transform: translateY(10px) !important;
  }

  .woocommerce ul.products li.product:hover .woocommerce-loop-product__title,
  .woocommerce ul.products li.product:hover .price,
  .woocommerce-page ul.products li.product:hover .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product:hover .price{
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}
/* =========================================================
   SHOP CARD: price top-right + darker info panel
   Paste at VERY BOTTOM of style.css
   ========================================================= */

/* Make the overlay panels darker (not white/bright) */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price{
  background: rgba(20, 18, 16, .92) !important; /* darker charcoal */
  border-color: rgba(255,255,255,.10) !important;
}

/* Move price pill to TOP RIGHT (desktop hover overlay) */
@media (hover: hover) and (pointer: fine){
  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .price{
    top: 14px !important;
    right: 14px !important;
    bottom: auto !important;
  }

  /* Keep title in bottom-left (leave room if you ever want) */
  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title{
    bottom: 14px !important;
    left: 14px !important;
    right: 14px !important; /* no need to reserve price space now */
  }
}

/* If a theme wrapper is still white, force common containers darker */
.woocommerce ul.products li.product .product-details,
.woocommerce ul.products li.product .product-content,
.woocommerce ul.products li.product .product-info,
.woocommerce ul.products li.product .product-inner,
.woocommerce ul.products li.product .entry-wrap,
.woocommerce ul.products li.product .entry-content,
.woocommerce-page ul.products li.product .product-details,
.woocommerce-page ul.products li.product .product-content,
.woocommerce-page ul.products li.product .product-info,
.woocommerce-page ul.products li.product .product-inner,
.woocommerce-page ul.products li.product .entry-wrap,
.woocommerce-page ul.products li.product .entry-content{
  background: #141210 !important; /* hard override */
}

/* Mobile/touch: keep your “below image” layout but make it darker too */
@media (hover: none) and (pointer: coarse){
  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title,
  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .price{
    background: transparent !important; /* text below image, no panel */
  }
}
/* =========================================================
   SHOP CARD: remove any white edges/borders/lines
   Paste at VERY BOTTOM of style.css
   ========================================================= */

/* Kill any border/outline/shadow that can read as a white edge */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product *,
.woocommerce-page ul.products li.product *{
  outline: none !important;
}

/* Card wrapper: no border, no inset highlight */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{
  border: 0 !important;
  box-shadow: 0 14px 36px rgba(0,0,0,.40) !important;
  background: transparent !important;
}

/* Image itself (some themes add borders to img or the link wrapper) */
.woocommerce ul.products li.product a,
.woocommerce-page ul.products li.product a,
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img{
  border: 0 !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Common “inner” wrappers that often have a 1px light border */
.woocommerce ul.products li.product .product-inner,
.woocommerce ul.products li.product .product-content,
.woocommerce ul.products li.product .product-details,
.woocommerce ul.products li.product .product-info,
.woocommerce ul.products li.product .entry-wrap,
.woocommerce ul.products li.product .entry-content,
.woocommerce ul.products li.product .thumbnail,
.woocommerce-page ul.products li.product .product-inner,
.woocommerce-page ul.products li.product .product-content,
.woocommerce-page ul.products li.product .product-details,
.woocommerce-page ul.products li.product .product-info,
.woocommerce-page ul.products li.product .entry-wrap,
.woocommerce-page ul.products li.product .entry-content,
.woocommerce-page ul.products li.product .thumbnail{
  border: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  background: transparent !important;
}

/* Your title/price overlay panels: remove their border if it reads as a white edge */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price{
  border: 0 !important;
  box-shadow: none !important;
}

/* If there’s still a faint “stroke”, it’s often from a pseudo-element */
.woocommerce ul.products li.product::before,
.woocommerce ul.products li.product::after,
.woocommerce-page ul.products li.product::before,
.woocommerce-page ul.products li.product::after,
.woocommerce ul.products li.product a::before,
.woocommerce ul.products li.product a::after,
.woocommerce-page ul.products li.product a::before,
.woocommerce-page ul.products li.product a::after{
  content: none !important;
  display: none !important;
}
/* ===== Header polish: menu markers + type size ===== */

/* Remove bullets/dots anywhere in the nav menu */
.l12-menu,
.l12-menu ul{
  list-style: none !important;
  margin: 0;
  padding: 0;
}
.l12-menu li{
  list-style: none !important;
  margin: 0;
  padding: 0;
}
/* Defensive: if dots are injected as separators */
.l12-menu li::marker{ content: "" !important; }
.l12-menu li::before{ content: none !important; }
.l12-menu li + li::before{ content: none !important; }

/* Layout + spacing for a cleaner “pro” menu */
.l12-menu{
  display: flex;
  align-items: center;
  gap: 26px;              /* spacing between links */
}

/* Bigger, more premium nav text */
.l12-menu a{
  font-size: 16px;        /* bump up */
  line-height: 1;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-decoration: none;
}

/* Professional hover/active treatment */
.l12-menu a:hover{
  opacity: 0.9;
}
.l12-menu .current-menu-item > a,
.l12-menu .current_page_item > a{
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-thickness: 2px;
}

/* Header itself: less bare/empty, more structure */
#site-header.l12-header{
  border-bottom: 1px solid var(--l12-line);
  background: rgba(0,0,0,0.55);        /* subtle depth */
  backdrop-filter: blur(10px);
}
.l12-nav{
  min-height: 76px;                    /* more intentional height */
}

/* Brand spacing/typography */
.l12-wordmark{
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.03em;
  opacity: 0.95;
}

/* Slightly larger action icons so header feels “filled” */
.l12-actions .l12-iconbtn{
  width: 40px;
  height: 40px;
}
/* Footer menus: remove list bullets/dots everywhere */
.l12-foot-menu,
.l12-foot-menu ul{
  list-style: none !important;
  margin: 0;
  padding: 0;
}

.l12-foot-menu li{
  list-style: none !important;
  margin: 0;
  padding: 0;
}

/* Defensive: some themes use markers/pseudo-elements for bullets */
.l12-foot-menu li::marker{ content: "" !important; }
.l12-foot-menu li::before{ content: none !important; }
.l12-foot-menu li + li::before{ content: none !important; }
/* =========================
   MOBILE LAYOUT FIXES
   ========================= */
@media (max-width: 900px){

  /* Global side padding so content isn't on the edge */
  .l12-container,
  .l12-contact-wrap,
  .l12-shop-wrap{
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  /* Slightly more breathing room below header */
  #primary-content{
    padding-top: 10px;
  }

  /* HERO: put image first on mobile (fills the gap under header) */
  .l12-hero-wrap{
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
  }
  /* Ensure the image column becomes first */
  .l12-hero-wrap .l12-hero-right{
    order: -1 !important;
    width: 100% !important;
  }
  .l12-hero-wrap > div:not(.l12-hero-right){
    order: 0 !important;
    width: 100% !important;
  }

  /* Make hero image full-width and consistent */
  .l12-hero-card img{
    width: 100% !important;
    height: auto !important;
    display: block !important;
  }

  /* Reduce top padding so content starts sooner */
  .l12-hero{
    padding-top: 22px !important;
    padding-bottom: 28px !important;
  }

  /* -------------------------
     BELT SIZING MOBILE FIX
     ------------------------- */

  /* Avoid overly centered/awkward layout */
  .l12-hero--belt-home .l12-hero-wrap{
    gap: 16px !important;
  }

  /* Improve typography spacing */
  .l12-hero--belt-home h2{
    line-height: 1.08 !important;
    margin-bottom: 10px !important;
  }
  .l12-hero--belt-home p{
    margin-top: 8px !important;
    margin-bottom: 10px !important;
  }

  /* Make list readable on small screens */
  .l12-hero--belt-home ol{
    margin: 10px 0 0 20px !important;
    padding: 0 !important;
    text-align: left !important;
  }
  .l12-hero--belt-home ol li{
    margin: 8px 0 !important;
    line-height: 1.45 !important;
  }

  /* Make the "Quick rule" box fit nicely */
  .l12-hero--belt-home .l12-hero-wrap > div > div[style*="Quick rule of thumb"]{
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* The belt guide image: full width, no awkward crop */
  .l12-hero--belt-home .l12-hero-card img{
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    background: rgba(255,255,255,.02);
    border-radius: 16px;
  }
}
/* =========================
   MOBILE HERO + BELT FIXES
   Place this AFTER prior mobile CSS
   ========================= */
@media (max-width: 900px){

  /* --- Kill the big gap above the first hero section --- */
  #primary-content{ padding-top: 0 !important; margin-top: 0 !important; }
  .l12-hero--home{ padding-top: 14px !important; }
  .l12-hero--home .l12-container{ padding-top: 0 !important; }

  /* --- HERO: image first, text second, materials third (materials stays "where it was" under the image) --- */
  .l12-hero--home .l12-hero-wrap{
    display:flex !important;
    flex-direction:column !important;
    gap:16px !important;
  }

  /* Make the right column's children participate in the parent flow */
  .l12-hero--home .l12-hero-right{ display: contents !important; }

  /* Default everything to "middle" order */
  .l12-hero--home .l12-hero-wrap > *{ order: 2; }

  /* Image card FIRST */
  .l12-hero--home .l12-hero-card{
    order: 1 !important;
    margin-top: 0 !important;
  }

  /* Materials card LAST (it's the other direct child inside .l12-hero-right) */
  .l12-hero--home .l12-hero-right > div:not(.l12-hero-card){
    order: 3 !important;
    /* keep a little spacing like it had originally */
    margin-top: 14px !important;
  }

  /* Ensure image isn't being pushed down by any inherited spacing */
  .l12-hero--home .l12-hero-card img{
    display:block !important;
    width:100% !important;
    height:auto !important;
  }

  /* --- Global side padding so text doesn't hit the edge --- */
  .l12-container{ padding-left: 18px !important; padding-right: 18px !important; }

  /* =========================
     BELT SIZING: fix mobile list formatting
     ========================= */

  /* Keep headings centered, but make the list readable */
  .l12-hero--belt-home .eyebrow,
  .l12-hero--belt-home h2,
  .l12-hero--belt-home p{ text-align: center; }

  .l12-hero--belt-home ol{
    text-align:left !important;
    max-width: 34ch;
    margin: 12px auto 0 !important;
    padding-left: 1.25rem !important;
    list-style-position: outside !important;
  }
  .l12-hero--belt-home ol li{
    display:list-item !important;
    margin: 8px 0 !important;
    line-height: 1.45 !important;
  }

  /* Make the "Quick rule" box and tip feel consistent */
  .l12-hero--belt-home .l12-hero-wrap > div:first-child > div{
    max-width: 40ch;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Belt guide image: no weird crop on mobile */
  .l12-hero--belt-home .l12-hero-card img{
    width:100% !important;
    height:auto !important;
    object-fit: contain !important;
  }
}