/* ============================================================
   ESW theme — ported verbatim from the storefront mockup
   (css/header-esw2.css + css/home-v2.css + v5 colour override)
   ============================================================ */
:root{
  --navy:#1344b1; --royal:#114ccf; --green:#0f9447; --red:#bc1212;
  --gold:#fdc700; --ink:#222a44; --muted:#6b7280; --line:#e3e6ef; --maxw:1320px;
}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.h2-top a,.h2-main a,.h2-nav a,.h2-acts a,.mm a,.v2-hero a{text-decoration:none}
.h2-top svg,.h2-main svg,.h2-nav svg,.h2-acts svg,.mm svg,.v2-hero svg,.tb-btn svg{display:block}
.h2-logo img,.v2-slide>img{display:block;max-width:100%}

/* ---------- flush the header to the top of the page (kill Magento chrome spacing) ---------- */
.page-wrapper{margin-top:0}
.page-header{margin:0 0 0;border-bottom:0;background:transparent}
.page-header .header.content,.header.content{padding:0;margin:0;max-width:none;width:auto}
.nav-sections{display:none}
.page-main{padding-top:0}

/* ---------- top bar (solid navy) ---------- */
.h2-top{background:var(--navy);color:#fff;font-size:14px;font-family:'Inter',system-ui,sans-serif}
.h2-top-in{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:11px 28px;flex-wrap:wrap}
.h2-top .l,.h2-top .c,.h2-top .r{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.h2-top a{color:#fff}.h2-top a:hover{text-decoration:underline}
.h2-top .w9{background:var(--green);color:#fff;font-weight:700;border-radius:999px;padding:6px 18px}
.h2-top .ph{display:inline-flex;align-items:center;gap:7px;font-weight:600}
.h2-top .c b{font-weight:800}
.h2-top .bar{width:180px;height:8px;background:rgba(255,255,255,.25);border-radius:5px;overflow:hidden}
.h2-top .fill{display:block;width:9%;height:100%;background:var(--gold)}
.h2-top .r{display:flex;align-items:center;gap:14px;font-weight:700}
.h2-top .sep,.tb-sep{opacity:.4;font-weight:400}

/* ---------- main row ---------- */
.h2-main{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:44px;padding:20px 28px;font-family:'Inter',system-ui,sans-serif}
.h2-logo{display:inline-block}
.h2-logo img{height:92px;width:auto}
.h2-search{display:flex;align-items:stretch;height:54px;border:2.5px solid var(--navy);border-radius:0;overflow:hidden;background:#fff;max-width:840px;margin:0}
.h2-search input{flex:1;min-width:0;border:0;outline:0;background:transparent;padding:0 22px;font:inherit;font-size:14px;color:var(--ink);box-shadow:none;height:auto}
.h2-search input::placeholder{font-size:14px;color:#9aa3b2}
.h2-search button{width:74px;border:0;background:var(--navy);color:#fff;display:grid;place-items:center;cursor:pointer;border-radius:0}
.h2-search button svg{width:24px;height:24px}
/* instant-search "All Categories" scope dropdown as a left segment of the pill */
.h2-search{overflow:visible;position:relative}
.h2-search .eo-is-scope{position:static;flex:0 0 auto;align-self:stretch;height:auto;width:auto;max-width:185px;border:0;border-right:1px solid var(--line);background:#f3f4f7 url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='11'%20height='7'%20viewBox='0%200%2011%207'%3E%3Cpath%20d='M1%201l4.5%204.5L10%201'%20stroke='%23444'%20stroke-width='1.6'%20fill='none'%20stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 12px center;background-size:11px 7px;color:var(--ink);border-radius:0;padding:0 32px 0 18px;font-size:14px;font-weight:600;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}
.h2-search input{padding-left:18px}
.h2-search .eo-is-box{left:0;right:0;border-radius:0}
.h2-acts{display:flex;align-items:flex-start;gap:30px}
.h2-acts a{display:inline-flex;flex-direction:column;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--navy)}
.h2-acts svg{width:28px;height:28px}
.h2-acts .cart{position:relative}
.h2-acts .cart .badge{position:absolute;top:-7px;right:6px;background:var(--red);color:#fff;border-radius:999px;min-width:20px;height:20px;display:grid;place-items:center;font-size:11px;font-weight:800;padding:0 5px}

/* ---------- nav bar (v5: white) ---------- */
/* Header → body separator: Option E from separator-options.html — 2px
   gradient ribbon walking through the full brand palette
   (navy → royal → gold → royal → navy) so the separator carries brand
   identity instead of just being a flat gold line. */
.h2-nav{
    background-color:#fff;
    background-image:linear-gradient(90deg,
        transparent 0%,
        rgba(20,41,107,.4) 12%,
        rgba(19,68,177,.7) 30%,
        var(--gold) 50%,
        rgba(19,68,177,.7) 70%,
        rgba(20,41,107,.4) 88%,
        transparent 100%
    );
    background-size:100% 2px;
    background-repeat:no-repeat;
    background-position:0 100%;
    border-bottom:0;
    font-family:'Inter',system-ui,sans-serif;
}
.h2-nav-in{display:flex;align-items:stretch;gap:0;flex-wrap:wrap}
/* All Categories button — keep background TRANSPARENT (not #fff) so the
   2px gradient ribbon under .h2-nav stays visible. A white fill here
   covers that strip and breaks the separator's left edge. */
.h2-allcat{display:inline-flex;align-items:center;gap:11px;background:transparent !important;background-color:transparent !important;color:var(--ink);border:0 !important;border-bottom:0 !important;box-shadow:none !important;font:inherit;font-weight:800;font-size:16px;padding:18px 26px 18px 0;cursor:pointer;transition:color .15s}
.h2-allcat:hover,.h2-allcat:focus,.h2-allcat:active{color:var(--green);background:transparent !important;background-color:transparent !important;outline:0;border:0 !important;border-bottom:0 !important;box-shadow:none !important}
.h2-allcat svg{width:20px;height:20px}
/* Nav links — explicitly null out background + border in default state so the
   gradient separator under .h2-nav (background-image at bottom) is never
   obscured by a Magento-blank-theme inherited link background or border. */
.h2-nav a{
    display:inline-flex;align-items:center;
    color:var(--ink);font-size:16px;font-weight:700;
    padding:18px 22px;
    background:transparent !important;
    background-color:transparent !important;
    border:0 !important;
    border-bottom:0 !important;
    box-shadow:none !important;
    text-decoration:none;
}
.h2-nav a:hover,
.h2-nav a:visited,
.h2-nav a:focus,
.h2-nav a:active{
    background:transparent !important;
    background-color:transparent !important;
    color:var(--green);
    text-decoration:none;
    border:0 !important;
    border-bottom:0 !important;
}

@media(max-width:980px){
  .h2-main{grid-template-columns:1fr;gap:18px}
  .h2-search{max-width:none}
  .h2-acts{justify-content:center}
  .h2-allcat,.h2-nav a{font-size:14px;padding:14px 16px}
}

/* ---------- language/currency pickers ---------- */
.tb-pick{position:relative}
.tb-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:0;color:#fff;font:inherit;font-size:13px;font-weight:600;cursor:pointer;padding:4px 4px}
.tb-btn .globe{width:15px;height:15px}
.tb-btn .car{width:12px;height:12px;opacity:.85}
.tb-cur{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700}
.tb-cur .cur{width:18px;height:18px;border-radius:50%;background:var(--gold);color:var(--navy);display:grid;place-items:center;font-weight:800;font-size:12px;line-height:1}
.tb-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;color:var(--ink);border-radius:8px;box-shadow:0 14px 30px rgba(10,16,40,.22);min-width:168px;padding:6px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .15s,transform .15s,visibility .15s;z-index:120}
.tb-pick:hover .tb-menu,.tb-pick:focus-within .tb-menu{opacity:1;visibility:visible;transform:translateY(0)}
.tb-menu a{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:6px;font-size:13px;color:var(--ink)}
.tb-menu a:hover{background:#eef3ff;color:var(--navy)}
.tb-menu a.active{font-weight:800;color:var(--navy)}
.tb-menu .flag{font-size:15px}

/* ============================================================
   Mega panel (Amazon-style drill-down)
   ============================================================ */
.mm-overlay{position:fixed;inset:0;background:rgba(10,16,40,.55);opacity:0;visibility:hidden;transition:opacity .25s ease;z-index:200}
.mm-overlay.open{opacity:1;visibility:visible}
.mm{position:fixed;top:0;left:0;height:100%;width:388px;max-width:88vw;background:#fff;transform:translateX(-100%);transition:transform .3s ease;z-index:201;display:flex;flex-direction:column;box-shadow:0 0 50px rgba(0,0,0,.35);font-family:'Inter',system-ui,sans-serif}
.mm.open{transform:translateX(0)}
.mm-head{background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;flex-shrink:0}
.mm-head .t{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px}
.mm-head .t svg{width:22px;height:22px}
.mm-head .back{display:none;align-items:center;gap:9px;background:none;border:0;color:#fff;font:inherit;font-weight:800;font-size:15px;letter-spacing:.4px;cursor:pointer;text-transform:uppercase}
.mm-head .back svg{width:20px;height:20px}
.mm.drilled .mm-head .t{display:none}
.mm.drilled .mm-head .back{display:inline-flex}
.mm-head .x{background:none;border:0;color:#fff;cursor:pointer;display:grid;place-items:center}
.mm-head .x svg{width:24px;height:24px}
.mm-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mm-view{display:none} .mm-view.active{display:block} .mm.drilled .l1{display:none}
.mm.drilled .l2.active{display:block}
.mm-sec h4{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:16px 22px 6px;margin:0}
.mm-divider{height:8px;background:#f1f3f9}
.mm-list a,.mm-list button{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;background:none;border:0;border-bottom:1px solid #f2f4f8;font:inherit;font-size:15px;color:var(--ink);padding:13px 22px;cursor:pointer}
.mm-list a:hover,.mm-list button:hover{background:#eef3ff;color:var(--navy)}
.mm-list .chev{width:17px;height:17px;color:#b7bdcc;flex-shrink:0}
.mm-sec.trend a{font-weight:600}
.mm-title{font-size:21px;font-weight:800;padding:18px 22px 6px;color:var(--ink);margin:0}

/* ============================================================
   Home hero slider
   ============================================================ */
.v2-hero{position:relative;width:100%;max-width:var(--maxw);margin:20px auto;overflow:hidden;background:var(--navy);font-family:'Inter',system-ui,sans-serif}
.v2-track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.v2-slide{flex:0 0 100%;position:relative;height:clamp(360px,40vw,560px)}
.v2-slide>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 25%}
.v2-veil{position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,12,28,.92) 0%,rgba(8,12,28,.64) 30%,rgba(8,12,28,.24) 56%,rgba(8,12,28,0) 80%),linear-gradient(90deg,rgba(8,12,28,.6) 0%,rgba(8,12,28,.2) 40%,rgba(8,12,28,0) 64%)}
.v2-copy{position:absolute;left:0;right:0;bottom:0;padding:0 48px 40px;color:#fff}
.v2-copy .inner{max-width:760px;display:flex;flex-direction:column;gap:10px}
.v2-copy h2{font-size:clamp(26px,3.6vw,44px);font-weight:800;line-height:1.08;color:#fff;margin:0}
.v2-copy p{font-size:clamp(15px,2vw,20px);color:#eef1fb;margin:0}
.v2-acts{margin-top:12px;display:flex;gap:12px;flex-wrap:wrap}
.v2-btn{display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;font:inherit;font-weight:700;border-radius:999px;padding:12px 26px;transition:background .15s,color .15s}
.v2-btn.gold{background:var(--gold);color:var(--navy)} .v2-btn.gold:hover{background:#ffd766}
.v2-btn.ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7)} .v2-btn.ghost:hover{background:#fff;color:var(--navy)}
.v2-burst{position:absolute;top:20px;right:28px;width:124px;height:124px;z-index:4;filter:drop-shadow(0 4px 10px rgba(0,0,0,.28))}
.v2-burst svg{position:absolute;inset:0;width:100%;height:100%}
.v2-burst .bt{position:absolute;inset:0;display:grid;place-items:center;text-align:center;font-size:12px;font-weight:800;color:var(--navy);line-height:1.18;padding:0 22px}
.v2-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:2px solid var(--gold);background:#14296b;color:#fff;display:grid;place-items:center;cursor:pointer;z-index:5;box-shadow:0 6px 16px rgba(8,12,28,.3);transition:background .15s,color .15s,border-color .15s,transform .15s}
.v2-arrow:hover{background:var(--gold);color:#14296b;border-color:var(--gold);transform:translateY(-50%) scale(1.06)}
.v2-arrow.prev{left:18px}.v2-arrow.next{right:18px}.v2-arrow svg{width:22px;height:22px}
.v2-dots{position:absolute;bottom:18px;right:40px;display:flex;gap:8px;z-index:5}
.v2-dots button{width:11px;height:11px;border-radius:50%;border:0;background:rgba(255,255,255,.55);cursor:pointer;padding:0;transition:width .2s,background .2s}
.v2-dots button.is-active{background:#fff;width:28px;border-radius:6px}

@media(max-width:680px){
  .v2-arrow{display:none}
  .v2-copy{padding:0 24px 26px}
  .v2-burst{width:90px;height:90px;top:12px;right:14px}
  .v2-burst .bt{font-size:10px;padding:0 12px}
  .v2-dots{right:20px}
}

/* ===== Hero Slide 2 · v5 (white BG · circular sticker · giant gold "%") ===== */
/* Ported from storefront-mockup/slider-options.html — variant "2 · B · v5". */
.v2-slide.w5{background:#fff;display:flex;align-items:center;padding:0 56px;overflow:hidden}
.v2-slide.w5 > img{display:none}                    /* no background photo in white variant */
.v2-slide.w5 .v2-veil{display:none}
.v2-slide.w5 .v2-copy{position:relative;left:auto;right:auto;bottom:auto;padding:0;color:var(--ink, #1f2a44);max-width:55%;z-index:2}
.v2-slide.w5 .v2-copy .inner{max-width:480px;gap:14px}
.v2-slide.w5::before{content:"%";position:absolute;left:-60px;bottom:-80px;font-size:300px;font-weight:900;line-height:1;color:rgba(253,199,0,.16);pointer-events:none;z-index:1}
.v2-slide.w5 .w5-eyebrow{display:block;color:#bc1212;font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:0}
.v2-slide.w5 h2{margin:0;font-size:clamp(28px,3.8vw,44px);font-weight:800;line-height:1.05;color:#14296b}
.v2-slide.w5 h2 .b{color:#114ccf}
.v2-slide.w5 .w5-code{display:inline-flex;align-items:center;background:#fdc700;color:#14296b;border:2px solid #14296b;border-radius:8px;padding:2px 14px;font-family:'JetBrains Mono','Menlo','Consolas',monospace;font-weight:700;font-size:.6em;letter-spacing:.5px;vertical-align:8px;margin-left:8px;line-height:1.4}
.v2-slide.w5 p{margin:0;color:#1f2a44;opacity:.85;font-size:16px;line-height:1.55;max-width:440px}
.v2-slide.w5 .v2-acts{margin-top:6px}
.v2-slide.w5 .v2-btn.ghost{color:#14296b;border-color:#14296b;background:transparent}
.v2-slide.w5 .v2-btn.ghost:hover{background:#14296b;color:#fff;border-color:#14296b}

/* Circular photo sticker, right-anchored, with gold ring + navy "25% OFF" corner badge */
.v2-slide.w5 .w5-sticker{position:absolute;right:calc(20% + 48px);top:50%;transform:translateY(-50%);width:38%;max-width:380px;aspect-ratio:1;border-radius:50%;overflow:hidden;border:8px solid #fdc700;box-shadow:0 14px 38px rgba(20,41,107,.22);z-index:3}
.v2-slide.w5 .w5-sticker img{width:100%;height:100%;object-fit:cover;display:block;position:static;inset:auto}
.v2-slide.w5 .w5-corner{position:absolute;top:-8px;right:-8px;width:90px;height:90px;border-radius:50%;background:#14296b;color:#fff;display:grid;place-items:center;text-align:center;line-height:1;border:6px solid #fff;z-index:4}
.v2-slide.w5 .w5-big{font-size:26px;font-weight:900;display:block}
.v2-slide.w5 .w5-lbl{font-size:9px;font-weight:800;letter-spacing:1px;margin-top:2px;color:#fdc700;text-transform:uppercase;display:block}

@media (max-width:780px){
  .v2-slide.w5{padding:0 22px;text-align:left}
  .v2-slide.w5 .v2-copy{max-width:100%}
  .v2-slide.w5 .w5-sticker{display:none}
  .v2-slide.w5::before{font-size:200px;left:-30px;bottom:-50px}
}

/* ===== Hero Slide 3 · v3 "w3pro" — gold sunburst + halo + chips + dashed route =====
   Ported from storefront-mockup/slider-options.html variant "3 · D · v3". */
.v2-slide.w3pro{background:#fff;display:grid;grid-template-columns:.85fr 1.15fr;padding:0;align-items:center;overflow:hidden}
.v2-slide.w3pro > img{display:none}
.v2-slide.w3pro .v2-veil{display:none}
.v2-slide.w3pro .left{padding:40px 32px 40px 56px;display:flex;flex-direction:column;justify-content:center;color:#222a44;position:relative;z-index:2}
.v2-slide.w3pro .left::before{content:"";position:absolute;left:0;top:25%;bottom:25%;width:4px;background:#fdc700;border-radius:2px}
.v2-slide.w3pro .left .e{display:block;color:#bc1212;font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}
.v2-slide.w3pro .left h2{margin:0 0 10px;font-size:clamp(26px,3.4vw,40px);font-weight:800;line-height:1.05;color:#14296b}
.v2-slide.w3pro .left h2 .b{color:#1344b1}
.v2-slide.w3pro .left p{margin:0 0 20px;color:#222a44;opacity:.85;font-size:15.5px;line-height:1.55;max-width:420px}
.v2-slide.w3pro .left .v2-acts{margin-bottom:14px}
.v2-slide.w3pro .left .v2-btn.ghost{color:#14296b;border-color:#14296b;background:transparent}
.v2-slide.w3pro .left .v2-btn.ghost:hover{background:#14296b;color:#fff;border-color:#14296b}
.v2-slide.w3pro .left .micro{display:flex;align-items:center;gap:18px;font-size:12px;font-weight:700;color:#14296b;text-transform:uppercase;letter-spacing:1px}
.v2-slide.w3pro .left .micro span{display:inline-flex;align-items:center;gap:6px}
.v2-slide.w3pro .left .micro svg{width:14px;height:14px;color:#0f9447;flex:0 0 14px}

.v2-slide.w3pro .stage{position:relative;height:100%;display:grid;place-items:center;background:radial-gradient(circle at 60% 50%,#fff8d8 0%,#fef3b8 20%,#f3f6fc 60%,#eaf0ff 100%);overflow:hidden}
.v2-slide.w3pro .stage::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(20,41,107,.06) 1.5px,transparent 1.5px);background-size:18px 18px;mask-image:radial-gradient(circle at 60% 50%,transparent 30%,#000 60%);-webkit-mask-image:radial-gradient(circle at 60% 50%,transparent 30%,#000 60%);opacity:.6;pointer-events:none}
.v2-slide.w3pro .halo{position:absolute;width:78%;max-width:520px;aspect-ratio:1;background:radial-gradient(circle,rgba(253,199,0,.45) 0%,rgba(253,199,0,.15) 45%,transparent 70%);filter:blur(20px);pointer-events:none}
.v2-slide.w3pro .burst{position:relative;width:72%;max-width:340px;aspect-ratio:1;display:grid;place-items:center;text-align:center;color:#14296b;filter:drop-shadow(0 12px 28px rgba(20,41,107,.25));z-index:2;animation:w3pro-spin 30s linear infinite}
.v2-slide.w3pro .burst svg{position:absolute;inset:0;width:100%;height:100%}
.v2-slide.w3pro .burst .bt{position:relative;z-index:1;display:grid;gap:2px;animation:w3pro-spin-rev 30s linear infinite}
.v2-slide.w3pro .burst .num{font-family:Inter,system-ui,sans-serif;font-size:96px;font-weight:900;line-height:.85;letter-spacing:-2px;color:#14296b;display:inline-flex;align-items:flex-start;justify-content:center}
.v2-slide.w3pro .burst .num sup{font-size:32px;font-weight:900;line-height:1;letter-spacing:1px;margin-left:4px;margin-top:8px;color:#bc1212}
.v2-slide.w3pro .burst .lbl{font-size:15px;font-weight:800;letter-spacing:3px;color:#14296b;margin-top:6px}
.v2-slide.w3pro .burst .sub{font-size:10px;font-weight:800;letter-spacing:1.8px;color:#a07849;margin-top:4px;text-transform:uppercase}
@keyframes w3pro-spin     {from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes w3pro-spin-rev {from{transform:rotate(0)}to{transform:rotate(-360deg)}}
.v2-slide.w3pro:hover .burst,
.v2-slide.w3pro:hover .burst .bt{animation-play-state:paused}

.v2-slide.w3pro .chip{position:absolute;background:#fff;color:#14296b;border:1.5px solid #fdc700;border-radius:999px;padding:8px 14px;font-size:11px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;box-shadow:0 6px 16px rgba(20,41,107,.12);z-index:3;display:inline-flex;align-items:center;gap:7px}
.v2-slide.w3pro .chip svg{width:13px;height:13px;color:#0f9447;flex:0 0 13px}
.v2-slide.w3pro .chip.tl{top:8%;left:6%}
.v2-slide.w3pro .chip.tr{top:14%;right:8%}
.v2-slide.w3pro .chip.bl{bottom:12%;left:10%}
.v2-slide.w3pro .chip.br{bottom:8%;right:6%}

.v2-slide.w3pro .route{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.v2-slide.w3pro .route path{fill:none;stroke:#fdc700;stroke-width:2;stroke-dasharray:6 8;opacity:.55}

@media (max-width:780px){
    .v2-slide.w3pro{grid-template-columns:1fr}
    .v2-slide.w3pro .stage{min-height:300px}
    .v2-slide.w3pro .chip{display:none}
    .v2-slide.w3pro .burst .num{font-size:72px}
}

/* ===== Footer (ported from homepage-final-v2.html .ft) ===== */
.ft{background:#1e3eb9;color:#fff;padding:36px 0 0;font-size:13.5px;line-height:1.55;font-family:'Inter',system-ui,sans-serif}
.ft a{color:#fff;text-decoration:none}
.ft .wrap{max-width:var(--maxw,1320px);margin:0 auto;padding:0 28px}
.ft h4{font-size:13px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;margin:0 0 12px;color:#fff}
.ft p{margin:0 0 8px}
.ft a.line,.ft ul a{text-decoration:underline;text-underline-offset:3px}
.ft a.line:hover,.ft ul a:hover{color:#fdc700}
.ft ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.ft .blockgap{margin-top:18px}
.ft .top{display:grid;grid-template-columns:1.4fr 1fr 1.1fr .85fr .85fr;gap:32px;align-items:start}
.ft .brand img{max-width:200px;height:auto;margin-bottom:18px;display:block}
.ft .social{display:flex;gap:10px;margin-bottom:18px}
.ft .social a{width:34px;height:34px;border-radius:50%;background:#fff;color:#1e3eb9;display:grid;place-items:center}
.ft .social svg{width:18px;height:18px}
.ft .qr-stack{margin-top:6px}
.ft .qr-stack .qrbox{width:100px;height:100px;background:#fff;border-radius:8px;padding:8px;display:grid;place-items:center}
.ft .qr-stack .qrbox svg{width:100%;height:100%}
.ft .qr-stack .qrcap{display:block;margin-top:10px;font-size:13px;font-weight:600}
.ft .mid{padding:22px 0 24px;text-align:center;border-top:1px solid rgba(255,255,255,.18);margin-top:24px}
.ft .helper{font-size:14px}
.ft .helper a{text-decoration:underline;text-underline-offset:3px;font-weight:600}
.ft .helper a:hover{color:#fdc700}
.ft .bottom{background:#fff;color:#1f2a44;padding:14px 0}
.ft .bottom .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px}
.ft .copy{font-size:11.5px;color:#7c869a;line-height:1.55;max-width:62%}
.ft .pays{display:flex;gap:10px}
.ft .pays img{height:22px;width:auto;display:block}

@media (max-width:980px){
    .ft .top{grid-template-columns:repeat(2,1fr)}
    .ft .bottom .wrap{flex-direction:column;text-align:center}
    .ft .copy{max-width:100%}
}

/* ===== About band — above footer (ported from homepage-final-v2.html .welcome-band) ===== */
.ab-band{max-width:var(--maxw,1320px);margin:32px auto;padding:0 28px;font-family:'Inter',system-ui,sans-serif}
.ab-band .inner{background:#fff;border:1px solid #e6e9ef;border-radius:12px;padding:32px 36px;position:relative}
.ab-band .ab-eyebrow{display:block;color:#bc1212;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px}
.ab-band h2{font-size:clamp(24px,3vw,32px);font-weight:800;line-height:1.05;margin:0 0 8px;display:inline-block;position:relative;padding-bottom:10px}
.ab-band h2::after{content:"";position:absolute;left:0;bottom:0;width:62px;height:3px;background:#fdc700;border-radius:2px}
.ab-band h2 .ab-red{color:#14296b}
.ab-band h2 .ab-blue{color:#1344b1}
.ab-band p{font-size:14.5px;color:#444;line-height:1.7;margin:18px 0;max-width:none}
.ab-band .ab-btn{display:inline-flex;align-items:center;gap:8px;border:1.5px solid #0f9447;color:#0f9447;background:transparent;border-radius:999px;padding:8px 18px;font-weight:700;font-size:13px;text-decoration:none;transition:background .15s,color .15s}
.ab-band .ab-btn:hover{background:#0f9447;color:#fff}

/* ===== Welcome band — between hero and Featured Collections
   (ported verbatim from storefront-mockup/homepage-final-v2.html .welcome-band).
   The CMS block `esw_welcome_band` provides the markup; these styles paint it. ===== */
.welcome-band{max-width:var(--maxw,1320px);margin:24px auto 0;padding:0 28px;font-family:'Inter',system-ui,sans-serif}
.welcome-band .inner{background:#fff;border:1px solid #e6e9ef;border-radius:12px;padding:32px 36px;display:grid;grid-template-columns:260px 1fr;gap:32px;align-items:center}
.welcome-band h2{font-size:clamp(28px,3.2vw,38px);font-weight:800;text-transform:uppercase;line-height:1.05;margin:0}
.welcome-band .wb-red{color:#bc1212}
.welcome-band .wb-blue{color:#1344b1}
.welcome-band p{font-style:italic;font-size:16px;color:#222;line-height:1.55;margin:0}
@media(max-width:760px){
    .welcome-band .inner{grid-template-columns:1fr;gap:14px;padding:24px}
}
@media(max-width:780px){.ab-band .inner{padding:24px}.ab-band h2{font-size:24px}}

/* ===== Why-Choose-Us (Built for Educators) — ported from homepage-final-v2.html .tb-split-r ===== */
.tb-split-r{max-width:var(--maxw,1320px);margin:32px auto;padding:0 28px;font-family:'Inter',system-ui,sans-serif}
.tb-split-r .grid{display:grid;grid-template-columns:1.05fr 1fr;gap:0;background:#fff;border:1px solid #e6e9ef;border-radius:14px;overflow:hidden;box-shadow:0 8px 28px rgba(20,41,107,.06)}
.tb-split-r .photo{aspect-ratio:1/1.05;background:#eef2fb}
.tb-split-r .photo img{width:100%;height:100%;object-fit:cover;display:block}
.tb-split-r .pane{padding:28px 28px 24px}
.tb-split-r .sec-eyebrow{display:block;color:#bc1212;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.tb-split-r .sec-title{font-size:clamp(24px,2.6vw,30px);font-weight:800;display:inline-block;position:relative;padding-bottom:10px;margin:0;line-height:1.05}
.tb-split-r .sec-title .a{color:#14296b}
.tb-split-r .sec-title .b{color:#1344b1}
.tb-split-r .sec-title::after{content:"";position:absolute;left:0;bottom:0;width:62px;height:3px;background:#fdc700;border-radius:2px}
.tb-split-r .stack{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.tb-split-r .row{display:flex;align-items:flex-start;gap:14px;padding:10px 0;border-top:1px solid #e6e9ef}
.tb-split-r .row:first-of-type{border-top:0;padding-top:0}
.tb-split-r .row .ic{flex:0 0 44px;width:44px;height:44px;border-radius:10px;display:grid;place-items:center;color:#fff}
.tb-split-r .row .ic svg{width:22px;height:22px}
.tb-split-r .row .ic.g{background:#0f9447}
.tb-split-r .row .ic.b{background:#1344b1}
.tb-split-r .row .ic.r{background:#bc1212}
.tb-split-r .row .ic.n{background:#14296b}
.tb-split-r .row .ic.y{background:transparent}
.tb-split-r .row .ic.y .seal{width:44px;height:44px}
.tb-split-r .row h4{margin:0 0 2px;font-size:14px;font-weight:800;color:#1f2a44}
.tb-split-r .row p{margin:0;font-size:12px;color:#6b7280;line-height:1.45}

@media (max-width:780px){
    .tb-split-r .grid{grid-template-columns:1fr}
    .tb-split-r .photo{aspect-ratio:16/9}
}

/* ===== Testimonials section ===== */
.tm-section{max-width:var(--maxw,1320px);margin:32px auto;padding:0 28px;font-family:'Inter',system-ui,sans-serif}
.tm-head{margin-bottom:18px}
.tm-eyebrow{display:block;color:#bc1212;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.tm-title{font-size:clamp(26px,3vw,32px);font-weight:800;display:inline-block;position:relative;padding-bottom:10px;margin:0;line-height:1.05}
.tm-title .a{color:#14296b}
.tm-title .b{color:#1344b1}
.tm-title::after{content:"";position:absolute;left:0;bottom:0;width:62px;height:3px;background:#fdc700;border-radius:2px}
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tm-card{background:#fff;border:1px solid #e6e9ef;border-radius:12px;padding:22px;box-shadow:0 6px 20px rgba(20,41,107,.05);display:flex;flex-direction:column;gap:14px;min-height:200px}
.tm-stars{color:#fdc700;font-size:16px;letter-spacing:2px;line-height:1}
.tm-quote{margin:0;color:#1f2a44;font-size:15px;line-height:1.55;flex:1}
.tm-by{display:flex;align-items:center;gap:12px;margin-top:6px}
.tm-avatar{width:42px;height:42px;border-radius:50%;background:#14296b;color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;letter-spacing:.3px;flex:0 0 42px}
.tm-name{font-weight:700;font-size:14px;color:#1f2a44;line-height:1.2}
.tm-role{font-size:12.5px;color:#6b7280;margin-top:2px;line-height:1.2}
@media(max-width:780px){.tm-grid{grid-template-columns:1fr}}

/* ===== Partner / brand-logos marquee (auto-scroll, hover-paused) ===== */
.pn-section{max-width:var(--maxw,1320px);margin:32px auto;padding:0 28px;font-family:'Inter',system-ui,sans-serif}
.pn-head{text-align:left;margin-bottom:14px}
.pn-eyebrow{display:block;color:#bc1212;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.pn-title{font-size:clamp(26px,3vw,32px);font-weight:800;display:inline-block;position:relative;padding-bottom:10px;margin:0}
.pn-title .a{color:#14296b}
.pn-title .b{color:#1344b1}
.pn-title::after{content:"";position:absolute;left:0;bottom:0;width:62px;height:3px;background:#fdc700;border-radius:2px}
.pn-marquee{position:relative;overflow:hidden;padding:28px 0;background:linear-gradient(180deg,transparent,#fafbff,transparent)}
.pn-fade{position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.pn-fade-l{left:0;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.85) 50%,transparent)}
.pn-fade-r{right:0;background:linear-gradient(-90deg,#fff 0%,rgba(255,255,255,.85) 50%,transparent)}
.pn-track{display:flex;align-items:center;gap:56px;width:max-content;animation:pn-scroll 38s linear infinite;will-change:transform}
.pn-marquee:hover .pn-track{animation-play-state:paused}
@keyframes pn-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.partner-logo{flex-shrink:0;display:inline-flex;align-items:center;height:56px;font-weight:800;font-size:28px;line-height:1;letter-spacing:-.3px;filter:none;transition:filter .35s ease,transform .25s ease;cursor:default;user-select:none;color:#1f2a44}
.partner-logo:hover{filter:grayscale(0) opacity(1);transform:translateY(-2px)}
.partner-logo img{height:42px;width:auto;object-fit:contain;display:block}
.pn-cta{text-align:center;margin-top:14px}
.pn-cta .ab-btn{display:inline-flex;align-items:center;gap:8px;border:1.5px solid #0f9447;color:#0f9447;background:transparent;border-radius:999px;padding:9px 22px;font-weight:700;font-size:13px;text-decoration:none;transition:background .15s,color .15s}
.pn-cta .ab-btn:hover{background:#0f9447;color:#fff}

/* ============================================================
   Homepage body padding override (added 2026-06-01).
   The blank theme's shared `.page-main` rule sets padding-left/right:20px
   and max-width:1280px to keep header / breadcrumbs / body / footer
   aligned in one brand-wide content rail. Per user request we strip
   that on the homepage only — header / footer keep their 20 px so they
   still align with each other; only the homepage body content
   (hero, brands, testimonials, why-choose, newsletter, about band)
   extends further out. Scoped to body.cms-home so other CMS pages
   are untouched.
   ============================================================ */
body.cms-home .page-main {
    padding-left: 0;
    padding-right: 0;
    max-width: none;
}


/* Account sidebar active-item highlight + header/body spacing (2026-06-08) */
.account .block-collapsible-nav .item,
.account .account-nav .item {
    border-left: 3px solid transparent;
}
.account .block-collapsible-nav .item.current,
.account .account-nav .item.current {
    border-left-color: #1465a8;
    background: #eef4fb;
}
.account .block-collapsible-nav .item.current strong,
.account .block-collapsible-nav .item.current > a,
.account .account-nav .item.current strong,
.account .account-nav .item.current > a {
    color: #1465a8;
    font-weight: 700;
}
.account .block-collapsible-nav .item > a:hover,
.account .account-nav .item > a:hover {
    background: #f5f8fc;
    color: #1465a8;
}
.account .columns,
.account .page-main {
    padding-top: 24px;
}


/* H1 top margin on login + dashboard pages (2026-06-08) */
.customer-account-login .page-title-wrapper .page-title,
.customer-account-index .page-title-wrapper .page-title {
    margin-top: 40px;
}


/* Customer login: Sign In progress bar (2026-06-09) */
.action.login.primary.mc-loading { opacity: .85; cursor: wait; }
.mc-login-progress {
    position: relative;
    height: 3px;
    max-width: 220px;
    margin: 12px 0 0;
    background: #dfe6f3;
    border-radius: 2px;
    overflow: hidden;
}
.mc-login-progress span {
    position: absolute;
    top: 0; left: -40%;
    width: 40%; height: 100%;
    background: #1465a8;
    border-radius: 2px;
    animation: mcLoginBar 1s infinite linear;
}
@keyframes mcLoginBar { 0% { left: -40%; } 100% { left: 100%; } }

/* ============================================================
   Floating sticky pill header (js/sticky-pill toggles .show)
   ============================================================ */
.h2-pill{position:fixed;left:50%;top:14px;transform:translateX(-50%) translateY(-170%);width:min(1200px,calc(100% - 32px));z-index:150;opacity:0;pointer-events:none;transition:transform .38s cubic-bezier(.34,1.25,.5,1),opacity .3s ease;font-family:'Inter',system-ui,sans-serif}
.h2-pill.show{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto}
.h2-pill-in{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 46px rgba(20,30,80,.22);padding:10px 16px}
.h2-pill .pill-logo{display:flex;align-items:center}
.h2-pill .pill-logo img{height:34px;width:auto;display:block}
.h2-pill .pill-search{flex:1;display:flex;align-items:center;height:42px;border:2px solid var(--navy);border-radius:999px;background:#fff;overflow:visible;position:relative;min-width:160px}
.h2-pill .pill-search input{flex:1;min-width:0;height:38px;line-height:38px;border:0;outline:0;font:inherit;font-size:14px;padding:0 8px 0 158px;background:transparent;color:var(--ink);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* instant-search category-scope select + dropdown inside the pill */
.h2-pill .pill-search .eo-is-scope{border-radius:999px 0 0 999px;border-right:1px solid #ccc}
.h2-pill .pill-search .eo-is-box{border-radius:0 0 12px 12px;margin-top:2px;z-index:160}
.h2-pill .pill-search button{align-self:stretch;display:grid;place-items:center;background:var(--navy);color:#fff;border:0;padding:0 22px;cursor:pointer;border-radius:0 999px 999px 0}
.h2-pill .pill-search button svg{width:17px;height:17px}
.h2-pill .pill-cats{display:inline-flex;align-items:center;gap:7px;background:var(--gold);color:var(--navy);border:0;font-weight:800;font-size:12.5px;padding:11px 15px;border-radius:9px;white-space:nowrap;cursor:pointer}
.h2-pill .pill-cats svg{width:15px;height:15px}
.h2-pill .pill-fship{display:inline-flex;align-items:center;gap:9px;color:var(--green);white-space:nowrap}
.h2-pill .pill-fship .t{width:20px;height:20px;color:var(--red);flex:none}
.h2-pill .pfree-lines{display:flex;flex-direction:column;gap:4px;line-height:1}
.h2-pill .pfree-l1{font-size:11.5px;font-weight:800;color:var(--green)}
.h2-pill .pfree-l2{display:flex;align-items:center;height:8px}
.h2-pill .pfree-l2 .bar{width:130px;height:6px;background:#cdeccf;border-radius:5px;overflow:hidden}
.h2-pill .pfree-l2 .bar .fill{display:block;height:100%;width:8%;background:var(--green);border-radius:5px;transition:width .5s ease}
.h2-pill .pfree-l2 .js-pill-unlocked{display:none;font-size:11.5px;font-weight:800;color:var(--green)}
.h2-pill.free-won .pfree-l2 .bar{display:none}
.h2-pill.free-won .pfree-l2 .js-pill-unlocked{display:inline}
.h2-pill .pill-cart{position:relative;display:grid;place-items:center;width:42px;height:42px;background:var(--navy);border-radius:10px;color:#fff}
.h2-pill .pill-cart svg{width:21px;height:21px}
.h2-pill .pill-cart .badge{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;border-radius:999px;font-size:10px;font-weight:800;min-width:18px;height:18px;display:grid;place-items:center;padding:0 4px}
/* bottom progress bar removed per design — free-ship progress lives in the .pill-fship chip */
.h2-pill .pill-prog{display:none}
@media(max-width:760px){
  .h2-pill .pill-fship{display:none}
  .h2-pill .pill-cats .t{display:none}
  .h2-pill .pill-cats{padding:11px 12px}
}

/* ===== Header account dropdown (logged-in, Option 2) — added 2026-06-14 ===== */
.h2-account{position:relative}
.h2-acct-trigger{display:inline-flex;flex-direction:column;align-items:center;gap:5px;background:transparent;border:0;
    cursor:pointer;color:var(--navy);font-family:inherit;font-size:13px;font-weight:600;padding:0;line-height:1}
.h2-acct-ico{width:28px;height:28px}
.h2-acct-line{display:inline-flex;align-items:center;gap:3px}
.h2-acct-chev{width:12px;height:12px;transition:transform .2s}
.h2-account.is-open .h2-acct-chev{transform:rotate(180deg)}

.h2-acct-menu{position:absolute;top:calc(100% + 14px);right:0;width:min(290px,calc(100vw - 20px));background:#fff;border:1px solid #e6e9ef;
    border-radius:12px;box-shadow:0 16px 40px rgba(20,41,107,.20);padding:8px;z-index:160;text-align:left;
    opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s,transform .18s,visibility .18s}
.h2-account.is-open .h2-acct-menu{opacity:1;visibility:visible;transform:none}
.h2-acct-menu:before{content:"";position:absolute;top:-7px;right:24px;width:13px;height:13px;background:#fff;
    border-left:1px solid #e6e9ef;border-top:1px solid #e6e9ef;transform:rotate(45deg)}
.h2-acct-greet{padding:9px 12px 11px;border-bottom:1px solid #e6e9ef;margin-bottom:6px}
.h2-acct-greet b{display:block;color:#14296b;font-size:14px;line-height:1.25}
.h2-acct-greet span{font-size:12px;color:#8a93a8;font-weight:500}
.h2-acct-menu a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:#14296b;
    font-size:13.5px;font-weight:600;text-decoration:none}
.h2-acct-menu a:hover{background:#eef3ff;color:#14296b}
.h2-acct-menu a svg{width:16px;height:16px;stroke:var(--navy);flex:none}
.h2-acct-menu a.out{color:#bc1212;border-top:1px solid #e6e9ef;margin-top:6px}
.h2-acct-menu a.out:hover{background:#fdeaea}
.h2-acct-menu a.out svg{stroke:#bc1212}

/* default = guest set; js/account-menu adds .is-logged-in to swap */
.h2-acct-user{display:none}
.h2-account.is-logged-in .h2-acct-user{display:block}
.h2-account.is-logged-in .h2-acct-guest{display:none}

/* enriched guest menu — welcome header + Sign In button + links (2026-06-24) */
.h2-acct-menu .h2-acct-guesthead{padding:10px 12px 12px}
.h2-acct-menu .h2-acct-guesthead b{display:block;color:#14296b;font-size:15px;font-weight:800}
.h2-acct-menu .h2-acct-guesthead span{display:block;color:#8a93a8;font-size:12px;margin-top:2px;font-weight:500}
.h2-acct-menu a.h2-acct-btn{display:flex;align-items:center;justify-content:center;margin:0 4px 8px;padding:12px;border-radius:999px;
    background:linear-gradient(180deg,#114ccf,#1344b1);color:#fff;font-weight:800;font-size:14px;box-shadow:0 8px 18px rgba(17,76,207,.25)}
.h2-acct-menu a.h2-acct-btn:hover{filter:brightness(1.06);background:linear-gradient(180deg,#114ccf,#1344b1);color:#fff}
.h2-acct-menu .h2-acct-reg{text-align:center;font-size:12.5px;color:#8a93a8;margin:0 0 8px}
.h2-acct-menu .h2-acct-reg a{display:inline;padding:0;font-weight:800;color:#1344b1}
.h2-acct-menu .h2-acct-reg a:hover{background:transparent;text-decoration:underline}
.h2-acct-sep{height:1px;background:#eef0f4;margin:6px 8px 8px}
/* mobile: anchor the dropdown to the wider acts row so it never overflows the viewport */
@media(max-width:600px){
  .h2-acts{position:relative}
  .h2-account{position:static}
  .h2-acct-menu{right:0;left:auto;width:min(300px,calc(100vw - 24px))}
  .h2-acct-menu:before{right:20px}
}


/* Login + Create Account: align body content with the header/footer content rail
   (2026-06-24, calc-rail rewrite). The old rule used max-width:1320 + padding:0,
   which only lands on the rail above ~1376px (where margin:auto centres it) and
   collapses the left edge to x=0 at laptop widths (1280/1366) — title/cards sat
   ~28px LEFT of the header logo. Use the site calc rail so the edges floor at 28px
   and match nav/breadcrumb/footer at EVERY width. */
.customer-account-login .page-main,
.customer-account-create .page-main {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left:  max(28px, calc((100% - var(--maxw, 1320px)) / 2));
    padding-right: max(28px, calc((100% - var(--maxw, 1320px)) / 2));
}


/* Create Account: top breathing room above the page title (2026-06-14).
   The 'Create New Customer Account' heading sat flush against the nav (0px gap);
   match the login/dashboard pages which already have a 40px top margin. */
.customer-account-create .page-title-wrapper .page-title {
    margin-top: 40px;
}


/* Account left nav: switch the active/hover accent from blue to brand green
   (--green #0f9447) to match the site's green menu styling (2026-06-14). */
.account .block-collapsible-nav .item.current,
.account .account-nav .item.current {
    border-left-color: var(--green, #0f9447);
    background: #eaf7ef;
}
.account .block-collapsible-nav .item.current strong,
.account .block-collapsible-nav .item.current > a,
.account .account-nav .item.current strong,
.account .account-nav .item.current > a {
    color: var(--green, #0f9447);
}
.account .block-collapsible-nav .item > a:hover,
.account .account-nav .item > a:hover {
    background: #f0f9f4;
    color: var(--green, #0f9447);
}


/* ===== Account left nav — GREEN PILLS (style C), 2026-06-14 =====
   Supersedes the earlier green-accent rules: rounded green pill on the active
   item (solid green bg + white text), soft green pill on hover. */
.account .block-collapsible-nav .content .nav.items,
.account .account-nav.items { padding: 6px 10px; }
.account .block-collapsible-nav .item,
.account .account-nav .item {
    border-left: 0 !important;
    background: transparent !important;
    margin: 2px 0;
}
.account .block-collapsible-nav .item > a,
.account .block-collapsible-nav .item > strong,
.account .account-nav .item > a,
.account .account-nav .item > strong {
    display: block;
    border: 0 !important;
    border-radius: 10px;
    padding: 10px 16px;
    transition: background .15s ease, color .15s ease;
}
.account .block-collapsible-nav .item > a:hover,
.account .account-nav .item > a:hover {
    background: #eaf7ef !important;
    color: #0c7d3c !important;
}
.account .block-collapsible-nav .item.current > strong,
.account .block-collapsible-nav .item.current > a,
.account .account-nav .item.current > strong,
.account .account-nav .item.current > a {
    background: var(--green, #0f9447) !important;
    color: #fff !important;
    font-weight: 700;
}


/* ===== Newsletter Subscription page — fix form alignment + tidy (2026-06-14) =====
   Luma indents fieldset content by the label-column width, pushing the single
   checkbox + Save ~25% to the right of the title. Left-align + card + green btn. */
.newsletter-manage-index .column.main .fieldset > .field,
.newsletter-manage-index .column.main .fieldset > .field.choice,
.newsletter-manage-index .column.main .fieldset .legend,
.newsletter-manage-index .column.main .actions-toolbar,
.newsletter-manage-index .column.main .actions-toolbar > .primary {
    margin-left: 0 !important; padding-left: 0 !important;
    width: auto !important; max-width: none !important; float: none !important;
}
.newsletter-manage-index .column.main form {
    max-width: 520px; background:#fff; border:1px solid #e3e6ef; border-radius:12px; padding:22px 24px; margin-top:8px;
}
.newsletter-manage-index .column.main .fieldset { margin-bottom:0; }
.newsletter-manage-index .column.main .fieldset .legend {
    font-size:16px; font-weight:700; border:0; margin:0 0 14px; padding:0;
}
.newsletter-manage-index .column.main .field.choice { margin:6px 0; }
.newsletter-manage-index .column.main .actions-toolbar { margin:18px 0 0; }
.newsletter-manage-index .column.main .actions-toolbar .action.save,
.newsletter-manage-index .column.main .actions-toolbar button {
    background:var(--green,#0f9447) !important; border-color:var(--green,#0f9447) !important; color:#fff !important; border-radius:8px;
}
.newsletter-manage-index .column.main .actions-toolbar .action.save:hover,
.newsletter-manage-index .column.main .actions-toolbar button:hover {
    background:#0c7d3c !important; border-color:#0c7d3c !important;
}

/* Newsletter: remove Luma's label-column :before spacer that indents the checkbox */
.newsletter-manage-index .column.main .fieldset > .field:before,
.newsletter-manage-index .column.main .fieldset > .field.choice:before {
    display: none !important; width: 0 !important; content: none !important;
}
.newsletter-manage-index .column.main .field.choice { padding-left: 0 !important; }

/* Contact page: top breathing room on the title (was jammed under the nav) */
.contact-index-index .page-title-wrapper .page-title { margin-top: 40px; }

/* ESW loader: brand dots GIF (web/images/loader-1.gif & loader-2.gif) replaces the default spinner site-wide. Dots only = hide the loader text line. */
.loading-mask .loader > p { display: none !important; }
/* ESW loader display size: downscale the hi-res dots gif for crisp edges */
.loading-mask .loader > img { width: 80px !important; height: auto !important; max-width: 80px; }

/* ===== ESW checkout: Stripe payment block polish (heading + card + trust row + spacing) ===== */
/* #3 tighten spacing */
.stripe-payments .payment-method-content { padding-top: 6px; }
.stripe-payments .payment-method-billing-address { margin: 2px 0 14px; line-height: 1.5; }
.stripe-payments .payment-method-billing-address .field.choice { margin-bottom: 12px; }

/* #4 heading + titled card around the Stripe Payment Element */
.stripe-payments .esw-pay-heading {
    font-size: 14px; font-weight: 700; color: #14296b; margin: 4px 0 8px;
}
.stripe-payments #stripe-payment-element {
    border: 1px solid #e3e9f2; border-radius: 10px; padding: 14px; background: #fff;
}

/* #5 trust row */
.stripe-payments .esw-trust-row {
    display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
    margin: 12px 2px 6px; font-size: 12px; color: #6b7280;
}
.stripe-payments .esw-trust-row .esw-lock { font-size: 13px; line-height: 1; }
.stripe-payments .esw-trust-row .esw-trust-text { font-weight: 600; color: #14296b; }
.stripe-payments .esw-trust-row .esw-cards { display: inline-flex; gap: 6px; margin-left: auto; align-items: center; }
.stripe-payments .esw-trust-row .esw-card {
    display: inline-block; width: 34px; height: 22px;
    background-size: contain; background-repeat: no-repeat; background-position: center;
    border: 1px solid #eef1f6; border-radius: 4px;
}
.stripe-payments .esw-trust-row .esw-card--visa { background-image: url("../images/pay-visa.png"); }
.stripe-payments .esw-trust-row .esw-card--mc   { background-image: url("../images/pay-mc.png"); }
.stripe-payments .esw-trust-row .esw-card--amex { background-image: url("../images/pay-amex.png"); }
.stripe-payments .esw-trust-row .esw-card--disc { background-image: url("../images/pay-discover.png"); }
@media (max-width: 600px) {
    .stripe-payments .esw-trust-row .esw-cards { margin-left: 0; }
}

/* ============================================================
   HOMEPAGE + HEADER RESPONSIVE (added 2026-06-17)
   Additive only — every rule is inside a media query (or homepage-
   scoped) so the >980px desktop design is unchanged. Fixes mobile
   horizontal overflow + header/hero/welcome sizing.
   Breakpoints: 980 / 768 / 480.
   ============================================================ */

/* backstop: kill any stray horizontal overflow on the homepage only */
body.cms-home .page-wrapper { overflow-x: hidden; }
body.cms-home img { max-width: 100%; }

/* ---------- Tablet & below (<= 980px) ---------- */
@media (max-width: 980px) {
  .h2-logo img { height: 64px; }                 /* logo not so tall */
  .h2-main { gap: 16px; }
  .h2-search { width: 100%; max-width: none; height: 48px; }
  .h2-search input { min-width: 0; }
  .h2-search .eo-is-scope { max-width: 140px; }  /* category select shrinks */
  /* nav: never wrap into broken rows — scroll horizontally instead, contained */
  .h2-nav-in { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .h2-nav-in::-webkit-scrollbar { display: none; height: 0; }
  .h2-nav a, .h2-allcat { white-space: nowrap; flex: 0 0 auto; }
}

/* ---------- Mobile-ish (<= 768px) ---------- */
@media (max-width: 768px) {
  /* top bar: stack tidily + drop the wide free-ship progress widget */
  .h2-top-in { gap: 6px 14px; padding: 9px 0; justify-content: center; text-align: center; }
  .h2-top .c { display: none; }
  /* main row */
  .h2-main { gap: 12px; padding: 14px 0; }
  .h2-logo img { height: 54px; }
  .h2-acts { gap: 22px; }
  /* search */
  .h2-search { height: 46px; }
  .h2-search .eo-is-scope { max-width: 116px; font-size: 13px; padding: 0 26px 0 12px; }
  .h2-search input { padding: 0 14px; }
  /* hero: ~360-420 tall, readable, no clip */
  .v2-slide { height: clamp(360px, 62vw, 420px); }
  .v2-copy { padding: 0 20px 24px; }
  .v2-copy .inner { gap: 8px; }
  .v2-acts { gap: 10px; }
  .v2-btn { padding: 10px 20px; }
  /* welcome band -> one column + wrap long words */
  .welcome-band { padding: 0 16px; }
  .welcome-band .inner { grid-template-columns: 1fr; gap: 12px; padding: 22px; min-width: 0; }
  .welcome-band h2, .welcome-band p { overflow-wrap: anywhere; word-break: break-word; min-width: 0; }
  /* sliders: a touch more room */
  .bts-section, .fc-section { padding-left: 16px; padding-right: 16px; }
}

/* ---------- Small phones (<= 480px) ---------- */
@media (max-width: 480px) {
  .wrap { padding: 0 14px; }
  .h2-logo img { height: 46px; }
  .h2-acts { gap: 16px; }
  .h2-acts a { font-size: 11px; }
  .h2-acts svg { width: 24px; height: 24px; }
  .h2-search { height: 44px; }
  .h2-search .eo-is-scope { max-width: 96px; font-size: 12px; padding: 0 22px 0 9px; }
  .h2-search button { width: 56px; }
  .h2-nav a, .h2-allcat { font-size: 13px; padding: 12px 12px; }
  .v2-arrow { display: none; }
  .v2-slide { height: clamp(340px, 78vw, 400px); }
  .v2-copy h2 { font-size: 22px; }
  .v2-copy p { font-size: 14px; }
  .v2-dots { right: 16px; bottom: 14px; }
  .welcome-band h2 { font-size: 24px; }
}

/* ============================================================
   FINAL RESPONSIVE POLISH — homepage (added 2026-06-17, pass 2)
   Refines pass 1; scoped to .cms-home so other pages stay as-is.
   Does NOT revert pass-1 fixes; root-cause fixes (not overflow-x only).
   ============================================================ */

/* ---- Item 1: mobile search — usable input, compact select, fixed button ---- */
@media (max-width: 768px) {
  .cms-home .h2-search { width: 100%; min-width: 0; }
  .cms-home .h2-search .eo-is-scope { flex: 0 0 auto; max-width: 116px; padding: 0 24px 0 12px; font-size: 13px; }
  .cms-home .h2-search input { min-width: 0; font-size: 13px; padding-left: 12px; padding-right: 10px; }
  .cms-home .h2-search input::placeholder { font-size: 13px; }
  .cms-home .h2-search button { width: 62px; flex: 0 0 62px; }
}
@media (max-width: 480px) {
  .cms-home .h2-search .eo-is-scope { flex-basis: 96px; max-width: 96px; padding-left: 10px; padding-right: 22px; font-size: 12px; }
  .cms-home .h2-search input { min-width: 0; font-size: 13px; padding-left: 10px; padding-right: 8px; }
  .cms-home .h2-search input::placeholder { font-size: 12px; }
  .cms-home .h2-search button { width: 58px; flex: 0 0 58px; }
}

/* ---- Item 2: mobile nav — single clean "All Categories" trigger that opens the
   EXISTING mega-menu drawer (#mmTrigger -> .mm). Secondary text links stay in the
   footer on mobile. Contained, no wrap/clip, scrollbar hidden. ---- */
@media (max-width: 768px) {
  .cms-home .h2-nav-in { flex-wrap: nowrap; overflow-x: auto; scrollbar-width: none; gap: 6px; padding: 4px 0; }
  .cms-home .h2-nav-in::-webkit-scrollbar { display: none; height: 0; }
  .cms-home .h2-nav a { display: none; }
  .cms-home .h2-allcat { flex: 0 0 auto; white-space: nowrap; padding: 14px 18px 14px 2px; }
}

/* ---- Item 3: hero QA — keep dots inside the hero and clear of the CTA buttons ---- */
@media (max-width: 768px) {
  .cms-home .v2-copy { padding-bottom: 32px; }
  .cms-home .v2-dots { right: 18px; bottom: 12px; }
}
@media (max-width: 480px) {
  .cms-home .v2-arrow { display: none; }
  .cms-home .v2-dots { right: 14px; bottom: 10px; }
  .cms-home .v2-acts { gap: 8px; }
  .cms-home .v2-acts .v2-btn { padding: 9px 16px; font-size: 13px; }
}

/* ---- Pass 3 (2026-06-17): tablet/mobile search width — root-cause fit.
   The search row's 2.5px border was bleeding past the viewport (~772px in a
   768px viewport). Inset it inside the viewport and include the border in the
   width via box-sizing. Desktop (>768px) header layout unchanged. ---- */
@media (max-width: 768px) {
  .cms-home .h2-search {
    box-sizing: border-box;
    width: calc(100% - 28px);
    max-width: none;
    margin-left: 14px;
    margin-right: 14px;
  }
}

/* ============================================================
   PASS 4 (2026-06-17): compact mobile header (<=480px) so the hero starts
   higher (was ~307px). Scoped .cms-home; desktop + tablet layout unchanged.
   ============================================================ */
@media (max-width: 480px) {
  /* top bar — compact, keep W-9 + phone + language/currency */
  .cms-home .h2-top { font-size: 12px; }
  .cms-home .h2-top-in { padding-top: 6px; padding-bottom: 6px; gap: 6px 10px; justify-content: center; }
  .cms-home .h2-top .w9 { padding: 5px 14px; font-size: 12px; }
  .cms-home .h2-top .bar, .cms-home .h2-top .c { display: none; }
  /* main row — tighten + shrink the logo (the biggest height saver) */
  .cms-home .h2-main { gap: 10px; padding-top: 8px; padding-bottom: 10px; }
  .cms-home .h2-logo img { height: 42px; }
  .cms-home .h2-search { height: 42px; width: calc(100% - 28px); margin-left: 14px; margin-right: 14px; }
  .cms-home .h2-search .eo-is-scope { flex-basis: 92px; max-width: 92px; font-size: 12px; padding-left: 10px; padding-right: 20px; }
  .cms-home .h2-search input { font-size: 13px; min-width: 0; }
  .cms-home .h2-search button { width: 54px; flex: 0 0 54px; }
  /* account / wishlist / cart — visible but compact */
  .cms-home .h2-acts { gap: 26px; margin-top: 0; }
  .cms-home .h2-acts a, .cms-home .h2-acct-trigger { font-size: 12px; gap: 3px; }
  .cms-home .h2-acts svg, .cms-home .h2-acct-ico { width: 24px; height: 24px; }
  /* nav — single All Categories trigger, compact bar */
  .cms-home .h2-nav-in { min-height: 44px; align-items: center; }
  .cms-home .h2-allcat { padding-top: 10px; padding-bottom: 10px; font-size: 14px; }
}
/* Estimator re-enabled 2026-06-18 per user: show "Estimate Shipping and Tax" so customers can check Quaderno tax on the cart. (block kept in DOM regardless) */

/* ---- Cart item actions: hide "Edit", keep only "Remove item" w/ trash icon ---- */
.checkout-cart-index .cart.item .action-edit { display: none !important; }
.checkout-cart-index .cart.item .action-delete {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #c0392b;
}
.checkout-cart-index .cart.item .action-delete:hover { color: #a93226; text-decoration: none; }
.checkout-cart-index .cart.item .action-delete::before {
  content: "";
  flex: 0 0 16px;
  width: 16px;
  height: 16px;
  background: no-repeat center / contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c0392b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 6 5 6 21 6'/%3E%3Cpath d='M19 6l-1 14a2 2 0 0 1-2 2H8a2 2 0 0 1-2-2L5 6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2'/%3E%3Cline x1='10' y1='11' x2='10' y2='17'/%3E%3Cline x1='14' y1='11' x2='14' y2='17'/%3E%3C/svg%3E");
}

/* ===== Merge "Have a coupon?" box + native "Apply Discount Code" into ONE card ===== */
/* Top half = the available-coupons chip box */
.checkout-cart-index .mconnect-available-coupons {
  margin-bottom: 0 !important;
  border-bottom: 0 !important;
  border-radius: 8px 8px 0 0 !important;
  padding-bottom: 6px !important;
}
/* Bottom half = native discount form, joined seamlessly (only when chip box present) */
.checkout-cart-index .mconnect-available-coupons + #block-discount {
  margin: 0 0 16px !important;
  border: 1px solid #e3e8f0;
  border-top: 0;
  border-radius: 0 0 8px 8px;
  background: #fff;
  padding: 0 14px 14px;
}
/* Hide native collapsible title; force the form open (no extra click) */
.checkout-cart-index .mconnect-available-coupons + #block-discount > .title { display: none !important; }
.checkout-cart-index .mconnect-available-coupons + #block-discount > .content {
  display: block !important;
  border-top: 1px dashed #e3e8f0;
  margin-top: 4px;
  padding-top: 12px;
}
/* "or enter a code" divider label */
.checkout-cart-index .mconnect-available-coupons + #block-discount > .content::before {
  content: "or enter a code";
  display: block;
  text-align: center;
  color: #7a8499;
  font-size: 12px;
  margin: -2px 0 12px;
}
/* Input + button on one row, ESW styling */
.checkout-cart-index #block-discount .fieldset.coupon {
  display: flex;
  gap: 8px;
  align-items: stretch;
  margin: 0;
}
.checkout-cart-index #block-discount .fieldset.coupon .field {
  flex: 1 1 auto;
  margin: 0;
}
.checkout-cart-index #block-discount .fieldset.coupon .field .label { display: none; }
.checkout-cart-index #block-discount #coupon_code {
  width: 100%;
  height: 40px;
  border: 1px solid #cfd6e4;
  border-radius: 6px;
  padding: 0 12px;
  box-sizing: border-box;
}
.checkout-cart-index #block-discount .actions-toolbar,
.checkout-cart-index #block-discount .actions-toolbar .primary { margin: 0; padding: 0; }
.checkout-cart-index #block-discount .actions-toolbar .action.apply,
.checkout-cart-index #block-discount .actions-toolbar .action.cancel {
  height: 40px;
  border: 0;
  border-radius: 6px;
  padding: 0 18px;
  font-weight: 700;
  color: #fff;
  cursor: pointer;
  white-space: nowrap;
}
.checkout-cart-index #block-discount .actions-toolbar .action.apply { background: #1344b1; }
.checkout-cart-index #block-discount .actions-toolbar .action.apply:hover { background: #0e3590; }
.checkout-cart-index #block-discount .actions-toolbar .action.cancel { background: #c0392b; }
.checkout-cart-index #block-discount .actions-toolbar .action.cancel:hover { background: #a93226; }

/* ===== Cart: ONE loader only =====
   The page has a MAIN full-screen loader (body loaderAjax, uses loader-2.gif) that
   auto-closes when AJAX finishes, PLUS per-component block loaders (Magento_Ui/js/block-loader,
   uses loader-1.gif) that each overlay a section (free-ship bar, shipping/totals) at the same time.
   Keep the main one; hide the duplicate block loaders by matching their loader-1.gif icon. */
body.checkout-cart-index .loading-mask:has(img[src*="loader-1"]) {
  display: none !important;
}

/* ============================================================
   CMS policy pages — align content + breadcrumbs with the header
   rail (1320px + 28px) and add title top padding under the header.
   Pages: payment-terms, shipping-policy, returns-refunds. (2026-06-18)
   ============================================================ */
.cms-payment-terms .page-main,
.cms-shipping-policy .page-main,
.cms-returns-refunds .page-main {
    max-width: var(--maxw, 1320px);
    margin: 0 auto;
    padding: 36px 28px 64px;
    box-sizing: border-box;
}
.cms-payment-terms .breadcrumbs,
.cms-shipping-policy .breadcrumbs,
.cms-returns-refunds .breadcrumbs {
    max-width: var(--maxw, 1320px);
    margin: 0 auto;
    padding: 18px 28px 0;
    box-sizing: border-box;
}
@media (max-width: 768px) {
    .cms-payment-terms .page-main,
    .cms-shipping-policy .page-main,
    .cms-returns-refunds .page-main { padding: 22px 16px 44px; }
    .cms-payment-terms .breadcrumbs,
    .cms-shipping-policy .breadcrumbs,
    .cms-returns-refunds .breadcrumbs { padding: 14px 16px 0; }
}

/* CMS policy + about-us body text -> black, 15px (2026-06-18 per user) */
.cms-payment-terms .column.main p,
.cms-payment-terms .column.main li,
.cms-shipping-policy .column.main p,
.cms-shipping-policy .column.main li,
.cms-returns-refunds .column.main p,
.cms-returns-refunds .column.main li { color: #000; font-size: 15px; }
.cms-about-us .seo-text { color: #000; }

/* hero eyebrow label (added 2026-06-18 for Back to School slide) */
.v2-copy .v2-eyebrow{display:block;color:var(--gold);font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:2px}

/* Payment Terms — align body + breadcrumb to the .wrap content rail at EVERY
   viewport. content edge = max(28px, (100% - 1320)/2), identical to .wrap
   (nav/footer). Uses calc instead of max-width+margin:auto, which mis-centered
   the short breadcrumb on mobile. 2026-06-18 */
.cms-payment-terms .page-main,
.cms-payment-terms .breadcrumbs {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left: max(28px, calc((100% - var(--maxw, 1320px)) / 2));
    padding-right: max(28px, calc((100% - var(--maxw, 1320px)) / 2));
}

/* About Us — align body sections (about-shell) + seo-band to the .wrap content
   rail at EVERY viewport, identical to payment-terms. content edge =
   max(28px,(100%-1320)/2). Hero stays full-bleed by design. 2026-06-18 */
.cms-about-us .about-shell,
.cms-about-us .seo-band {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left: max(28px, calc((100% - var(--maxw, 1320px)) / 2));
    padding-right: max(28px, calc((100% - var(--maxw, 1320px)) / 2));
}

/* About Us — let the founder/about row cards fill the rail (they had their own
   max-width:1180 centered, sitting ~70px in from the rail). 2026-06-18 */
.cms-about-us .founder-row,
.cms-about-us .about-row {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
}

/* rail-align — body + breadcrumb to the .wrap content rail at every viewport,
   across all policy/info pages. content edge = max(28px,(100%-1320)/2). 2026-06-18 */
.cms-payment-terms .page-main,   .cms-payment-terms .breadcrumbs,
.cms-shipping-policy .page-main, .cms-shipping-policy .breadcrumbs,
.cms-returns-refunds .page-main, .cms-returns-refunds .breadcrumbs,
.cms-privacy-policy .page-main,  .cms-privacy-policy .breadcrumbs,
.cms-terms-conditions .page-main,.cms-terms-conditions .breadcrumbs,
.cms-faq .page-main,             .cms-faq .breadcrumbs {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left:  max(28px, calc((100% - var(--maxw, 1320px)) / 2));
    padding-right: max(28px, calc((100% - var(--maxw, 1320px)) / 2));
}
/* injected breadcrumb (about-us / shipping / returns) has inline styles -> need !important */
.esw-bc {
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left:  max(28px, calc((100% - var(--maxw, 1320px)) / 2)) !important;
    padding-right: max(28px, calc((100% - var(--maxw, 1320px)) / 2)) !important;
}

/* shipping/returns: .esw-bc is nested INSIDE the rail-padded .page-main, so it must
   not add its own rail padding again (about-us keeps calc: its page-main pad=0). 2026-06-18 */
.cms-shipping-policy .esw-bc,
.cms-returns-refunds .esw-bc {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* privacy/terms: esw-bc nested inside rail-padded .page-main -> no extra side padding. 2026-06-18 */
.cms-privacy-policy .esw-bc,
.cms-terms-conditions .esw-bc {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* About Us — founder-row was a padded card (36px 40px) so its content sat ~40px
   right of the rail while Mission/Team/breadcrumb were on the rail. Drop the
   card chrome + horizontal padding so the founder content aligns to the rail
   like the other sections (keep vertical spacing). 2026-06-18 */
.cms-about-us .founder-row {
    padding-left: 0;
    padding-right: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    border-radius: 0;
}

/* FAQ — match about-us page chrome: full-bleed hero banner + rail content +
   styled esw-bc breadcrumb (native crumb hidden). 2026-06-18 */
body.cms-faq .columns,
body.cms-faq .column.main { max-width:none; width:100%; padding:0; margin:0; float:none; }
body.cms-faq .page-main { max-width:none; padding:0; }
body.cms-faq #maincontent { padding-top:0; }
body.cms-faq .breadcrumbs { display:none; }
.faq-hero{position:relative;width:100%;margin:0 0 36px;overflow:hidden;aspect-ratio:48/7;min-height:100px;display:flex;align-items:center;background:#14296b}
.faq-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.95}
.faq-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(20,41,107,.78) 0%, rgba(20,41,107,.55) 35%, rgba(20,41,107,.10) 65%, transparent 100%)}
.faq-hero .copy{position:relative;z-index:2;padding:0 clamp(20px,4vw,60px);color:#fff;max-width:62%}
.faq-hero h1{margin:0 0 10px;font-size:clamp(28px,4.2vw,52px);font-weight:800;line-height:1.05;letter-spacing:.3px}
.faq-hero p{margin:0;font-size:clamp(15px,1.8vw,22px);font-weight:500;opacity:.96;letter-spacing:.2px}
.faq-shell{ padding-left:max(28px, calc((100% - var(--maxw,1320px))/2)); padding-right:max(28px, calc((100% - var(--maxw,1320px))/2)); }
@media(max-width:880px){ .faq-hero{aspect-ratio:32/9;min-height:120px} .faq-hero .copy{max-width:100%} }

/* FAQ accordion — designed collapsible Q&A (native <details>, no JS). 2026-06-18 */
.faq-shell .faq-intro{color:#5b6472;font-size:15px;line-height:1.6;margin:0 0 26px}
.faq-shell .faq-intro a{color:#1465a8}
.faq-accordion{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.faq-item{background:#fff;border:1px solid #e3e6ef;border-radius:12px;overflow:hidden;transition:box-shadow .2s ease,border-color .2s ease}
.faq-item:hover{border-color:#cdd6ea}
.faq-item[open]{border-color:#bcd0ee;box-shadow:0 8px 24px rgba(20,41,107,.07)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:20px 24px;font-family:'Inter',system-ui,sans-serif;font-size:17px;font-weight:700;color:#14296b;line-height:1.35;user-select:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";flex:0 0 auto;width:16px;height:16px;transition:transform .25s ease;
  background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%231465a8" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"/></svg>') center/contain no-repeat}
.faq-item[open] summary::after{transform:rotate(180deg)}
.faq-item summary:hover{color:#1344b1}
.faq-answer{padding:4px 24px 22px}
.faq-answer p{margin:0;color:#000;font-size:15px;line-height:1.7}
.faq-answer a{color:#1465a8;text-decoration:underline;text-underline-offset:2px}
@media(max-width:600px){
  .faq-item summary{font-size:15.5px;padding:16px 18px}
  .faq-answer{padding:2px 18px 18px}
}

/* Policy pages with injected .esw-bc breadcrumb + .esw-policy <h1>: hide Magento's
   native breadcrumb + page-title to avoid the duplicate crumb/title. NOT payment-terms
   (it uses the native breadcrumb). 2026-06-18 */
body.cms-shipping-policy .breadcrumbs,
body.cms-returns-refunds .breadcrumbs,
body.cms-privacy-policy .breadcrumbs,
body.cms-terms-conditions .breadcrumbs,
body.cms-shipping-policy .page-title-wrapper,
body.cms-returns-refunds .page-title-wrapper,
body.cms-privacy-policy .page-title-wrapper,
body.cms-terms-conditions .page-title-wrapper {
    display: none !important;
}

/* space between breadcrumb (.esw-bc) and the page title on policy pages
   (native page-title removed left them tight). 2026-06-18 */
.cms-shipping-policy .esw-policy,
.cms-returns-refunds .esw-policy,
.cms-privacy-policy .esw-policy,
.cms-terms-conditions .esw-policy {
    padding-top: 22px;
}

/* Mobile menu drawer (Menu A) — main nav links at top of L1 (About, Quick Order
   Form, Catalog, FAQ, Blog, Contact Us) so they're reachable on mobile. 2026-06-19 */
.mm-nav{display:flex;flex-direction:column;padding:6px 0}
.mm-nav a{display:block;padding:13px 22px;font-size:14.5px;font-weight:600;color:var(--ink);border-bottom:1px solid #f0f2f7;text-decoration:none}
.mm-nav a:last-child{border-bottom:0}
.mm-nav a:hover{color:var(--blue);background:#f6f8fd}

/* ===== Footer A — accordion on mobile, 5-col grid on desktop (2026-06-20) ===== */
.ft-acc{min-width:0}
.ft-acc > summary{list-style:none;color:#fff;font-size:13px;font-weight:800;letter-spacing:.4px;text-transform:uppercase}
.ft-acc > summary::-webkit-details-marker{display:none}
.ft-acc > summary .pm{display:none}
/* Desktop / tablet: render like the original columns (always open, no toggle) */
@media (min-width:769px){
    .ft-acc > .inner{display:block !important}
    .ft-acc > summary{margin:0 0 12px;cursor:default}
}
/* Mobile: real collapsible accordion */
@media (max-width:768px){
    .ft .top{display:block}
    .ft .brand{text-align:center;display:flex;flex-direction:column;align-items:center;margin-bottom:6px}
    .ft .social,.ft .qr-stack{justify-content:center}
    .ft .qr-stack .qrcap{text-align:center}
    .ft-acc{border-top:1px solid rgba(255,255,255,.15)}
    .ft-acc > summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:15px 2px;margin:0}
    .ft-acc > summary .pm{display:block;position:relative;width:20px;height:20px;flex:none}
    .ft-acc > summary .pm::before,.ft-acc > summary .pm::after{content:"";position:absolute;background:#fdc700;transition:transform .2s ease}
    .ft-acc > summary .pm::before{top:9px;left:3px;width:14px;height:2px}
    .ft-acc > summary .pm::after{top:3px;left:9px;width:2px;height:14px}
    .ft-acc[open] > summary .pm::after{transform:scaleY(0)}
    .ft-acc > .inner{padding:0 2px 14px}
}

/* ============================================================
   Mobile header restructure (proposed mockup) — 2026-06-20.
   <=768px: hamburger + logo + account/cart in one compact row,
   full-width search below, quick-link chips replace the
   All-Categories bar. Desktop/tablet (>768px) unchanged.
   ============================================================ */
.h2-burger{display:none}
.h2-chips{display:none}
@media (max-width:768px){
  .h2-burger{display:inline-flex;align-items:center;justify-content:center;background:none;border:0;color:var(--navy);padding:4px;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .h2-burger svg{width:26px;height:26px;display:block}
  .h2-main{display:flex;flex-wrap:wrap;align-items:center;gap:10px 12px;padding:11px 0}
  .h2-main .h2-burger{order:0}
  .h2-main .h2-logo{order:1;margin-right:auto}
  .h2-main .h2-logo img{height:40px}
  .h2-main .h2-acts{order:2;gap:18px;justify-content:flex-end}
  .h2-main .h2-search{order:3;flex-basis:100%;width:100%;max-width:none;margin:0;box-sizing:border-box}
  /* compact account/wishlist/cart — icons only (labels hidden, dropdown menu unaffected) */
  .h2-acts > a{font-size:0;gap:0}
  .h2-account .h2-acct-trigger{font-size:0}
  .h2-acts > a .badge{font-size:11px}
  .h2-acct-chev{display:none}
  /* drop the old All-Categories bar; chips take its place */
  .h2-nav{display:none}
  .h2-chips{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:8px 16px 10px;border-top:1px solid var(--line)}
  .h2-chips::-webkit-scrollbar{display:none;height:0}
  .h2-chips a{flex:0 0 auto;background:#eef2fb;color:var(--navy);font-size:12px;font-weight:700;padding:7px 14px;border-radius:20px;white-space:nowrap;text-decoration:none}
}

/* mobile header acts — higher specificity to beat .cms-home pass-4 rules (2026-06-20) */
@media (max-width:768px){
  .h2-main .h2-acts > a,
  .h2-main .h2-account .h2-acct-trigger{font-size:0;gap:0}
  .h2-main .h2-acts > a .badge{font-size:11px}
  .h2-main .h2-acct-chev{display:none}
}

/* mobile burger: kill Magento's default button chrome (gray box/border) 2026-06-20 */
.h2-burger,.h2-burger:hover,.h2-burger:focus,.h2-burger:active{
  background:transparent !important;background-color:transparent !important;
  border:0 !important;box-shadow:none !important;border-radius:0 !important;outline:0 !important}
@media (max-width:768px){ .h2-main .h2-burger{padding:2px 4px} .h2-main .h2-burger svg{width:26px;height:26px} }

/* mobile header: restore the side padding my .h2-main flex rule had zeroed
   (cart was flush to the edge; search went edge-to-edge). 2026-06-20 */
@media (max-width:768px){ .h2-main{padding-left:28px;padding-right:28px} }
@media (max-width:480px){ .h2-main{padding-left:14px;padding-right:14px} }

/* Mobile search — Option 1: drop the "All Categories" scope on phones for a
   clean full-width search (desktop keeps the dropdown). 2026-06-20 */
@media (max-width:768px){
  .h2-search .eo-is-scope{display:none !important}
  /* autocomplete box must stay JS-controlled (do not hide) */
  .h2-search input{padding-left:14px}
}

/* Quick-link buttons — Option 6: soft white cards + gold icon (2026-06-21) */
@media (max-width:768px){
  .h2-chips{gap:9px;padding:10px 16px 12px}
  .h2-chips a{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--navy);
    font-size:12px;font-weight:800;padding:9px 15px;border-radius:9px;border:1px solid var(--line);
    box-shadow:0 2px 6px rgba(20,30,80,.07);white-space:nowrap;text-decoration:none}
  .h2-chips a .ql-ico{width:15px;height:15px;flex:none;color:var(--gold);fill:none;
    stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;display:block}
  .h2-chips a:active{background:var(--navy);color:#fff}
}

/* ===== Header parity: apply the homepage's compact mobile header to ALL pages
   (these tweaks were previously scoped to .cms-home, so subcategory/other pages
   diverged — bigger account/cart icons, taller search). 2026-06-21 ===== */
@media (max-width:480px){
  .h2-top{font-size:12px}
  .h2-top-in{padding-top:6px;padding-bottom:6px;gap:6px 10px;justify-content:center}
  .h2-top .w9{padding:5px 14px;font-size:12px}
  .h2-main{gap:10px;padding-top:8px;padding-bottom:10px}
  .h2-main .h2-search{height:42px}
  .h2-acts svg{width:24px;height:24px}
}

/* === Fix (2026-06-22): active account-nav item on order detail/shipment pages is
   rendered <li.current><a><strong>My Orders</strong></a>; the nested <strong> took
   green text via '.item.current strong', i.e. green-on-green = an empty-looking pill.
   On the history page it is <li.current><strong> (matched by '> strong', white).
   Force the nested strong white so it shows on the green pill. === */
.account .block-collapsible-nav .item.current > a strong,
.account .account-nav .item.current > a strong {
    color: #fff !important;
    background: transparent !important;
}

/* ===== Option D sticky header (two-tier: promo strip + compact bar) — mobile. 2026-06-22 ===== */
.pill-promo{display:none}
@media (max-width:768px){
  /* the floating pill becomes a full-width two-tier bar */
  .h2-pill{left:0;right:0;top:0;width:100%;transform:translateY(-170%)}
  .h2-pill.show{transform:translateY(0)}
  /* tier 1: promo strip (free shipping + phone) */
  .pill-promo{display:flex;align-items:center;justify-content:center;gap:12px;background:var(--navy);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;white-space:nowrap}
  .pill-promo strong{color:var(--gold)}
  .pill-promo .pp-sep{opacity:.5}
  .pill-promo .pp-phone{color:#fff;text-decoration:none}
  /* tier 2: bar — order ☰ + logo + search + cart */
  .h2-pill .h2-pill-in{border-radius:0;box-shadow:none;border:0;border-bottom:1px solid var(--line);gap:9px;padding:7px 12px}
  .h2-pill .pill-cats{order:0;background:none !important;color:var(--navy);padding:2px !important}
  .h2-pill .pill-cats svg{width:23px;height:23px}
  .h2-pill .pill-logo{order:1}
  .h2-pill .pill-logo img{height:22px}
  .h2-pill .pill-search{order:2;height:34px;min-width:0}
  .h2-pill .pill-search input{padding-left:14px}
  .h2-pill .pill-search button{padding:0 14px}
  .h2-pill .pill-search .eo-is-scope{display:none !important}
  .h2-pill .pill-fship{display:none}
  .h2-pill .pill-cart{order:3;width:34px;height:34px}
}

/* ===== Slider cards (.bts-*) mobile: compact swipe cards + full-width Add to Cart
   + Wishlist/Share/Compare BELOW it (match the approved subcategory cards). 2026-06-23 ===== */
@media (max-width:768px){
  .bts-card{flex:0 0 74% !important;max-width:270px !important;min-width:0}
  .bts-photo{aspect-ratio:1/1 !important;height:auto !important;min-height:0 !important}
  .bts-photo img{width:100% !important;height:100% !important;object-fit:contain !important}
  /* stack the bottom row */
  .bts-bottom{flex-direction:column !important;align-items:stretch !important;gap:10px !important;flex-wrap:nowrap !important}
  .bts-add-form{width:100% !important;margin:0 !important}
  .bts-add{width:100% !important;justify-content:center !important;text-align:center !important}
  .bts-actions{margin-left:0 !important;justify-content:space-around !important;width:100% !important}
}

/* 2026-06-23: round the MAIN header search corners to match the sticky pill header (.pill-search). Corners only — no size/color/layout change. */
.h2-search{border-radius:999px}
.h2-search .eo-is-scope{border-radius:999px 0 0 999px}
.h2-search button{border-radius:0 999px 999px 0}

/* 2026-06-23: payment-terms redesigned to match FAQ/about chrome
   (full-bleed hero banner + styled breadcrumb + rail shell). */
body.cms-payment-terms .column.main { max-width:none; width:100%; padding:0; margin:0; float:none; }
body.cms-payment-terms .page-main { max-width:none; padding:0; }
body.cms-payment-terms #maincontent { padding-top:0; }
body.cms-payment-terms .breadcrumbs { display:none; }
.pt-hero{position:relative;width:100%;margin:0 0 36px;overflow:hidden;aspect-ratio:48/7;min-height:100px;display:flex;align-items:center;background:#14296b}
.pt-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.95}
.pt-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(20,41,107,.78) 0%, rgba(20,41,107,.55) 35%, rgba(20,41,107,.10) 65%, transparent 100%)}
.pt-hero .copy{position:relative;z-index:2;padding:0 max(28px, calc((100% - var(--maxw,1320px))/2));color:#fff;max-width:62%}
.pt-hero h1{margin:0 0 10px;font-size:clamp(28px,4.2vw,52px);font-weight:800;line-height:1.05;letter-spacing:.3px}
.pt-hero p{margin:0;font-size:clamp(15px,1.8vw,22px);font-weight:500;opacity:.96;letter-spacing:.2px}
.pt-shell{padding-left:max(28px, calc((100% - var(--maxw,1320px))/2));padding-right:max(28px, calc((100% - var(--maxw,1320px))/2));padding-bottom:48px}
.pt-shell .esw-policy h2{font-family:'Inter',system-ui,sans-serif}
@media (max-width:600px){.pt-hero{aspect-ratio:32/9;min-height:120px}.pt-hero .copy{max-width:100%}}

/* 2026-06-23 payment-terms refinements: white hero subtitle (global p color was overriding) + proper breadcrumb->content spacing to match about-us (~36px) */
.pt-hero .copy h1, .pt-hero .copy p{color:#fff !important}
.pt-shell{padding-top:22px}

/* 2026-06-23: shipping/returns/privacy/terms get the same hero chrome as payment-terms/FAQ.
   Previously rail-padded .page-main + .esw-bc forced to padding:0; switch to full-bleed
   page-main (for the hero) + rail shell + restore esw-bc's own rail. */
body.cms-shipping-policy .page-main, body.cms-returns-refunds .page-main,
body.cms-privacy-policy .page-main, body.cms-terms-conditions .page-main { max-width:none; padding:0; }
body.cms-shipping-policy .column.main, body.cms-returns-refunds .column.main,
body.cms-privacy-policy .column.main, body.cms-terms-conditions .column.main { max-width:none; width:100%; padding:0; margin:0; float:none; }
body.cms-shipping-policy #maincontent, body.cms-returns-refunds #maincontent,
body.cms-privacy-policy #maincontent, body.cms-terms-conditions #maincontent { padding-top:0; }
body.cms-shipping-policy .esw-bc, body.cms-returns-refunds .esw-bc,
body.cms-privacy-policy .esw-bc, body.cms-terms-conditions .esw-bc {
  padding-left: max(28px, calc((100% - var(--maxw,1320px))/2)) !important;
  padding-right: max(28px, calc((100% - var(--maxw,1320px))/2)) !important;
}
.policy-hero{position:relative;width:100%;margin:0 0 36px;overflow:hidden;aspect-ratio:48/7;min-height:100px;display:flex;align-items:center;background:#14296b}
.policy-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.95}
.policy-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(20,41,107,.78) 0%, rgba(20,41,107,.55) 35%, rgba(20,41,107,.10) 65%, transparent 100%)}
.policy-hero .copy{position:relative;z-index:2;padding:0 max(28px, calc((100% - var(--maxw,1320px))/2));max-width:62%}
.policy-hero .copy h1, .policy-hero .copy p{color:#fff !important}
.policy-hero h1{margin:0 0 10px;font-size:clamp(28px,4.2vw,52px);font-weight:800;line-height:1.05;letter-spacing:.3px}
.policy-hero p{margin:0;font-size:clamp(15px,1.8vw,22px);font-weight:500;opacity:.96;letter-spacing:.2px}
.policy-shell{padding-left:max(28px, calc((100% - var(--maxw,1320px))/2));padding-right:max(28px, calc((100% - var(--maxw,1320px))/2));padding-top:22px;padding-bottom:48px}
@media (max-width:600px){.policy-hero{aspect-ratio:32/9;min-height:120px}.policy-hero .copy{max-width:100%}}

/* 2026-06-23: space between FAQ breadcrumb and content (matches payment-terms/policy pages) */
.faq-shell{padding-top:22px}

/* Account trigger hover fix — suppress Luma's default grey button box; match the
   other header actions (transparent) with a subtle opacity cue. Added 2026-06-24 */
.h2-acct-trigger,
.h2-acct-trigger:hover,
.h2-acct-trigger:focus,
.h2-acct-trigger:active,
.h2-acct-trigger:focus:active{
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    outline:none !important;
    color:var(--navy);
}
.h2-acct-trigger{transition:opacity .15s ease}
.h2-acct-trigger:hover{opacity:.72}

/* US-only store: hide the Country selector at checkout (defaults to United States). 2026-06-24 */
.checkout-index-index .field[name$=".country_id"],
.checkout-index-index .field.country,
.checkout-shipping-address .field[name$="country_id"],
.opc-wrapper .field[name$="country_id"]{display:none !important;}

/* Wishlist: rail-align body to the header/footer content rail (2026-06-24) */
body.wishlist-index-index .page-main{
    max-width:none;margin-left:0;margin-right:0;
    padding-left:max(28px,calc((100% - 1320px)/2));
    padding-right:max(28px,calc((100% - 1320px)/2));
}

/* Tax exemption note in order summary (checkout + cart) */
.totals-tax .mc-tax-exempt{color:#1a7a3c;font-style:italic;font-weight:600;font-size:13px;white-space:nowrap;}

.ft .ft-subhead{margin-top:24px}

/* Account dropdown rows — left-aligned with icon chip + chevron (match approved
   account-dropdown-final.html mockup). Fixes inherited flex-direction:column from
   .h2-acts a (line ~50). 2026-06-25 */
.h2-acct-menu a[role=menuitem]{
    flex-direction:row;
    justify-content:flex-start;
    align-items:center;
    text-align:left;
    gap:11px;
    padding:9px 10px;
}
.h2-acct-menu a[role=menuitem] > svg{
    width:34px;height:34px;flex:0 0 34px;
    padding:8px;background:#eef3ff;border-radius:9px;box-sizing:border-box;
    stroke:#1344b1;
}
.h2-acct-menu a[role=menuitem]::after{
    content:"\203A";
    margin-left:auto;color:#c2cad8;font-size:17px;font-weight:700;line-height:1;
}
.h2-acct-menu a.out[role=menuitem]::after{content:none}
.h2-acct-menu a.out[role=menuitem] > svg{background:#fdeceb;stroke:#bc1212}

/* Order success page: rail-align body to header/footer content rail + spacing (2026-06-25) */
body.checkout-onepage-success .page-main{
    max-width:none;margin-left:0;margin-right:0;
    padding-left:max(28px,calc((100% - 1320px)/2));
    padding-right:max(28px,calc((100% - 1320px)/2));
}
body.checkout-onepage-success .column.main{padding-top:28px;padding-bottom:48px}

/* Show "Apply Discount Code" on the cart page so customers can enter private/
   winner codes (was hidden when the available-coupons list is shown). 2026-06-25 */
.checkout-cart-index .mconnect-available-coupons + #block-discount > .title{display:block !important}

/* 2026-06-25: Offers card owns code entry -> hide native checkout "Apply Discount Code" in the
   order summary (sidebar + modal) when offers exist; body.mac-has-offers set by the Offers component. */
body.mac-has-offers.checkout-index-index .opc-block-summary .payment-option.discount-code { display: none !important; }

/* 2026-06-26: rail-align the customer dashboard (account) pages — sidebar + content + breadcrumb
   edges match the header/footer 28px rail at all widths (same technique as the login page). */
.account .page-main,
.account .breadcrumbs {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left:  max(28px, calc((100% - var(--maxw, 1320px)) / 2));
    padding-right: max(28px, calc((100% - var(--maxw, 1320px)) / 2));
}

/* 2026-06-26: account pages — match the header 14px rail on small phones */
@media (max-width:480px){
    .account .page-main, .account .breadcrumbs { padding-left:14px; padding-right:14px; }
}
