:root{
  --brand:#0c3866;
  --brand-dark:#082745;
  --accent:#e63946;
  --accent-dark:#c82a37;
  --dark:#0a1929;
  --gray-100:#f6f7f9;
  --gray-200:#eceff3;
  --gray-300:#d8dde3;
  --gray-500:#8a93a0;
  --gray-700:#4a525e;
  --gray-900:#1f242c;
  --shadow:0 6px 24px rgba(0,0,0,.06);
  --radius:6px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter','Roboto',-apple-system,Segoe UI,Helvetica,Arial,sans-serif;color:var(--gray-900);background:#fff;line-height:1.55}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{color:var(--brand-dark)}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.btn{display:inline-block;padding:12px 22px;background:var(--brand);color:#fff;border-radius:4px;border:none;cursor:pointer;font-weight:600;letter-spacing:.3px;transition:.2s}
.btn:hover{background:var(--brand-dark);color:#fff}
.btn.outline{background:transparent;color:#fff;border:2px solid #fff}
.btn.outline:hover{background:#fff;color:var(--gray-900)}
.btn.dark{background:var(--gray-900)}
.btn.dark:hover{background:#000}

/* Top bar */
.topbar{background:var(--gray-900);color:#cfd5dd;font-size:13px;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.topbar a{color:#cfd5dd}
.topbar .info span{margin-right:18px}

/* Header */
.site-header{background:#fff;box-shadow:var(--shadow);position:sticky;top:0;z-index:50}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:18px 20px}
.logo{font-weight:800;font-size:22px;color:var(--gray-900);display:flex;align-items:center;gap:10px}
.logo img{height:44px;width:auto}
.logo .mark{display:inline-block;width:36px;height:36px;background:var(--brand);color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:18px}
.main-nav{display:flex;align-items:center;gap:6px}
.main-nav a{padding:10px 14px;color:var(--gray-900);font-weight:600;font-size:15px;border-radius:4px}
.main-nav a:hover{background:var(--gray-100);color:var(--brand)}
.menu-toggle{display:none;background:none;border:0;font-size:24px;cursor:pointer;color:var(--gray-900)}

/* Hero slider */
.hero{position:relative;overflow:hidden}
.slides{position:relative;height:520px}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;display:flex;align-items:center;opacity:0;transition:opacity .8s}
.slide.active{opacity:1}
.slide::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.65),rgba(0,0,0,.2))}
.slide-content{position:relative;color:#fff;max-width:640px;padding:0 20px;margin:0 auto;width:100%}
.slide-content .sub{display:inline-block;background:var(--brand);padding:6px 14px;border-radius:3px;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.slide-content h1{font-size:46px;line-height:1.15;margin:14px 0 16px;font-weight:800}
.slide-content p{font-size:17px;opacity:.92;margin-bottom:24px}
.hero .dots{position:absolute;bottom:20px;left:0;right:0;text-align:center;z-index:2}
.hero .dots span{display:inline-block;width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.5);margin:0 4px;cursor:pointer}
.hero .dots span.active{background:#fff}
.hero .arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);color:#fff;border:none;width:46px;height:46px;border-radius:50%;font-size:24px;cursor:pointer;z-index:2}
.hero .arrow:hover{background:rgba(255,255,255,.3)}
.hero .arrow.prev{left:20px}
.hero .arrow.next{right:20px}

/* Sections */
.section{padding:70px 0}
.section.alt{background:var(--gray-100)}
.section-head{text-align:center;margin-bottom:40px}
.section-head .eyebrow{color:var(--brand);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;font-size:13px}
.section-head h2{font-size:34px;margin:8px 0 12px;font-weight:800}
.section-head p{color:var(--gray-700);max-width:680px;margin:0 auto}

/* Grids */
.grid{display:grid;gap:24px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}

/* Cards */
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:.25s;border:1px solid var(--gray-200)}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.1)}
.card .thumb{aspect-ratio:4/3;background:var(--gray-100);overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .thumb img{transform:scale(1.05)}
.card .body{padding:18px}
.card .body h3{font-size:17px;margin:0 0 6px;font-weight:700}
.card .body p{font-size:14px;color:var(--gray-700);margin:0 0 10px}
.card .body .more{font-size:13px;font-weight:700;color:var(--brand)}

/* Category cards */
.cat-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;background:var(--gray-200)}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:.4s}
.cat-card:hover img{transform:scale(1.06)}
.cat-card .label{position:absolute;left:0;right:0;bottom:0;padding:18px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.8));color:#fff}
.cat-card .label h3{margin:0;font-size:18px;font-weight:700}

/* Features */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.feature{text-align:center;padding:26px 18px;background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200)}
.feature .icon{width:60px;height:60px;background:var(--brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 16px}
.feature h3{font-size:16px;margin:0 0 8px}
.feature p{font-size:14px;color:var(--gray-700);margin:0}

/* About strip */
.about-strip{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.about-strip img{border-radius:var(--radius);box-shadow:var(--shadow)}
.about-strip h2{font-size:32px;margin:0 0 14px;font-weight:800}
.about-strip ul{padding-left:18px;margin:14px 0 24px}
.about-strip ul li{margin-bottom:6px}

/* Page header */
.page-head{background:linear-gradient(135deg,var(--gray-900),#2b3340);color:#fff;padding:60px 0;text-align:center}
.page-head h1{font-size:36px;margin:0 0 8px}
.page-head .crumbs{font-size:14px;opacity:.85}
.page-head .crumbs a{color:#fff;opacity:.8}

/* Product detail */
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.gallery .main-img{aspect-ratio:1/1;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;background:#fff}
.gallery .main-img img{width:100%;height:100%;object-fit:contain}
.gallery .thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.gallery .thumbs img{width:72px;height:72px;object-fit:cover;border:2px solid transparent;border-radius:6px;cursor:pointer}
.gallery .thumbs img.active{border-color:var(--brand)}
.product-info h1{font-size:30px;margin:0 0 8px}
.product-info .sku{color:var(--gray-500);font-size:14px;margin-bottom:16px}
.product-info .desc{color:var(--gray-700);margin-bottom:20px}
.tabs{margin-top:30px;border-top:1px solid var(--gray-200);padding-top:20px}
.tabs .tab-headers{display:flex;gap:6px;border-bottom:2px solid var(--gray-200);margin-bottom:20px}
.tabs .tab-headers button{background:none;border:0;padding:12px 18px;cursor:pointer;font-weight:600;color:var(--gray-700);border-bottom:3px solid transparent;margin-bottom:-2px}
.tabs .tab-headers button.active{color:var(--brand);border-color:var(--brand)}
.tabs .tab-content{display:none}
.tabs .tab-content.active{display:block}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:30px}
.contact-info{background:var(--gray-900);color:#fff;padding:30px;border-radius:var(--radius)}
.contact-info h3{margin-top:0}
.contact-info .item{display:flex;gap:12px;margin-bottom:16px}
.contact-info .item .ic{width:40px;height:40px;background:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.form-row{margin-bottom:16px}
.form-row label{display:block;margin-bottom:6px;font-weight:600;font-size:14px}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:12px 14px;border:1px solid var(--gray-300);border-radius:6px;font:inherit;font-size:15px}
.form-row textarea{resize:vertical;min-height:120px}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--brand)}

/* News */
.news-card .thumb{aspect-ratio:16/10}
.news-card .meta{font-size:13px;color:var(--gray-500);margin-bottom:6px}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:6px;margin-top:30px}
.pagination a,.pagination span{padding:8px 14px;border:1px solid var(--gray-300);border-radius:4px;color:var(--gray-900)}
.pagination .active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* Footer */
.site-footer{background:#0f1419;color:#cfd5dd;padding:60px 0 0}
.site-footer h4{color:#fff;font-size:16px;margin:0 0 16px}
.site-footer a{color:#cfd5dd}
.site-footer a:hover{color:#fff}
.site-footer .grid{grid-template-columns:1.5fr 1fr 1fr 1.5fr}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin-bottom:8px;font-size:14px}
.socials{display:flex;gap:10px;margin-top:14px}
.socials a{width:36px;height:36px;background:#1c232c;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#cfd5dd}
.socials a:hover{background:var(--brand);color:#fff}
.copyright{border-top:1px solid #1c232c;margin-top:40px;padding:18px 0;text-align:center;font-size:13px}

/* Flash */
.alert{padding:12px 16px;border-radius:6px;margin-bottom:16px}
.alert.success{background:#d1fae5;color:#065f46}
.alert.error{background:#fee2e2;color:#991b1b}
.alert.info{background:#dbeafe;color:#1e3a8a}

/* Responsive */
@media (max-width:992px){
  .grid.cols-4{grid-template-columns:repeat(3,1fr)}
  .features{grid-template-columns:repeat(2,1fr)}
  .about-strip,.contact-grid,.product-detail{grid-template-columns:1fr}
  .site-footer .grid{grid-template-columns:1fr 1fr}
  .slide-content h1{font-size:34px}
}
@media (max-width:720px){
  .grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .menu-toggle{display:block}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:10px;box-shadow:var(--shadow)}
  .main-nav.open{display:flex}
  .main-nav a{padding:12px;border-bottom:1px solid var(--gray-200)}
  .slides{height:420px}
  .slide-content h1{font-size:26px}
  .section{padding:50px 0}
  .site-footer .grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .grid.cols-3,.grid.cols-4{grid-template-columns:1fr}
}

/* ============ Marine theme additions ============ */
.topbar{background:var(--brand-dark)}
.site-header{background:var(--brand);box-shadow:0 2px 0 rgba(0,0,0,.1)}
.site-header .logo{color:#fff}
.site-header .logo .mark{background:var(--accent)}
.main-nav a{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.5px}
.main-nav a:hover{background:rgba(255,255,255,.1);color:#fff}
.menu-toggle{color:#fff}
.btn{background:var(--accent);border-radius:3px;text-transform:uppercase;letter-spacing:.5px;font-size:13px}
.btn:hover{background:var(--accent-dark)}
.btn.dark{background:var(--brand)}
.btn.dark:hover{background:var(--brand-dark)}

/* Offer hero strip */
.offer-hero{position:relative;height:300px;background-size:cover;background-position:center;display:flex;align-items:center;color:#fff;overflow:hidden}
.offer-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,25,41,.75),rgba(10,25,41,.2))}
.offer-hero .container{position:relative;z-index:2}
.offer-hero .pill{display:inline-block;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);padding:6px 14px;border-radius:999px;font-size:12px;letter-spacing:1px;text-transform:uppercase}
.offer-hero h1{font-size:54px;margin:14px 0 12px;font-weight:800;line-height:1;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.offer-hero p{font-size:17px;opacity:.95;margin:0 0 20px;max-width:480px}

/* Quick categories strip */
.quick-cats{background:#fff;padding:30px 0;border-bottom:1px solid var(--gray-200)}
.quick-cats .row{display:grid;grid-template-columns:repeat(7,1fr);gap:14px}
.quick-cats a{display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--gray-900);padding:10px;border-radius:6px;transition:.2s}
.quick-cats a:hover{background:var(--gray-100);color:var(--brand);transform:translateY(-2px)}
.quick-cats .ico{background:var(--gray-100);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;overflow:hidden}
.quick-cats .ico img{width:100%;height:100%;object-fit:contain;padding:6px}
.quick-cats .name{font-size:12px;font-weight:600;line-height:1.3}

/* Section heading marine style */
.sec-head{padding:30px 0 18px}
.sec-head h2{font-size:22px;font-weight:800;margin:0;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-900)}
.sec-head .more{float:right;font-size:13px;font-weight:700;color:var(--gray-700);text-transform:uppercase}
.sec-head .more:hover{color:var(--accent)}

/* Application big cards (2 cols) */
.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:30px}
.app-card{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:16/7;background:var(--gray-200);display:block}
.app-card img{width:100%;height:100%;object-fit:cover;transition:.5s}
.app-card:hover img{transform:scale(1.05)}
.app-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 30%,rgba(10,25,41,.85))}
.app-card .label{position:absolute;left:0;right:0;bottom:0;padding:24px;color:#fff;z-index:2}
.app-card .label h3{margin:0;font-size:22px;font-weight:800;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.app-card .label p{margin:4px 0 0;font-size:14px;opacity:.9}

/* Build section (3 cols) */
.build-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.build-grid .build-card{aspect-ratio:16/8}

/* Build feature grid: 1 large left + 2 small top-right + 1 wide bottom-right */
.build-feature-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:280px 280px;gap:18px}
.build-feature-grid .app-card{aspect-ratio:unset;height:100%}
.build-feature-grid .build-feat-0{grid-column:1;grid-row:1 / 3}
.build-feature-grid .build-feat-1{grid-column:2;grid-row:1}
.build-feature-grid .build-feat-2{grid-column:3;grid-row:1}
.build-feature-grid .build-feat-3{grid-column:2 / span 2;grid-row:2}
.build-feature-grid .label h3{font-size:18px}
.build-feature-grid .build-feat-0 .label h3{font-size:22px}
@media (max-width:900px){
  .build-feature-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .build-feature-grid .build-feat-0,
  .build-feature-grid .build-feat-1,
  .build-feature-grid .build-feat-2,
  .build-feature-grid .build-feat-3{grid-column:auto;grid-row:auto;aspect-ratio:16/9}
}
@media (max-width:600px){
  .build-feature-grid{grid-template-columns:1fr}
}

/* ── Customer Favorites ─────────────────────────────────────── */
.fav-row{display:flex;gap:0;margin-bottom:32px;align-items:stretch;border:1px solid var(--gray-200);border-radius:10px;overflow:hidden}

/* Left: tall category banner */
.fav-side{flex:0 0 260px;position:relative;background:var(--brand) center/cover no-repeat;color:#fff;text-decoration:none;display:flex;align-items:flex-end;min-height:320px}
.fav-side::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(12,56,102,.15),rgba(12,56,102,.75))}
.fav-side-inner{position:relative;z-index:2;padding:24px 20px}
.fav-side h3{margin:0 0 6px;font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}
.fav-side p{margin:0 0 14px;font-size:13px;opacity:.9;line-height:1.5}
.fav-side .btn{background:#fff;color:var(--brand);font-size:12px;padding:8px 16px;display:inline-block;width:auto;border-radius:4px}
.fav-side .btn:hover{background:var(--accent);color:#fff}

/* Right: scrollable carousel */
.fav-carousel-wrap{flex:1 1 0;min-width:0;position:relative;background:#f8f9fa}
.fav-carousel{display:flex;gap:0;overflow-x:hidden;height:100%}
.fav-prod-card{flex:1 1 0;min-width:0;scroll-snap-align:start;border-left:1px solid var(--gray-200);background:#fff;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:.15s}
.fav-prod-card:hover{background:#fafbff;z-index:1}
.fav-prod-img{position:relative;aspect-ratio:1/1;background:var(--gray-100);overflow:hidden}
.fav-prod-img img{width:100%;height:100%;object-fit:contain;padding:12px;transition:.2s}
.fav-prod-card:hover .fav-prod-img img{transform:scale(1.04)}
.fav-badge{position:absolute;top:10px;right:10px;background:#111;color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:3px;z-index:2}
.fav-prod-body{flex:1;display:flex;flex-direction:column;padding:12px 14px 14px;gap:4px}
.fav-prod-name{font-size:13px;font-weight:600;color:var(--gray-900);line-height:1.35;flex:1}
.fav-stars{display:flex;align-items:center;gap:3px;font-size:13px;color:#f5a623;margin-top:2px}
.fav-stars span{color:var(--gray-600);font-size:12px;margin-left:3px}
.fav-sku{font-size:11px;color:var(--gray-500)}
.fav-price-row{display:flex;align-items:center;flex-wrap:wrap;gap:5px;margin-top:4px}
.fav-old{text-decoration:line-through;color:var(--gray-500);font-size:13px}
.fav-now{color:var(--accent);font-weight:700;font-size:14px}
.fav-save{color:#d97706;font-weight:700;font-size:12px}
.fav-atc{align-self:flex-start;margin-top:8px;width:36px;height:36px;border-radius:50%;background:var(--brand);color:#fff;border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:.15s}
.fav-atc:hover{background:var(--accent)}

/* Scroll arrows */
.fav-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#fff;border:1px solid var(--gray-200);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;color:var(--gray-700);z-index:5;box-shadow:0 2px 8px rgba(0,0,0,.1);transition:.15s}
.fav-arrow:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.fav-arrow-prev{left:6px}
.fav-arrow-next{right:6px}

/* ── legacy fav-card kept for other sections ────────────────── */
.fav-card{background:#fff;border:1px solid var(--gray-200);border-radius:6px;overflow:hidden;text-align:center;padding:14px 10px;transition:.2s;display:block}
.fav-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.08)}
.fav-card .pic{aspect-ratio:1/1;background:var(--gray-100);border-radius:4px;overflow:hidden;margin-bottom:10px}
.fav-card .pic img{width:100%;height:100%;object-fit:contain;padding:8px}
.fav-card h4{margin:0 0 4px;font-size:13px;font-weight:700;color:var(--gray-900);min-height:32px;line-height:1.3}
.fav-card .price{color:var(--accent);font-weight:700;font-size:14px}

/* Promo strip */
/* Promo strip — full width with background image */
.promo-strip-wrap{position:relative;background:var(--brand-dark) center/cover no-repeat;color:#fff;padding:120px 20px;text-align:center;margin:50px 0;overflow:hidden;width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.promo-strip-overlay{position:absolute;inset:0;background:linear-gradient(rgba(10,25,41,.55),rgba(10,25,41,.8))}
.promo-strip-inner{position:relative;z-index:2;max-width:900px}
.promo-strip-wrap h2{font-size:40px;margin:0 0 12px;font-weight:800;letter-spacing:-.3px;text-shadow:0 2px 14px rgba(0,0,0,.3)}
.promo-strip-wrap p{margin:0 0 24px;font-size:17px;opacity:.95}
.promo-strip-wrap .btn{padding:14px 32px;font-size:14px}

/* Legacy promo-strip kept for backward compatibility */
.promo-strip{background:var(--brand-dark) center/cover no-repeat;color:#fff;padding:120px 20px;text-align:center;position:relative;border-radius:6px;margin:30px 0;overflow:hidden}
.promo-strip::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(10,25,41,.65),rgba(10,25,41,.85))}
.promo-strip > *{position:relative;z-index:2}
.promo-strip h2{font-size:32px;margin:0 0 8px;font-weight:800}
.promo-strip p{margin:0 0 20px;opacity:.9}

@media (max-width:720px){
  .promo-strip-wrap{padding:70px 20px}
  .promo-strip-wrap h2{font-size:26px}
  .promo-strip-wrap p{font-size:14px}
}

/* New arrivals (5 cols) */
.arrivals-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media (max-width:1100px){
  .arrivals-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:900px){
  .arrivals-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:600px){
  .arrivals-grid{grid-template-columns:repeat(2,1fr)}
}

/* DIY tricks */
.diy-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;align-items:stretch}
.diy-card{position:relative;border-radius:6px;overflow:hidden;display:block}
.diy-card img{width:100%;height:100%;object-fit:cover;transition:.4s}
.diy-card:hover img{transform:scale(1.05)}
.diy-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.85))}
.diy-card .lbl{position:absolute;left:0;right:0;bottom:0;padding:18px;color:#fff;z-index:2}
.diy-card .lbl h3{margin:0;font-size:18px;font-weight:700}
/* Left big card: fixed height */
.diy-grid > .diy-card{height:360px}
/* Right column: two equal cards that together match the left */
.diy-side{display:grid;grid-template-rows:1fr 1fr;gap:18px;height:360px}
.diy-side .diy-card{height:100%}

/* Footer marine */
.site-footer{background:var(--brand-dark)}

@media (max-width:992px){
  .quick-cats .row{grid-template-columns:repeat(4,1fr)}
  .fav-row{flex-direction:column}
  .fav-side{flex:0 0 auto;min-height:200px}
  .fav-prod-card{flex:0 0 180px}
  .arrivals-grid{grid-template-columns:repeat(2,1fr)}
  .app-grid,.build-grid,.diy-grid{grid-template-columns:1fr}
  .offer-hero h1{font-size:36px}
}
@media (max-width:600px){
  .quick-cats .row{grid-template-columns:repeat(3,1fr)}
  .fav-prod-card{flex:0 0 160px}
}

/* ============ Shop Mega Menu ============ */
.site-header{position:sticky}                /* keep sticky as positioning context */
.main-nav{position:static}                   /* let .mega ascend to .site-header */
.has-mega{position:static}
.has-mega .mega-trigger{display:inline-flex;align-items:center}
.mega{position:absolute;left:0;right:0;top:100%;background:#fff;color:var(--gray-900);box-shadow:0 14px 40px rgba(0,0,0,.18);border-top:1px solid var(--gray-200);visibility:hidden;opacity:0;transform:translateY(-6px);transition:.18s ease;z-index:60}
.has-mega:hover .mega,.has-mega.open .mega,.mega:hover{visibility:visible;opacity:1;transform:translateY(0)}
.has-mega:hover > .mega-trigger,.has-mega.open > .mega-trigger{background:rgba(255,255,255,.1)}
.mega-inner{max-width:1200px;margin:0 auto;padding:24px;display:grid;grid-template-columns:260px 1fr;gap:30px;text-transform:none;letter-spacing:0}
/* Reset nav uppercase inside mega panel */
.mega .mega-list a,.mega .mega-child .nm,.mega .mega-all,.mega .mega-children h4{text-transform:none;letter-spacing:0}
.mega-list{list-style:none;margin:0;padding:0;border-right:1px solid var(--gray-200)}
.mega-list li{display:flex;align-items:center;justify-content:space-between;padding:0;margin:0;cursor:pointer;border-bottom:1px solid var(--gray-200);transition:.15s}
.mega-list li:last-child{border-bottom:none}
.mega-list li:hover{background:var(--gray-100)}
.mega-list li.active{background:#f0f4ff;border-bottom:2px solid var(--brand)}
.mega-list li.active a{color:var(--brand)}
.mega-list li > i{color:var(--gray-400);font-size:12px;margin-right:14px;flex-shrink:0}
.mega-list li.active > i{color:var(--brand)}
.mega-list a{display:block;padding:13px 14px;color:var(--gray-800);font-weight:500;font-size:14px;flex:1;text-transform:none;letter-spacing:0}
.mega-list a:hover{color:var(--brand)}

.mega-preview{position:relative}
.mega-card{display:none;gap:24px;padding:0}
.mega-card.active{display:block}

.mega-children h4{margin:0 0 14px;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--gray-500);font-weight:700}
.mega-all{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--gray-100);border-radius:6px;color:var(--gray-900);font-weight:600;font-size:13px;margin-bottom:18px;transition:.15s}
.mega-all:hover{background:var(--brand);color:#fff}
.mega-all i{font-size:12px}
.mega-children-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.mega-child{display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--gray-900);padding:10px 8px;border-radius:8px;border:1px solid transparent;transition:.15s}
.mega-child:hover{background:var(--gray-100);border-color:var(--gray-200);color:var(--gray-900);transform:translateY(-2px)}
.mega-child .pic{width:100%;aspect-ratio:1/1;background:#fff;border-radius:6px;overflow:hidden;margin-bottom:10px;display:flex;align-items:center;justify-content:center;border:1px solid var(--gray-200)}
.mega-child .pic img{width:100%;height:100%;object-fit:contain;padding:10px;transition:.2s}
.mega-child:hover .pic img{transform:scale(1.05)}
.mega-child .nm{font-size:13px;font-weight:600;line-height:1.3;color:var(--gray-900)}
.mega-child:hover .nm{color:var(--accent)}
.mega-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%;background:var(--gray-100);border-radius:8px;padding:40px}
.mega-empty p{margin:0 0 14px;color:var(--gray-700);font-size:15px;font-weight:600}

/* Mobile fallback: simple stacked list */
@media (max-width:720px){
  .mega{position:static;visibility:visible;opacity:1;transform:none;box-shadow:none;display:none;border-top:0;background:transparent;max-height:none}
  .has-mega.open .mega{display:block}
  .mega-inner{grid-template-columns:1fr;padding:0;gap:0}
  .mega-list{border-right:0;padding-left:14px}
  .mega-list li{margin:0}
  .mega-list a{color:#fff;font-weight:500}
  .mega-list li.active{background:transparent}
  .mega-list li.active a{color:#fff}
  .mega-list li > i{display:none}
  .mega-preview{display:none}
}
@media (max-width:1100px) and (min-width:721px){
  .mega-children-grid{grid-template-columns:repeat(3,1fr)}
}

/* ============ Category / Collection page ============ */
.cat-hero{padding:50px 20px 30px;text-align:center;background:#fff}
.cat-hero h1{margin:0;font-size:34px;font-weight:800;color:var(--gray-900);letter-spacing:-.3px}
.cat-hero .cat-subtitle{font-size:18px;font-weight:600;color:var(--gray-700);margin:8px 0 14px}
.cat-hero .cat-desc{max-width:820px;margin:0 auto;color:var(--gray-700);font-size:14px;line-height:1.7}

.cat-page{padding:24px 0 60px;background:#fff}
.cat-toolbar{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);padding:14px 0;margin-bottom:24px;flex-wrap:wrap;gap:10px}
.cat-toolbar .count{font-size:14px;color:var(--gray-700);font-weight:600}
.cat-toolbar .sort-form label{font-size:14px;color:var(--gray-700)}
.cat-toolbar .sort-form select{margin-left:8px;padding:6px 10px;border:1px solid var(--gray-300);border-radius:4px;font:inherit;font-size:14px;background:#fff}

.cat-layout{display:grid;grid-template-columns:240px 1fr;gap:30px;align-items:flex-start}
.cat-sidebar{position:sticky;top:80px}
.filter-block{background:var(--gray-100);border-radius:8px;padding:16px;margin-bottom:14px}
.filter-block h4{margin:0 0 12px;font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--gray-900);font-weight:700}
.filter-block input[type="text"],.filter-block input[type="number"]{width:100%;padding:8px 10px;border:1px solid var(--gray-300);border-radius:4px;font:inherit;font-size:13px;background:#fff}
.filter-cats{list-style:none;padding:0;margin:0;font-size:13px}
.filter-cats > li{margin-bottom:4px}
.filter-cats a{display:block;padding:5px 8px;color:var(--gray-900);border-radius:3px}
.filter-cats a:hover{background:#fff;color:var(--accent)}
.filter-cats a.active{background:var(--brand);color:#fff;font-weight:600}
.filter-cats ul{list-style:none;padding-left:14px;margin:4px 0;border-left:2px solid var(--gray-300)}
.filter-cats ul a{font-size:12px;color:var(--gray-700);padding:3px 8px}
.price-row{display:flex;align-items:center;gap:6px}
.price-row span{color:var(--gray-500)}
.filter-list{list-style:none;padding:0;margin:0;font-size:13px}
.filter-list li{margin-bottom:6px}
.filter-list label{display:flex;align-items:center;gap:6px;cursor:pointer}

.top-picks .pick{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--gray-300);color:var(--gray-900)}
.top-picks .pick:last-child{border-bottom:0}
.top-picks .pick:hover .nm{color:var(--accent)}
.top-picks .pick .pic{width:60px;height:60px;background:#fff;border-radius:4px;flex-shrink:0;overflow:hidden;border:1px solid var(--gray-300)}
.top-picks .pick .pic img{width:100%;height:100%;object-fit:contain;padding:4px}
.top-picks .nm{font-size:12px;font-weight:600;line-height:1.3;margin-bottom:2px}
.top-picks .stars{font-size:10px;color:#fbbf24;margin-bottom:2px}
.top-picks .stars i{margin-right:1px}
.top-picks .pr{font-size:13px;font-weight:700;color:var(--accent)}

/* Product grid */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.prod-card{background:#fff;border:1px solid var(--gray-200);border-radius:6px;overflow:hidden;transition:.2s;position:relative;display:flex;flex-direction:column}
.prod-card:hover{border-color:var(--accent);box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-2px)}
.prod-link{display:block;color:inherit}
.prod-pic{aspect-ratio:1/1;background:var(--gray-100);overflow:hidden;position:relative}
.prod-pic img{width:100%;height:100%;object-fit:contain;padding:14px;transition:.4s}
.prod-card:hover .prod-pic img{transform:scale(1.05)}
.prod-pic .badge{position:absolute;top:10px;font-size:10px;font-weight:700;padding:4px 10px;border-radius:3px;text-transform:uppercase;letter-spacing:.6px;color:#fff;z-index:2}
.prod-pic .badge.sale{left:10px;background:var(--accent)}
.prod-pic .badge.new{right:10px;background:#22c55e}

.prod-body{padding:14px;display:flex;flex-direction:column;flex:1;position:relative}
.prod-name{display:block;font-size:13px;font-weight:600;color:var(--gray-900);line-height:1.4;margin-bottom:6px;min-height:36px}
.prod-name:hover{color:var(--accent)}
.prod-rating{font-size:11px;color:#fbbf24;margin-bottom:4px}
.prod-rating i{margin-right:1px}
.prod-rating span{color:var(--gray-500);margin-left:4px;font-size:11px}
.prod-sku{font-size:11px;color:var(--gray-500);margin-bottom:6px;font-weight:600;letter-spacing:.3px}
.prod-price{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-top:auto}
.prod-price .old{font-size:12px;color:var(--gray-500);text-decoration:line-through}
.prod-price .now{font-size:16px;font-weight:800;color:var(--accent)}
.prod-price .save{font-size:10px;background:var(--accent);color:#fff;padding:2px 6px;border-radius:3px;font-weight:700}
.prod-cta{position:absolute;bottom:14px;right:14px;width:32px;height:32px;background:var(--brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;transition:.2s}
.prod-cta:hover{background:var(--accent);color:#fff;transform:scale(1.1)}
.prod-card .prod-cta{opacity:0;transform:translateY(4px)}
.prod-card:hover .prod-cta{opacity:1;transform:translateY(0)}

.empty{text-align:center;padding:60px 20px;background:var(--gray-100);border-radius:8px}
.empty h3{margin:14px 0 6px}

/* SEO content */
.cat-seo{background:#fff;padding:50px 20px;border-top:1px solid var(--gray-200)}
.cat-seo h2{font-size:24px;font-weight:800;margin:0 0 16px;color:var(--gray-900)}
.cat-seo .seo-content{color:var(--gray-700);line-height:1.8;font-size:15px;max-width:980px}

/* FAQ */
.cat-faq{background:var(--gray-100);padding:50px 20px}
.cat-faq h2{text-align:center;font-size:22px;font-weight:800;margin:0 0 24px;text-transform:uppercase;letter-spacing:.5px}
.faq-list{max-width:880px;margin:0 auto}
.faq-item{background:#fff;border-radius:6px;margin-bottom:10px;border:1px solid var(--gray-200);overflow:hidden}
.faq-item summary{padding:16px 20px;cursor:pointer;font-weight:600;font-size:15px;display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary i{transition:.2s;color:var(--gray-500)}
.faq-item[open] summary i{transform:rotate(45deg);color:var(--accent)}
.faq-item .faq-answer{padding:0 20px 18px;color:var(--gray-700);line-height:1.7;font-size:14px}

/* You may also like */
.cat-also{background:#fff;padding:50px 20px}
.cat-also h2{font-size:18px;font-weight:800;margin:0 0 20px;text-transform:uppercase;letter-spacing:.5px}

@media (max-width:1100px){
  .prod-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .cat-layout{grid-template-columns:1fr}
  .cat-sidebar{position:static}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:520px){
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .prod-name{min-height:auto;font-size:12px}
  .cat-hero h1{font-size:24px}
  .cat-hero .cat-subtitle{font-size:15px}
}

/* ============ Product Detail Page ============ */
.pdp-bread{background:var(--gray-100);padding:14px 20px;font-size:13px;border-bottom:1px solid var(--gray-200)}
.pdp-bread .container{display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.pdp-bread a{color:var(--gray-700)}
.pdp-bread a:hover{color:var(--accent)}
.pdp-bread span{color:var(--gray-900);font-weight:600}
.pdp-bread i{font-size:10px;color:var(--gray-500)}

.pdp{padding:30px 20px 50px;background:#fff}
.pdp-top{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;margin-bottom:50px}

/* Gallery */
.pdp-gallery{display:grid;grid-template-columns:80px 1fr;gap:14px}
.pdp-thumbs{display:flex;flex-direction:column;gap:8px;max-height:560px;overflow-y:auto}
.pdp-thumb{width:80px;height:80px;background:#fff;border:2px solid var(--gray-200);border-radius:6px;overflow:hidden;cursor:pointer;padding:4px;transition:.2s}
.pdp-thumb:hover{border-color:var(--gray-500)}
.pdp-thumb.active{border-color:var(--accent)}
.pdp-thumb img{width:100%;height:100%;object-fit:contain}
.pdp-main-img{position:relative;background:var(--gray-100);border-radius:8px;aspect-ratio:1/1;overflow:hidden}
.pdp-main-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:30px;opacity:0;transition:.25s}
.pdp-main-img img.active{opacity:1}
.pdp-badge{position:absolute;top:18px;left:18px;background:var(--accent);color:#fff;padding:8px 14px;border-radius:4px;font-weight:700;font-size:13px;letter-spacing:.5px;z-index:5}

/* Info */
.pdp-info{padding:0}
.pdp-title{font-size:26px;font-weight:800;margin:0 0 12px;line-height:1.25;color:var(--gray-900)}
.pdp-rating{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#fbbf24;font-size:14px}
.pdp-rating span{color:var(--gray-700);font-size:13px;font-weight:500}
.pdp-sku{font-size:13px;color:var(--gray-700);margin-bottom:14px}
.pdp-sku strong{color:var(--gray-900)}
.pdp-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--gray-200)}
.pdp-now{font-size:30px;font-weight:800;color:var(--accent)}
.pdp-old{font-size:18px;color:var(--gray-500);text-decoration:line-through}
.pdp-save{font-size:12px;background:var(--accent);color:#fff;padding:4px 10px;border-radius:3px;font-weight:700;letter-spacing:.4px}
.pdp-short{color:var(--gray-700);line-height:1.7;font-size:14px;margin-bottom:20px}

.pdp-form{margin-bottom:24px}
.pdp-qty{margin-bottom:16px}
.pdp-qty label{display:block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-700);margin-bottom:8px}
.qty-input{display:inline-flex;align-items:center;border:1px solid var(--gray-300);border-radius:4px;overflow:hidden}
.qty-btn{width:38px;height:38px;background:#fff;border:0;font-size:18px;cursor:pointer;color:var(--gray-700);transition:.2s}
.qty-btn:hover{background:var(--gray-100)}
.qty-input input{width:60px;height:38px;border:0;border-left:1px solid var(--gray-300);border-right:1px solid var(--gray-300);text-align:center;font:inherit;font-size:15px;font-weight:600;background:#fff;-moz-appearance:textfield}
.qty-input input::-webkit-outer-spin-button,.qty-input input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.pdp-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:18px}
.pdp-cart{background:#fff;color:var(--gray-900);border:2px solid var(--gray-900);text-align:center}
.pdp-cart:hover{background:var(--gray-900);color:#fff}
.pdp-buy{background:var(--accent);color:#fff;text-align:center;font-size:15px;padding:14px}
.pdp-buy:hover{background:var(--accent-dark);color:#fff}

.pdp-trust{background:var(--gray-100);border-radius:8px;padding:16px;margin-bottom:18px}
.trust-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px}
.trust-row:last-child{margin-bottom:0}
.trust-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-700);font-weight:500}
.trust-item i{color:var(--brand);font-size:16px;width:20px;text-align:center}

.pdp-share{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gray-700)}
.pdp-share span{font-weight:600}
.pdp-share a{width:32px;height:32px;background:var(--gray-100);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gray-700);font-size:13px;transition:.2s}
.pdp-share a:hover{background:var(--accent);color:#fff}

/* Tabs */
.pdp-content{display:grid;grid-template-columns:240px 1fr;gap:30px;padding-top:30px;border-top:1px solid var(--gray-200)}
.pdp-tabs{position:sticky;top:90px;display:flex;flex-direction:column;align-self:start;background:#fff;border:1px solid var(--gray-200);border-radius:6px;overflow:hidden}
.pdp-tab{padding:16px 20px;color:var(--gray-900);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:1.2px;border-left:4px solid transparent;transition:.2s;cursor:pointer;border-bottom:1px solid var(--gray-200);background:#fff}
.pdp-tab:last-child{border-bottom:0}
.pdp-tab:hover{color:var(--brand);background:var(--gray-100)}
.pdp-tab.active{color:var(--brand);border-left-color:var(--brand);background:var(--gray-100);font-weight:700}
.pdp-tab-count{font-weight:400;color:var(--gray-500);text-transform:none;letter-spacing:0;margin-left:4px}
.pdp-tab-content{min-width:0}
.pdp-tab-content section{margin-bottom:50px;scroll-margin-top:100px}
.pdp-tab-content h2{font-size:22px;font-weight:800;margin:0 0 16px;color:var(--gray-900)}
.pdp-tab-content p,.pdp-tab-content ul,.pdp-tab-content ol{color:var(--gray-700);line-height:1.8;font-size:15px}
.pdp-tab-content table{width:100%;border-collapse:collapse;margin:14px 0}
.pdp-tab-content table td,.pdp-tab-content table th{padding:10px 14px;border-bottom:1px solid var(--gray-200);text-align:left;font-size:14px}
.pdp-tab-content table th{background:var(--gray-100);font-weight:700}
.pdp-tab-content img{border-radius:6px;margin:14px 0;max-width:100%;height:auto}

.pdp-related{background:var(--gray-100);padding:50px 20px}
.pdp-related h2{font-size:18px;font-weight:800;margin:0 0 20px;text-transform:uppercase;letter-spacing:.5px}
.pdp-related .prod-grid{grid-template-columns:repeat(5,1fr)}

@media (max-width:1100px){
  .pdp-related .prod-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:900px){
  .pdp-top{grid-template-columns:1fr;gap:24px}
  .pdp-content{grid-template-columns:1fr}
  .pdp-tabs{position:static;flex-direction:row;overflow-x:auto;border-radius:0;border-left:0;border-right:0;border-top:0;border-bottom:2px solid var(--gray-200);margin-bottom:20px}
  .pdp-tab{border-left:0;border-bottom:3px solid transparent;flex-shrink:0;white-space:nowrap}
  .pdp-tab.active{border-left-color:transparent;border-bottom-color:var(--brand);background:transparent}
  .pdp-related .prod-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:640px){
  .pdp-gallery{grid-template-columns:70px 1fr;gap:8px}
  .pdp-thumb{width:70px;height:70px}
  .pdp-title{font-size:20px}
  .pdp-now{font-size:24px}
  .trust-row{grid-template-columns:1fr}
  .pdp-related .prod-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============ Cart icon, cart, checkout ============ */
.header-actions{display:flex;align-items:center;gap:14px;margin-left:14px}
.cart-icon{position:relative;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;transition:.2s}
.cart-icon:hover{background:var(--accent);color:#fff}
.cart-count{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid var(--brand)}

.cart-layout{display:grid;grid-template-columns:1.7fr 1fr;gap:30px;align-items:flex-start}
.cart-table{background:#fff;border:1px solid var(--gray-200);border-radius:8px;overflow:hidden}
.cart-table table{width:100%;border-collapse:collapse}
.cart-table th{background:var(--gray-100);padding:12px 14px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-700);text-align:left;font-weight:700}
.cart-table td{padding:14px;border-top:1px solid var(--gray-200);font-size:14px;vertical-align:middle}
.cart-actions{padding:16px;background:var(--gray-100);display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;align-items:center}
.btn-icon{background:transparent;border:1px solid var(--gray-300);width:34px;height:34px;border-radius:50%;cursor:pointer;color:var(--gray-700);transition:.2s}
.btn-icon:hover{border-color:var(--accent);color:var(--accent)}

.cart-summary,.checkout-summary{background:var(--gray-100);border-radius:8px;padding:22px;position:sticky;top:90px}
.cart-summary h3,.checkout-summary h3{margin:0 0 16px;font-size:15px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-900)}
.sum-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;color:var(--gray-700)}
.sum-row strong{color:var(--gray-900)}
.sum-row.total{border-top:1px solid var(--gray-300);margin-top:8px;padding-top:14px;font-size:18px;color:var(--gray-900);font-weight:700}
.sum-row.total strong{font-size:22px;color:var(--accent)}
.cart-trust{margin-top:16px;font-size:13px;color:var(--gray-700);display:grid;gap:6px}
.cart-trust i{color:var(--brand);width:18px;text-align:center;margin-right:4px}

.success-box{text-align:center;padding:40px 20px;background:var(--gray-100);border-radius:10px;margin-bottom:24px}
.success-ic{width:72px;height:72px;background:#0a7d3b;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:34px;margin:0 auto 16px}
.success-box h1{margin:0 0 8px;font-size:26px}
.success-box .order-num{margin-top:12px;font-size:14px;background:#fff;border:1px dashed var(--gray-300);border-radius:4px;padding:10px;display:inline-block}

.checkout-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:24px;align-items:flex-start}
.checkout-main .card{margin-bottom:18px}
.checkout-main .card h3{margin:0 0 14px;font-size:15px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-900);padding-bottom:10px;border-bottom:1px solid var(--gray-200)}
.pay-option{display:flex;gap:12px;padding:14px;border:2px solid var(--gray-200);border-radius:6px;cursor:pointer;margin-bottom:10px;transition:.2s}
.pay-option:has(input:checked){border-color:var(--accent);background:#fff5f5}
.pay-option input{margin-top:4px}
.pay-option strong{display:block;font-size:15px}
.pay-option p{margin:4px 0 0;font-size:13px;color:var(--gray-700)}

.checkout-items{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--gray-300)}
.ci{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.ci-pic{position:relative;width:54px;height:54px;background:#fff;border-radius:6px;border:1px solid var(--gray-300);overflow:hidden;flex-shrink:0}
.ci-pic img{width:100%;height:100%;object-fit:contain;padding:4px}
.ci-qty{position:absolute;top:-6px;right:-6px;background:var(--gray-900);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:13px;font-weight:600;color:var(--gray-900);line-height:1.3}
.ci-sku{font-size:11px;color:var(--gray-500);margin-top:2px}
.ci-price{font-size:14px;font-weight:700;color:var(--gray-900)}

@media (max-width:900px){
  .cart-layout,.checkout-grid{grid-template-columns:1fr}
  .cart-summary,.checkout-summary{position:static}
  .cart-table th:nth-child(3),.cart-table td:nth-child(3){display:none}
}

/* ============ Hero slider (homepage) ============ */
.offer-hero-wrap{position:relative;overflow:hidden}
.hero-slides{position:relative;width:100%;padding-top:42%}/* 42% ≈ typical banner ratio; adjusts to image */
.hero-slide{position:absolute;inset:0;background-size:contain;background-position:center;background-repeat:no-repeat;background-color:#0a1929;display:flex;align-items:center;color:#fff;opacity:0;transition:opacity .8s ease}
.hero-slide.active{opacity:1;z-index:2}
.hero-slide::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,25,41,.55),rgba(10,25,41,.05))}
.hero-slide .container{position:relative;z-index:2}
.hero-slide .pill{display:inline-block;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);padding:6px 14px;border-radius:999px;font-size:12px;letter-spacing:1px;text-transform:uppercase}
.hero-slide h1{font-size:54px;margin:14px 0 12px;font-weight:800;line-height:1;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.hero-slide p{font-size:17px;opacity:.95;margin:0 0 20px;max-width:520px}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;background:rgba(255,255,255,.18);color:#fff;border:0;border-radius:50%;font-size:24px;cursor:pointer;z-index:5;display:flex;align-items:center;justify-content:center}
.hero-arrow:hover{background:rgba(255,255,255,.3)}
.hero-arrow.prev{left:20px}
.hero-arrow.next{right:20px}
.hero-dots{position:absolute;bottom:18px;left:0;right:0;text-align:center;z-index:5}
.hero-dots span{display:inline-block;width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.45);margin:0 5px;cursor:pointer;transition:.2s}
.hero-dots span.active{background:#fff;width:24px;border-radius:6px}
@media (max-width:720px){
  .hero-slides{padding-top:56%}
  .hero-slide h1{font-size:32px}
  .hero-slide p{font-size:14px}
  .hero-arrow{width:36px;height:36px;font-size:18px}
}

/* ============ Topbar widgets (lang/cur, search, account, cart) ============ */
.topbar .container{align-items:center}
.topbar-right{display:flex;align-items:center;gap:14px}
.topbar .socials-top a{margin-left:8px;color:#cfd5dd;font-size:13px}
.topbar .socials-top a:hover{color:#fff}

.lang-cur{position:relative}
.lang-cur-btn{background:rgba(255,255,255,.1);border:0;color:#fff;font:inherit;font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.lang-cur-btn:hover{background:rgba(255,255,255,.18)}
.lc-pill{display:inline-flex;align-items:center;gap:5px}
.lc-sep{opacity:.5}
.lang-cur-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:240px;background:#fff;color:var(--gray-900);border-radius:8px;box-shadow:0 12px 32px rgba(0,0,0,.18);padding:8px 0;visibility:hidden;opacity:0;transform:translateY(-4px);transition:.18s;z-index:80}
.lang-cur.open .lang-cur-menu{visibility:visible;opacity:1;transform:translateY(0)}
.lc-section{padding:8px 0;border-bottom:1px solid var(--gray-200)}
.lc-section:last-child{border-bottom:0}
.lc-title{padding:4px 16px 8px;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--gray-500);font-weight:700}
.lc-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 16px;background:none;border:0;font:inherit;font-size:13px;color:var(--gray-900);cursor:pointer;text-align:left}
.lc-item:hover{background:var(--gray-100)}
.lc-item.active{color:var(--accent);font-weight:700}
.lc-item.active i{color:var(--accent)}

.header-actions{display:flex;align-items:center;gap:10px;margin-left:14px}
.hdr-icon{position:relative;width:38px;height:38px;border-radius:50%;background:transparent;border:0;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:.2s;text-decoration:none}
.hdr-icon:hover{background:rgba(255,255,255,.1);color:#fff}
.cart-icon .cart-dot{position:absolute;top:6px;right:6px;width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px var(--brand)}
.cart-count{position:absolute;top:-2px;right:-2px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid var(--brand)}

/* Search overlay */
.search-overlay{position:fixed;inset:0;background:rgba(10,25,41,.85);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:80px 20px;visibility:hidden;opacity:0;transition:.2s}
.search-overlay.open{visibility:visible;opacity:1}
.search-overlay-inner{width:100%;max-width:720px}
.search-box{display:flex;align-items:center;background:#fff;border-radius:8px;padding:0 18px;box-shadow:0 14px 40px rgba(0,0,0,.2)}
.search-box i.fa-magnifying-glass{color:var(--gray-500);font-size:18px}
.search-box input{flex:1;border:0;padding:18px 14px;font:inherit;font-size:18px;outline:none;background:transparent}
.search-close{background:none;border:0;font-size:20px;color:var(--gray-500);cursor:pointer;padding:6px}
.search-close:hover{color:var(--accent)}
.search-results{margin-top:14px;background:#fff;border-radius:8px;max-height:60vh;overflow-y:auto;box-shadow:0 14px 40px rgba(0,0,0,.2)}
.search-results:empty{display:none}
.sr-section{padding:8px 0}
.sr-section + .sr-section{border-top:1px solid var(--gray-200)}
.sr-title{padding:8px 18px;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--gray-500);font-weight:700}
.sr-item{display:flex;align-items:center;gap:12px;padding:10px 18px;color:var(--gray-900);text-decoration:none;border-radius:0}
.sr-item:hover{background:var(--gray-100);color:var(--gray-900)}
.sr-pic{width:48px;height:48px;background:var(--gray-100);border-radius:6px;flex-shrink:0;overflow:hidden;border:1px solid var(--gray-200)}
.sr-pic img{width:100%;height:100%;object-fit:contain;padding:4px}
.sr-info{flex:1;min-width:0}
.sr-name{font-size:14px;font-weight:600;line-height:1.3;color:var(--gray-900)}
.sr-sku{font-size:11px;color:var(--gray-500);margin-top:2px}
.sr-prc{text-align:right}
.sr-prc .now{font-weight:700;color:var(--accent);font-size:14px}
.sr-prc .old{font-size:12px;color:var(--gray-500);text-decoration:line-through}
.sr-cat{display:inline-block;padding:6px 12px;background:var(--gray-100);border-radius:999px;font-size:13px;color:var(--gray-900);margin:0 6px 6px 0}
.sr-cat:hover{background:var(--accent);color:#fff}
.sr-empty{padding:30px 18px;text-align:center;color:var(--gray-500);font-size:14px}

/* Cart added toast */
.toast{position:fixed;top:90px;right:20px;background:var(--gray-900);color:#fff;padding:14px 18px;border-radius:8px;box-shadow:0 12px 30px rgba(0,0,0,.2);z-index:300;font-size:14px;display:flex;align-items:center;gap:10px;transform:translateX(120%);transition:.3s}
.toast.show{transform:translateX(0)}
.toast i.fa-circle-check{color:#22c55e;font-size:20px}
.toast a{color:#fff;text-decoration:underline;font-weight:600;margin-left:8px}

@media (max-width:720px){
  .topbar .info{display:none}
  .topbar-right{margin-left:auto}
  .lang-cur-btn{padding:5px 10px;font-size:11px}
  .search-overlay{padding:40px 14px}
  .search-box input{font-size:16px;padding:14px 10px}
}

/* ============ Simple nav dropdowns (non-mega) ============ */
.has-dd{position:relative}
.has-dd .dd-trigger{display:inline-flex;align-items:center}
.dd-menu{position:absolute;left:0;top:100%;min-width:220px;background:#fff;color:var(--gray-900);border-radius:6px;box-shadow:0 12px 32px rgba(0,0,0,.18);padding:8px 0;visibility:hidden;opacity:0;transform:translateY(-6px);transition:.18s;z-index:55;text-transform:none;letter-spacing:0}
.has-dd:hover .dd-menu,.has-dd.open .dd-menu,.dd-menu:hover{visibility:visible;opacity:1;transform:translateY(0)}
.has-dd:hover > .dd-trigger,.has-dd.open > .dd-trigger{background:rgba(255,255,255,.1)}
.dd-menu a{display:block;padding:9px 18px;color:var(--gray-900);font-weight:500;font-size:14px;text-transform:none;letter-spacing:0}
.dd-menu a:hover{background:var(--gray-100);color:var(--accent)}

@media (max-width:720px){
  .has-dd{display:block}
  .dd-menu{position:static;visibility:visible;opacity:1;transform:none;box-shadow:none;background:transparent;display:none;padding:0 0 0 14px;border-radius:0}
  .has-dd.open .dd-menu{display:block}
  .dd-menu a{color:#fff;border-bottom:1px solid var(--gray-200);padding:10px 14px}
}

/* ============ Attribute filter blocks ============ */
.attr-block h4{display:flex;justify-content:space-between;align-items:center}
.attr-block .attr-toggle{transition:.2s;color:var(--gray-500)}
.attr-block.collapsed .attr-toggle{transform:rotate(-90deg)}
.attr-block.collapsed .attr-list{display:none}
.attr-list{max-height:240px;overflow-y:auto;padding-right:4px}
.attr-list label{align-items:center;line-height:1.3;padding:2px 0}
.attr-label{flex:1;color:var(--gray-900)}
.attr-count{color:var(--gray-500);font-size:12px;margin-left:auto}
.attr-list input[type="checkbox"]{accent-color:var(--accent);margin-right:2px}
.attr-list label:hover .attr-label{color:var(--accent)}
.attr-list::-webkit-scrollbar{width:6px}
.attr-list::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}

/* ============ Site Footer (rich) ============ */
.site-footer{background:#0f1419;color:#cfd5dd;padding:50px 0 0}
.site-footer .footer-grid{display:grid;grid-template-columns:1fr 1fr 1.4fr 1.2fr;gap:36px;margin-bottom:30px}
.footer-col h4{color:#fff;font-size:14px;margin:0 0 16px;font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col ul li{margin-bottom:10px;font-size:14px}
.footer-col ul li a{color:#cfd5dd}
.footer-col ul li a:hover{color:#fff}

.footer-newsletter h4{font-size:13px;line-height:1.4}
.nl-form{display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:6px;max-width:380px}
.nl-form input{flex:1;background:transparent;border:0;color:#fff;padding:10px 0;font:inherit;font-size:14px;outline:none}
.nl-form input::placeholder{color:rgba(255,255,255,.55)}
.nl-form button{background:transparent;border:0;color:#fff;font-size:18px;cursor:pointer;padding:6px}
.nl-form button:hover{color:var(--accent)}
.nl-msg{font-size:13px;padding:8px 12px;border-radius:4px;margin-bottom:10px}
.nl-msg.ok{background:rgba(34,197,94,.18);color:#86efac}
.nl-msg.err{background:rgba(239,68,68,.18);color:#fca5a5}

.footer-socials{display:flex;gap:14px;margin-bottom:14px}
.footer-socials a{width:36px;height:36px;background:rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;transition:.2s}
.footer-socials a:hover{background:var(--accent);color:#fff}
.footer-expert{font-size:13px;line-height:1.6;color:#9aa3af;margin:10px 0 0}
.footer-expert a{color:#fff;font-weight:600}
.footer-expert a:hover{color:var(--accent)}

.footer-payments{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;border-top:1px solid #1c232c;padding:18px 0;margin-top:10px}
.footer-payments .pay{display:inline-flex;align-items:center;justify-content:center;width:42px;height:28px;background:#fff;border-radius:4px;color:#0f1419;font-size:18px}

.copyright{border-top:1px solid #1c232c;padding:18px 0;text-align:center;font-size:13px;color:#9aa3af}

@media (max-width:992px){
  .site-footer .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:560px){
  .site-footer .footer-grid{grid-template-columns:1fr}
  .footer-payments .pay{width:38px;height:24px;font-size:16px}
}

/* ============ Wholesale page (redesigned) ============ */
.ws-hero{position:relative;padding:90px 20px 110px;text-align:center;color:#fff;overflow:hidden;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%)}
.ws-hero-bg{position:absolute;inset:0;background:
  radial-gradient(circle at 20% 20%,rgba(255,255,255,.08),transparent 50%),
  radial-gradient(circle at 80% 80%,rgba(230,57,70,.18),transparent 50%);
  opacity:.9;pointer-events:none}
.ws-hero-shape{position:absolute;left:0;right:0;bottom:-1px;height:60px;background:#f6f7f9;clip-path:polygon(0 100%,100% 100%,100% 30%,0 100%)}
.ws-hero .container{position:relative;z-index:2;max-width:880px}
.ws-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);padding:8px 18px;border-radius:99px;font-size:13px;font-weight:600;letter-spacing:.4px;margin-bottom:20px;border:1px solid rgba(255,255,255,.18)}
.ws-pill i{color:var(--accent)}
.ws-hero h1{font-size:54px;font-weight:800;margin:0 0 18px;letter-spacing:-1px;line-height:1.05;text-shadow:0 4px 24px rgba(0,0,0,.15)}
.ws-hero p{font-size:17px;line-height:1.7;opacity:.92;max-width:720px;margin:0 auto}

.ws-benefits{background:#f6f7f9;padding:60px 20px;position:relative;z-index:2}
.ws-benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:-40px}
.ws-benefit{background:#fff;padding:28px 22px;border-radius:14px;box-shadow:0 6px 24px rgba(15,20,40,.06);border:1px solid #eceff3;transition:.25s;text-align:center}
.ws-benefit:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(15,20,40,.1);border-color:transparent}
.ws-benefit-ic{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 16px}
.ws-benefit:nth-child(2) .ws-benefit-ic{background:linear-gradient(135deg,#0ea5e9,#0369a1)}
.ws-benefit:nth-child(3) .ws-benefit-ic{background:linear-gradient(135deg,#10b981,#047857)}
.ws-benefit:nth-child(4) .ws-benefit-ic{background:linear-gradient(135deg,var(--accent),var(--accent-dark))}
.ws-benefit h4{margin:0 0 8px;font-size:16px;font-weight:700;color:var(--gray-900)}
.ws-benefit p{margin:0;color:var(--gray-700);font-size:13px;line-height:1.6}

.ws-main{background:#f6f7f9;padding:30px 20px 80px}
.ws-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:50px;align-items:flex-start}

.ws-info{padding:14px 4px}
.ws-info-tag{display:inline-block;background:rgba(230,57,70,.1);color:var(--accent);padding:6px 14px;border-radius:99px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
.ws-info h2{font-size:36px;font-weight:800;margin:0 0 16px;line-height:1.15;letter-spacing:-.5px;color:var(--gray-900)}
.ws-info-lead{color:var(--gray-700);font-size:15px;line-height:1.7;margin:0 0 28px}

.ws-contact-list{display:grid;gap:14px;margin-bottom:32px}
.ws-contact{display:flex;gap:14px;align-items:center;padding:16px;background:#fff;border:1px solid #eceff3;border-radius:12px;color:var(--gray-900);text-decoration:none;transition:.2s}
.ws-contact:hover{border-color:var(--accent);transform:translateX(4px);color:var(--gray-900);box-shadow:0 6px 20px rgba(0,0,0,.06)}
.ws-contact-ic{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ws-contact-label{display:block;font-size:11px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-bottom:2px}
.ws-contact strong{display:block;font-size:14px;color:var(--gray-900);font-weight:600}

.ws-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:#fff;border:1px solid #eceff3;border-radius:14px;padding:22px;text-align:center}
.ws-stats > div{padding:0 6px}
.ws-stats > div + div{border-left:1px solid #eceff3}
.ws-stats strong{display:block;font-size:24px;font-weight:800;color:var(--accent);margin-bottom:4px}
.ws-stats span{font-size:12px;color:var(--gray-700);font-weight:500}

/* Form card */
.ws-form-card{background:#fff;border-radius:18px;padding:40px;box-shadow:0 10px 40px rgba(15,20,40,.08);border:1px solid #eceff3;position:relative}
.ws-form-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;border-radius:18px 18px 0 0;background:linear-gradient(90deg,var(--brand),var(--accent),var(--brand))}
.ws-form-head{margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid #f0f2f5}
.ws-form-head h2{font-size:26px;font-weight:800;margin:0 0 6px;color:var(--gray-900)}
.ws-form-head p{margin:0;color:var(--gray-500);font-size:13px}

.wholesale-form{}
.wholesale-form .wf-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.wf-field{position:relative;margin-bottom:14px}
.wf-field input,.wf-field select,.wf-field textarea{
  width:100%;padding:18px 16px 8px;border:1px solid #d8dde3;border-radius:10px;
  font:inherit;font-size:14px;color:var(--gray-900);background:#fff;
  transition:.2s;
}
.wf-field select{padding:14px 40px 14px 16px;cursor:pointer;appearance:none;-webkit-appearance:none}
.wf-field textarea{padding:22px 16px 12px;resize:vertical;min-height:130px}
.wf-field label{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--gray-500);pointer-events:none;transition:.18s ease;background:transparent;padding:0 4px}
.wf-field textarea + label{top:22px;transform:none}
.wf-field input:focus,.wf-field select:focus,.wf-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(230,57,70,.1)}
.wf-field input:focus + label,
.wf-field input:not(:placeholder-shown) + label,
.wf-field textarea:focus + label,
.wf-field textarea:not(:placeholder-shown) + label{
  top:6px;transform:none;font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.4px;background:#fff
}
.wf-field textarea:focus + label,
.wf-field textarea:not(:placeholder-shown) + label{top:6px}
.wf-icon{position:absolute;right:18px;top:50%;transform:translateY(-50%);color:var(--gray-500);font-size:12px;pointer-events:none}

.wf-submit{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border:0;padding:16px 28px;border-radius:10px;font:inherit;font-size:15px;font-weight:700;cursor:pointer;transition:.25s;display:inline-flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 8px 24px rgba(230,57,70,.3);letter-spacing:.3px}
.wf-submit:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(230,57,70,.4)}
.wf-submit i{transition:.25s}
.wf-submit:hover i{transform:translateX(4px)}

.wf-disclaimer{margin:14px 0 0;text-align:center;font-size:12px;color:var(--gray-500);display:flex;align-items:center;justify-content:center;gap:6px}
.wf-disclaimer i{color:#10b981}

.ws-success{text-align:center;padding:30px 20px}
.ws-success-ic{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#10b981,#047857);color:#fff;display:flex;align-items:center;justify-content:center;font-size:38px;margin:0 auto 18px;box-shadow:0 10px 30px rgba(16,185,129,.3)}
.ws-success h3{margin:0 0 8px;font-size:22px;color:var(--gray-900)}
.ws-success p{color:var(--gray-700);margin:0 0 20px;line-height:1.6}

.ws-trust{background:var(--gray-900);color:#fff;padding:32px 20px}
.ws-trust-row{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:18px}
.ws-trust-item{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:#cfd5dd}
.ws-trust-item i{color:var(--accent);font-size:18px}

@media (max-width:1100px){
  .ws-benefits-grid{grid-template-columns:repeat(2,1fr)}
  .ws-grid{grid-template-columns:1fr;gap:30px}
  .ws-info h2{font-size:30px}
}
@media (max-width:640px){
  .ws-hero{padding:60px 20px 80px}
  .ws-hero h1{font-size:34px}
  .ws-hero p{font-size:14px}
  .ws-benefits-grid{grid-template-columns:1fr;margin-top:-20px}
  .ws-form-card{padding:26px 20px;border-radius:14px}
  .wholesale-form .wf-2col{grid-template-columns:1fr;gap:0}
  .ws-info h2{font-size:24px}
  .ws-stats strong{font-size:20px}
  .ws-trust-row{justify-content:flex-start}
}

/* ============ Ask a Question + WhatsApp pill ============ */
.ask-whatsapp{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background:var(--accent);color:#fff;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-size:13px;margin:18px 0 14px;transition:.2s;text-decoration:none}
.ask-whatsapp:hover{background:var(--accent-dark);color:#fff;transform:translateY(-1px);box-shadow:0 6px 18px rgba(230,57,70,.3)}
.ask-whatsapp i{font-size:18px}

.ask-box{border:1px solid var(--gray-200);border-radius:8px;background:#fff;overflow:hidden;margin-bottom:16px}
.ask-box summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:24px 1fr 24px;align-items:center;padding:14px 18px;text-align:center;font-size:12px;font-weight:600;letter-spacing:2px;color:var(--gray-900);text-transform:uppercase}
.ask-box summary::-webkit-details-marker{display:none}
.ask-box summary span{grid-column:2}
.ask-box summary .ask-arrow{grid-column:3;transition:.2s;color:var(--gray-700);font-size:13px;justify-self:end}
.ask-box[open] summary .ask-arrow{transform:rotate(180deg)}
.ask-box[open] summary{border-bottom:1px solid var(--gray-200)}

.ask-body{padding:20px 22px 22px}
.ask-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.ask-field{display:flex;flex-direction:column}
.ask-field label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--gray-900);margin-bottom:6px}
.ask-field input,.ask-field textarea{border:1px solid var(--gray-300);border-radius:0;padding:10px 12px;font:inherit;font-size:14px;background:#fff;color:var(--gray-900);transition:.15s}
.ask-field input:focus,.ask-field textarea:focus{outline:none;border-color:var(--accent)}
.ask-field textarea{min-height:160px;resize:vertical}

.ask-submit-wrap{text-align:center;margin-top:18px}
.ask-submit{background:var(--accent);color:#fff;border:0;padding:12px 32px;border-radius:999px;font:inherit;font-size:13px;font-weight:700;letter-spacing:3px;cursor:pointer;transition:.2s}
.ask-submit:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 6px 18px rgba(230,57,70,.3)}

.ask-disclaimer{margin:14px 0 0;text-align:center;font-size:12px;color:var(--gray-500);line-height:1.5}
.ask-error{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:6px;margin-bottom:14px;font-size:13px}
.ask-success{text-align:center;padding:18px}
.ask-success i{font-size:40px;color:#10b981;margin-bottom:10px;display:block}
.ask-success p{margin:0;color:var(--gray-700);font-size:14px}

@media (max-width:560px){
  .ask-grid{grid-template-columns:1fr;gap:12px}
}

/* ============ Reviews ============ */
.reviews-summary{background:var(--gray-100);border-radius:8px;padding:20px;margin-bottom:24px}
.reviews-avg{display:flex;align-items:center;gap:14px}
.reviews-avg .big{font-size:42px;font-weight:800;color:var(--gray-900);line-height:1}
.reviews-avg .reviews-stars{color:#fbbf24;font-size:18px}
.reviews-avg small{color:var(--gray-700);font-size:13px;margin-left:auto}

.reviews-list{margin-bottom:30px}
.review{border-bottom:1px solid var(--gray-200);padding:18px 0}
.review:last-child{border-bottom:0}
.review-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:6px}
.review-head strong{font-size:15px;color:var(--gray-900)}
.review-stars{color:#fbbf24;font-size:13px}
.review-stars i{margin-right:1px}
.review-date{margin-left:auto;color:var(--gray-500);font-size:12px}
.review-title{margin:6px 0;font-size:15px;font-weight:700;color:var(--gray-900)}
.review p{margin:0;color:var(--gray-700);line-height:1.7;font-size:14px}

.review-form-wrap{background:var(--gray-100);border-radius:8px;padding:24px;margin-top:20px}
.review-form-wrap h3{margin:0 0 16px;font-size:18px}
.review-form{}
.review-form .form-row{margin-bottom:14px}
.review-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.star-input{display:inline-flex;flex-direction:row-reverse;gap:4px}
.star-input input{display:none}
.star-input label{font-size:24px;color:var(--gray-300);cursor:pointer;transition:.15s}
.star-input label:hover,
.star-input label:hover ~ label,
.star-input input:checked ~ label{color:#fbbf24}

@media (max-width:560px){
  .review-form .row2{grid-template-columns:1fr;gap:0}
  .review-date{margin-left:0;width:100%;font-size:11px}
}

/* ============ Blog page ============ */
.blog-hero{background:#fff;padding:50px 0 0;border-bottom:1px solid var(--gray-200)}
.blog-hero-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;padding:0 20px;margin-bottom:14px}
.blog-hero-row h1{font-size:42px;font-weight:800;margin:0;letter-spacing:-.5px;color:var(--gray-900)}
.blog-hero .crumbs{font-size:14px;color:var(--gray-500)}
.blog-hero .crumbs a{color:var(--gray-700)}
.blog-hero .crumbs .sep{margin:0 8px;color:var(--gray-300)}
.blog-hero .crumbs span{color:var(--gray-900);font-weight:600}
.blog-hero-desc{padding:0 20px;color:var(--gray-700);font-size:15px;line-height:1.7;margin:0 0 14px;max-width:880px}

.blog-tabs{margin-top:20px;border-top:1px solid var(--gray-200)}
.blog-tabs .container{display:flex;gap:0;align-items:center;justify-content:center;flex-wrap:wrap;padding:0 20px}
.blog-tabs a{padding:18px 28px;color:var(--gray-700);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:1.4px;border-bottom:3px solid transparent;margin-bottom:-1px;transition:.2s;white-space:nowrap}
.blog-tabs a:hover{color:var(--gray-900)}
.blog-tabs a.active{color:var(--gray-900);border-bottom-color:var(--brand);font-weight:700}

.blog-page{padding:40px 0 60px;background:var(--gray-100)}
.blog-layout{display:grid;grid-template-columns:280px 1fr;gap:30px;align-items:flex-start}

.blog-sidebar{position:sticky;top:90px;display:grid;gap:18px}
.blog-side-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:22px}
.blog-side-card h3{margin:0 0 16px;font-size:16px;font-weight:800;color:var(--gray-900);padding-bottom:10px;border-bottom:2px solid var(--brand);display:inline-block;letter-spacing:.2px}
.blog-side-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--gray-200);color:var(--gray-900);text-decoration:none;transition:.15s}
.blog-side-item:last-child{border-bottom:0}
.blog-side-item:hover .bs-title{color:var(--accent)}
.blog-side-item .bs-pic{width:64px;height:64px;border-radius:6px;background:var(--gray-100);overflow:hidden;flex-shrink:0;border:1px solid var(--gray-200)}
.blog-side-item .bs-pic img{width:100%;height:100%;object-fit:cover}
.bs-info{flex:1;min-width:0}
.bs-title{font-size:13px;font-weight:600;line-height:1.4;color:var(--gray-900);margin-bottom:4px;transition:.15s}
.bs-date{font-size:11px;color:var(--gray-500);font-weight:500}

.blog-side-cats{list-style:none;padding:0;margin:0}
.blog-side-cats li{margin-bottom:4px}
.blog-side-cats a{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;color:var(--gray-900);border-radius:5px;font-size:14px;font-weight:500;transition:.15s}
.blog-side-cats a:hover{background:var(--gray-100);color:var(--accent)}
.blog-side-cats a.active{background:var(--brand);color:#fff;font-weight:700}
.blog-side-cats .cn{background:var(--gray-100);color:var(--gray-700);font-size:11px;padding:2px 8px;border-radius:99px;font-weight:600}
.blog-side-cats a.active .cn{background:rgba(255,255,255,.2);color:#fff}

.blog-main{}
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.blog-post{background:#fff;border:1px solid var(--gray-200);border-radius:8px;overflow:hidden;color:inherit;text-decoration:none;display:flex;flex-direction:column;transition:.2s}
.blog-post:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.08);border-color:var(--accent)}
.bp-pic{aspect-ratio:16/9;background:var(--gray-100);overflow:hidden}
.bp-pic img{width:100%;height:100%;object-fit:cover;transition:.4s}
.blog-post:hover .bp-pic img{transform:scale(1.05)}
.bp-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.bp-meta{font-size:12px;color:var(--gray-500);margin-bottom:8px;font-weight:500}
.bp-meta i{margin-right:4px}
.bp-title{font-size:18px;font-weight:700;color:var(--gray-900);line-height:1.35;margin:0 0 10px}
.blog-post:hover .bp-title{color:var(--accent)}
.bp-excerpt{font-size:14px;color:var(--gray-700);line-height:1.6;margin:0 0 14px;flex:1}
.bp-more{font-size:13px;font-weight:700;color:var(--brand);text-transform:uppercase;letter-spacing:.6px;display:inline-flex;align-items:center;gap:6px}
.bp-more i{transition:.2s}
.blog-post:hover .bp-more i{transform:translateX(4px)}

@media (max-width:992px){
  .blog-layout{grid-template-columns:1fr}
  .blog-sidebar{position:static;grid-template-columns:1fr 1fr;gap:18px}
  .blog-hero-row h1{font-size:32px}
}
@media (max-width:720px){
  .blog-sidebar{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .blog-tabs a{padding:14px 18px;font-size:12px;letter-spacing:1px}
  .blog-hero-row h1{font-size:26px}
}
