/*
Theme Name: Optikwelt
Theme URI: https://optikwelt.ee
Description: Optikwelt optics store v7.0
Version: 7.0
*/

:root{
    --accent:#F10E0B;--accent-h:#C80A08;
    --dark:#1B1B18;--dark2:#222220;
    --white:#fff;--light:#F9F9F9;
    --text:#1C1C16;--body:#7A7A7A;--muted:#999;
    --bdr:#E0E0E0;--bdr-w:rgba(255,255,255,.08);
    --r:8px;--t:.3s;--w:1290px;
    --shadow:0 5px 15px rgba(28,28,22,.05);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Inter',sans-serif;font-size:16px;line-height:1.7;color:var(--body);background:var(--white);overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:'Montserrat',sans-serif;letter-spacing:.02em;line-height:1.1;color:var(--text);font-weight:800}
a{text-decoration:none;color:inherit;transition:color var(--t)}
img{display:block;max-width:100%;height:auto}
ul{list-style:none}
button{font-family:inherit}
.container{max-width:1440px;margin:0 auto;padding:0 60px;box-sizing:border-box}

/* ── Section headers ──────────────────── */
.tag{display:block;font-family:'Inter',sans-serif;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.tag--light{color:var(--accent)}
.sh{text-align:center;margin-bottom:48px}
.sh h2{font-size:clamp(36px,5vw,60px);text-transform:uppercase}
.sh-link{display:inline-block;margin-top:10px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.sh-link:hover{color:var(--accent-h)}

/* ── Buttons ──────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'Inter',sans-serif;font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:14px 32px;border:2px solid transparent;border-radius:var(--r);cursor:pointer;transition:all var(--t);white-space:nowrap}
.btn-primary{background:var(--accent);color:var(--white);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-h);border-color:var(--accent-h);color:var(--white)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6);color:var(--white)}
.btn-outline{background:transparent;color:var(--text);border-color:var(--bdr)}
.btn-outline:hover{background:var(--text);color:var(--white);border-color:var(--text)}
.btn-sm{padding:10px 22px;font-size:10px}

/* ── Reveal ───────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* ══════════════════════════════════════════
   NAVBAR
══════════════════════════════════════════ */
/* Top bar */
.top-bar{background:var(--dark);border-bottom:1px solid rgba(255,255,255,.08)}
.top-bar__inner{display:flex;justify-content:space-between;align-items:center;padding-top:8px;padding-bottom:8px}
.top-bar__left,.top-bar__right{display:flex;align-items:center;gap:6px}
.top-bar__link{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.top-bar__link:hover{color:var(--white)}
.top-bar__sep{color:rgba(255,255,255,.2);font-size:11px}

.site-header{position:sticky;top:0;z-index:1000}
.navbar{background:var(--white);box-shadow:var(--shadow)}
.navbar-inner{display:flex;align-items:center;height:70px;gap:32px;max-width:1440px;margin:0 auto;padding:0 60px;box-sizing:border-box}
.nav-logo img{height:32px;width:auto}

.nav-menu{display:flex;align-items:center;flex:1;justify-content:center}
.nav-menu li{position:relative}
.nav-menu>li>a{display:block;padding:0 15px;height:70px;line-height:70px;font-size:14px;font-weight:500;color:var(--text);transition:color var(--t)}
.nav-menu>li>a:hover,.nav-menu>li.active>a{color:var(--accent)}

.dropdown{position:absolute;top:100%;left:0;background:var(--white);border-top:2px solid var(--accent);box-shadow:0 10px 30px rgba(0,0,0,.1);min-width:200px;opacity:0;visibility:hidden;transform:translateY(5px);transition:all var(--t);z-index:200}
.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:none}
.dropdown li a{display:block;padding:10px 18px;font-size:13px;color:var(--body);border-bottom:1px solid var(--bdr);transition:all var(--t)}
.dropdown li:last-child a{border-bottom:none}
.dropdown li a:hover{color:var(--accent);padding-left:22px;background:var(--light)}

.nav-actions{display:flex;align-items:center;gap:6px;margin-left:auto}
.nav-search-toggle,.nav-grid-toggle{background:none;border:none;cursor:pointer;padding:8px;color:var(--text);display:flex;align-items:center;justify-content:center;transition:color var(--t)}
.nav-search-toggle:hover,.nav-grid-toggle:hover{color:var(--accent)}
.nav-account{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--r);color:var(--text);transition:all var(--t)}
.nav-account:hover{background:var(--accent);color:var(--white)}
.nav-account:hover svg{stroke:var(--white)}
.nav-cart-wrap{position:relative}
.nav-cart{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--light);border-radius:var(--r);font-size:13px;font-weight:600;color:var(--text);transition:all var(--t)}
.nav-cart:hover{background:var(--accent);color:var(--white)}
.nav-cart:hover svg{stroke:var(--white)}
.nav-cart-count{background:var(--accent);color:var(--white);font-size:10px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}
.nav-cart:hover .nav-cart-count{background:var(--white);color:var(--accent)}

/* Mini Cart Dropdown */
.mini-cart{position:absolute;top:calc(100% + 10px);right:0;width:340px;background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:0 15px 50px rgba(0,0,0,.15);z-index:300;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s ease}
.nav-cart-wrap:hover .mini-cart{opacity:1;visibility:visible;transform:none}
.mini-cart-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--bdr)}
.mini-cart-header h4{font-size:14px;text-transform:uppercase;letter-spacing:.06em;margin:0}
.mini-cart-count{font-size:12px;color:var(--muted)}
.mini-cart-items{max-height:280px;overflow-y:auto;padding:12px 20px}
.mini-cart-item{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--bdr)}
.mini-cart-item:last-child{border-bottom:none}
.mini-cart-item img{width:52px;height:52px;object-fit:cover;border-radius:6px;border:1px solid var(--bdr);flex-shrink:0}
.mini-cart-item-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.mini-cart-item-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-cart-item-name:hover{color:var(--accent)}
.mini-cart-item-qty{font-size:12px;color:var(--muted)}
.mini-cart-empty{font-size:14px;color:var(--muted);text-align:center;padding:24px 0}
.mini-cart-footer{padding:16px 20px;border-top:1px solid var(--bdr);background:var(--light);border-radius:0 0 var(--r) var(--r)}
.mini-cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;color:var(--text)}
.mini-cart-total strong{font-size:16px;font-family:'Inter',sans-serif}
.mini-cart-btns{display:flex;gap:8px}
.mini-cart-btns .btn{flex:1;text-align:center;padding:10px 16px}

.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;margin-left:auto;width:40px;height:40px}
.nav-hamburger span{display:block;height:2px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.active span:nth-child(2){opacity:0}
.nav-hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.search-bar{display:none;border-top:1px solid var(--bdr);padding:12px 0;background:var(--white)}
.search-bar.active{display:block}
.search-bar-inner{display:flex}
.search-bar-inner form{display:flex;flex:1;border:1px solid var(--bdr);border-radius:var(--r);overflow:visible;position:relative}
.search-bar-inner input{flex:1;padding:11px 16px;font-size:14px;border:none;outline:none;background:var(--white);color:var(--text)}
.search-bar-inner button{padding:11px 18px;background:var(--accent);border:none;cursor:pointer;color:var(--white);display:flex;transition:background var(--t)}
.search-bar-inner button:hover{background:var(--accent-h)}

/* Search autocomplete */
.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:0 20px 50px rgba(0,0,0,.1);max-height:70vh;overflow-y:auto;display:none;z-index:1001}
.search-suggestions.is-open{display:block}
.search-sug-group{padding:12px 0;border-bottom:1px solid var(--bdr)}
.search-sug-group:last-child{border-bottom:none}
.search-sug-group h4{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:0 20px;margin-bottom:8px}
.search-sug-prod{display:flex;align-items:center;gap:14px;padding:10px 20px;color:var(--text);text-decoration:none;transition:background .15s}
.search-sug-prod:hover{background:var(--light)}
.search-sug-prod img{width:48px;height:48px;object-fit:cover;border-radius:var(--r);border:1px solid var(--bdr);flex-shrink:0}
.search-sug-info{flex:1;min-width:0}
.search-sug-name{display:block;font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-sug-price{font-size:14px;font-weight:700;color:var(--accent);display:inline-flex;gap:8px;align-items:baseline}
.search-sug-price s{color:var(--muted);font-weight:400;font-size:12px;text-decoration:line-through}
.search-sug-price strong{color:var(--accent);font-weight:800;font-size:15px}
.search-sug-price em{font-style:normal;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.search-sug-prod.is-oos{opacity:.6}
.search-sug-prod.is-oos img{filter:grayscale(40%)}
.search-sug-cat{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;color:var(--text);text-decoration:none;font-size:14px;transition:background .15s}
.search-sug-cat:hover{background:var(--light);color:var(--accent)}
.search-sug-cat small{color:var(--muted);font-size:12px}
.search-sug-empty{padding:24px 20px;text-align:center;color:var(--muted);font-size:14px}
.search-sug-all{display:block;text-align:center;padding:12px;background:var(--dark);color:var(--white);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:background .2s}
.search-sug-all:hover{background:var(--accent);color:var(--white)}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero{position:relative;height:840px;display:flex;align-items:center;justify-content:flex-start;overflow:hidden;background:var(--dark)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(27,27,24,.92) 0%,rgba(27,27,24,.74) 45%,rgba(27,27,24,.28) 100%);z-index:1}

.hero-inner{position:relative;z-index:3;text-align:left;width:100%}
.hero-tag{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:20px}
.hero-title{font-size:clamp(40px,4.5vw,64px);color:var(--white);text-transform:uppercase;margin-bottom:24px;line-height:1.05;max-width:580px}
.hero-desc{font-size:15px;color:rgba(255,255,255,.5);max-width:420px;margin-bottom:40px;line-height:1.8}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}

/* ══════════════════════════════════════════
   BRAND LOGOS ROW
══════════════════════════════════════════ */
.brands{background:var(--light);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);padding:0}
.brands-inner{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0;padding:0;margin:0;width:100%}
.brands-inner--3{flex-wrap:nowrap}
.brands-inner img{width:auto;max-height:150px;height:150px;padding:24px 70px;opacity:.35;filter:grayscale(100%);transition:opacity var(--t),filter var(--t);border-right:1px solid var(--bdr);object-fit:contain}
.brands-inner img:last-child{border-right:none}
.brands-inner img:hover{opacity:1;filter:none}

/* ══════════════════════════════════════════
   CATEGORIES — 5 tiles, contained, bordered
══════════════════════════════════════════ */
.categories{padding:80px 0;background:var(--white)}
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--bdr)}
.cat-card{position:relative;display:block;overflow:hidden;aspect-ratio:3/4;border-right:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.cat-card:nth-child(5){border-right:none}
.cat-img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.3;transition:opacity .3s,transform .6s}
.cat-card:hover .cat-img{opacity:1;transform:scale(1.06)}
.cat-info{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:2;background:linear-gradient(transparent,rgba(27,27,24,.7));color:var(--white)}
.cat-info h3{font-size:20px;text-transform:uppercase;letter-spacing:.04em;color:var(--white);margin-bottom:2px}
.cat-info span{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s;display:block}
.cat-card:hover .cat-info span{opacity:1;transform:none}
.categories--secondary{background:var(--light)}

/* ══════════════════════════════════════════
   MANUFACTURERS + FOUNDER
══════════════════════════════════════════ */
.mfr{position:relative;background:var(--dark);padding:100px 0;overflow:hidden}
.mfr::before{content:"";position:absolute;inset:0;background-image:linear-gradient(135deg,rgba(27,27,24,.92) 0%,rgba(27,27,24,.75) 50%,rgba(27,27,24,.95) 100%),url('/wp-content/themes/optikwelt/assets/img/hero-hunting-2.jpg');background-size:cover;background-position:center;background-repeat:no-repeat;z-index:1}
.mfr::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(241,14,11,.08) 0%,transparent 50%);pointer-events:none;z-index:2}
.mfr .container{position:relative;z-index:3}
.mfr-deco{position:absolute;inset:0;background-size:contain;background-repeat:no-repeat;background-position:right center;opacity:.03;pointer-events:none}
.mfr-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.mfr-title{font-size:clamp(36px,4.5vw,56px);color:var(--white);text-transform:uppercase;margin-bottom:20px}
.mfr-desc{font-size:15px;color:rgba(255,255,255,.45);line-height:1.85;max-width:400px}

.mfr-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.mfr-stat{background:var(--dark2);border:1px solid var(--bdr-w);border-radius:var(--r);padding:28px 20px;text-align:center}
.mfr-stat-n{display:block;font-family:'Montserrat',sans-serif;font-size:clamp(32px,3.5vw,48px);color:var(--accent);line-height:1;margin-bottom:6px}
.mfr-stat-l{display:block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* ══════════════════════════════════════════
   PRODUCTS — grids
══════════════════════════════════════════ */
.products{background:var(--white);padding:100px 0}
.products--secondary{background:var(--light)}
.prod-grid{display:grid;gap:20px}
.prod-grid--3{grid-template-columns:repeat(3,1fr)}
.prod-grid--4{grid-template-columns:repeat(4,1fr)}
.prod{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;transition:box-shadow var(--t),transform var(--t)}
.prod:hover{box-shadow:0 10px 40px rgba(0,0,0,.1);transform:translateY(-3px)}
.prod-img{position:relative;aspect-ratio:1/1;background:var(--light);overflow:hidden}
.prod-img>img,.prod-img>a>img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.prod-img>a{display:block;width:100%;height:100%}
.prod:hover .prod-img>img{transform:scale(1.04)}
.prod-wish{position:absolute;top:10px;right:10px;background:var(--white);border:1px solid var(--bdr);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;color:var(--body);opacity:0;transition:all var(--t);box-shadow:0 2px 6px rgba(0,0,0,.08)}
.prod:hover .prod-wish{opacity:1}
.prod-wish:hover{background:var(--accent);color:var(--white);border-color:var(--accent)}
.prod-badge{position:absolute;top:10px;left:10px;background:var(--accent);color:var(--white);font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--r)}
.prod-body{padding:18px}
.prod-stars{margin-bottom:8px}
.prod-stars .star-rating{font-size:14px;color:var(--accent);line-height:1}
.star-rating{display:inline-block;overflow:hidden;position:relative;height:1.2em;line-height:1.2;font-size:14px;width:5.4em;font-family:star}
.star-rating::before{content:"\2606\2606\2606\2606\2606";color:var(--bdr);float:left;top:0;left:0;position:absolute}
.star-rating span{overflow:hidden;float:left;top:0;left:0;position:absolute;padding-top:1.5em}
.star-rating span::before{content:"\2605\2605\2605\2605\2605";top:0;position:absolute;left:0;color:var(--accent)}
.prod-body h3{font-family:'Inter',sans-serif;font-size:14px;font-weight:600;text-transform:none;letter-spacing:0;line-height:1.4;margin-bottom:8px}
.prod-body h3 a{color:var(--text)}
.prod-body h3 a:hover{color:var(--accent)}
.prod-price{font-size:17px;font-weight:700;color:var(--text);margin-bottom:14px;font-family:'Inter',sans-serif}
.prod-price s{color:var(--muted);font-weight:400;font-size:13px;margin-right:6px}
.prod-add-form{display:flex;gap:8px;align-items:stretch}
.prod-qty{display:inline-flex;align-items:center;border:1.5px solid var(--bdr);border-radius:var(--r);overflow:hidden;flex-shrink:0}
.prod-qty-btn{width:32px;height:36px;background:var(--white);border:none;cursor:pointer;font-size:16px;font-weight:600;color:var(--text);display:flex;align-items:center;justify-content:center;transition:all .15s}
.prod-qty-btn:hover{background:var(--light)}
.prod-qty-input{width:36px;height:36px;border:none;border-left:1px solid var(--bdr);border-right:1px solid var(--bdr);text-align:center;font-size:13px;font-weight:600;font-family:'Inter',sans-serif;outline:none;-moz-appearance:textfield;background:var(--white);padding:0}
.prod-qty-input::-webkit-inner-spin-button,.prod-qty-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.prod-add-btn{flex:1;min-width:0}
.prod-add-btn.loading{opacity:.6;pointer-events:none}
.prod-add-btn.added{background:#2D8A4E !important;border-color:#2D8A4E !important}
.prod--oos{opacity:.75}
.prod--oos .prod-img img{filter:grayscale(30%)}
.prod-badge--oos{background:var(--muted);color:var(--white)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--bdr)}
.btn-outline:hover{background:var(--dark);color:var(--white);border-color:var(--dark)}

/* ══════════════════════════════════════════
   OFFER + STATS — LIGHT bg with texture
══════════════════════════════════════════ */
.offer{position:relative;padding:100px 0;background:var(--light);overflow:hidden}
.offer .offer-texture{position:absolute;inset:0;background-repeat:repeat;opacity:.03;pointer-events:none}
.offer-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.offer-title{font-size:clamp(36px,4.5vw,56px);text-transform:uppercase;margin-bottom:20px}
.offer-desc{font-size:15px;color:var(--body);line-height:1.85;margin-bottom:32px;max-width:440px}

.stats{display:grid;grid-template-columns:1fr 1fr}
.stat{padding:32px 20px;text-align:center;border:1px solid var(--bdr)}
.stat-n{display:block;font-family:'Montserrat',sans-serif;font-size:clamp(44px,5vw,68px);color:var(--accent);line-height:1;margin-bottom:6px}
.stat-l{display:block;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--body)}

/* ══════════════════════════════════════════
   HOTSPOT
══════════════════════════════════════════ */
.hotspot-section{background:var(--white);padding:100px 0}
.hs-wrap{position:relative;border-radius:var(--r);overflow:hidden}
.hs-wrap>img{width:100%;display:block}
.hs{position:absolute;z-index:10;cursor:pointer}
.hs-dot{width:16px;height:16px;background:var(--accent);border-radius:50%;border:3px solid var(--white);box-shadow:0 0 0 0 rgba(241,14,11,.5);animation:pulse 2s ease-out infinite}
.hs-tip{position:absolute;left:24px;top:50%;transform:translateY(-50%) translateX(-6px);background:var(--white);color:var(--text);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:var(--r);white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.14);opacity:0;pointer-events:none;transition:all .2s}
.hs:hover .hs-tip{opacity:1;transform:translateY(-50%) translateX(0)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(241,14,11,.5)}70%{box-shadow:0 0 0 14px rgba(241,14,11,0)}100%{box-shadow:0 0 0 0 rgba(241,14,11,0)}}

/* ══════════════════════════════════════════
   BENEFITS — 4 columns
══════════════════════════════════════════ */
.bens{background:var(--light);padding:80px 0}
.bens-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.ben{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);padding:36px 28px;text-align:center;transition:all var(--t);position:relative;overflow:hidden}
.ben::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.ben:hover{border-color:var(--dark);box-shadow:0 10px 30px rgba(0,0,0,.08);transform:translateY(-4px)}
.ben:hover::before{transform:scaleX(1)}
.ben-ico{width:64px;height:64px;background:var(--light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:all var(--t)}
.ben:hover .ben-ico{background:var(--accent)}
.ben-ico svg{width:28px;height:28px;color:var(--accent);transition:color var(--t)}
.ben:hover .ben-ico svg{color:var(--white)}
.ben h4{font-size:15px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;color:var(--text)}
.ben p{font-size:13px;color:var(--body);line-height:1.7;margin:0}

/* ══════════════════════════════════════════
   NEWSLETTER SIGNUP
══════════════════════════════════════════ */
.newsletter{background:var(--dark);padding:60px 0}
.newsletter-inner{text-align:center}
.newsletter .tag{color:var(--accent);margin-bottom:24px}
.newsletter-form{max-width:560px;margin:0 auto}
.newsletter-field{display:flex;gap:0;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.newsletter-field input{flex:1;padding:14px 20px;font-size:14px;border:none;outline:none;background:rgba(255,255,255,.06);color:var(--white);font-family:'Inter',sans-serif}
.newsletter-field input::placeholder{color:rgba(255,255,255,.35)}
.newsletter-field .btn{border-radius:0;border:none;padding:14px 28px}
.newsletter-consent{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:14px;font-size:12px;color:rgba(255,255,255,.4)}
.newsletter-consent input[type="checkbox"]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}
.newsletter-consent a{color:var(--accent);text-decoration:underline}
.newsletter-consent a:hover{color:var(--white)}

/* ══════════════════════════════════════════
   SCROLL TOP
══════════════════════════════════════════ */
.scroll-top{position:fixed;bottom:24px;right:24px;width:42px;height:42px;background:var(--accent);color:var(--white);border:none;border-radius:var(--r);cursor:pointer;opacity:0;pointer-events:none;transition:all .3s;z-index:900;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(241,14,11,.3)}
.scroll-top.visible{opacity:1;pointer-events:auto}
.scroll-top:hover{background:var(--accent-h);transform:translateY(-2px)}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.footer{background:var(--dark);color:rgba(255,255,255,.45);padding-top:72px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:56px}
img.footer-logo{height:32px !important;width:auto !important;max-height:32px;margin-bottom:16px}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.55);max-width:260px;margin-bottom:18px;line-height:1.75}

/* Footer subscribe form */
.footer-subscribe{display:flex;gap:0;margin-bottom:18px;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.footer-subscribe input{flex:1;padding:10px 14px;font-size:13px;border:none;outline:none;background:rgba(255,255,255,.05);color:var(--white);font-family:'Inter',sans-serif}
.footer-subscribe input::placeholder{color:rgba(255,255,255,.3)}
.footer-subscribe button{padding:10px 16px;background:var(--accent);border:none;cursor:pointer;color:var(--white);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-family:'Inter',sans-serif;transition:background var(--t)}
.footer-subscribe button:hover{background:var(--accent-h)}

.footer-social{display:flex;gap:8px;margin-bottom:16px}
.footer-social a{width:36px;height:36px;border-radius:var(--r);background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all var(--t)}
.footer-social a:hover{background:var(--accent);color:var(--white)}

/* Footer contact */
.footer-contact{display:flex;flex-direction:column;gap:6px}
.footer-contact span{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.6)}
.footer-contact svg{flex-shrink:0;color:var(--accent);stroke:var(--accent)}

.footer-col h4{font-size:18px;letter-spacing:.08em;text-transform:uppercase;color:var(--white);margin-bottom:14px}
.footer-col p{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7}
.footer-col a{color:rgba(255,255,255,.55);transition:color var(--t)}
.footer-col a:hover{color:var(--accent)}

/* Footer mini products */
.footer-mini-products{display:flex;flex-direction:column;gap:14px}
.footer-mini-prod{display:flex;gap:12px;align-items:center}
.footer-mini-prod img{width:56px;height:56px;object-fit:cover;border-radius:var(--r);flex-shrink:0;border:1px solid rgba(255,255,255,.08)}
.footer-mini-prod div{display:flex;flex-direction:column;gap:2px}
.footer-mini-name{font-size:13px;color:rgba(255,255,255,.65);line-height:1.3;transition:color var(--t)}
.footer-mini-prod:hover .footer-mini-name{color:var(--accent)}
.footer-mini-price{font-size:14px;font-weight:700;color:var(--accent);font-family:'Inter',sans-serif}

/* Footer links */
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links li a{font-size:14px;color:rgba(255,255,255,.6);display:block;padding:2px 0;transition:color var(--t),padding-left var(--t)}
.footer-links li a:hover{color:var(--accent);padding-left:4px}

.footer-bottom{border-top:1px solid var(--bdr-w);padding:18px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(255,255,255,.4)}
.footer-bottom-inner div{display:flex;gap:20px}
.footer-bottom-inner a{color:rgba(255,255,255,.4)}
.footer-bottom-inner a:hover{color:var(--accent)}

/* ══════════════════════════════════════════
   SITE MAIN — shared inner-page wrapper
══════════════════════════════════════════ */
.site-main{padding-top:0}

/* ══════════════════════════════════════════
   BREADCRUMBS (WooCommerce)
══════════════════════════════════════════ */
.woocommerce-breadcrumb{font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.woocommerce-breadcrumb a{color:var(--body);transition:color var(--t)}
.woocommerce-breadcrumb a:hover{color:var(--accent)}

/* ══════════════════════════════════════════
   SHOP HERO — archive page header
══════════════════════════════════════════ */
.shop-hero{background:var(--dark);padding:60px 0 50px;position:relative;overflow:hidden}
.shop-hero--bg{background-size:cover;background-position:center;background-repeat:no-repeat}
.shop-hero--bg > .container{position:relative;z-index:2}
.shop-hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(27,27,24,.85) 0%,rgba(27,27,24,.7) 100%);z-index:1}
.shop-hero .woocommerce-breadcrumb{color:rgba(255,255,255,.35)}
.shop-hero .woocommerce-breadcrumb a{color:rgba(255,255,255,.5)}
.shop-hero .woocommerce-breadcrumb a:hover{color:var(--accent)}
.shop-hero-title{font-size:clamp(32px,4vw,52px);color:var(--white);text-transform:uppercase;margin-bottom:8px}
.shop-hero-desc{font-size:15px;color:rgba(255,255,255,.45);max-width:540px}

/* ══════════════════════════════════════════
   SHOP LAYOUT — sidebar + grid
══════════════════════════════════════════ */
.shop-content{padding:60px 0 80px;background:var(--light)}
.shop-layout{display:grid;grid-template-columns:260px 1fr;gap:40px}

/* Sidebar */
.shop-sidebar{position:sticky;top:90px;align-self:start}
.sidebar-section{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;margin-bottom:20px}
.sidebar-title{font-size:16px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px}
.sidebar-cats{display:flex;flex-direction:column;gap:2px}
.sidebar-cats li a{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:14px;color:var(--body);border-radius:6px;transition:all var(--t)}
.sidebar-cats li a:hover,.sidebar-cats li.active a{background:var(--light);color:var(--accent)}
.sidebar-cats li a span{font-size:12px;color:var(--muted)}

/* Price filter */
.price-filter-form{display:flex;flex-direction:column;gap:12px}
.price-inputs{display:flex;align-items:center;gap:8px}
.price-inputs input{width:100%;padding:8px 10px;border:1px solid var(--bdr);border-radius:6px;font-size:13px;font-family:'Inter',sans-serif;outline:none;background:var(--light)}
.price-inputs input:focus{border-color:var(--accent)}
.price-sep{color:var(--muted);font-size:14px}

/* Toolbar */
.shop-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.shop-result-count,.shop-toolbar .woocommerce-result-count{font-size:13px;color:var(--muted);margin:0;padding:0;text-align:left}
.shop-toolbar p.woocommerce-result-count{float:none;margin:0}
.shop-ordering select,.shop-toolbar .woocommerce-ordering select{padding:8px 14px;border:1px solid var(--bdr);border-radius:6px;font-size:13px;font-family:'Inter',sans-serif;background:var(--white);cursor:pointer;outline:none}
.shop-toolbar .woocommerce-ordering{float:none;margin:0}

/* Shop pagination */
/* Shop pagination — paginate_links() outputs <ul class="page-numbers"><li><a/span> */
.shop-pagination{margin-top:48px}
.shop-pagination ul.page-numbers{display:flex;flex-direction:row;justify-content:center;gap:6px;flex-wrap:wrap;list-style:none;padding:0;margin:0}
.shop-pagination ul.page-numbers li{list-style:none;margin:0;padding:0}
.shop-pagination ul.page-numbers li a,.shop-pagination ul.page-numbers li span{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 4px;border:1px solid var(--bdr);border-radius:var(--r);font-size:14px;font-weight:600;color:var(--text);background:var(--white);transition:all var(--t);text-decoration:none}
.shop-pagination ul.page-numbers li span.current,.shop-pagination ul.page-numbers li a:hover{background:var(--accent);color:var(--white);border-color:var(--accent)}

.wc-no-products,.search-no-results{text-align:center;padding:80px 0;font-size:16px;color:var(--body)}
.search-no-results .btn{margin-top:20px}

/* ══════════════════════════════════════════
   SINGLE PRODUCT
══════════════════════════════════════════ */
.single-product-wrap{padding:40px 0 80px}
.sp-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:60px}

/* Gallery */
.sp-gallery{position:sticky;top:90px;align-self:start}
.sp-main-img{position:relative;border-radius:var(--r);overflow:hidden;background:var(--light);border:1px solid var(--bdr);margin-bottom:12px;aspect-ratio:1/1}
.sp-main-img img{width:100%;height:100%;object-fit:contain}
.prod-badge--lg{font-size:13px;padding:6px 16px}
.sp-thumbs{display:flex;gap:8px;flex-wrap:wrap}
.sp-thumb{width:72px;height:72px;border:2px solid var(--bdr);border-radius:6px;overflow:hidden;cursor:pointer;padding:0;background:var(--light);transition:border-color var(--t)}
.sp-thumb.active,.sp-thumb:hover{border-color:var(--accent)}
.sp-thumb img{width:100%;height:100%;object-fit:cover}

/* Info */
.sp-cat{font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:block}
.sp-cat a{color:var(--accent)}
.sp-cat a:hover{color:var(--accent-h)}
.sp-title{font-size:clamp(28px,3.5vw,42px);text-transform:uppercase;margin-bottom:16px;line-height:1.15}
.sp-price{font-size:28px;font-weight:800;color:var(--text);margin-bottom:20px;font-family:'Inter',sans-serif}
.sp-price del{color:var(--muted);font-weight:400;font-size:20px;margin-right:8px}
.sp-price ins{text-decoration:none;color:var(--accent)}
.sp-short-desc{font-size:15px;color:var(--body);line-height:1.8;margin-bottom:20px;max-width:500px}
.sp-short-desc p{margin-bottom:10px}

.sp-stock{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;margin-bottom:24px}
.sp-stock span{width:8px;height:8px;border-radius:50%;display:inline-block}
.sp-stock--in{color:#2D8A4E}
.sp-stock--in span{background:#2D8A4E}
.sp-stock--out{color:var(--accent)}
.sp-stock--out span{background:var(--accent)}

/* Add to cart */
.sp-add-to-cart{display:flex;gap:12px;align-items:center;margin-bottom:24px;flex-wrap:wrap}
.sp-qty{display:flex;align-items:center;border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden}
.sp-qty-btn{width:40px;height:44px;background:var(--light);border:none;cursor:pointer;font-size:18px;font-weight:600;color:var(--text);transition:background var(--t)}
.sp-qty-btn:hover{background:var(--bdr)}
.sp-qty-input{width:52px;height:44px;border:none;text-align:center;font-size:15px;font-weight:600;font-family:'Inter',sans-serif;outline:none;-moz-appearance:textfield}
.sp-qty-input::-webkit-inner-spin-button,.sp-qty-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.sp-add-to-cart .btn{padding:14px 36px}
.sp-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;padding-top:18px;padding-bottom:18px;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.sp-compare-btn,.sp-ask-btn,.sp-notify-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--white);color:var(--text);border:1.5px solid var(--bdr);border-radius:var(--r);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all var(--t);font-family:'Inter',sans-serif}
.sp-compare-btn:hover,.sp-ask-btn:hover{border-color:var(--dark);color:var(--text);background:var(--light)}
.sp-compare-btn.active{background:var(--dark);color:var(--white);border-color:var(--dark)}
.sp-compare-btn.active svg{color:var(--accent)}
.sp-notify-btn{background:var(--dark);color:var(--white);border-color:var(--dark);padding:14px 28px;font-size:12px;width:100%;justify-content:center;margin-bottom:14px}
.sp-notify-btn:hover{background:var(--accent);border-color:var(--accent);color:var(--white)}

/* Modal */
.ow-modal{display:none;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center}
.ow-modal.is-open{display:flex}
.ow-modal__overlay{position:absolute;inset:0;background:rgba(27,27,24,.6);backdrop-filter:blur(4px);cursor:pointer}
.ow-modal__dialog{position:relative;background:var(--white);border-radius:1rem;padding:36px 32px 28px;max-width:560px;width:calc(100% - 32px);max-height:90vh;overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.3);animation:modal-in .25s ease}
@keyframes modal-in{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}
.ow-modal__close{position:absolute;top:14px;right:14px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--light);border:none;border-radius:50%;cursor:pointer;font-size:24px;line-height:1;color:var(--text);transition:all var(--t)}
.ow-modal__close:hover{background:var(--accent);color:var(--white)}
.ow-modal__title{font-size:20px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;padding-right:32px}
.ow-modal__product{font-size:14px;color:var(--accent);font-weight:600;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--bdr)}
.ow-modal__product:empty{display:none}
.ow-modal .wpcf7-form > p:last-of-type{display:flex;justify-content:flex-end}

/* Compare page */
.compare-page{padding:48px 0 80px}
.compare-empty{text-align:center;padding:60px 0;max-width:520px;margin:0 auto}
.compare-empty h2{font-size:24px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}
.compare-empty p{color:var(--body);font-size:15px;line-height:1.7;margin-bottom:24px}
.compare-loading{text-align:center;padding:60px 0}
.compare-spinner{width:40px;height:40px;border:3px solid var(--bdr);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.compare-actions{display:flex;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}
.compare-table-scroll{overflow-x:auto;border:1px solid var(--bdr);border-radius:var(--r);background:var(--white)}
.compare-table{width:100%;border-collapse:collapse;min-width:600px}
.compare-table thead th{padding:24px 18px;border-bottom:1px solid var(--bdr);background:var(--light);vertical-align:top;text-align:center;position:relative}
.compare-table .compare-th-empty{background:var(--white);border-bottom:1px solid var(--bdr);width:200px;min-width:200px}
.compare-table .compare-th-product{min-width:240px}
.compare-remove{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;background:var(--white);border:1px solid var(--bdr);font-size:18px;line-height:1;cursor:pointer;color:var(--muted);transition:all var(--t);display:flex;align-items:center;justify-content:center;padding:0}
.compare-remove:hover{background:var(--accent);color:var(--white);border-color:var(--accent)}
.compare-prod-link{display:flex;flex-direction:column;align-items:center;gap:14px;text-decoration:none;color:var(--text)}
.compare-prod-img{width:140px;height:140px;object-fit:cover;border-radius:var(--r);border:1px solid var(--bdr);background:var(--white)}
.compare-prod-name{font-size:14px;font-weight:700;line-height:1.4;text-align:center;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.compare-prod-link:hover .compare-prod-name{color:var(--accent)}
.compare-table tbody tr{border-bottom:1px solid var(--bdr)}
.compare-table tbody tr:last-child{border-bottom:none}
.compare-table tbody tr:nth-child(even){background:var(--light)}
.compare-table tbody td,.compare-table tbody th{padding:14px 18px;font-size:14px;vertical-align:middle;line-height:1.5}
.compare-row-label{font-weight:600;color:var(--text);text-align:left;background:var(--white) !important;border-right:1px solid var(--bdr);width:200px;min-width:200px}
.compare-table tbody tr:nth-child(even) .compare-row-label{background:var(--light) !important}
.compare-cell-price{font-size:16px;font-weight:700;color:var(--accent)}
.compare-cell-price s{color:var(--muted);font-weight:400;font-size:13px;margin-right:6px;text-decoration:line-through}
.compare-cell-price strong{color:var(--accent);font-weight:800;font-size:17px}
.compare-cell-price em{font-style:normal;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.compare-cell-desc{font-size:13px;color:var(--body);max-width:280px}
.compare-stock{display:inline-block;padding:4px 10px;border-radius:9999px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.compare-stock--in{background:#ecfdf5;color:#059669}
.compare-stock--out{background:#fef2f2;color:#dc2626}
.compare-row-divider td{padding:18px;background:var(--dark) !important;color:var(--white) !important;text-transform:uppercase;letter-spacing:.06em;font-size:13px}
.compare-row-divider td strong{color:var(--white)}
@media (max-width: 768px) {
    .compare-table .compare-th-empty,.compare-row-label{width:140px;min-width:140px}
    .compare-table .compare-th-product{min-width:180px}
    .compare-prod-img{width:100px;height:100px}
}

/* Compare dock */
.compare-dock{position:fixed;bottom:0;left:0;right:0;background:var(--dark);color:var(--white);transform:translateY(100%);transition:transform .3s ease;z-index:900;box-shadow:0 -10px 30px rgba(0,0,0,.15)}
.compare-dock.is-open{transform:translateY(0)}
.compare-dock__inner{max-width:1440px;margin:0 auto;padding:16px 60px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.compare-dock__label{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white);flex-shrink:0}
.compare-dock__items{display:flex;gap:12px;flex:1;overflow-x:auto;min-width:0}
.compare-dock__item{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border-radius:var(--r);padding:8px 12px;flex-shrink:0;min-width:200px;max-width:260px}
.compare-dock__item img{width:36px;height:36px;object-fit:cover;border-radius:4px;flex-shrink:0}
.compare-dock__item span{font-size:12px;color:var(--white);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.compare-dock__remove{background:transparent;border:none;color:rgba(255,255,255,.5);cursor:pointer;font-size:18px;line-height:1;padding:0 4px}
.compare-dock__remove:hover{color:var(--accent)}
.compare-dock__view{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:var(--white);padding:10px 18px;border-radius:var(--r);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:all var(--t);flex-shrink:0;border:1px solid var(--accent)}
.compare-dock__view:hover{background:var(--accent-h);border-color:var(--accent-h);transform:translateY(-1px)}
.compare-dock__clear{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--white);padding:8px 16px;border-radius:var(--r);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all var(--t);flex-shrink:0}
.compare-dock__clear:hover{background:var(--accent);border-color:var(--accent)}
@media (max-width: 768px){
    .compare-dock__inner{padding:12px 24px;flex-direction:column;align-items:stretch}
    .compare-dock__items{overflow-x:auto}
}

.sp-meta{font-size:13px;color:var(--muted);padding-top:16px;border-top:1px solid var(--bdr)}

/* Key-specs strip (above tabs) */
.key-specs{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin:0 0 36px;background:transparent}
.key-specs__item{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:8px;padding:24px 12px;background:#f3f4f5;border-radius:6px;text-align:center;min-height:140px}
.key-specs__icon{width:32px;height:32px;color:var(--text);stroke-width:1.6;flex-shrink:0;margin-bottom:4px}
.key-specs__label{font-size:13px;color:var(--muted);font-weight:500;line-height:1.3}
.key-specs__value{font-size:15px;color:var(--accent);font-weight:700;line-height:1.3;margin-top:auto}
@media (max-width:900px){.key-specs{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:480px){.key-specs{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* Meedia tab */
.sp-media{display:flex;flex-direction:column;gap:32px}
.sp-media__videos{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:24px}
.sp-media__video{margin:0}
.sp-media__embed{position:relative;aspect-ratio:16/9;background:#000;border-radius:6px;overflow:hidden}
.sp-media__embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.sp-media__caption{margin:8px 0 0;font-size:13px;color:var(--muted)}
.sp-media__gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.sp-media__gallery-item{display:block;aspect-ratio:1;background:#f3f4f5;border-radius:6px;overflow:hidden;transition:transform var(--t)}
.sp-media__gallery-item:hover{transform:translateY(-2px)}
.sp-media__gallery-item img{width:100%;height:100%;object-fit:cover;display:block}

/* Tabs */
.sp-tabs{border-top:1px solid var(--bdr);padding-top:40px;margin-bottom:60px}
.sp-tab-nav{display:flex;gap:0;border-bottom:2px solid var(--bdr);margin-bottom:32px}
.sp-tab-btn{padding:12px 28px;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--muted);transition:all var(--t);font-family:'Inter',sans-serif}
.sp-tab-btn.active,.sp-tab-btn:hover{color:var(--text);border-bottom-color:var(--accent)}
.sp-tab-pane{display:none}
.sp-tab-pane.active{display:block}
.sp-description{font-size:15px;color:var(--body);line-height:1.85;max-width:720px}
.sp-description p{margin-bottom:16px}
.sp-description h2,.sp-description h3{color:var(--text);margin:32px 0 16px;font-size:20px}
.sp-description h3{font-size:17px;font-weight:700}
.sp-description ul,.sp-description ol{padding-left:20px;margin-bottom:16px}
.sp-description li{margin-bottom:6px}
.sp-description img{max-width:100%;height:auto;border-radius:var(--r);margin:16px 0}
.sp-description iframe{max-width:100%;margin:16px 0}
.yt-embed,.sp-description .yt-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--r);margin:20px 0;background:var(--dark)}
.yt-embed iframe,.sp-description .yt-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;margin:0;border-radius:var(--r)}
.sp-description a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* Spec tables inside description — style as proper spec tables */
.sp-description table{width:100%;max-width:100%;border-collapse:collapse;margin:24px 0;background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden}
.sp-description table tr{border-bottom:1px solid var(--bdr)}
.sp-description table tr:last-child{border-bottom:none}
.sp-description table tr:nth-child(odd) td{background:var(--light)}
.sp-description table td,.sp-description table th{padding:12px 18px;font-size:14px;text-align:left;vertical-align:top;line-height:1.5}
.sp-description table td:first-child,.sp-description table th:first-child{font-weight:600;color:var(--text);width:45%;min-width:180px}
.sp-description table td:not(:first-child),.sp-description table th:not(:first-child){color:var(--body)}
.sp-description table tbody,.sp-description table thead{display:table-row-group}

/* Specs table */
.sp-specs-table{width:100%;max-width:600px;border-collapse:collapse}
.sp-specs-table tr{border-bottom:1px solid var(--bdr)}
.sp-specs-table th,.sp-specs-table td{padding:12px 16px;font-size:14px;text-align:left}
.sp-specs-table th{font-weight:600;color:var(--text);width:40%;background:var(--light)}
.sp-specs-table td{color:var(--body)}

/* Related products */
.sp-related{padding-top:40px;border-top:1px solid var(--bdr)}

/* ══════════════════════════════════════════
   GENERIC PAGE
══════════════════════════════════════════ */
.page-hero{background:var(--dark);padding:60px 0 50px}
.page-hero-title{font-size:clamp(32px,4vw,52px);color:var(--white);text-transform:uppercase}
.page-content{padding:60px 0 80px;font-size:15px;color:var(--body);line-height:1.85}

/* ══════════════════════════════════════════
   STORIES — Blog Index
══════════════════════════════════════════ */
.stories-hero{background:var(--dark);padding:60px 0 50px;text-align:center}
.stories-hero__title{font-size:clamp(32px,4vw,52px);color:var(--white);text-transform:uppercase;margin-bottom:8px}
.stories-hero__sub{font-size:15px;color:rgba(255,255,255,.45);margin-bottom:16px}
.stories-hero__count{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--white);background:rgba(255,255,255,.1);padding:6px 16px;border-radius:9999px}

.stories-wrap{padding:48px 0 80px}

.stories-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.stories-grid--3{grid-template-columns:repeat(3,1fr)}

.story-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--bdr);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all .3s}
.story-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.1)}
.story-card__image{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--light)}
.story-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.story-card:hover .story-card__image img{transform:scale(1.04)}
.story-card__placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--dark) 0%,var(--dark2) 100%)}
.story-card__cat{position:absolute;top:12px;left:12px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--accent);color:var(--white);padding:4px 10px;border-radius:4px}
.story-card__body{padding:20px 24px 24px;display:flex;flex-direction:column;flex:1}
.story-card__meta{font-size:12px;color:var(--muted);margin-bottom:8px;font-weight:500}
.story-card__title{font-size:18px;font-weight:800;color:var(--text);line-height:1.3;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.story-card__excerpt{font-size:14px;color:var(--body);line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.story-card__more{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-top:auto}
.story-card:hover .story-card__more{color:var(--accent-h)}

/* Pagination */
.stories-pagination{margin-top:48px;text-align:center}
.stories-pagination .page-numbers{display:inline-flex;gap:0;list-style:none;padding:0;margin:0;align-items:center}
.stories-pagination .page-numbers li{margin:0}
.stories-pagination .page-numbers a,.stories-pagination .page-numbers span{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;font-size:13px;font-weight:600;color:var(--text);text-decoration:none;border:1px solid var(--bdr);border-radius:var(--r);margin:0 3px;transition:all .2s}
.stories-pagination .page-numbers a:hover{background:var(--light);border-color:var(--dark)}
.stories-pagination .page-numbers .current{background:var(--dark);color:var(--white);border-color:var(--dark)}
.stories-pagination .page-numbers .prev,.stories-pagination .page-numbers .next{font-size:12px;letter-spacing:.04em}

.stories-empty{text-align:center;padding:80px 0}
.stories-empty h2{font-size:24px;margin-bottom:8px}
.stories-empty p{color:var(--body)}

/* ══════════════════════════════════════════
   SINGLE STORY — Blog Post
══════════════════════════════════════════ */
.single-story__header{background:var(--dark);padding:60px 0 50px;text-align:center}
.single-story__cat{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:var(--accent);color:var(--white);padding:5px 14px;border-radius:4px;margin-bottom:16px}
.single-story__title{font-size:clamp(24px,3.5vw,42px);color:var(--white);line-height:1.2;margin-bottom:16px}
.single-story__meta{display:flex;gap:8px;justify-content:center;font-size:13px;color:rgba(255,255,255,.45);font-weight:500}

.single-story__wrap{padding:48px 0 80px}
.single-story__hero-img,.single-story__content,.single-story__tags,.single-story__share,.single-story__nav{max-width:800px;margin-left:auto;margin-right:auto}

.single-story__hero-img{margin-bottom:40px;border-radius:12px;overflow:hidden}
.single-story__hero-img img{width:100%;height:auto;display:block}

.single-story__content{font-size:17px;color:var(--body);line-height:1.85}
.single-story__content p{margin-bottom:20px}
.single-story__content h2{font-size:24px;color:var(--text);margin:40px 0 16px}
.single-story__content h3{font-size:20px;color:var(--text);margin:32px 0 12px}
.single-story__content img{max-width:100%;height:auto;border-radius:var(--r);margin:24px 0}
.single-story__content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.single-story__content a:hover{color:var(--accent-h)}
.single-story__content ul,.single-story__content ol{padding-left:24px;margin-bottom:20px}
.single-story__content li{margin-bottom:8px}
.single-story__content blockquote{border-left:4px solid var(--accent);margin:32px 0;padding:16px 24px;background:var(--light);border-radius:0 var(--r) var(--r) 0;font-style:italic;color:var(--text)}
.single-story__content iframe,.single-story__content .wp-block-embed{max-width:100%;margin:32px 0}
.single-story__content .wp-block-embed__wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden}
.single-story__content .wp-block-embed__wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%}

/* Tags */
.single-story__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px}
.single-story__tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--body);background:var(--light);border:1px solid var(--bdr);padding:6px 14px;border-radius:9999px;text-decoration:none;transition:all .2s}
.single-story__tag:hover{background:var(--dark);color:var(--white);border-color:var(--dark)}

/* Share buttons */
.single-story__share{margin-top:40px;padding:24px 0;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.single-story__share-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text)}
.single-story__share-btns{display:flex;gap:8px;align-items:center}
.single-story__share-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:40px;height:40px;border-radius:50%;border:1px solid var(--bdr);background:var(--white);color:var(--body);text-decoration:none;transition:all .2s;cursor:pointer;font-family:'Inter',sans-serif;font-size:12px;font-weight:600}
.single-story__share-btn:hover{background:var(--dark);color:var(--white);border-color:var(--dark)}
.single-story__share-btn--fb:hover{background:#1877F2;border-color:#1877F2}
.single-story__share-btn--x:hover{background:#000;border-color:#000}
.single-story__share-btn--li:hover{background:#0A66C2;border-color:#0A66C2}
.single-story__share-btn--copy{width:auto;border-radius:var(--r);padding:0 16px;gap:6px}
.single-story__share-btn--copy span{font-size:12px}
.single-story__share-btn--copy.copied{background:var(--dark);color:var(--white);border-color:var(--dark)}

/* Post navigation */
.single-story__nav{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:60px;padding-top:40px;border-top:1px solid var(--bdr)}
.single-story__nav-link{display:flex;flex-direction:column;gap:6px;padding:20px;background:var(--light);border:1px solid var(--bdr);border-radius:var(--r);text-decoration:none;transition:all .2s}
.single-story__nav-link:hover{border-color:var(--dark);background:var(--white)}
.single-story__nav-link--next{text-align:right}
.single-story__nav-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.single-story__nav-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Related posts */
.single-story__related{margin-top:60px;padding-top:40px;border-top:1px solid var(--bdr)}
.single-story__related-title{font-size:20px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:24px}
.page-content p{margin-bottom:16px}
.page-content h2,.page-content h3{color:var(--text);margin:32px 0 12px}
.page-content ul,.page-content ol{padding-left:20px;margin-bottom:16px}
.page-content li{margin-bottom:6px}
.page-content a{color:var(--accent)}
.page-content a:hover{color:var(--accent-h)}

/* ── Contact page ── */
.ow-contact-grid{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:flex-start}
.ow-contact-form h2{font-size:24px;margin-bottom:8px}
.ow-contact-form > p{color:var(--body);font-size:14px;line-height:1.7;margin-bottom:28px}
.ow-contact-info{display:flex;flex-direction:column;gap:20px}
.ow-contact-card{background:var(--light);border:1px solid var(--bdr);border-radius:var(--r);padding:28px}
.ow-contact-card h3{font-size:15px;text-transform:uppercase;letter-spacing:.06em;margin:0 0 16px}
.ow-contact-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.ow-contact-card li{font-size:14px;color:var(--body);line-height:1.6}
.ow-contact-card a{color:var(--accent);font-weight:600}
.ow-contact-card a:hover{color:var(--accent-h)}

/* CF7 form styling */
.ow-cf7-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.ow-cf7-col{display:flex;flex-direction:column}
.wpcf7 label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:6px}
.wpcf7 input[type="text"],.wpcf7 input[type="email"],.wpcf7 input[type="tel"],.wpcf7 select,.wpcf7 textarea{width:100%;padding:12px 16px;border:1.5px solid var(--bdr);border-radius:var(--r);font-size:14px;font-family:'Inter',sans-serif;color:var(--text);background:var(--white);transition:border-color .2s,box-shadow .2s;box-sizing:border-box;outline:none}
.wpcf7 input:focus,.wpcf7 select:focus,.wpcf7 textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(241,14,11,.1)}
.wpcf7 textarea{min-height:140px;resize:vertical}
.wpcf7 select{appearance:auto;cursor:pointer}
.wpcf7 input[type="submit"]{display:block;width:100%;background:var(--dark);color:var(--white);font-family:'Inter',sans-serif;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:16px 40px;border:none;border-radius:var(--r);cursor:pointer;transition:all .2s;margin-top:8px}
.wpcf7 input[type="submit"]:hover{background:var(--accent);transform:translateY(-1px);box-shadow:0 4px 16px rgba(241,14,11,.25)}
.wpcf7-response-output{padding:12px 16px !important;border-radius:var(--r) !important;font-size:13px !important;margin:16px 0 0 !important}
.wpcf7-response-output:empty,.wpcf7-response-output[style*="display: none"]{display:none !important;border:none !important;padding:0 !important;margin:0 !important}
.wpcf7-not-valid-tip{font-size:12px;color:#dc2626;margin-top:4px}
.wpcf7 .wpcf7-not-valid{border-color:#dc2626 !important}

@media(max-width:768px){
    .ow-contact-grid{grid-template-columns:1fr;gap:32px}
    .ow-cf7-row{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════
   404 PAGE
══════════════════════════════════════════ */
.error-404{background:var(--white);padding:80px 0 100px;text-align:center;min-height:60vh;display:flex;align-items:center;justify-content:center}
.error-404-inner{max-width:560px;margin:0 auto}
.error-404-gif{width:100%;max-width:360px;margin:0 auto 32px;border-radius:var(--r);overflow:hidden}
.error-404-gif img{width:100%;height:auto;display:block;border-radius:var(--r)}
.error-404-code{font-family:'Montserrat',sans-serif;font-size:clamp(80px,16vw,140px);font-weight:900;color:var(--accent);line-height:1;display:block;margin-bottom:8px}
.error-404 h1{font-size:clamp(24px,3.5vw,36px);color:var(--text);text-transform:uppercase;margin-bottom:12px}
.error-404 p{font-size:15px;color:var(--body);margin-bottom:32px}
.error-404-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════════
   WOOCOMMERCE PAGES — Cart / Checkout / Account
══════════════════════════════════════════ */
.wc-page-wrap{padding:48px 0 80px;width:100%}
.wc-page-wrap > .container{width:100%}
.wc-page-wrap .container > .woocommerce{width:100%}
.wc-page-wrap .container > .woocommerce > .woocommerce{width:100%}

/* Cart & Checkout: Kanepi-style max-width constraint (72rem = 1152px) */
.woocommerce-cart .wc-page-wrap{padding-bottom:40px}
.woocommerce-cart .woocommerce-cart-form{margin-bottom:0}
.woocommerce-cart .wc-page-wrap .woocommerce{gap:24px;margin-bottom:0}
.woocommerce-cart .shop-hero,
.woocommerce-checkout .shop-hero{padding:40px 0 32px}
.woocommerce-cart .shop-hero-title,
.woocommerce-checkout .shop-hero-title{font-size:clamp(24px,3vw,36px);margin-bottom:0}

/* ── Global WC Buttons ── */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce .button,.woocommerce-page a.button,.woocommerce-page button.button,.woocommerce-page input.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'Inter',sans-serif;font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:14px 32px;border:2px solid var(--accent);border-radius:var(--r);cursor:pointer;transition:all var(--t);white-space:nowrap;background:var(--accent);color:var(--white) !important;line-height:1.4}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce .button:hover{background:var(--accent-h);border-color:var(--accent-h);color:var(--white) !important;transform:translateY(-1px);box-shadow:0 4px 16px rgba(241,14,11,.3)}
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce input.button.alt,.woocommerce #place_order{background:var(--dark);border-color:var(--dark);color:var(--white) !important;padding:16px 40px;font-size:12px}
.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover,.woocommerce input.button.alt:hover,.woocommerce #place_order:hover{background:var(--accent);border-color:var(--accent)}
.woocommerce a.button:disabled,.woocommerce button.button:disabled,.woocommerce input.button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

/* ── WC Forms (shared) ── */
.woocommerce form .form-row{margin-bottom:16px}
.woocommerce form .form-row label{display:block;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text);margin-bottom:6px}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select{width:100%;padding:13px 16px;border:1px solid var(--bdr);border-radius:var(--r);font-size:14px;font-family:'Inter',sans-serif;background:var(--white);outline:none;transition:border-color var(--t),box-shadow var(--t)}
.woocommerce form .form-row input.input-text:focus,.woocommerce form .form-row textarea:focus,.woocommerce form .form-row select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(241,14,11,.08)}
.woocommerce form .form-row .required{color:var(--accent)}

/* ── WC Notices ── */
.woocommerce-message,.woocommerce-info,.woocommerce-error{padding:16px 24px;margin-bottom:24px;border-radius:var(--r);font-size:14px;border-left:4px solid;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.woocommerce-message{background:#f0faf4;border-color:#2D8A4E;color:#1a5c32}
.woocommerce-info{background:#f0f4fa;border-color:#3b82f6;color:#1e40af}
.woocommerce-error{background:#fef2f2;border-color:var(--accent);color:#991b1b;display:block}
.woocommerce-error li{margin-bottom:4px}
.woocommerce-message .button,.woocommerce-info .button{font-size:10px;padding:8px 18px}

/* ══════════════════════════════════════════
   CART (Kanepi-style card layout)
══════════════════════════════════════════ */
/* Cart page grid: items left, totals right */
.woocommerce-cart .wc-page-wrap .woocommerce{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:32px;align-items:flex-start}
.woocommerce-cart .wc-page-wrap .woocommerce > .woocommerce-notices-wrapper{grid-column:1/-1}
.woocommerce-cart .woocommerce-cart-form{grid-column:1;min-width:0}
.woocommerce-cart .cart-collaterals{grid-column:2;grid-row:2;min-width:0}
.woocommerce-cart .cross-sells{grid-column:1/-1}

/* Cart item cards */
.ow-cart-item{background:var(--white);border:1px solid #f3f4f6;border-radius:0.75rem;padding:1rem 1.25rem;display:flex;gap:1rem;align-items:flex-start;transition:all .2s;margin-bottom:0.75rem;box-sizing:border-box}
.ow-cart-item:hover{box-shadow:0 1px 3px rgba(0,0,0,.05)}
.ow-cart-item > div:first-child{flex-shrink:0;width:5rem;height:5rem;border-radius:0.5rem;overflow:hidden;background:var(--light);border:1px solid #f3f4f6}
.ow-cart-item img{width:100%;height:100%;object-fit:cover;display:block}
.ow-cart-item .product-quantity .quantity{display:inline-flex;align-items:center;border-radius:9999px;background:var(--light);border:1px solid var(--bdr)}
.ow-cart-item .product-quantity .quantity .qty{border:none;border-radius:0;width:2.25rem;height:2.25rem;text-align:center;font-weight:700;font-size:0.875rem;color:var(--text);font-family:'Inter',sans-serif;background:var(--white);outline:none;-moz-appearance:textfield}
.ow-cart-item .product-quantity .quantity .qty::-webkit-outer-spin-button,.ow-cart-item .product-quantity .quantity .qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.ow-cart-item .ow-qty-btn{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border:none;background:transparent;color:var(--text);cursor:pointer;transition:all .15s;flex-shrink:0;border-radius:0}
.ow-cart-item .ow-qty-btn:hover{background:var(--bdr)}
.ow-cart-remove{text-decoration:none !important}
.ow-cart-item dl.variation{display:flex;gap:0.25rem 0.5rem;flex-wrap:wrap;margin:0.25rem 0 0;padding:0}
.ow-cart-item dl.variation dt{font-weight:600;font-size:0.75rem;color:#6b7280;margin:0;padding:0}
.ow-cart-item dl.variation dd{font-size:0.75rem;color:#374151;margin:0 0.5rem 0 0;padding:0}
.ow-cart-item dl.variation dd p{margin:0}

/* Cart actions row (coupon + update cart) */
.woocommerce-cart .woocommerce-cart-form > div:not(.space-y-4){display:flex !important;flex-wrap:nowrap !important;align-items:center;gap:0.75rem;margin-top:1.5rem}
.woocommerce-cart .woocommerce-cart-form > div > button[name="update_cart"]{margin-left:auto}

/* Coupon & update buttons — override global WC button styles */
.woocommerce-cart .woocommerce .coupon{display:flex;gap:0.5rem;align-items:center;flex:1;min-width:0}
.woocommerce-cart .woocommerce .coupon #coupon_code{flex:1;min-width:120px;border:1.5px solid var(--bdr);border-radius:var(--r);padding:0.625rem 0.875rem;font-size:0.8125rem;outline:none;transition:border-color .2s;font-family:'Inter',sans-serif;background:var(--white);color:var(--text)}
.woocommerce-cart .woocommerce .coupon #coupon_code:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(241,14,11,.12)}
.woocommerce-cart .woocommerce button.button[name="apply_coupon"],.woocommerce-cart .woocommerce button.button[name="update_cart"]{padding:0.625rem 1rem !important;border-radius:var(--r) !important;font-weight:700 !important;font-size:0.75rem !important;cursor:pointer;transition:all .2s;border:1.5px solid var(--bdr) !important;background:var(--white) !important;color:var(--text) !important;font-family:'Inter',sans-serif;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em;line-height:1.2;display:inline-flex;align-items:center}
.woocommerce-cart .woocommerce button.button[name="apply_coupon"]:hover,.woocommerce-cart .woocommerce button.button[name="update_cart"]:hover{background:var(--dark) !important;border-color:var(--dark) !important;color:var(--white) !important;transform:none !important;box-shadow:none !important}
.woocommerce-cart .woocommerce button.button[name="update_cart"]:disabled{opacity:.4;cursor:not-allowed}

/* Cart totals panel */
.woocommerce-cart .woocommerce .cart_totals{background:var(--white);border-radius:1rem;border:1px solid #f3f4f6;padding:1.5rem 1.25rem;box-shadow:0 1px 3px rgba(0,0,0,.05);position:sticky;top:100px;box-sizing:border-box;width:100%;overflow:hidden}
.woocommerce-cart .woocommerce .cart_totals h2{font-family:'Inter',sans-serif;font-size:0.875rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--text);margin-bottom:1rem;padding-bottom:0;border-bottom:none;white-space:nowrap}
.woocommerce-cart .woocommerce .cart_totals table{border:none;width:100%;table-layout:auto;border-collapse:collapse;margin:0}
.woocommerce-cart .woocommerce .cart_totals table th{font-weight:600;color:#6b7280;background:transparent;border:none;padding:0.625rem 0;font-size:0.875rem;text-align:left;text-transform:none;letter-spacing:0;width:auto;white-space:nowrap}
.woocommerce-cart .woocommerce .cart_totals table td{text-align:right;font-weight:700;color:var(--text);border:none;padding:0.625rem 0;background:transparent;font-size:0.875rem;white-space:nowrap}
.woocommerce-cart .woocommerce .cart_totals .cart-subtotal td,.woocommerce-cart .woocommerce .cart_totals .cart-subtotal th{border-bottom:1px solid #f3f4f6;padding-bottom:0.75rem}
.woocommerce-cart .woocommerce .cart_totals table tr{border-bottom:none}
.woocommerce-cart .woocommerce .cart_totals .order-total td{font-size:1.125rem;font-weight:800;padding-top:0.75rem}
.woocommerce-cart .woocommerce .cart_totals .order-total td .includes_tax{font-size:0.6875rem;font-weight:500;color:#6b7280}
.woocommerce-cart .woocommerce .cart_totals .order-total th{font-weight:700;color:var(--text);padding-top:0.75rem;border-top:2px solid var(--dark);font-size:0.875rem}
.woocommerce-cart .cart_totals table.shop_table{display:table}

/* Proceed to checkout button */
.woocommerce-cart .woocommerce .wc-proceed-to-checkout{padding-top:1.25rem}
.woocommerce-cart .woocommerce .wc-proceed-to-checkout a.checkout-button{display:flex !important;align-items:center;justify-content:center;gap:0.5rem;width:100% !important;max-width:100% !important;box-sizing:border-box !important;padding:1rem 0.75rem !important;background:var(--dark) !important;color:var(--white) !important;font-weight:700;font-size:0.8125rem;text-align:center;text-transform:uppercase;letter-spacing:.05em;border-radius:0.75rem;transition:all .2s;text-decoration:none;border:none !important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.woocommerce-cart .woocommerce .wc-proceed-to-checkout a.checkout-button:hover{opacity:.9;transform:translateY(-1px)}

/* Notices in cart */
.woocommerce-cart .woocommerce-message,.woocommerce-cart .woocommerce-info,.woocommerce-cart .woocommerce-error{margin-bottom:1rem;padding:0.875rem 1rem 0.875rem 3rem !important;border-radius:var(--r);font-size:0.875rem;font-weight:600;position:relative}
.woocommerce-cart .woocommerce-message{background:#f0fdf4;border-left:4px solid #16a34a;color:#15803d}
.woocommerce-cart .woocommerce-error{background:#fef2f2;border-left:4px solid #dc2626;color:#dc2626}
.woocommerce-cart .woocommerce-info{background:var(--light);border-left:4px solid var(--accent);color:var(--text)}

/* btn-primary scoped to empty cart only */
.woocommerce-cart .btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;padding:0.75rem 1.5rem;border-radius:9999px;font-weight:700;font-size:0.875rem;cursor:pointer;transition:all .3s;text-decoration:none;background:var(--dark);border:2px solid var(--dark);color:var(--white)}
.woocommerce-cart .btn-primary:hover{opacity:.9;transform:translateY(-2px)}

/* Cross-sells — 4-column under cart form */
.ow-cross-sells{margin-top:0;display:block;width:100%;grid-column:1/-1}
.ow-cross-sells__title{font-size:16px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;display:block;width:100%}
.ow-cross-sells__title i,.ow-cross-sells__title svg{display:none}
.ow-cross-sells__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;width:100%}
.ow-cross-sells__item{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;transition:all var(--t);text-decoration:none;display:flex;flex-direction:column}
.ow-cross-sells__item:hover{box-shadow:0 4px 20px rgba(0,0,0,.08);transform:translateY(-2px)}
.ow-cross-sells__image{aspect-ratio:1;overflow:hidden;background:var(--light)}
.ow-cross-sells__image img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.ow-cross-sells__item:hover .ow-cross-sells__image img{transform:scale(1.05)}
.ow-cross-sells__info{padding:14px 16px;flex:1}
.ow-cross-sells__name{display:block;font-size:13px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:6px}
.ow-cross-sells__price{font-size:14px;font-weight:700;color:var(--accent)}
.ow-cross-sells__btn{display:block;text-align:center;padding:10px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border-top:1px solid var(--bdr);transition:all var(--t)}
.ow-cross-sells__item:hover .ow-cross-sells__btn{background:var(--accent);color:var(--white)}

/* Empty cart */
.woocommerce .cart-empty{text-align:center;padding:80px 0 20px;font-size:20px;color:var(--text);font-weight:600;grid-column:1/-1}
.woocommerce .return-to-shop{text-align:center;padding-bottom:40px;grid-column:1/-1}
.woocommerce .return-to-shop a{padding:16px 40px}

/* Generic shop tables (checkout order review, my account tables) */
.woocommerce table.shop_table{width:100%;border-collapse:collapse;border:none;margin-bottom:0}
.woocommerce table.shop_table th{font-size:0.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;padding:0.75rem 0;border-bottom:2px solid var(--bdr);background:transparent;text-align:left}
.woocommerce table.shop_table td{padding:0.75rem 0;border-bottom:1px solid #f3f4f6;font-size:0.9375rem;color:var(--text);background:transparent}

/* Thank you page */
.ow-thankyou{padding:20px 0}
.ow-thankyou-success,.ow-thankyou-failed{text-align:center;padding:40px 0 32px}
.ow-thankyou-icon{display:flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:50%;margin:0 auto 24px}
.ow-thankyou-icon--success{background:#ecfdf5;color:#059669}
.ow-thankyou-icon--error{background:#fef2f2;color:#dc2626}
.ow-thankyou-success h2,.ow-thankyou-failed h2{font-size:24px;margin-bottom:8px}
.ow-thankyou-subtitle{font-size:15px;color:var(--body)}
.ow-thankyou-failed p{font-size:15px;color:var(--body);max-width:480px;margin:0 auto 24px}
.ow-thankyou-actions{display:flex;gap:12px;justify-content:center}
.ow-thankyou-overview{max-width:600px;margin:0 auto;background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);padding:32px;margin-bottom:32px}
.ow-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ow-overview-item{display:flex;flex-direction:column;gap:4px}
.ow-overview-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.ow-overview-value{font-size:15px;font-weight:700;color:var(--text)}

/* ══════════════════════════════════════════
   CHECKOUT & CART — WooCommerce Blocks
══════════════════════════════════════════ */

/* Container width */
.woocommerce-checkout .wp-block-woocommerce-checkout,.woocommerce-checkout .wp-block-woocommerce-checkout.alignwide,.woocommerce-cart .wp-block-woocommerce-cart,.woocommerce-cart .wp-block-woocommerce-cart.alignwide{font-family:'Inter',sans-serif;max-width:none;padding:0;box-sizing:border-box;margin:0}

/* Section headings */
.wc-block-checkout .wc-block-components-checkout-step__title,.wc-block-checkout .wc-block-components-title,.wc-block-cart .wc-block-components-title{font-family:'Inter',sans-serif;font-weight:700;color:var(--text);font-size:1.125rem}

/* Form inputs */
.wc-block-checkout input[type="text"],.wc-block-checkout input[type="email"],.wc-block-checkout input[type="tel"],.wc-block-checkout input[type="number"],.wc-block-checkout input[type="password"],.wc-block-checkout select,.wc-block-checkout textarea,.wc-block-checkout .wc-block-components-text-input input,.wc-block-checkout .wc-block-components-text-input textarea{font-family:'Inter',sans-serif;border:1.5px solid #e5e7eb;border-radius:0.625rem;padding:0.75rem 1rem;font-size:0.9375rem;outline:none;transition:border-color .2s,box-shadow .2s;background:var(--white);color:var(--text)}
.wc-block-checkout input:focus,.wc-block-checkout select:focus,.wc-block-checkout textarea:focus,.wc-block-checkout .wc-block-components-text-input.is-active input{border-color:var(--accent);box-shadow:0 0 0 3px rgba(241,14,11,.12)}
.wc-block-checkout .wc-block-components-text-input label,.wc-block-checkout label{font-weight:500;color:#6b7280;font-size:0.8125rem}

/* Order summary panel */
.wc-block-checkout .wc-block-components-order-summary,.wc-block-checkout .wp-block-woocommerce-checkout-totals-block{background:var(--white);border-radius:1rem;border:1px solid #f3f4f6;padding:1.5rem}
.wc-block-checkout .wc-block-components-order-summary .wc-block-components-title,.wc-block-checkout .wc-block-components-panel__button{font-family:'Inter',sans-serif;font-weight:700;color:var(--text)}

/* Summary product items */
.wc-block-checkout .wc-block-components-order-summary-item{border-bottom:1px solid #f3f4f6;padding:1rem 0}
.wc-block-checkout .wc-block-components-order-summary-item:last-child{border-bottom:none}
.wc-block-checkout .wc-block-components-order-summary-item__image img{border-radius:0.5rem;border:1px solid #f3f4f6}
.wc-block-checkout .wc-block-components-order-summary-item__name,.wc-block-checkout .wc-block-components-product-name{font-weight:700;color:var(--text);font-size:0.875rem}
.wc-block-checkout .wc-block-components-order-summary-item__total-price{font-weight:700;color:var(--text)}

/* Sale badge */
.wc-block-checkout .wc-block-components-sale-badge,.wc-block-cart .wc-block-components-sale-badge{background-color:var(--accent);color:var(--white);font-weight:700;border-radius:0.375rem;font-size:0.6875rem}

/* Product quantity badge */
.wc-block-checkout .wc-block-components-order-summary-item__quantity{background-color:var(--dark);color:var(--white);font-weight:700;border-radius:9999px;border:2px solid var(--white);box-shadow:0 1px 3px rgba(0,0,0,.15)}

/* Totals rows — nuke all WC block borders, then add our own */
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-block,
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-block > *,
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-subtotal-block,
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-fee-block,
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-discount-block,
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-shipping-block,
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-taxes-block,
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-coupon-form-block,
.wc-block-checkout .wc-block-components-totals-wrapper,
.wc-block-checkout .wc-block-components-panel{border:none !important;box-shadow:none !important}
.wc-block-checkout .wc-block-components-totals-item,.wc-block-cart .wc-block-components-totals-item{border:none !important;border-top:1px solid #f3f4f6 !important;padding:0.75rem 0 !important;box-shadow:none !important}
.wc-block-checkout .wc-block-components-totals-item::before,.wc-block-checkout .wc-block-components-totals-item::after{display:none !important;content:none !important;border:none !important}
.wc-block-checkout .wc-block-components-totals-item__label,.wc-block-cart .wc-block-components-totals-item__label{font-weight:600;color:#6b7280;font-size:0.875rem}
.wc-block-checkout .wc-block-components-totals-item__value,.wc-block-cart .wc-block-components-totals-item__value{font-weight:700;color:var(--text)}

/* Grand total */
.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__label,.wc-block-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__label{font-weight:800;color:var(--text);font-size:1rem}
.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value,.wc-block-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__value{font-weight:800;color:var(--text);font-size:1.25rem}

/* Place order button */
.wc-block-checkout .wc-block-components-checkout-place-order-button,.wc-block-checkout .wc-block-components-button:not(.is-link){background-color:var(--dark) !important;color:var(--white) !important;font-weight:700;font-size:0.9375rem;border-radius:0.625rem;padding:0.875rem 1.5rem;text-transform:uppercase;letter-spacing:.05em;transition:all .2s;border:none;cursor:pointer;font-family:'Inter',sans-serif;width:100%}
.wc-block-checkout .wc-block-components-checkout-place-order-button:hover,.wc-block-checkout .wc-block-components-button:not(.is-link):hover{opacity:.9;transform:translateY(-1px)}

/* Proceed to checkout (cart page) */
.wc-block-cart .wc-block-cart__submit-button,.wc-block-cart .wc-block-components-button:not(.is-link){background-color:var(--dark) !important;color:var(--white) !important;font-weight:700;font-size:0.9375rem;border-radius:0.625rem;padding:0.875rem 1.5rem;text-transform:uppercase;letter-spacing:.05em;transition:all .2s;border:none;cursor:pointer;font-family:'Inter',sans-serif;width:100%}
.wc-block-cart .wc-block-cart__submit-button:hover,.wc-block-cart .wc-block-components-button:not(.is-link):hover{opacity:.9;transform:translateY(-1px)}

/* Coupon toggle */
.wc-block-checkout .wc-block-components-panel__button{color:var(--accent);text-decoration:none}
.wc-block-checkout .wc-block-components-panel__button:hover{color:var(--text)}
.wc-block-checkout .wc-block-components-totals-coupon__input-container{display:flex;gap:0.5rem}

/* Shipping method options */
.wc-block-checkout .wc-block-components-radio-control__option{border:1.5px solid #e5e7eb;border-radius:0.625rem;padding:1rem 1rem 1rem 3rem;margin-bottom:0.5rem;transition:all .15s;position:relative}
.wc-block-checkout .wc-block-components-radio-control__option:hover{border-color:var(--accent)}
.wc-block-checkout .wc-block-components-radio-control__option--checked{border-color:var(--dark);background-color:rgba(241,14,11,.04)}
.wc-block-checkout .wc-block-components-radio-control__input{position:absolute !important;left:1rem !important;top:50% !important;transform:translateY(-50%) !important}
.wc-block-checkout .wc-block-components-radio-control__input:checked{border-color:var(--dark);background-color:var(--dark)}
.wc-block-checkout input[type="checkbox"]:checked{background-color:var(--dark);border-color:var(--dark)}

/* Payment method labels */
.wc-block-checkout .wc-block-components-payment-method-label{font-weight:600;color:var(--text)}

/* Error/success notices */
.wc-block-checkout .wc-block-components-validation-error,.wc-block-checkout .wc-block-components-notice-banner.is-error{color:#dc2626;font-size:0.8125rem;font-weight:500}
.wc-block-checkout .wc-block-components-notice-banner.is-success{border-color:#16a34a;background-color:#f0fdf4}

/* Step separators */
.wc-block-checkout .wc-block-components-checkout-step{border-bottom:1px solid #f3f4f6;padding-bottom:1.5rem;margin-bottom:1.5rem}
.wc-block-checkout .wc-block-components-checkout-step:last-child{border-bottom:none}

/* Select dropdown */
.wc-block-checkout .wc-block-components-combobox .components-combobox-control input,.wc-block-checkout select{border:1.5px solid #e5e7eb;border-radius:0.625rem;padding:0.75rem 1rem;font-size:0.9375rem;font-family:'Inter',sans-serif;background:var(--white)}

/* Terms box */
.wc-block-checkout .wc-block-checkout__terms{background:var(--light);border:1.5px solid var(--bdr);border-radius:var(--r);padding:14px 16px;font-size:0.875rem;color:var(--text)}
.wc-block-checkout .wc-block-checkout__terms a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;font-weight:600}

/* Cart block — quantity buttons */
.wc-block-cart .wc-block-components-quantity-selector{border:1.5px solid #e5e7eb;border-radius:0.5rem;overflow:hidden}
.wc-block-cart .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button{background:var(--light);color:var(--text);border:none;transition:all .15s}
.wc-block-cart .wc-block-components-quantity-selector .wc-block-components-quantity-selector__button:hover{background:var(--dark);color:var(--white)}
.wc-block-cart .wc-block-components-quantity-selector input.wc-block-components-quantity-selector__input{font-weight:700;font-family:'Inter',sans-serif;color:var(--text)}

/* Cart block — product names & images */
.wc-block-cart .wc-block-components-product-name{font-weight:700;color:var(--text);text-decoration:none;font-size:0.9375rem}
.wc-block-cart .wc-block-components-product-name:hover{color:var(--accent)}
.wc-block-cart .wc-block-cart-items__row img{border-radius:0.5rem;border:1px solid #f3f4f6}

/* Cart block — totals sidebar */
.wc-block-cart .wp-block-woocommerce-cart-totals-block{background:var(--white);border-radius:1rem;border:1px solid #f3f4f6;padding:1.5rem}

/* Loading spinner */
.wc-block-checkout .wc-block-components-spinner,.wc-block-cart .wc-block-components-spinner{border-color:var(--accent);border-top-color:transparent}

/* ══════════════════════════════════════════
   MY ACCOUNT
══════════════════════════════════════════ */

/* Layout: side nav + content (logged in) */
.woocommerce-account.logged-in .wc-page-wrap .woocommerce{display:flex;flex-direction:row;flex-wrap:nowrap;gap:48px;align-items:flex-start;width:100%}

/* Login / Register (logged out) */
.woocommerce-account:not(.logged-in) .wc-page-wrap .woocommerce{display:block;max-width:none;margin:0 auto}
.woocommerce-account:not(.logged-in) #customer_login.col2-set{display:grid !important;grid-template-columns:1fr 1fr !important;gap:40px !important;width:100% !important}
.woocommerce-account:not(.logged-in) #customer_login.col2-set::before,.woocommerce-account:not(.logged-in) #customer_login.col2-set::after{display:none !important;content:none !important}
.woocommerce .col2-set .col-1,.woocommerce .col2-set .col-2{float:none !important;width:100% !important;max-width:none !important;margin:0 !important}
.woocommerce-account:not(.logged-in) #customer_login .col-1,.woocommerce-account:not(.logged-in) #customer_login .col-2{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);padding:36px;box-sizing:border-box}
.woocommerce-account:not(.logged-in) #customer_login h2{font-size:20px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:24px;padding-bottom:12px;border-bottom:2px solid var(--bdr)}
.woocommerce-account:not(.logged-in) .woocommerce-form-login,.woocommerce-account:not(.logged-in) .woocommerce-form-register{margin:0}
.woocommerce-account:not(.logged-in) .woocommerce-form-login .form-row,.woocommerce-account:not(.logged-in) .woocommerce-form-register .form-row{margin-bottom:16px}
.woocommerce-account:not(.logged-in) .woocommerce form .form-row label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.woocommerce-account:not(.logged-in) .woocommerce form .form-row input[type=text],.woocommerce-account:not(.logged-in) .woocommerce form .form-row input[type=email],.woocommerce-account:not(.logged-in) .woocommerce form .form-row input[type=password]{width:100% !important;box-sizing:border-box !important;padding:12px 16px;border:1px solid var(--bdr);border-radius:var(--r);font-size:14px}
.woocommerce-account:not(.logged-in) .woocommerce form .form-row input[type=checkbox]{margin-right:6px;accent-color:var(--accent)}
.woocommerce-account:not(.logged-in) .woocommerce .lost_password{margin-top:12px;font-size:13px}
.woocommerce-account:not(.logged-in) .woocommerce .lost_password a{color:var(--accent);text-decoration:underline}
.woocommerce-account:not(.logged-in) .woocommerce .woocommerce-privacy-policy-text{font-size:13px;color:var(--body);line-height:1.6;margin-bottom:16px}

/* Side nav (logged in) */
.woocommerce-MyAccount-navigation{margin-bottom:0;flex:0 0 280px;width:280px;max-width:280px}
.woocommerce-MyAccount-navigation ul{display:flex;flex-direction:column;gap:4px;border-bottom:none;padding:0}
.woocommerce-MyAccount-navigation ul li{list-style:none}
.woocommerce-MyAccount-navigation ul li a{display:flex;align-items:center;gap:10px;padding:12px 18px;font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--body);border:1px solid var(--bdr);border-radius:var(--r);margin-bottom:0;transition:all var(--t);background:var(--white)}
.woocommerce-MyAccount-navigation ul li.is-active a{background:var(--dark);color:var(--white);border-color:var(--dark)}
.woocommerce-MyAccount-navigation ul li a:hover{background:var(--light);color:var(--accent);border-color:var(--accent)}
.woocommerce-MyAccount-navigation ul li.is-active a:hover{background:var(--dark);color:var(--white)}

/* WC Notices */
.woocommerce-info,.woocommerce-message,.woocommerce-error{position:relative;display:flex;align-items:center;gap:16px;padding:20px 24px 20px 56px;border-radius:var(--r);margin-bottom:24px;font-size:14px;line-height:1.6;border:1px solid var(--bdr);background:var(--light);color:var(--body);list-style:none}
.woocommerce-info::before,.woocommerce-message::before{position:absolute !important;top:50% !important;left:24px !important;transform:translateY(-50%);font-size:18px;display:inline-block}
.woocommerce-info::after,.woocommerce-message::after,.woocommerce-error::after{display:none !important}
.woocommerce-info .button,.woocommerce-message .button{margin-left:auto;flex-shrink:0}
.woocommerce-error{border-color:#e2401c;background:#fef2f0;color:#c0392b}

/* Content area */
.woocommerce-MyAccount-content{flex:1;min-width:0}
.woocommerce-MyAccount-content p{font-size:15px;color:var(--body);line-height:1.8;margin-bottom:12px}
.woocommerce-MyAccount-content h2,.woocommerce-MyAccount-content h3{font-size:20px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:20px}
.woocommerce-MyAccount-content table{width:100%;border-collapse:collapse;border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden}
.woocommerce-MyAccount-content table th{background:var(--dark);color:var(--white);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:14px 18px;text-align:left}
.woocommerce-MyAccount-content table td{padding:14px 18px;border-bottom:1px solid var(--bdr);font-size:14px;color:var(--body);background:var(--white)}
.woocommerce-MyAccount-content table td a.button,.woocommerce-MyAccount-content table td .button{font-size:10px;padding:8px 16px;letter-spacing:.1em}
.woocommerce-MyAccount-content .col2-set.addresses{display:grid !important;grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:24px !important;width:100% !important;overflow:visible !important}
.woocommerce-MyAccount-content .col2-set.addresses::before,.woocommerce-MyAccount-content .col2-set.addresses::after{display:none !important;content:none !important}
.woocommerce .col2-set.addresses .col-1,.woocommerce .col2-set.addresses .col-2,.woocommerce-page .col2-set.addresses .col-1,.woocommerce-page .col2-set.addresses .col-2,.woocommerce-MyAccount-content .woocommerce-Address{float:none !important;width:100% !important;max-width:none !important;clear:none !important;margin:0 !important;box-sizing:border-box !important;background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);padding:24px}
.woocommerce-MyAccount-content .woocommerce-Address header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--bdr);gap:12px;flex-wrap:wrap}
.woocommerce-MyAccount-content .woocommerce-Address h3,.woocommerce-MyAccount-content .col2-set.addresses h2,.woocommerce-MyAccount-content .col2-set.addresses h3{font-size:14px;text-transform:uppercase;letter-spacing:.06em;margin:0}
.woocommerce-MyAccount-content address{font-style:normal;font-size:14px;color:var(--body);line-height:1.8}
.woocommerce-MyAccount-content .woocommerce-Address header a,.woocommerce-MyAccount-content .col2-set.addresses header a,.woocommerce-MyAccount-content .u-columns header a{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);white-space:nowrap}
.woocommerce-MyAccount-content .woocommerce-Address header a:hover{color:var(--accent-h)}

/* AJAX add-to-cart */
.ajax-add-to-cart{cursor:pointer;border:none;transition:all var(--t)}
.ajax-add-to-cart.loading{opacity:.6;pointer-events:none}
.ajax-add-to-cart.added{background:#2D8A4E;border-color:#2D8A4E}

/* Cookie consent */
.cookie-consent{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--dark);color:rgba(255,255,255,.7);padding:16px 0;border-top:2px solid var(--accent)}
.cookie-consent-inner{max-width:var(--w);margin:0 auto;padding:0 60px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.cookie-consent p{margin:0;font-size:13px;line-height:1.6}
.cookie-consent a{color:var(--accent);text-decoration:underline}
.cookie-consent .btn{white-space:nowrap;flex-shrink:0}

/* ══════════════════════════════════════════
   TABLET ≤1024
══════════════════════════════════════════ */
@media(max-width:1024px){
    .hero{height:620px}
    .hero-inner{max-width:100%}
    .hero-desc{margin:0 0 40px}
    .brands-inner{justify-content:center}
    .cat-grid{grid-template-columns:repeat(3,1fr)}
    .cat-card:nth-child(3n){border-right:none}
    .mfr-inner{grid-template-columns:1fr;gap:40px;text-align:center}
    .mfr-desc{margin:0 auto}
    .founder{max-width:480px;margin:0 auto}
    .prod-grid--3{grid-template-columns:repeat(2,1fr)}
    .prod-grid--4{grid-template-columns:repeat(2,1fr)}
    .offer-inner{grid-template-columns:1fr;gap:40px;text-align:center}
    .offer-desc{margin:0 auto 32px}
    .bens-inner{grid-template-columns:repeat(2,1fr)}
    .footer-inner{grid-template-columns:1fr 1fr;gap:32px}
    .footer-brand{grid-column:1/-1}
    .shop-layout{grid-template-columns:220px 1fr;gap:28px}
    .sp-layout{gap:40px}
    .single-product-wrap{padding:40px 0 60px}
    .wc-page-wrap{padding:40px 0 60px}
    .woocommerce-cart .wc-page-wrap .woocommerce{grid-template-columns:1fr}
    .woocommerce-cart .cart-collaterals{grid-column:1;grid-row:auto}
    .ow-cross-sells__grid{grid-template-columns:repeat(3,1fr)}
    .woocommerce .cart_totals{position:static}
    .woocommerce-checkout form.checkout{grid-template-columns:1fr}
    .woocommerce-checkout .col2-set,.woocommerce-checkout #order_review_heading,.woocommerce-checkout #order_review,.woocommerce-checkout #payment{grid-column:1}
    .woocommerce-account.logged-in .wc-page-wrap .woocommerce{flex-direction:column}
    .woocommerce-MyAccount-navigation{width:100%}
    .woocommerce-MyAccount-navigation ul{flex-direction:row;flex-wrap:wrap;gap:4px}
    .woocommerce-MyAccount-content .col2-set.addresses{grid-template-columns:1fr !important}
    .woocommerce-account:not(.logged-in) .u-columns{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════
   MOBILE ≤768
══════════════════════════════════════════ */
@media(max-width:768px){
    .container{padding:0 24px}
    .navbar-inner{padding:0 24px}
    .nav-menu{display:none;flex-direction:column;position:fixed;top:70px;left:0;right:0;bottom:0;background:var(--white);overflow-y:auto;z-index:999;border-top:2px solid var(--accent)}
    .nav-menu.active{display:flex}
    .nav-menu>li>a{height:auto;line-height:1;padding:15px 20px;border-bottom:1px solid var(--bdr)}
    .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;display:none;background:var(--light)}
    .has-dropdown:hover .dropdown{display:block}
    .nav-hamburger{display:flex}
    .nav-cart-count{display:flex}
    .mini-cart{width:300px;right:-60px}
    .nav-grid-toggle{display:none}
    .hero{height:500px}
    .brands-inner img{height:24px}
    .cat-grid{grid-template-columns:repeat(2,1fr)}
    .cat-card:nth-child(2n){border-right:none}
    .prod-grid--3,.prod-grid--4{grid-template-columns:1fr 1fr;gap:14px}
    .stats{grid-template-columns:1fr 1fr}
    .bens-inner{grid-template-columns:1fr 1fr;gap:24px}
    .newsletter-field{flex-direction:column}
    .newsletter-field .btn{border-radius:0}
    .footer-inner{grid-template-columns:1fr;gap:24px}
    .footer-brand{grid-column:auto}
    .footer-bottom-inner{flex-direction:column;gap:8px;text-align:center}
    .shop-layout{grid-template-columns:1fr}
    .shop-sidebar{position:static}
    .sp-layout{grid-template-columns:1fr;gap:32px}
    .sp-gallery{position:static}
    .single-product-wrap{padding:24px 0 60px}
    .wc-page-wrap{padding:24px 0 60px}
    .sp-add-to-cart{flex-direction:column;align-items:stretch}
    .sp-add-to-cart .btn{width:100%}
    .woocommerce-checkout form.checkout{grid-template-columns:1fr}
    .woocommerce-checkout .col2-set,.woocommerce-checkout #order_review_heading,.woocommerce-checkout #order_review,.woocommerce-checkout #payment{grid-column:1}
    .woocommerce-account.logged-in .wc-page-wrap .woocommerce{flex-direction:column;gap:24px}
    .woocommerce-MyAccount-navigation{width:100%}
    .woocommerce-MyAccount-navigation ul{flex-direction:row;flex-wrap:wrap;gap:4px}
    .woocommerce-MyAccount-navigation ul li a{padding:10px 14px;font-size:11px}
    .woocommerce .cart_totals{max-width:100%;padding:20px}
    .woocommerce-checkout #order_review{padding:20px}
    .woocommerce .cart td.actions{flex-direction:column;align-items:stretch}
    .woocommerce .cart .coupon{flex-direction:column}
    .woocommerce .cart .coupon #coupon_code{min-width:0;width:100%}
    .cookie-consent-inner{padding:0 24px;flex-direction:column;text-align:center}
    .stories-grid,.stories-grid--3{grid-template-columns:1fr}
    .single-story__nav{grid-template-columns:1fr}
    .story-card__title{font-size:16px}
    .top-bar{display:none}
    .ow-cross-sells__grid{grid-template-columns:repeat(2,1fr)}
}

/* ══════════════════════════════════════════
   SMALL ≤480
══════════════════════════════════════════ */
@media(max-width:480px){
    .hero{height:auto;min-height:420px;padding:80px 0 60px}
    .hero-title{font-size:clamp(36px,12vw,52px)}
    .hero-btns{flex-direction:column;align-items:stretch}
    .cat-grid{grid-template-columns:1fr 1fr}
    .prod-grid--3,.prod-grid--4{grid-template-columns:1fr}
    .stats{grid-template-columns:1fr}
    .bens-inner{grid-template-columns:1fr;gap:20px}
}
