/*
Theme Name: Nova Shop
Author: Nova Steels
Description: Premium Gates & Railings WooCommerce Theme
Version: 1.0.3
Text Domain: nova-shop
*/

:root{
  --bg:#070707;--bg2:#0c0c0c;--bg3:#111;
  --panel:rgba(255,255,255,.03);--panel2:rgba(255,255,255,.055);
  --line:rgba(255,255,255,.10);--line2:rgba(255,255,255,.07);
  --text:rgba(255,255,255,.92);--muted:rgba(255,255,255,.68);--dim:rgba(255,255,255,.50);
  --gold:#f5b301;--gold2:#ffcc3d;--gold3:rgba(245,179,1,.14);
  --shadow:0 20px 65px rgba(0,0,0,.60);
  --shadow2:0 8px 30px rgba(0,0,0,.40);
  --radius:16px;--radius2:22px;--radius3:28px;
  --container:1200px;
  --sticky-h:76px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Montserrat,system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
  min-height:100vh;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
.container{width:min(var(--container),calc(100% - 40px));margin:0 auto}
.hidden{display:none!important}

/* ─── Ambient background ─── */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(800px 500px at 15% 8%,rgba(245,179,1,.09),transparent 60%),
    radial-gradient(600px 450px at 88% 18%,rgba(245,179,1,.06),transparent 60%),
    radial-gradient(500px 500px at 50% 80%,rgba(245,179,1,.04),transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg2) 55%,var(--bg));
}
.dots-bg{
  position:absolute;inset:0;pointer-events:none;
  opacity:.18;
  background-image:radial-gradient(circle at 1px 1px,rgba(245,179,1,.5) 1px,transparent 1px);
  background-size:28px 28px;
}

/* ─── Top Bar ─── */
.topbar{
  background:rgba(0,0,0,.65);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line2);
  position:relative;z-index:70;
}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding:9px 0;font-size:12.5px;color:var(--muted);flex-wrap:wrap;
}
.pill{
  display:inline-flex;gap:7px;align-items:center;
  padding:5px 10px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);
  color:rgba(255,255,255,.82);white-space:nowrap;font-size:12px;font-weight:600;
}
.pill-highlight {
  border:1px solid var(--gold);background:rgba(245,179,1,.08);
  color:var(--gold2);text-decoration:none;transition:all .2s;
}
.pill-highlight:hover {
  background:rgba(245,179,1,.15);border-color:var(--gold2);
}
.pill-highlight strong { color:#fff; }
.spark{width:7px;height:7px;border-radius:999px;background:var(--gold);box-shadow:0 0 0 4px rgba(245,179,1,.18)}

/* ─── Header ─── */
header{
  position:sticky;top:0;z-index:65;
  background:rgba(0,0,0,.78);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer}
.logo-img{
  width:42px;height:42px;min-width:42px;border-radius:12px;
  object-fit:cover;
  border:1px solid rgba(245,179,1,.30);
  box-shadow:0 0 20px rgba(245,179,1,.15);
  background:rgba(255,255,255,0.05); color:transparent;
}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-weight:900;font-size:15px;letter-spacing:.4px}
.brand-name span{color:var(--gold)}
.brand-tag{font-size:9.5px;color:var(--muted);margin-top:2px;letter-spacing:.1px;line-height:1.3;white-space:normal;}

nav.menu{display:flex;gap:4px;align-items:center;flex:1;justify-content:center}
nav.menu a{
  padding:9px 12px;border-radius:10px;
  font-weight:600;font-size:13.5px;color:rgba(255,255,255,.80);
  transition:background .15s,color .15s,transform .15s;white-space:nowrap;
}
nav.menu a:hover,nav.menu a.active{background:rgba(255,255,255,.06);color:#fff;transform:translateY(-1px)}

.nav-actions{display:flex;gap:9px;align-items:center}
.btn{
  display:inline-flex;gap:8px;align-items:center;justify-content:center;
  padding:10px 16px;border-radius:12px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.90);font-weight:700;font-size:12.5px;letter-spacing:.2px;
  transition:all .15s;white-space:nowrap;cursor:pointer;
}
.btn:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18);transform:translateY(-1px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),rgba(245,179,1,.78));border-color:rgba(245,179,1,.55);color:#120d00;box-shadow:0 12px 40px rgba(245,179,1,.18)}
.btn-gold:hover{box-shadow:0 16px 50px rgba(245,179,1,.26);border-color:rgba(245,179,1,.80)}
.btn-sm{padding:8px 12px;font-size:12px;border-radius:10px}

.cart-btn{position:relative}
.cart-count{
  position:absolute;top:-6px;right:-6px;
  width:18px;height:18px;border-radius:999px;
  background:var(--gold);color:#120d00;
  font-size:10px;font-weight:900;
  display:grid;place-items:center;
}

.burger{
  display:none;width:42px;height:42px;border-radius:12px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:#fff;align-items:center;justify-content:center;flex-direction:column;gap:4px;
}
.burger span{display:block;width:17px;height:2px;background:#fff;border-radius:99px}

/* ─── Mobile menu ─── */
.mobile-menu{
  display:none;padding:0 0 12px;border-top:1px solid var(--line2);
}
.mobile-menu .stack{display:grid;gap:7px;padding-top:10px}

/* ─── Page router ─── */
.page{display:none;position:relative;z-index:1;padding-bottom:40px}
.page.active{display:block}

/* ─── Hero ─── */
.hero{padding:60px 0 30px;position:relative;overflow:hidden;}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;}
.kicker{
  display:inline-flex;gap:9px;align-items:center;
  padding:7px 13px;border-radius:999px;
  border:1px solid rgba(245,179,1,.30);background:rgba(245,179,1,.08);
  color:rgba(255,255,255,.88);font-size:11.5px;font-weight:700;letter-spacing:.2px;
  width:fit-content;margin-bottom:14px;
}
.hero h1{font-size:clamp(32px,4.5vw,58px);letter-spacing:-1px;line-height:1.02;margin-bottom:14px;}
.hero h1 .accent{color:var(--gold)}
.hero .lead{color:var(--muted);line-height:1.78;font-size:15.5px;margin-bottom:20px;max-width:60ch}
.hero-ctas{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:18px}
.trust-row{display:flex;gap:10px;flex-wrap:wrap}
.trust-item{
  display:inline-flex;gap:8px;align-items:center;
  padding:7px 10px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);
  font-size:12px;color:var(--muted);
}
.tick{
  width:16px;height:16px;border-radius:999px;
  display:grid;place-items:center;
  border:1px solid rgba(245,179,1,.50);background:rgba(245,179,1,.12);
  color:var(--gold2);font-weight:900;font-size:10px;flex:0 0 auto;
}

/* Hero visual */
.hero-visual{
  border-radius:var(--radius3);border:1px solid rgba(255,255,255,.12);
  background:radial-gradient(600px 350px at 20% 0%,rgba(245,179,1,.14),transparent 55%),
             linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  box-shadow:var(--shadow);overflow:hidden;padding:14px;
}
.hero-img{
  height:280px;border-radius:18px;border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.68)),
             url('https://images.unsplash.com/photo-1615873968403-89e068629265?auto=format&fit=crop&w=1600&q=80') center/cover;
  position:relative;overflow:hidden;
}
.hero-img::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(240px 220px at 30% 30%,rgba(245,179,1,.18),transparent 60%);
  animation:glow 7s ease-in-out infinite;
}
@keyframes glow{0%,100%{opacity:.7}50%{opacity:1}}
.hero-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}
.mini-stat{
  border-radius:13px;border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);padding:10px 12px;
}
.mini-stat .n{font-weight:900;font-size:14px;color:var(--gold2)}
.mini-stat .t{font-size:11px;color:var(--dim);margin-top:3px;line-height:1.4}

/* ─── Section ─── */
section{padding:52px 0;position:relative}
.section-head{margin-bottom:22px}
.section-head h2{font-size:clamp(20px,2.6vw,34px);letter-spacing:-0.4px;text-transform:uppercase;margin-bottom:6px;}
.section-head p{color:var(--muted);font-size:14px;line-height:1.7;max-width:68ch}
.underline{display:inline-block;position:relative;padding-bottom:5px}
.underline::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;border-radius:999px;
  background:linear-gradient(90deg,rgba(245,179,1,.95),rgba(245,179,1,.40));
  box-shadow:0 10px 28px rgba(245,179,1,.14);
}
.flex-between{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin-bottom:22px}

/* ─── Category cards ─── */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.cat-card{
  border-radius:var(--radius2);border:1px solid rgba(255,255,255,.12);
  overflow:hidden;position:relative;cursor:pointer;
  box-shadow:var(--shadow2);
  transition:transform .2s,box-shadow .2s,border-color .2s;
  transform:translateZ(0);display:block;
}
.cat-card:hover{transform:translateY(-7px);border-color:rgba(245,179,1,.35);box-shadow:var(--shadow)}
.cat-img{
  height:240px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.72)),var(--cat-bg,#111) center/cover;
  transition:transform .5s ease;
}
.cat-card:hover .cat-img{transform:scale(1.04)}
.cat-img-gates{background-image:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.72)),url('https://images.unsplash.com/photo-1615873968403-89e068629265?auto=format&fit=crop&w=900&q=80')}
.cat-img-railings{background-image:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.72)),url('https://images.unsplash.com/photo-1523413651479-597eb2da0ad6?auto=format&fit=crop&w=900&q=80')}
.cat-img-balcony{background-image:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.72)),url('https://images.unsplash.com/photo-1496307653780-42ee777d4833?auto=format&fit=crop&w=900&q=80')}
.cat-badge{
  position:absolute;top:14px;left:14px;
  display:inline-flex;gap:7px;align-items:center;
  padding:6px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.50);
  backdrop-filter:blur(8px);font-size:11px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;
}
.cat-body{
  padding:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
}
.cat-body h3{font-size:18px;letter-spacing:-.2px;margin-bottom:6px}
.cat-body p{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:14px}
.cat-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.15);
}
.cat-foot .from{font-size:12px;color:var(--muted)}
.cat-foot .from strong{color:var(--gold2);font-size:15px;font-weight:900}


/* ─── NEW: How Ordering Works (3 Steps) ─── */
.steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.step-card {
    border-radius: var(--radius2);
    border: 1px solid rgba(255,255,255,.10);
    background: radial-gradient(circle at top right, rgba(245,179,1,.06), transparent 60%), rgba(255,255,255,.03);
    padding: 30px;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow2);
    transition: transform .2s ease, border-color .2s ease;
}
.step-card:hover {
    transform: translateY(-5px);
    border-color: rgba(245,179,1,.35);
}
.step-num {
    font-size: 52px;
    font-weight: 900;
    color: rgba(245,179,1,.12);
    position: absolute;
    top: 10px;
    right: 20px;
    line-height: 1;
    pointer-events: none;
}
.step-card h4 {
    font-size: 18px;
    margin-bottom: 12px;
    font-weight: 800;
    color: #fff;
    position: relative;
}
.step-card p {
    font-size: 13.5px;
    color: var(--muted);
    line-height: 1.6;
    position: relative;
    margin: 0;
}

/* ─── NEW: Installation Highlight Banner ─── */
.install-banner {
    border-radius: var(--radius3);
    border: 1px solid rgba(255,255,255,.14);
    background: var(--bg2);
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr 1fr;
    box-shadow: var(--shadow);
}
.install-content {
    padding: 50px 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.install-content h2 {
    font-size: clamp(26px, 3.5vw, 40px);
    letter-spacing: -1px;
    margin-bottom: 16px;
    color: #fff;
    line-height: 1.1;
}
.install-content p {
    color: var(--muted);
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 24px;
}
.install-features {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 30px;
}
.i-feat {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    font-weight: 700;
    color: #fff;
}
.i-feat span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: rgba(245,179,1,.15);
    color: var(--gold2);
    border: 1px solid rgba(245,179,1,.3);
    font-size: 14px;
}
.install-ctas {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

/* --- Pure CSS Radar/Map Replacement --- */
.install-visual {
    position: relative;
    min-height: 350px;
    background-color: var(--bg2);
    background-image:
        radial-gradient(circle at 65% 50%, rgba(245,179,1,.15) 0%, transparent 20%),
        repeating-radial-gradient(circle at 65% 50%, transparent 0, transparent 40px, rgba(245,179,1,.05) 40px, rgba(245,179,1,.05) 41px),
        linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
    background-size: 100% 100%, 100% 100%, 30px 30px, 30px 30px;
    background-position: center;
    overflow: hidden;
}

.install-visual::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, var(--bg2) 0%, transparent 30%, transparent 70%, var(--bg2) 100%),
                linear-gradient(0deg, var(--bg2) 0%, transparent 20%, transparent 80%, var(--bg2) 100%);
    pointer-events: none;
    z-index: 1;
}

.install-visual::after {
    content: "📍 Greater London";
    position: absolute;
    top: 50%;
    left: 65%;
    transform: translate(-50%, -50%);
    padding: 10px 20px;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(245, 179, 1, 0.4);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
    color: var(--gold2);
    z-index: 2;
    box-shadow: 0 0 0 0 rgba(245, 179, 1, 0.4);
    animation: pin-pulse 2s infinite;
}

@keyframes pin-pulse {
    0% { box-shadow: 0 0 0 0 rgba(245, 179, 1, 0.4); }
    70% { box-shadow: 0 0 0 25px rgba(245, 179, 1, 0); }
    100% { box-shadow: 0 0 0 0 rgba(245, 179, 1, 0); }
}

/* ─── Product cards ─── */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.prod-card{
  border-radius:var(--radius2);border:1px solid rgba(255,255,255,.12);
  overflow:hidden;position:relative;
  box-shadow:var(--shadow2);background:rgba(255,255,255,.03);
  transition:transform .2s,box-shadow .2s,border-color .2s;display:block;
}
.prod-card:hover{transform:translateY(-6px);border-color:rgba(245,179,1,.32);box-shadow:var(--shadow)}
.prod-card::before{
  content:"";position:absolute;inset:-60px -60px auto auto;
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(245,179,1,.20),transparent 65%);
  filter:blur(14px);opacity:.6;pointer-events:none;
}
.prod-img{
  height:200px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.68)) center/cover;
  transition:transform .5s;
}
.prod-card:hover .prod-img{transform:scale(1.04)}
.prod-chip{
  position:absolute;top:12px;left:12px;
  padding:5px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.50);
  backdrop-filter:blur(8px);font-size:10.5px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;
}
.prod-body{padding:14px 16px}
.prod-body h3{font-size:16px;font-weight:800;letter-spacing:-.1px;margin-bottom:7px}
.prod-body p{font-size:12.5px;color:var(--muted);line-height:1.65;margin-bottom:12px}
.prod-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.tag{
  padding:4px 9px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);
  font-size:11px;color:var(--dim);font-weight:600;
}
.prod-foot{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 16px;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.14);
}
.price-from{font-size:11.5px;color:var(--muted)}
.price-from strong{display:block;font-size:18px;font-weight:900;color:var(--gold2);line-height:1.1}

/* ─── Category page header ─── */
.cat-page-header{
  padding:40px 0 28px;
  border-bottom:1px solid var(--line2);
  margin-bottom:30px;
}
.cat-page-header .kicker{margin-bottom:12px}
.cat-page-header h1{font-size:clamp(26px,3.5vw,44px);letter-spacing:-.6px;margin-bottom:10px}
.cat-page-header p{color:var(--muted);font-size:14.5px;line-height:1.75;max-width:65ch}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px;align-items:center;}
.filter-btn{
  padding:8px 14px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:var(--muted);font-weight:700;font-size:12px;
  cursor:pointer;transition:all .15s;
}
.filter-btn.active,.filter-btn:hover{background:rgba(245,179,1,.12);border-color:rgba(245,179,1,.35);color:var(--gold2);}

/* ─── Features strip ─── */
.features-strip{
  border-radius:var(--radius2);border:1px solid rgba(255,255,255,.10);
  background:radial-gradient(700px 400px at 20% 0%,rgba(245,179,1,.10),transparent 55%),
             linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  padding:28px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  box-shadow:var(--shadow2);
}
.feat{display:flex;flex-direction:column;gap:8px;position:relative}
.feat+.feat::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:1px;height:60%;background:rgba(255,255,255,.10);
}
.feat-icon{
  width:40px;height:40px;border-radius:12px;
  border:1px solid rgba(245,179,1,.30);background:rgba(245,179,1,.08);
  display:grid;place-items:center;color:var(--gold2);font-size:18px;
}
.feat h4{font-size:13.5px;font-weight:800;margin:0}
.feat p{font-size:12px;color:var(--muted);line-height:1.6;margin:0}

/* ─── Footer ─── */
footer{
  border-top:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);padding:44px 0 32px;
  position:relative;z-index:1;
}
.footer-grid{display:grid;grid-template-columns:1.3fr .9fr .9fr;gap:24px}
.ft-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.ft-title{font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.3px;margin-bottom:10px;color:rgba(255,255,255,.70)}
.ft-text{color:rgba(255,255,255,.65);font-size:13.5px;line-height:1.78}
.ft-links{list-style:none;display:grid;gap:8px}
.ft-links a{color:rgba(255,255,255,.72);font-size:13.5px;transition:color .15s}
.ft-links a:hover{color:#fff}
.fine{
  margin-top:22px;padding-top:16px;
  border-top:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.52);font-size:12px;
  display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;
}
.fine a{color:rgba(255,255,255,.52)}
.fine a:hover{color:rgba(255,255,255,.80)}

/* ─── Utils & Scroll reveal ─── */
.divider{height:1px;background:rgba(255,255,255,.08);margin:0}
.small{font-size:12px;color:var(--dim)}
.text-gold{color:var(--gold2)}
.mt8{margin-top:8px}
.mt14{margin-top:14px}
.mt20{margin-top:20px}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .65s ease,transform .65s ease}
.reveal.show{opacity:1;transform:translateY(0)}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ─── RESPONSIVE ─── */
@media(max-width:980px){
  nav.menu{display:none}
  .burger{display:flex}
  .hero-inner{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:1fr 1fr}
  .features-strip{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-mini{grid-template-columns:1fr}
  
  /* Mobile overwrites for new blocks */
  .steps-grid { grid-template-columns: 1fr; }
  .install-banner { grid-template-columns: 1fr; }
  .install-visual { height: 280px; }
  .install-visual::after { top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 12px; }
  .install-content { padding: 40px 30px; }
}
@media(max-width:620px){
  .prod-grid{grid-template-columns:1fr}
  .features-strip{grid-template-columns:1fr}
  .feat+.feat::before{display:none}
  .topbar-inner{justify-content:center; gap: 8px;}
  .pill-highlight { width: 100%; justify-content: center; padding: 8px; font-size: 13px; }
}

/* ════════════════ WORDPRESS OVERRIDES ════════════════ */
/* Admin Bar Fix */
body.admin-bar .topbar { margin-top: 32px; }
@media screen and (max-width: 782px) { body.admin-bar .topbar { margin-top: 46px; } }

/* WordPress Desktop Menu Fix */
nav.menu ul { list-style: none; display: flex; gap: 4px; margin: 0; padding: 0; align-items: center; justify-content: center; }
nav.menu li { position: relative; }
nav.menu > ul > li > a {
  display: block; padding: 9px 12px; border-radius: 10px;
  font-weight: 600; font-size: 13.5px; color: rgba(255,255,255,.80);
  transition: background .15s, color .15s, transform .15s; white-space: nowrap; text-decoration: none;
}
nav.menu > ul > li > a:hover, nav.menu li.current-menu-item > a, nav.menu li.current-product_cat-ancestor > a {
  background: rgba(255,255,255,.06); color: #fff; transform: translateY(-1px);
}

/* Dropdown Submenus */
nav.menu ul.sub-menu {
  position: absolute; top: 100%; left: 0; transform: translateY(10px);
  background: rgba(10,10,10,.98); backdrop-filter: blur(12px);
  border: 1px solid var(--line); border-radius: 12px;
  padding: 8px; display: flex; flex-direction: column; gap: 4px;
  opacity: 0; visibility: hidden; transition: all 0.2s ease;
  box-shadow: var(--shadow2); min-width: 220px; z-index: 100;
}
nav.menu li:hover > ul.sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
nav.menu ul.sub-menu li a {
  display: block; font-size: 12.5px; padding: 10px 12px; text-align: left;
  background: transparent; white-space: normal; line-height: 1.4; color: rgba(255,255,255,.80);
  border-radius: 8px; transition: background .15s; text-decoration: none; font-weight: 500;
}
nav.menu ul.sub-menu li a:hover { background: rgba(255,255,255,.06); color: #fff; }

/* WordPress Mobile Menu Stack */
#mobileStack ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 7px; width: 100%; }
#mobileStack li { width: 100%; }
#mobileStack > ul > li > a {
  display: flex; gap: 8px; align-items: center; justify-content: flex-start;
  padding: 12px 16px; border-radius: 12px;
  border: 1px solid var(--line); background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.90); font-weight: 700; font-size: 13px; letter-spacing: .2px;
  transition: all .15s; width: 100%; text-decoration: none;
}
#mobileStack > ul > li > a:hover { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.18); transform: translateY(-1px); }

/* Mobile Submenus (Indented) */
#mobileStack ul.sub-menu { padding-left: 20px; margin-top: 7px; display: flex; flex-direction: column; gap: 7px; border-left: 2px solid var(--line2); }
#mobileStack ul.sub-menu li a { font-size: 12.5px; background: transparent; border-color: transparent; padding: 8px 12px; color: var(--muted); display: block; text-decoration: none; font-weight: 600;}
#mobileStack ul.sub-menu li a:hover { background: rgba(255,255,255,.04); border-color: var(--line); color: #fff; border-radius: 8px;}

/* ════════ PREMIUM WOOCOMMERCE CART & CHECKOUT BLOCKS ════════ */

.wp-block-woocommerce-cart,
.wp-block-woocommerce-checkout {
    padding-top: 40px;
    padding-bottom: 80px;
}

/* Cart Items & Main Checkout Column */
.wc-block-cart-items,
.wc-block-checkout__main {
    background: rgba(255, 255, 255, 0.02) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 16px !important;
    padding: 30px !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.15) !important;
}

/* Order Summary / Totals Column */
.wc-block-cart__totals-container,
.wc-block-checkout__sidebar {
    background: rgba(255, 255, 255, 0.03) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 30px !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.2) !important;
}

/* Table Headers & Section Titles */
.wc-block-components-title, 
.wc-block-cart__totals-title,
.wc-block-checkout__title,
.wc-block-components-checkout-step__title {
    color: #ffffff !important;
    font-weight: 900 !important;
    font-size: 16px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    padding-bottom: 16px !important;
    margin-bottom: 24px !important;
}

.wc-block-components-checkout-step__description {
    color: var(--muted) !important;
}

/* Cart Item Rows */
.wc-block-cart-items td, 
.wc-block-cart-items th {
    border-color: rgba(255,255,255,0.05) !important;
}

/* Product Titles */
.wc-block-components-product-name {
    color: #ffffff !important;
    font-weight: 800 !important;
    font-size: 16px !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
}
.wc-block-components-product-name:hover {
    color: #f5b301 !important; /* Gold */
}

/* Selected Variations (The Pills) */
.wc-block-components-product-details__item {
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 12px !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    padding: 4px 12px !important;
    border-radius: 999px !important;
    display: inline-block !important;
    margin-top: 8px !important;
    margin-right: 6px !important;
}
.wc-block-components-product-details__item-label { 
    font-weight: 600 !important; 
    color: rgba(255, 255, 255, 0.5) !important; 
}

/* Product Price & Totals */
.wc-block-components-product-price__value,
.wc-block-components-totals-item__value,
.wc-block-formatted-money-amount {
    color: #f5b301 !important; /* Gold */
    font-weight: 900 !important;
}

/* Quantity Selector */
.wc-block-components-quantity-selector {
    background: rgba(0, 0, 0, 0.4) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}
.wc-block-components-quantity-selector input {
    color: #ffffff !important;
    font-weight: 800 !important;
    background: transparent !important;
}
.wc-block-components-quantity-selector button {
    color: rgba(255, 255, 255, 0.5) !important;
    background: transparent !important;
}
.wc-block-components-quantity-selector button:hover {
    color: #f5b301 !important;
    background: rgba(255, 255, 255, 0.05) !important;
}

/* Remove Button */
.wc-block-cart-item__remove-link {
    color: rgba(255, 255, 255, 0.4) !important;
    transition: color 0.2s !important;
}
.wc-block-cart-item__remove-link:hover {
    color: #ff5555 !important;
}

/* Form Inputs (Coupons & Checkout Fields) - Fixed White Backgrounds */
.wc-block-components-text-input,
.wc-block-components-combobox,
.wc-block-components-combobox-control,
.wc-block-components-text-input.is-active,
.wc-block-components-combobox-control.is-active {
    background: transparent !important;
}

.wc-block-components-text-input input,
.wc-block-components-combobox-control input,
.wc-block-components-radio-control input[type="radio"],
.wc-block-components-checkbox-control input[type="checkbox"] {
    background: rgba(0, 0, 0, 0.4) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: #ffffff !important;
    border-radius: 12px !important;
    box-shadow: none !important;
}

.wc-block-components-text-input input:focus,
.wc-block-components-combobox-control input:focus {
    border-color: #f5b301 !important;
    box-shadow: 0 0 0 1px #f5b301 !important;
}

/* Floating Labels Fix */
.wc-block-components-text-input label,
.wc-block-components-combobox-control label {
    color: rgba(255, 255, 255, 0.6) !important;
    font-size: 13px !important;
    background: #141414 !important; /* Hides the input border when label floats */
    padding: 0 6px !important;
    margin-left: 8px !important;
    border-radius: 4px !important;
}

/* Dropdown Menus (Country / Region) */
.wc-block-components-combobox-control__menu {
    background: #1a1a1a !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    color: #fff !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5) !important;
}
.wc-block-components-combobox-control__menu-item {
    color: #fff !important;
    background: transparent !important;
    transition: background 0.2s !important;
}
.wc-block-components-combobox-control__menu-item:hover,
.wc-block-components-combobox-control__menu-item[aria-selected="true"],
.wc-block-components-combobox-control__menu-item.is-focused {
    background: rgba(255, 255, 255, 0.08) !important;
}

/* Checkout Actions Row (Align Return to Cart & Place Order) */
.wc-block-checkout__actions {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 20px !important;
    margin-top: 30px !important;
    flex-wrap: wrap !important;
}

.wc-block-components-checkout-return-to-cart-button {
    color: rgba(255, 255, 255, 0.6) !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    display: inline-flex !important;
    align-items: center !important;
    margin: 0 !important;
}
.wc-block-components-checkout-return-to-cart-button:hover {
    color: #fff !important;
}

/* The Big "Proceed to Cart" / "Place Order" Button */
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button {
    display: block !important;
    text-align: center !important;
    padding: 16px 28px !important;
    border-radius: 14px !important;
    background: linear-gradient(135deg, #f5b301, rgba(245,179,1,0.80)) !important;
    border: 1px solid rgba(245,179,1,0.55) !important;
    color: #120d00 !important;
    font-weight: 900 !important;
    font-size: 15px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    box-shadow: 0 14px 35px rgba(245,179,1,0.2) !important;
    transition: all 0.2s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
    text-decoration: none !important;
    margin: 0 !important;
}

.wc-block-cart__submit-button {
    width: 100% !important;
    margin-top: 24px !important;
}

.wc-block-components-checkout-place-order-button {
    flex: 1 !important;
    max-width: 320px !important; /* Constrains width neatly next to return button */
}

.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover {
    box-shadow: 0 18px 45px rgba(245,179,1,0.3) !important;
    transform: translateY(-2px) !important;
}

/* Secondary Action Buttons (Apply Coupon) */
.wc-block-components-button:not(.wc-block-cart__submit-button):not(.wc-block-components-checkout-place-order-button) {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: #ffffff !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    padding: 12px 20px !important;
    transition: all 0.2s !important;
}
.wc-block-components-button:not(.wc-block-cart__submit-button):not(.wc-block-components-checkout-place-order-button):hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: #f5b301 !important;
    color: #f5b301 !important;
}

/* Accordion Panels */
.wc-block-components-panel__button {
    color: #ffffff !important;
    font-weight: 700 !important;
}
.wc-block-components-totals-coupon-link {
    color: #f5b301 !important;
}

/* Image Thumbnails */
.wc-block-cart-item__image img {
    border-radius: 12px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Mobile Adaptations */
@media(max-width: 768px) {
    .wc-block-cart-items, .wc-block-cart__totals-container,
    .wc-block-checkout__main, .wc-block-checkout__sidebar {
        padding: 20px !important;
    }
    .wp-block-woocommerce-cart,
    .wp-block-woocommerce-checkout {
        gap: 20px !important;
    }
    
    /* Stack checkout buttons perfectly on mobile */
    .wc-block-checkout__actions {
        flex-direction: column-reverse !important;
        align-items: stretch !important;
        gap: 15px !important;
    }
    .wc-block-components-checkout-place-order-button {
        max-width: 100% !important;
    }
    .wc-block-components-checkout-return-to-cart-button {
        justify-content: center !important;
        padding: 10px !important;
    }
}

/* ════════ WOOCOMMERCE MY ACCOUNT ════════ */
.woocommerce-account .page { padding-top: 40px; padding-bottom: 80px; }

/* Dashboard Layout */
.woocommerce-account .woocommerce { display: flex; gap: 40px; align-items: flex-start; }
.woocommerce-account.logged-out .woocommerce { display: block; max-width: 900px; margin: 0 auto; } /* Login/Reg page */

/* Sidebar Navigation */
.woocommerce-MyAccount-navigation { width: 260px; flex-shrink: 0; }
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; margin: 0; }
.woocommerce-MyAccount-navigation li { margin-bottom: 8px; }
.woocommerce-MyAccount-navigation li a {
    display: block; padding: 14px 18px; border-radius: 12px;
    background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.08);
    color: var(--muted); font-weight: 600; font-size: 14px; text-decoration: none;
    transition: all .2s;
}
.woocommerce-MyAccount-navigation li a:hover,
.woocommerce-MyAccount-navigation li.is-active a {
    background: rgba(245,179,1,.08); border-color: rgba(245,179,1,.3); color: var(--gold2);
}

/* Content Area */
.woocommerce-MyAccount-content {
    flex: 1; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--radius2); padding: 30px; box-shadow: 0 4px 24px rgba(0,0,0,.15);
}
.woocommerce-MyAccount-content h3, .woocommerce-MyAccount-content legend {
    font-size: 20px; color: #fff; margin-bottom: 20px; font-weight: 800; letter-spacing: -.2px;
}
.woocommerce-MyAccount-content p { color: var(--muted); font-size: 14.5px; line-height: 1.7; margin-bottom: 20px; }
.woocommerce-MyAccount-content mark { background: transparent; color: var(--text); font-weight: bold; }
.woocommerce-MyAccount-content a { color: var(--gold); text-decoration: none; font-weight: 600; }
.woocommerce-MyAccount-content a:hover { color: var(--gold2); text-decoration: underline; }

/* Orders Table */
.woocommerce-MyAccount-orders { width: 100%; border-collapse: collapse; margin-bottom: 20px; }
.woocommerce-MyAccount-orders th { padding: 16px; text-align: left; background: rgba(0,0,0,.3); border-bottom: 1px solid rgba(255,255,255,.1); font-size: 13px; text-transform: uppercase; color: var(--text); }
.woocommerce-MyAccount-orders td { padding: 16px; border-bottom: 1px solid rgba(255,255,255,.05); font-size: 14px; color: var(--muted); }
.woocommerce-MyAccount-orders td.woocommerce-orders-table__cell-order-actions a {
    display: inline-block; padding: 8px 14px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
    border-radius: 8px; color: #fff; font-size: 12px; font-weight: 600; text-decoration: none; transition: all .2s;
}
.woocommerce-MyAccount-orders td.woocommerce-orders-table__cell-order-actions a:hover { background: rgba(255,255,255,.1); border-color: var(--gold); color: var(--gold); }

/* Login & Register Forms */
.u-columns.col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.u-column1, .u-column2 {
    background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--radius2); padding: 30px; box-shadow: 0 4px 24px rgba(0,0,0,.15);
}
.u-column1 h2, .u-column2 h2 { font-size: 24px; margin-bottom: 20px; font-weight: 800; color: #fff; }

.woocommerce-form-login, .woocommerce-form-register, .woocommerce-EditAccountForm, .woocommerce-address-fields__field-wrapper {
    display: flex; flex-direction: column; gap: 15px;
}
.woocommerce-form-login p, .woocommerce-form-register p { margin: 0; }
.woocommerce-form-login .form-row, .woocommerce-form-register .form-row { margin: 0; display: block; width: 100%; }

/* My Account Form Inputs */
.woocommerce-account .woocommerce form input[type="text"],
.woocommerce-account .woocommerce form input[type="email"],
.woocommerce-account .woocommerce form input[type="password"],
.woocommerce-account .woocommerce form input[type="tel"] {
    width: 100%; padding: 14px 16px; border-radius: 12px;
    border: 1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.4);
    color: #fff; font-size: 14.5px; transition: border-color .2s;
}
.woocommerce-account .woocommerce form input:focus { border-color: var(--gold); outline: none; background: rgba(0,0,0,.6); }
.woocommerce-account .woocommerce form label { display: block; font-size: 12.5px; color: var(--muted); margin-bottom: 8px; font-weight: 600; }

/* My Account Buttons */
.woocommerce-account .woocommerce button.button,
.woocommerce-account .woocommerce input.button {
    padding: 14px 28px; border-radius: 12px; background: linear-gradient(135deg, var(--gold), rgba(245,179,1,.80));
    border: 1px solid rgba(245,179,1,.55); color: #120d00; font-weight: 900; font-size: 14px;
    text-transform: uppercase; cursor: pointer; transition: all 0.2s; box-shadow: 0 10px 30px rgba(245,179,1,.15);
    display: inline-block; width: auto; min-width: 150px; margin-top: 10px;
}
.woocommerce-account .woocommerce button.button:hover,
.woocommerce-account .woocommerce input.button:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(245,179,1,.25); }

.woocommerce-form-login__rememberme { display: flex; align-items: center; gap: 8px; margin-top: 10px !important; }
.woocommerce-form-login__rememberme input[type="checkbox"] { width: 18px; height: 18px; border-radius: 4px; cursor: pointer; }
.woocommerce-LostPassword { margin-top: 15px; font-size: 13px; }

/* Addresses */
.woocommerce-Address { margin-bottom: 30px; }
.woocommerce-Address-title { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.woocommerce-Address-title h3 { margin: 0; }
.woocommerce-Address-title a { font-size: 13px; font-weight: 700; background: rgba(255,255,255,.05); padding: 6px 12px; border-radius: 8px; border: 1px solid rgba(255,255,255,.1); transition: all .2s; }
.woocommerce-Address-title a:hover { background: rgba(255,255,255,.1); color: #fff; text-decoration: none; }
address { font-style: normal; color: var(--muted); line-height: 1.8; font-size: 14px; background: rgba(0,0,0,.2); padding: 20px; border-radius: 12px; border: 1px solid rgba(255,255,255,.05); }

/* Mobile Adaptations */
@media(max-width: 768px) {
    .woocommerce-account .woocommerce { flex-direction: column; gap: 20px; }
    .woocommerce-MyAccount-navigation { width: 100%; }
    .woocommerce-MyAccount-navigation ul { display: flex; overflow-x: auto; gap: 8px; padding-bottom: 10px; }
    .woocommerce-MyAccount-navigation li { margin-bottom: 0; flex-shrink: 0; }
    .woocommerce-MyAccount-navigation li a { padding: 10px 16px; white-space: nowrap; }
    .woocommerce-MyAccount-content { width: 100%; padding: 20px; }
    .u-columns.col2-set { grid-template-columns: 1fr; gap: 30px; }
}

/* ════════ FALLBACK: CLASSIC CART & CHECKOUT ════════ */

.woocommerce-cart .woocommerce { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: 28px; align-items: start; padding-top: 30px; }
@media(max-width: 980px) { .woocommerce-cart .woocommerce { grid-template-columns: 1fr; } }

.woocommerce-cart-form { background: rgba(255,255,255,.03); border-radius: var(--radius); border: 1px solid rgba(255,255,255,.10); overflow: hidden; }
.woocommerce table.shop_table.cart { width: 100%; border-collapse: collapse; border: none; margin: 0; border-radius: 0; }
.woocommerce table.shop_table.cart thead { background: rgba(0,0,0,.20); border-bottom: 1px solid rgba(255,255,255,.10); }
.woocommerce table.shop_table.cart th { padding: 14px 18px; font-weight: 900; font-size: 13px; text-transform: uppercase; letter-spacing: .2px; text-align: left; color: var(--text); border: none; }
.woocommerce table.shop_table.cart tbody tr { border-bottom: 1px solid rgba(255,255,255,.10); }
.woocommerce table.shop_table.cart tbody tr:last-child { border-bottom: none; }
.woocommerce table.shop_table.cart td { padding: 16px 18px; vertical-align: middle; border: none; }

.woocommerce table.cart .product-thumbnail { width: 100px; }
.woocommerce table.cart .product-thumbnail img { width: 80px; height: 72px; border-radius: 12px; object-fit: cover; border: 1px solid rgba(255,255,255,.10); }
.woocommerce table.cart .product-name a { font-size: 14px; font-weight: 800; text-decoration: none; color: #fff; }

.woocommerce table.cart dl.variation { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.woocommerce table.cart dl.variation dt { color: var(--dim); font-weight: 500; font-size: 11px; display: inline-block; clear: both; float: left; margin-bottom: 4px; }
.woocommerce table.cart dl.variation dd { margin: 0 0 4px 0; padding: 0 9px; display: inline-block; float: left; clear: right; }
.woocommerce table.cart dl.variation dd p { margin: 0; padding: 4px 9px; border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.04); font-size: 11px; color: var(--dim); font-weight: 600; }

.woocommerce table.cart .quantity { display: inline-flex; align-items: center; border: 1px solid var(--line); border-radius: 10px; background: rgba(0,0,0,.18); height: 36px; padding: 0 4px; }
.woocommerce table.cart .quantity input.qty { width: 36px; background: transparent; border: none; color: #fff; text-align: center; font-weight: 800; font-size: 14px; outline: none; -moz-appearance: textfield; }
.woocommerce table.cart .product-price, .woocommerce table.cart .product-subtotal { font-size: 16px; font-weight: 900; color: var(--gold2); }
.woocommerce table.cart .product-remove a.remove { color: var(--dim) !important; background: transparent !important; font-size: 22px; transition: color .15s; display: block; text-align: center; font-weight: 300; line-height: 1; }
.woocommerce table.cart .product-remove a.remove:hover { color: rgba(255,80,80,.8) !important; background: transparent !important; }

.woocommerce table.cart td.actions { padding: 16px 18px; background: rgba(0,0,0,.15); }
.woocommerce table.cart td.actions .coupon { display: flex; gap: 10px; flex-wrap: wrap; float: left; }
.woocommerce table.cart td.actions .coupon input { padding: 10px 14px; border-radius: 10px; border: 1px solid var(--line); background: rgba(255,255,255,.04); color: #fff; font-size: 13px; min-width: 160px; outline: none; }
.woocommerce table.cart td.actions button { padding: 10px 16px; border-radius: 10px; border: 1px solid var(--line); background: rgba(255,255,255,.08); color: #fff; font-weight: 700; font-size: 12.5px; cursor: pointer; transition: all .15s; }
.woocommerce table.cart td.actions button:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); }
.woocommerce table.cart td.actions > button[name="update_cart"] { float: right; background: rgba(255,255,255,.04); }

.cart-collaterals { position: sticky; top: 90px; }
.cart_totals { border-radius: var(--radius2); border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); overflow: hidden; }
.cart_totals h2 { padding: 16px 20px; background: rgba(0,0,0,.25); border-bottom: 1px solid rgba(255,255,255,.08); font-weight: 900; font-size: 14px; text-transform: uppercase; margin: 0; }
.cart_totals table { width: 100%; border-collapse: collapse; }
.cart_totals th, .cart_totals td { padding: 18px 20px; border-bottom: 1px solid rgba(255,255,255,.08); }
.cart_totals th { color: var(--muted); font-size: 14px; font-weight: normal; text-align: left; }
.cart_totals td { font-weight: 700; text-align: right; }
.cart_totals .order-total th { font-weight: 900; font-size: 16px; color: var(--text); }
.cart_totals .order-total td strong { font-size: 22px; font-weight: 900; color: var(--gold2); }

.wc-proceed-to-checkout { padding: 20px; }
.wc-proceed-to-checkout .checkout-button { display: block; width: 100%; text-align: center; padding: 13px 22px; border-radius: 14px; background: linear-gradient(135deg, var(--gold), rgba(245,179,1,.80)); border: 1px solid rgba(245,179,1,.55); color: #120d00 !important; font-weight: 900; font-size: 13.5px; text-transform: uppercase; box-shadow: 0 14px 45px rgba(245,179,1,.22); transition: all .15s; cursor: pointer; text-decoration: none; }
.wc-proceed-to-checkout .checkout-button:hover { box-shadow: 0 18px 55px rgba(245,179,1,.32); transform: translateY(-1px); }

/* Classic Checkout Form */
.woocommerce-checkout .woocommerce { display: grid; grid-template-columns: 1fr 0.8fr; gap: 40px; align-items: start; padding-top: 30px; }
@media(max-width: 980px) { .woocommerce-checkout .woocommerce { grid-template-columns: 1fr; } }
.woocommerce-checkout h3 { font-size: 22px; margin-bottom: 20px; border-bottom: 1px solid var(--line2); padding-bottom: 10px; color: var(--text); }

.woocommerce form .form-row { margin-bottom: 15px; }
.woocommerce form .form-row label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 6px; font-weight: 600; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea { width: 100%; padding: 12px 14px; border-radius: 12px; border: 1px solid rgba(255,255,255,.12) !important; background: rgba(255,255,255,.04) !important; color: #fff !important; font-size: 13px; outline: none; }
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus { border-color: var(--gold) !important; }

#order_review { background: rgba(255,255,255,.03); border-radius: var(--radius2); border: 1px solid var(--line); padding: 20px; position: sticky; top: 90px; }
.woocommerce-checkout-review-order-table th, .woocommerce-checkout-review-order-table td { padding: 15px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.woocommerce-checkout-review-order-table td.product-total { text-align: right; font-weight: 700; color: var(--gold2); }

#payment { background: transparent !important; margin-top: 20px; }
#payment ul.payment_methods { border-bottom: 1px solid rgba(255,255,255,.08); padding-bottom: 15px; }
#payment div.payment_box { background: rgba(0,0,0,.2); border-radius: 12px; border: 1px solid var(--line); padding: 15px; font-size: 13px; color: var(--muted); }
.woocommerce-checkout-payment .place-order { padding: 0 !important; margin-top: 20px; }
#place_order { width: 100%; padding: 16px; border-radius: 14px; background: linear-gradient(135deg, var(--gold), rgba(245,179,1,.80)); border: 1px solid rgba(245,179,1,.55); color: #120d00; font-weight: 900; font-size: 15px; text-transform: uppercase; box-shadow: 0 14px 45px rgba(245,179,1,.22); cursor: transform .15s; }

