/* ===== ZONIFY v2 — Amazon-style, mobile-first, premium ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#131921;--navy2:#232f3e;--yellow:#febd69;--yellow2:#f3a847;
  --amz-yellow:#ffd814;--amz-yellow-h:#f7ca00;--amz-orange:#ffa41c;--amz-orange-h:#fa8900;
  --blue:#007185;--blue-h:#c7511f;--border:#d5d9d9;--ink:#0f1111;--muted:#565959;--bg:#eaeded;
}
html{-webkit-text-size-adjust:100%}
body{font-family:"Amazon Ember","Segoe UI",Arial,Helvetica,sans-serif;background:var(--bg);color:var(--ink);line-height:1.4}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:inherit}
.wrap{max-width:1500px;margin:0 auto;padding:0 14px}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--navy);color:#fff;display:flex;align-items:center;gap:8px;padding:8px 14px}
.burger{display:none;background:none;border:1px solid transparent;color:#fff;font-size:22px;cursor:pointer;padding:4px 8px;border-radius:4px}
.burger:hover{border-color:#fff}
.logo{font-size:24px;font-weight:800;letter-spacing:-1px;padding:6px 8px;border:1px solid transparent;border-radius:4px;white-space:nowrap}
.logo:hover{border-color:#fff}.logo .a{color:#ff9900}.logo .t{color:var(--yellow);font-size:12px;font-weight:400}
.deliver{display:flex;align-items:flex-end;gap:4px;padding:6px 8px;border:1px solid transparent;border-radius:4px;cursor:pointer}
.deliver:hover{border-color:#fff}.deliver .pin{font-size:18px;align-self:center}
.deliver small{color:#ccc;font-size:11px;display:block}.deliver b{font-size:13px}
.search{flex:1;display:flex;height:42px;border-radius:8px;min-width:0;border:2px solid transparent}
.search:focus-within{border-color:#ff9900;box-shadow:0 0 0 1px #ff9900}
.search input{flex:1;border:none;padding:0 14px;font-size:15px;outline:none;min-width:0;border-radius:6px 0 0 6px}
.search button{background:var(--yellow);border:none;width:48px;cursor:pointer;font-size:18px;border-radius:0 6px 6px 0}
.search button:hover{background:var(--yellow2)}
.nav-right{display:flex;align-items:center;gap:2px}
.nav-item{position:relative;padding:8px 9px;border:1px solid transparent;border-radius:4px;cursor:pointer;white-space:nowrap;color:#fff}
.nav-item:hover{border-color:#fff}
.nav-item small{font-size:11px;display:block;color:#ddd}.nav-item b{font-size:13px}
.basket{display:flex;align-items:flex-end;gap:2px}.basket .c{color:var(--yellow);font-weight:800;font-size:17px}.basket .i{font-size:24px}
/* account dropdown */
.acct-menu{display:none;position:absolute;top:100%;right:0;background:#fff;color:var(--ink);width:230px;border-radius:8px;box-shadow:0 6px 24px rgba(0,0,0,.25);padding:14px;z-index:60;margin-top:4px}
.acct-menu.open{display:block}
.acct-menu .btn-amz{display:block;text-align:center;margin-bottom:8px}
.acct-menu .reg{font-size:12px;color:var(--muted);text-align:center;margin-bottom:6px}
.acct-menu .reg a{color:var(--blue)}.acct-menu hr{border:none;border-top:1px solid #eee;margin:8px 0}
.acct-menu>a{display:block;padding:6px 4px;font-size:13px;color:var(--ink)}
.acct-menu>a:hover{color:var(--blue-h);text-decoration:underline}

/* ---------- SUBNAV ---------- */
.subnav{background:var(--navy2);color:#fff;display:flex;align-items:center;gap:2px;padding:6px 12px;font-size:14px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.subnav::-webkit-scrollbar{display:none}
.subnav a{padding:6px 10px;border:1px solid transparent;border-radius:4px;white-space:nowrap}
.subnav a:hover{border-color:#fff}.subnav .uk{color:var(--yellow);font-weight:700}

/* ---------- MOBILE SLIDE MENU ---------- */
.mobile-menu{position:fixed;top:0;left:-320px;width:300px;height:100%;background:#fff;z-index:200;transition:left .25s ease;overflow-y:auto;box-shadow:2px 0 18px rgba(0,0,0,.3)}
.mobile-menu.open{left:0}
.mm-head{background:var(--navy2);color:#fff;padding:16px;font-size:17px;font-weight:700;display:flex;justify-content:space-between;align-items:center}
.mm-head button{background:none;border:none;color:#fff;font-size:20px;cursor:pointer}
.mm-signin{display:block;background:var(--amz-yellow);text-align:center;margin:12px 16px;padding:10px;border-radius:8px;font-weight:700}
.mm-sec{font-weight:700;font-size:15px;padding:12px 16px 6px;border-top:1px solid #eee;margin-top:6px}
.mobile-menu>a{display:flex;justify-content:space-between;padding:11px 16px;font-size:14px;color:var(--ink);border-bottom:1px solid #f3f3f3}
.mobile-menu>a:active{background:#f7f7f7}.mobile-menu>a span{color:var(--muted);font-size:12px}
.mm-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150}
.mm-overlay.open{display:block}

/* ---------- HERO ---------- */
.hero{background:linear-gradient(180deg,#cfe9f5,#eaeded 80%);padding:42px 0 86px;position:relative}
.hero-in{max-width:1500px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.hero h1{font-size:38px;line-height:1.1;max-width:520px}
.hero p{font-size:17px;margin:14px 0 22px;color:#333}
.hero-btn{background:var(--amz-yellow);color:var(--ink);padding:12px 28px;border-radius:10px;font-weight:700;font-size:15px;display:inline-block;box-shadow:0 2px 5px rgba(0,0,0,.18);border:1px solid #e0a800}
.hero-btn:hover{background:var(--amz-yellow-h)}.hero-badge{font-size:110px}

/* ---------- CATEGORY CARDS ---------- */
.card-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:28px;position:relative;z-index:1}
.cat-card{background:#fff;padding:18px;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.cat-card h3{font-size:18px;margin-bottom:12px}
.cat-card .ph{background:var(--bg);height:150px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:56px;overflow:hidden}
.cat-card .ph img{width:100%;height:100%;object-fit:cover}
.cat-card a.l{color:var(--blue);font-size:13px;margin-top:12px;display:inline-block}
.cat-card a.l:hover{color:var(--blue-h);text-decoration:underline}

/* ---------- STRIP / SECTION ---------- */
.strip{background:#fff;border-radius:8px;margin-top:18px;padding:16px 18px 22px;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.strip h2{font-size:20px;margin-bottom:14px}

/* ---------- PRODUCT GRID (equal height cards) ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.prod{border:1px solid #e7e7e7;border-radius:10px;padding:12px;background:#fff;display:flex;flex-direction:column;transition:box-shadow .15s,transform .15s}
.prod:hover{box-shadow:0 6px 18px rgba(0,0,0,.13);transform:translateY(-2px)}
.prod .pimg{background:#fff;aspect-ratio:1/1;border-radius:6px;display:flex;align-items:center;justify-content:center;margin-bottom:10px;overflow:hidden}
.prod .pimg img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.prod .title{font-size:13.5px;line-height:1.35;max-height:38px;overflow:hidden;color:var(--ink);margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.prod .title:hover{color:var(--blue-h)}
.prod .rate{font-size:12px;color:#ffa41c;margin-bottom:4px}.prod .rate span{color:var(--muted);margin-left:4px}
.prod .price{font-size:18px;font-weight:700;margin-top:auto}
.prod .price .was{font-size:12px;color:var(--muted);text-decoration:line-through;font-weight:400;margin-left:6px}
.prod .ship{font-size:11px;color:#067d62;margin-top:3px}
.prod .add{margin-top:10px;width:100%;background:var(--amz-yellow);border:1px solid #e0a800;border-radius:20px;padding:8px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.12)}
.prod .add:hover{background:var(--amz-yellow-h)}

/* ---------- PRODUCT PAGE (PDP) ---------- */
.crumb{font-size:13px;color:var(--muted);padding:12px 0}.crumb a{color:var(--blue)}.crumb a:hover{color:var(--blue-h);text-decoration:underline}
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:30px;background:#fff;border-radius:8px;padding:24px;margin-top:6px;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.gallery{align-self:start;position:relative}
.gallery img.main{width:100%;aspect-ratio:1/1;object-fit:contain;border:1px solid #eee;border-radius:8px;background:#fff}
.thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.thumbs img{width:56px;height:56px;object-fit:contain;border:1px solid #ddd;border-radius:6px;cursor:pointer;padding:2px;background:#fff}
.thumbs img:hover{border-color:var(--amz-orange)}
.pdp h1{font-size:24px;font-weight:500;line-height:1.3}
.brand-link{color:var(--blue);font-size:13px}.brand-link:hover{color:var(--blue-h);text-decoration:underline}
.stars{color:#ffa41c;font-size:15px;margin-top:6px}.stars span{color:var(--blue);font-size:13px;margin-left:6px}
.divider{border:none;border-top:1px solid #e7e7e7;margin:14px 0}
.buybox{border:1px solid var(--border);border-radius:10px;padding:18px;box-shadow:0 1px 4px rgba(0,0,0,.07);max-width:380px}
.price-lg{font-size:28px;font-weight:700}.price-lg .was{font-size:14px;color:var(--muted);text-decoration:line-through;font-weight:400;margin-left:8px}
.ship{color:#067d62;font-size:13px}
.instock{color:#067d62;font-weight:600;margin:8px 0}
.btn-cart,.btn-buy{display:block;width:100%;border-radius:24px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;margin-top:10px;border:1px solid;transition:background .12s}
.btn-cart{background:var(--amz-yellow);border-color:#e0a800;box-shadow:0 2px 5px rgba(0,0,0,.15)}
.btn-cart:hover{background:var(--amz-yellow-h)}
.btn-buy{background:var(--amz-orange);border-color:#e88a00;box-shadow:0 2px 5px rgba(0,0,0,.15);color:#0f1111}
.btn-buy:hover{background:var(--amz-orange-h)}
.desc{font-size:14px;color:#333}
.about-list{list-style:none;margin-top:8px}
.about-list li{position:relative;padding-left:18px;margin-bottom:6px;font-size:14px;line-height:1.5}
.about-list li:before{content:"";position:absolute;left:4px;top:8px;width:5px;height:5px;background:#555;border-radius:50%}
.trust{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid #eee}
.trust div{font-size:12px;color:var(--muted);text-align:center;flex:1;min-width:90px}
.trust .ic{font-size:22px;display:block;margin-bottom:3px}
.spectable{width:100%;border-collapse:collapse;max-width:680px}
.spectable td{padding:9px 12px;border:1px solid #eee;font-size:14px}
.spectable td.k{background:#f7f8f8;font-weight:600;width:38%}
.reviews-empty{text-align:center;padding:30px;color:var(--muted)}
.reviews-empty .big{font-size:40px}

/* ---------- FOOTER ---------- */
.foot{background:var(--navy2);color:#fff;margin-top:30px}
.back-top{background:#37475a;text-align:center;padding:14px;font-size:13px;cursor:pointer}.back-top:hover{background:#485769}
.foot-cols{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:36px 20px}
.foot-cols h4{font-size:15px;margin-bottom:12px}
.foot-cols a{display:block;color:#ddd;font-size:13px;margin-bottom:8px}.foot-cols a:hover{text-decoration:underline}
.foot-base{background:var(--navy);text-align:center;padding:20px;font-size:12px;color:#aaa}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1000px){
  .card-row{grid-template-columns:1fr 1fr;margin-top:20px}
  .hero-badge{display:none}.hero h1{font-size:30px}
  .foot-cols{grid-template-columns:1fr 1fr}
  .pdp{grid-template-columns:1fr}
  .grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}
}
@media(max-width:760px){
  /* MOBILE HEADER: two-row layout */
  .burger{display:block}
  .topbar{flex-wrap:wrap;gap:6px;padding:8px 10px}
  .logo{font-size:21px;order:2}
  .deliver{display:none}
  .nav-right{order:3;margin-left:auto;gap:0}
  .nav-item.acct small,.nav-item b{display:none}
  .nav-item.acct:after{content:"👤";font-size:20px}
  .nav-item:not(.basket):not(.acct){display:none}
  .search{order:5;flex:1 0 100%;height:40px;margin-top:6px}
  .acct-menu{right:-40px}
  .subnav{font-size:13px;padding:5px 8px}
  .subnav .all-btn{display:none}
  .grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .prod{padding:9px;border-radius:8px}
  .prod .title{font-size:13px}
  .prod .price{font-size:16px}
  .strip{padding:14px 12px 18px;border-radius:6px}
  .strip h2{font-size:17px}
  .hero{padding:28px 0 56px}.hero-in{padding:0 18px}.hero h1{font-size:24px}.hero p{font-size:14px}
  .card-row{gap:10px}.cat-card{padding:12px}.cat-card .ph{height:120px}
  .pdp{padding:14px;gap:18px}
  .pdp h1{font-size:20px}
  .price-lg{font-size:24px}
  .foot-cols{grid-template-columns:1fr 1fr;gap:18px;padding:24px 16px}
}
@media(max-width:420px){
  .grid{grid-template-columns:1fr 1fr;gap:8px}
  .nav-item.basket .i{font-size:22px}
}

/* ---------- AUTH PAGES ---------- */
.auth-wrap{display:flex;justify-content:center;padding:24px 14px}
.auth-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:26px;width:100%;max-width:380px;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.auth-card h1{font-size:26px;font-weight:500;margin-bottom:16px}
.auth-card label{display:block;font-size:13px;font-weight:600;margin:12px 0 4px}
.auth-card input{width:100%;padding:10px;border:1px solid #ccc;border-radius:6px;font-size:15px}
.auth-card input:focus{outline:none;border-color:#ff9900;box-shadow:0 0 0 2px rgba(255,153,0,.3)}
.btn-amz{display:block;width:100%;text-align:center;background:var(--amz-yellow);border:1px solid #e0a800;border-radius:8px;padding:11px;font-size:14px;font-weight:600;cursor:pointer;margin-top:18px;color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.12)}
.btn-amz:hover{background:var(--amz-yellow-h)}
.auth-err{background:#fff0f0;border:1px solid #f5c6cb;color:#a12;padding:10px;border-radius:6px;font-size:13px;margin-bottom:6px}
.auth-alt{font-size:13px;margin-top:14px;color:var(--muted)}.auth-alt a{color:var(--blue)}.auth-alt a:hover{color:var(--blue-h);text-decoration:underline}
.auth-note{font-size:11px;color:var(--muted);margin-top:14px;line-height:1.5}.auth-note a{color:var(--blue)}

/* ---------- ORDER STATUS BADGE ---------- */
.ostatus{display:inline-block;padding:4px 10px;border-radius:14px;font-size:12px;font-weight:600}
.s-pending_payment{background:#fff3cd;color:#856404}
.s-awaiting_fulfilment,.s-fulfilled{background:#e1ecf7;color:#0c5460}
.s-shipped{background:#d4edda;color:#155724}
.s-delivered{background:#d1f0d8;color:#0a5128}
.s-cancelled,.s-refunded{background:#f8d7da;color:#721c24}

/* ---------- TRACK PROGRESS ---------- */
.track-line{display:flex;justify-content:space-between;position:relative;margin:10px 0 4px}
.track-line:before{content:"";position:absolute;top:15px;left:8%;right:8%;height:3px;background:#e0e0e0;z-index:0}
.track-step{position:relative;z-index:1;text-align:center;flex:1}
.track-step .dot{width:32px;height:32px;border-radius:50%;background:#e0e0e0;color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 6px;font-size:14px;font-weight:700;border:3px solid #fff}
.track-step.done .dot{background:#067d62}
.track-step.current .dot{background:#067d62;box-shadow:0 0 0 4px rgba(6,125,98,.2)}
.track-step .lbl{font-size:12px;color:var(--muted);line-height:1.3}
.track-step.done .lbl{color:var(--ink);font-weight:600}
@media(max-width:760px){.track-step .lbl{font-size:10px}}

/* ---------- GOOGLE SIGN-IN BUTTON ---------- */
.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:#fff;border:1px solid #dadce0;border-radius:8px;padding:11px;font-size:14px;font-weight:600;color:#3c4043;cursor:pointer;margin-top:16px;transition:background .12s,box-shadow .12s}
.google-btn:hover{background:#f8f9fa;box-shadow:0 1px 3px rgba(60,64,67,.2)}
.google-btn svg{flex-shrink:0}
.auth-or{display:flex;align-items:center;text-align:center;margin:16px 0 4px;color:#999;font-size:12px}
.auth-or:before,.auth-or:after{content:"";flex:1;border-top:1px solid #e0e0e0}
.auth-or span{padding:0 12px}

/* ---------- IMAGE ZOOM (Amazon-style) ---------- */
.zoom-stage{position:relative;cursor:crosshair;border:1px solid #eee;border-radius:8px;overflow:hidden;background:#fff}
.zoom-stage .main{width:100%;aspect-ratio:1/1;object-fit:contain;display:block;border:none;border-radius:0}
.zoom-lens{display:none;position:absolute;border:1px solid #9ecaed;background:rgba(70,150,229,.18);pointer-events:none;z-index:3}
.zoom-panel{display:none;position:absolute;top:0;left:105%;width:480px;height:480px;border:1px solid #ddd;border-radius:8px;background:#fff no-repeat;background-size:cover;z-index:100;box-shadow:0 8px 30px rgba(0,0,0,.18)}
.thumbs img.sel{border-color:var(--amz-orange);box-shadow:0 0 0 1px var(--amz-orange)}
/* hide zoom panel on smaller screens (no room) */
@media(max-width:1100px){ .zoom-panel{display:none!important} .zoom-lens{display:none!important} .zoom-stage{cursor:default} }

/* ---------- LIVE SEARCH DROPDOWN (typeahead) ---------- */
.search{position:relative}
.ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 8px 28px rgba(0,0,0,.18);z-index:200;display:none;overflow:hidden;max-height:70vh;overflow-y:auto}
.ac-dropdown.open{display:block}
.ac-item{display:flex;align-items:center;gap:12px;padding:9px 12px;text-decoration:none;color:#0f1111;border-bottom:1px solid #f3f3f3}
.ac-item:hover,.ac-item.hl{background:#f0f7ff}
.ac-item img{width:46px;height:46px;object-fit:contain;border-radius:6px;background:#fff;flex:0 0 auto;border:1px solid #f0f0f0}
.ac-item .ac-noimg{width:46px;height:46px;display:flex;align-items:center;justify-content:center;font-size:22px;background:#f7f7f7;border-radius:6px;flex:0 0 auto}
.ac-txt{display:flex;flex-direction:column;min-width:0;gap:2px}
.ac-title{font-size:13.5px;line-height:1.3;color:#0f1111;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ac-price{font-size:13px;font-weight:700;color:#b12704}
.ac-all{display:block;padding:10px 12px;text-align:center;font-size:13px;font-weight:600;color:#007185;text-decoration:none;background:#fafafa}
.ac-all:hover,.ac-all.hl{background:#f0f7ff;text-decoration:underline}
@media(max-width:760px){ .ac-item img,.ac-item .ac-noimg{width:40px;height:40px} .ac-title{font-size:13px} }

/* ---------- VARIANT SELECTORS ---------- */
.variants{margin:14px 0;display:flex;flex-direction:column;gap:14px}
.vrow{display:flex;flex-direction:column;gap:7px}
.vlabel{font-size:14px;font-weight:700;color:#0f1111}
.vlabel .vsel{font-weight:400;color:#565959}
.vswatches{display:flex;flex-wrap:wrap;gap:8px}
.vswatch{width:50px;height:50px;border:2px solid #d5d9d9;border-radius:8px;padding:0;background:#fff;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:border-color .12s,box-shadow .12s}
.vswatch img{width:100%;height:100%;object-fit:cover;display:block}
.vswatch .vchip-txt{font-size:11px;padding:2px}
.vswatch:hover{border-color:#888}
.vswatch.vactive{border-color:#e77600;box-shadow:0 0 0 2px rgba(231,118,0,.35)}
.vchips{display:flex;flex-wrap:wrap;gap:8px}
.vchip{padding:8px 14px;border:1px solid #d5d9d9;border-radius:8px;background:#fff;cursor:pointer;font-size:13.5px;color:#0f1111;transition:border-color .12s,box-shadow .12s}
.vchip:hover{border-color:#888}
.vchip.vactive{border-color:#e77600;box-shadow:0 0 0 2px rgba(231,118,0,.35);background:#fff7ec}
.vselect{padding:9px 12px;border:1px solid #d5d9d9;border-radius:8px;background:#f0f2f2;font-size:14px;max-width:100%;cursor:pointer}
.vswatch.vdis,.vchip.vdis{opacity:.4;cursor:not-allowed;position:relative}
.vswatch.vdis{filter:grayscale(1)}
.vchip.vdis{text-decoration:line-through}
.btn-cart.bdis,.btn-buy.bdis{background:#e7e9ec !important;border-color:#d5d9d9 !important;color:#8b8f94 !important;cursor:not-allowed;box-shadow:none !important;filter:none;opacity:1}

/* ---------- SOCIAL PROOF ---------- */
.soldcard{font-size:12px;color:#565959;margin:2px 0 4px}
.soldline{color:#565959;font-size:14px;margin-top:6px}
.soldline strong{color:#0f1111}
.popular{color:#c45500;font-weight:600;font-size:13px}
.add.selopt{display:block;text-align:center;text-decoration:none;line-height:1.4}

/* ---------- WISHLIST HEARTS ---------- */
.pimg-wrap{position:relative}
.wish-btn{position:absolute;top:8px;right:8px;z-index:4;width:34px;height:34px;border-radius:50%;border:1px solid #e3e3e3;background:rgba(255,255,255,.95);color:#888;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(0,0,0,.12);transition:transform .1s,color .12s}
.wish-btn:hover{transform:scale(1.1);color:#e77600}
.wish-btn.wished{color:#e60023;border-color:#f3c2c2}
/* product-page labelled wish button */
.btn-wish{position:static;width:100%;height:auto;border-radius:8px;margin-top:8px;padding:9px;font-size:14px;background:#fff;border:1px solid #d5d9d9;color:#0f1111;box-shadow:none;gap:6px}
.btn-wish:hover{background:#f7fafa;transform:none;border-color:#888;color:#0f1111}
.btn-wish.wished{color:#e60023;border-color:#f3c2c2;background:#fff5f6}

/* ---------- VARIANT GUIDANCE (pulse + shake + instruction) ---------- */
/* gentle pulse on a variant group still needing a choice */
/* left-to-right shimmer sweep — calm, premium "look here" cue */
@keyframes vShimmer {
  0%   { background-position:-150% 0; }
  100% { background-position:250% 0; }
}
.vrow.vneed{ border-radius:10px; }
.vrow.vneed .vlabel{ color:#c45500; }
/* soft amber border so it still reads as "needs a choice" */
.vrow.vneed .vselect{ border-color:#e77600; box-shadow:0 0 0 1px rgba(231,118,0,.20); }
/* the shimmer overlay glides across the picker area */
/* swatches & chips: shimmer via overlay (pointer-events none so clicks pass through) */
.vrow.vneed .vswatches,
.vrow.vneed .vchips{ position:relative; }
.vrow.vneed .vswatches::after,
.vrow.vneed .vchips::after{
  content:""; position:absolute; inset:-4px; pointer-events:none; border-radius:10px;
  background:linear-gradient(100deg, transparent 35%, rgba(231,118,0,.14) 48%, rgba(255,180,80,.30) 50%, rgba(231,118,0,.14) 52%, transparent 65%);
  background-size:200% 100%;
  animation:vShimmer 2.4s ease-in-out infinite;
}
/* native <select>: animate its OWN background (pseudo-elements don't render on selects) */
.vrow.vneed .vselect{
  background-image:linear-gradient(100deg, transparent 35%, rgba(231,118,0,.12) 48%, rgba(255,180,80,.26) 50%, rgba(231,118,0,.12) 52%, transparent 65%), linear-gradient(#f7f8f8,#f0f2f2);
  background-size:200% 100%, 100% 100%;
  background-repeat:no-repeat;
  animation:vShimmer 2.4s ease-in-out infinite;
}

/* shake when a customer tries to buy without choosing */
@keyframes vShake {
  0%,100%{ transform:translateX(0); }
  20%{ transform:translateX(-6px); }
  40%{ transform:translateX(6px); }
  60%{ transform:translateX(-4px); }
  80%{ transform:translateX(4px); }
}
.vrow.vshake{ animation:vShake .5s ease; }

/* the "↑ Please choose Colour and Model" instruction pill */
.needpick{
  display:inline-block; background:#fff4e5; color:#c45500; font-weight:600;
  font-size:13.5px; padding:6px 12px; border-radius:8px; border:1px solid #ffd9a8;
}

/* ================= HERO CAROUSEL ================= */
.hero-carousel{position:relative;width:100%;height:440px;overflow:hidden;background:#0b1f33}
.hc-viewport{position:absolute;inset:0}
.hc-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .8s ease;display:flex;align-items:center}
.hc-slide.active{opacity:1;visibility:visible;z-index:2}
/* background image with slow ken-burns zoom */
.hc-bg{position:absolute;inset:0;background:var(--bg) center/cover no-repeat;transform:scale(1.05)}
.hc-slide.active .hc-bg{animation:hcZoom 9s ease-out forwards}
@keyframes hcZoom{from{transform:scale(1.05)}to{transform:scale(1.15)}}
.hc-scrim{position:absolute;inset:0;background:linear-gradient(90deg, rgba(8,18,30,.86) 0%, rgba(8,18,30,.62) 38%, rgba(8,18,30,.15) 70%, rgba(8,18,30,0) 100%)}
/* brand slide gradient (no image) */
.hc-brand{background:linear-gradient(120deg,#dff1ff 0%,#eaf6ff 40%,#ffffff 100%)}
.hc-content{position:relative;z-index:3;max-width:1280px;margin:0 auto;padding:0 60px;width:100%}
.hc-brand .hc-content h2,.hc-brand .hc-content p{color:#0b1f33}
.hc-slide:not(.hc-brand) .hc-content *{color:#fff}
.hc-content .hc-btn{color:#0f1111 !important}
.hc-kicker{display:inline-block;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);padding:5px 12px;border-radius:30px;margin-bottom:14px}
.hc-slide:not(.hc-brand) .hc-kicker{background:rgba(255,255,255,.18)}
.hc-title{font-size:46px;line-height:1.08;font-weight:800;max-width:620px;margin:0 0 12px;letter-spacing:-.5px}
.hc-title-sm{font-size:30px;max-width:560px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hc-sub{font-size:18px;max-width:520px;margin:0 0 18px;opacity:.95}
.hc-price{font-size:30px;font-weight:800;margin-bottom:16px;color:#fff}
.hc-was{font-size:18px;font-weight:400;text-decoration:line-through;opacity:.7;margin-left:8px}
.hc-btn{display:inline-block;background:var(--amz-yellow,#ffd814);color:#0f1111;font-weight:700;font-size:15px;padding:13px 26px;border-radius:30px;text-decoration:none;box-shadow:0 4px 14px rgba(0,0,0,.22);transition:transform .12s,background .12s}
.hc-btn:hover{background:var(--amz-yellow-h,#f7ca00);transform:translateY(-2px)}
/* arrows */
.hc-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:46px;height:46px;border-radius:50%;border:none;background:rgba(255,255,255,.85);color:#111;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,.18);transition:background .12s,transform .12s;opacity:0}
.hero-carousel:hover .hc-arrow{opacity:1}
.hc-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.08)}
.hc-prev{left:18px}.hc-next{right:18px}
/* dots */
.hc-dots{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:9px}
.hc-dot{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.5);cursor:pointer;padding:0;transition:width .25s,background .25s}
.hc-dot.active{width:26px;border-radius:6px;background:#fff}
.hc-brand ~ .hc-dots .hc-dot,.hc-dots .hc-dot{box-shadow:0 1px 3px rgba(0,0,0,.3)}

/* ---- horizontal best-sellers rail ---- */
.rail-wrap{position:relative;margin:8px 0 4px}
.rail{display:flex;gap:14px;overflow-x:auto;scroll-behavior:smooth;padding:4px 2px 12px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.rail::-webkit-scrollbar{height:8px}
.rail::-webkit-scrollbar-thumb{background:#d5d9d9;border-radius:4px}
.rail .prod{flex:0 0 210px;width:210px}
.rail-btn{position:absolute;top:38%;z-index:4;width:40px;height:40px;border-radius:50%;border:1px solid #e3e3e3;background:#fff;font-size:22px;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center}
.rail-btn.l{left:-6px}.rail-btn.r{right:-6px}

@media(max-width:760px){
  .hero-carousel{height:300px}
  .hc-content{padding:0 24px}
  .hc-title{font-size:30px}
  .hc-title-sm{font-size:22px}
  .hc-sub{font-size:15px}
  .hc-arrow{display:none}
  .hc-scrim{background:linear-gradient(180deg, rgba(8,18,30,.3) 0%, rgba(8,18,30,.55) 60%, rgba(8,18,30,.8) 100%)}
  .rail .prod{flex:0 0 160px;width:160px}
  .rail-btn{display:none}
}
