/* acasa365 — store styles */
:root{
  --ink:#15181E; --ink-2:#2A2F3A; --muted:#5B6472; --muted-2:#8A92A0;
  --line:#E5E8EC; --line-2:#EEF1F4; --paper:#F4F6F8; --paper-2:#EFF2F5; --surface:#FFFFFF;
  --accent:#F26522; --accent-d:#D2500F; --accent-soft:#FFF1E9; --accent-ink:#FFFFFF; --accent-lite:#FF8A4C;
  --navy:#16202E; --hero1:#1B2735; --hero2:#2D4256; --glow:rgba(242,101,34,.55);
  --fb1:#0E7E9B; --fb2:#13A6C2;
  --ok:#16A34A; --ok-soft:#E7F6EC; --sale:#E11D2E; --sale-soft:#FDECEE; --gold:#E8A317;
  --radius:12px; --radius-s:8px; --radius-l:18px; --radius-pill:999px;
  --shadow-1:0 1px 2px rgba(20,24,30,.05), 0 1px 3px rgba(20,24,30,.04);
  --shadow-2:0 6px 22px rgba(20,24,30,.10);
  --shadow-3:0 18px 50px rgba(20,24,30,.20);
  --container:1240px; --gutter:24px;
  --ease:cubic-bezier(.2,.7,.2,1); --dur:.18s;
  --fs:15px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,sans-serif; color:var(--ink); background:var(--surface);
  font-size:var(--fs); line-height:1.5; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Archivo','Inter',sans-serif; margin:0; line-height:1.08; letter-spacing:-.01em;}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:none; background:none}
img{display:block; max-width:100%}
.wrap{max-width:var(--container); margin:0 auto; padding:0 var(--gutter)}
.mono{font-family:'JetBrains Mono',monospace}
.eyebrow{font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent)}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--navy); color:#D7DEE8; font-size:12.5px}
.topbar .wrap{display:flex; align-items:center; gap:28px; height:38px}
.topbar .promos{display:flex; align-items:center; gap:26px; overflow:hidden}
.topbar .promo{display:flex; align-items:center; gap:8px; white-space:nowrap}
.topbar .promo svg{color:var(--accent); flex:none}
.topbar .promo b{color:#fff; font-weight:600}
.topbar .right{margin-left:auto; display:flex; align-items:center; gap:20px}
.topbar .right a{display:flex; align-items:center; gap:6px; color:#C3CCD8; transition:color var(--dur)}
.topbar .right a:hover{color:#fff}

/* ---------- Header ---------- */
.header{background:var(--surface); border-bottom:1px solid var(--line); position:sticky; top:0; z-index:60}
.header .wrap{display:flex; align-items:center; gap:28px; height:84px}
.logo{display:flex; align-items:center; gap:11px; flex:none}
.logo .mark{width:44px; height:44px; border-radius:50%; background:var(--accent); display:grid; place-items:center; color:#fff; box-shadow:var(--shadow-1)}
.logo .wordmark{font-family:'Archivo',sans-serif; font-weight:800; font-size:24px; letter-spacing:-.02em; color:var(--ink); line-height:1}
.logo .wordmark .o{color:var(--accent)}
.logo .tag{font-size:10.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); margin-top:3px}

.searchbar{flex:1; max-width:620px; display:flex; align-items:stretch; height:48px; position:relative;
  border:1.5px solid var(--line); border-radius:var(--radius); transition:border-color var(--dur),box-shadow var(--dur); background:var(--surface)}
.searchbar:focus-within{border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.searchbar .scope{display:flex; align-items:center; gap:6px; padding:0 14px; background:var(--paper);
  border-right:1px solid var(--line); border-radius:var(--radius) 0 0 var(--radius); font-size:13.5px; font-weight:600; color:var(--ink-2); white-space:nowrap}
.searchbar input{flex:1; border:none; outline:none; padding:0 14px; font-size:14.5px; background:transparent; color:var(--ink)}
.searchbar input::placeholder{color:var(--muted-2)}
.searchbar .go{width:54px; background:var(--accent); color:#fff; display:grid; place-items:center; border-radius:0 var(--radius) var(--radius) 0; transition:background var(--dur)}
.searchbar .go:hover{background:var(--accent-d)}
.search-sugg{position:absolute; top:calc(100% + 7px); left:0; right:0; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow-3); z-index:70; padding:6px}
.ss-item{display:flex; align-items:center; gap:12px; padding:9px 11px; border-radius:var(--radius-s); transition:background var(--dur)}
.ss-item:hover{background:var(--paper)}
.ss-img{width:40px; height:40px; border-radius:7px; background:var(--paper); display:grid; place-items:center; color:var(--muted-2); flex:none; overflow:hidden}
.ss-img img{width:100%; height:100%; object-fit:contain; padding:3px}
.ss-name{flex:1; font-size:13.5px; font-weight:500; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.ss-price{font-size:13px; font-weight:800; color:var(--ink); flex:none}
.ss-all{width:100%; display:flex; align-items:center; justify-content:center; gap:8px; padding:11px; margin-top:4px; border-top:1px solid var(--line-2);
  font-size:13px; font-weight:700; color:var(--accent); background:var(--accent-soft); border-radius:var(--radius-s)}
.ss-all:hover{background:var(--accent); color:#fff}
.search-head{margin:6px 0 22px}
.search-head h1{font-size:30px; font-weight:800; letter-spacing:-.02em; margin-bottom:14px}
.search-bigbar{display:flex; align-items:center; gap:12px; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--radius); padding:0 8px 0 16px; height:54px; max-width:640px; color:var(--muted)}
.search-bigbar:focus-within{border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.search-bigbar input{flex:1; border:none; outline:none; font-size:15px; font-family:inherit; background:transparent; color:var(--ink); height:100%}
.search-bigbar .btn{height:40px}
.search-meta{margin-top:12px; font-size:14px; color:var(--muted)}

.head-actions{margin-left:auto; display:flex; align-items:center; gap:6px}
.iconbtn{display:flex; flex-direction:column; align-items:center; gap:3px; padding:8px 12px; border-radius:var(--radius-s);
  color:var(--ink-2); transition:background var(--dur),color var(--dur); position:relative; min-width:62px}
.iconbtn:hover{background:var(--paper); color:var(--accent)}
.iconbtn .lbl{font-size:11.5px; font-weight:600}
.iconbtn .badge{position:absolute; top:2px; right:12px; background:var(--accent); color:#fff;
  font-size:10.5px; font-weight:800; min-width:18px; height:18px; border-radius:9px; display:grid; place-items:center; padding:0 4px; font-family:'Inter'}
.iconbtn.cart .ct{display:flex; flex-direction:column; align-items:flex-start; line-height:1.1}
.iconbtn.cart{flex-direction:row; gap:9px; min-width:auto; padding:8px 14px; background:var(--paper); border-radius:var(--radius); position:relative; z-index:92}
.iconbtn.cart:hover{background:var(--accent-soft)}
.iconbtn.cart .ct .t{font-size:11px; color:var(--muted); font-weight:600}
.iconbtn.cart .ct .v{font-size:14px; font-weight:800; color:var(--ink)}

/* ---------- Nav / mega menu ---------- */
.nav{background:var(--surface); border-bottom:1px solid var(--line); position:sticky; top:84px; z-index:55}
.nav .wrap{display:flex; align-items:center; gap:4px; height:52px}
.allcats{display:flex; align-items:center; gap:10px; background:var(--accent); color:#fff; font-weight:700;
  font-size:14px; padding:0 18px; height:52px; transition:background var(--dur)}
.allcats:hover,.allcats.open{background:var(--accent-d)}
.navlink{display:flex; align-items:center; gap:7px; padding:0 14px; height:52px; font-weight:600; font-size:14px;
  color:var(--ink-2); position:relative; transition:color var(--dur)}
.navlink:hover{color:var(--accent)}
.navlink.sale{color:var(--sale)}
.navlink::after{content:''; position:absolute; left:14px; right:14px; bottom:0; height:2.5px; background:var(--accent);
  transform:scaleX(0); transform-origin:left; transition:transform var(--dur) var(--ease)}
.navlink:hover::after{transform:scaleX(1)}
.nav .phone{margin-left:auto; display:flex; align-items:center; gap:8px; font-weight:700; color:var(--ink)}
.nav .phone svg{color:var(--accent)}
.nav .phone span{font-size:11px; color:var(--muted); font-weight:600; display:block}

.mega-overlay{position:fixed; inset:0; background:transparent; z-index:50; opacity:0; pointer-events:none; transition:opacity var(--dur)}
.mega-overlay.show{opacity:1; pointer-events:auto}
.mega{position:absolute; left:0; right:0; top:100%; background:var(--surface); z-index:56; display:grid; grid-template-columns:300px 1fr;
  max-height:0; overflow:hidden; transition:max-height .26s var(--ease)}
.mega.show{max-height:520px; border-top:1px solid var(--line); box-shadow:var(--shadow-2)}
.mega .col-list{background:var(--paper); padding:12px; border-right:1px solid var(--line)}
.mega .cat-row{display:flex; align-items:center; gap:12px; padding:11px 13px; border-radius:var(--radius-s);
  font-weight:600; font-size:14px; color:var(--ink-2); cursor:pointer; transition:background var(--dur)}
.mega .cat-row .ci{width:30px; height:30px; border-radius:8px; display:grid; place-items:center; flex:none; color:#fff}
.mega .cat-row.active,.mega .cat-row:hover{background:var(--surface); color:var(--ink); box-shadow:var(--shadow-1)}
.mega .cat-row .ch{margin-left:auto; color:var(--muted-2)}
.mega .panel{padding:26px 30px; overflow:auto}
.mega .panel h4{font-size:17px; margin-bottom:4px}
.mega .panel .ph-sub{color:var(--muted); font-size:13px; margin-bottom:18px}
.mega .sub-grid{columns:3; column-gap:24px}
.mega .sub-grid a{display:block; padding:7px 0; font-size:13.5px; color:var(--ink-2); break-inside:avoid; transition:color var(--dur)}
.mega .sub-grid a:hover{color:var(--accent)}
.mega .sub-grid a::before{content:'›'; color:var(--muted-2); margin-right:8px}
.mega .panel-foot{margin-top:18px; padding-top:16px; border-top:1px solid var(--line); display:flex; align-items:center; gap:10px}

/* ---------- Hero carousel ---------- */
.hero{padding:30px 0 8px}
.hero-tools{display:flex; justify-content:flex-end; margin-bottom:10px}
.edit-toggle{display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:var(--muted);
  padding:8px 14px; border:1.5px solid var(--line); border-radius:var(--radius-pill); background:var(--surface);
  transition:all var(--dur)}
.edit-toggle:hover{border-color:var(--accent); color:var(--accent)}
.edit-toggle.on{background:var(--accent); border-color:var(--accent); color:#fff}
.carousel{position:relative; height:190px; border-radius:var(--radius-l); overflow:hidden; box-shadow:var(--shadow-1)}
.carousel .track{display:flex; height:100%; transition:transform .55s var(--ease)}
.cslide{min-width:100%; height:100%; position:relative; display:flex; align-items:center;
  justify-content:space-between; gap:30px; padding:0 64px; color:#fff; overflow:hidden}
.cslide.dark{background:linear-gradient(120deg,var(--hero1),var(--hero2))}
.cslide.sano{background:linear-gradient(120deg,var(--fb1),var(--fb2))}
.cslide.cat{background:linear-gradient(120deg,var(--accent),var(--accent-lite))}
.cslide.text-dark{color:var(--ink)}
.cslide.has-image .c-deco{display:none}
.cslide .editable{outline:2px dashed rgba(255,255,255,.55); outline-offset:3px; border-radius:3px; cursor:text;
  min-width:14px; display:inline-block; transition:outline-color var(--dur)}
.cslide.text-dark .editable{outline-color:rgba(20,24,30,.35)}
.cslide .editable:focus{outline-style:solid; outline-color:#fff}
.cslide.text-dark .editable:focus{outline-color:var(--ink)}
.cslide .c-art{position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 2px, transparent 2px 22px);}
.cslide.dark .c-art{background:
   radial-gradient(160px 160px at 80% 18%, var(--glow), transparent 70%),
   repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 2px, transparent 2px 22px);}
.cslide .c-deco{position:absolute; right:188px; top:50%; transform:translateY(-50%); opacity:.16; pointer-events:none}
.cslide .c-inner{position:relative; z-index:2; max-width:640px}
.cslide .c-kick{display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:800;
  letter-spacing:.12em; text-transform:uppercase; opacity:.92; margin-bottom:11px}
.cslide h2{font-size:28px; font-weight:800; letter-spacing:-.02em; line-height:1.1; max-width:600px}
.cslide .c-cta{position:relative; z-index:2; flex:none}
.carousel .c-arrow{position:absolute; top:50%; transform:translateY(-50%); width:32px; height:48px;
  display:grid; place-items:center; color:#fff; background:none; box-shadow:none; z-index:5;
  filter:drop-shadow(0 1px 4px rgba(0,0,0,.4)); opacity:.85; transition:opacity var(--dur),transform var(--dur)}
.carousel .c-arrow:hover{opacity:1; transform:translateY(-50%) scale(1.14)}
.carousel .c-arrow.prev{left:10px}
.carousel .c-arrow.next{right:10px}
.carousel .dots{position:absolute; bottom:15px; left:64px; display:flex; gap:7px; z-index:5}
.carousel .dot{width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.5); cursor:pointer;
  border:none; padding:0; transition:all var(--dur)}
.carousel .dot.active{background:#fff; width:24px; border-radius:4px}
@media(max-width:820px){
  .carousel{height:auto; min-height:172px}
  .cslide{padding:0 40px} .cslide h2{font-size:19px} .cslide .c-deco{display:none}
  .carousel .dots{left:40px}
}
.btn{display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:14.5px; border-radius:var(--radius);
  padding:13px 22px; transition:background var(--dur),color var(--dur),transform var(--dur); white-space:nowrap}
.btn-primary{background:var(--accent); color:#fff}
.btn-primary:hover{background:var(--accent-d)}
.btn-light{background:#fff; color:var(--ink)}
.btn-light:hover{background:var(--paper)}
.btn-ghost{background:transparent; border:1.5px solid var(--line); color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent)}
.btn-dark{background:var(--ink); color:#fff}
.btn-dark:hover{background:var(--ink-2)}
.btn:active{transform:translateY(1px)}

/* ---------- Trust row ---------- */
.trust{display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line);
  border-radius:var(--radius); margin-top:22px; overflow:hidden; background:var(--surface)}
.trust .t{display:flex; align-items:center; gap:14px; padding:18px 22px; border-right:1px solid var(--line)}
.trust .t:last-child{border-right:none}
.trust .t .ic{width:42px; height:42px; border-radius:11px; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; flex:none}
.trust .t .ttl{font-weight:700; font-size:14px}
.trust .t .sub{font-size:12.5px; color:var(--muted)}

/* ---------- Section headers ---------- */
.section{padding:46px 0}
.sec-head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:24px; gap:20px}
.sec-head h2{font-size:30px; font-weight:800; letter-spacing:-.025em}
.sec-head .sub{color:var(--muted); font-size:14.5px; margin-top:7px}
.sec-head .more{display:inline-flex; align-items:center; gap:7px; font-weight:700; color:var(--ink); font-size:14px; white-space:nowrap}
.sec-head .more:hover{color:var(--accent)}

/* ---------- Category tiles ---------- */
.cat-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.cat-tile{display:flex; align-items:center; gap:16px; padding:18px 20px; border:1px solid var(--line);
  border-radius:var(--radius); background:var(--surface); transition:border-color var(--dur),box-shadow var(--dur),transform var(--dur); cursor:pointer}
.cat-tile:hover{border-color:transparent; box-shadow:var(--shadow-2); transform:translateY(-2px)}
.cat-tile .ci{width:52px; height:52px; border-radius:13px; display:grid; place-items:center; color:#fff; flex:none}
.cat-tile .nm{font-weight:700; font-size:15px; line-height:1.2}
.cat-tile .ct{font-size:12.5px; color:var(--muted); margin-top:3px}
.cat-tile .arr{margin-left:auto; color:var(--muted-2); transition:transform var(--dur),color var(--dur)}
.cat-tile:hover .arr{transform:translateX(3px); color:var(--accent)}

/* ---------- Filter chips ---------- */
.chips{display:flex; flex-wrap:wrap; gap:9px; margin-bottom:24px}
.chip{padding:9px 16px; border-radius:var(--radius-pill); border:1.5px solid var(--line); font-weight:600;
  font-size:13.5px; color:var(--ink-2); background:var(--surface); transition:all var(--dur)}
.chip:hover{border-color:var(--accent); color:var(--accent)}
.chip.active{background:var(--ink); border-color:var(--ink); color:#fff}

/* ---------- Product card ---------- */
.prod-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.card{border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); overflow:hidden;
  display:flex; flex-direction:column; transition:border-color var(--dur),box-shadow var(--dur); position:relative}
.card:hover{box-shadow:var(--shadow-2); border-color:transparent}
.card .media{position:relative; aspect-ratio:1/1; background:var(--paper); display:grid; place-items:center; overflow:hidden}
.card .media .ph{width:62%; height:62%; opacity:.5; color:var(--ink-2); display:grid; place-items:center}
.card .media .ph svg{width:100%; height:100%}
.card .media:has(img)::after{display:none}
.card .media::after{content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(60% 60% at 50% 40%, rgba(255,255,255,.6), transparent)}
.card .badges{position:absolute; top:12px; left:12px; display:flex; flex-direction:column; gap:6px; z-index:2}
.bdg{font-size:11px; font-weight:800; letter-spacing:.03em; text-transform:uppercase; padding:4px 9px; border-radius:6px; color:#fff}
.bdg.nou{background:var(--ok)} .bdg.redus{background:var(--sale)} .bdg.best{background:var(--gold)}
.card .wish{position:absolute; top:12px; right:12px; width:36px; height:36px; border-radius:50%; background:#fff;
  box-shadow:var(--shadow-1); display:grid; place-items:center; color:var(--muted); z-index:2; transition:color var(--dur),transform var(--dur)}
.card .wish:hover{color:var(--sale); transform:scale(1.08)}
.card .wish.on{color:var(--sale)} .card .wish.on svg{fill:var(--sale)}
.card .wish[data-tip]::after{content:attr(data-tip); position:absolute; top:50%; right:calc(100% + 8px); transform:translateY(-50%);
  background:var(--accent); color:#fff; font-size:11.5px; font-weight:600; padding:5px 9px; border-radius:6px; white-space:nowrap;
  opacity:0; pointer-events:none; transition:opacity var(--dur); z-index:5}
.card .wish:hover[data-tip]::after{opacity:1}
.card .body{padding:15px 15px 16px; display:flex; flex-direction:column; flex:1}
.card .brand{font-size:11px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--muted-2)}
.card .pname{font-weight:600; font-size:14px; line-height:1.32; margin:6px 0 8px; color:var(--ink); min-height:37px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.card .pname:hover{color:var(--accent)}
.card .rate{display:flex; align-items:center; gap:5px; font-size:12px; color:var(--muted); margin-bottom:12px}
.card .rate .stars{display:flex; color:var(--gold)}
.card .meta{display:flex; align-items:center; gap:7px; font-size:11px; color:var(--muted-2); margin-bottom:11px}
.card .sku{font-family:'JetBrains Mono'}
.card .stk{display:inline-flex; align-items:center; gap:5px; color:var(--ok); font-weight:600}
.card .stk.low{color:var(--gold)}
.card .stk.out{color:var(--sale)}
.card .stk i{width:7px; height:7px; border-radius:50%; background:currentColor; display:inline-block}
.card .foot{margin-top:auto; display:flex; align-items:flex-end; justify-content:space-between; gap:10px}
.card .price{display:flex; flex-direction:column}
.card .price .old{font-size:12.5px; color:var(--muted-2); text-decoration:line-through; font-weight:600}
.card .price .now{font-size:20px; font-weight:800; color:var(--ink); letter-spacing:-.02em; font-family:'Archivo'}
.card .price .tva{font-size:11px; color:var(--muted); font-weight:600}
.card .add{width:46px; height:46px; border-radius:var(--radius-s); background:var(--accent); color:#fff;
  display:grid; place-items:center; flex:none; transition:background var(--dur),transform var(--dur)}
.card .add:hover{background:var(--accent-d)}
.card .add:active{transform:scale(.92)}
.card .add.done{background:var(--ok)}

/* ---------- Full-bleed promo ---------- */
.bleed{background:var(--navy); color:#fff; overflow:hidden; position:relative}
.bleed .wrap{display:grid; grid-template-columns:1.1fr 1fr; align-items:center; gap:40px; padding:8px 24px}
.bleed .copy{padding:54px 0}
.bleed .copy .eyebrow{color:var(--accent-lite)}
.bleed .copy h2{font-size:38px; font-weight:800; letter-spacing:-.025em; margin:14px 0 14px; max-width:480px; line-height:1.05}
.bleed .copy p{color:#B9C4D0; font-size:16px; max-width:440px; margin:0 0 26px}
.bleed .art2{position:relative; min-height:300px; display:grid; place-items:center}
.bleed .art2 .ring{position:absolute; border:1.5px solid rgba(255,255,255,.12); border-radius:50%}
.bleed .art2 .badge-spec{background:var(--accent); color:#fff; border-radius:var(--radius-l); padding:30px 34px; box-shadow:var(--shadow-3); text-align:center}
.bleed .art2 .badge-spec .big{font-size:54px; font-weight:900; font-family:'Archivo'; line-height:1}
.bleed .art2 .badge-spec .sm{font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-top:6px; opacity:.92}

/* ---------- Brands ---------- */
.brand-grid{display:grid; grid-template-columns:repeat(6,1fr); gap:14px}
.brand-cell{height:84px; padding:14px 20px; box-sizing:border-box; border:1px solid var(--line); border-radius:var(--radius); display:grid; place-items:center;
  background:var(--surface); transition:border-color var(--dur),box-shadow var(--dur); cursor:pointer}
.brand-cell:hover{box-shadow:var(--shadow-1); border-color:transparent}
.brand-cell .bn{font-family:'Archivo'; font-weight:800; font-size:17px; letter-spacing:.02em; filter:grayscale(.15)}
.brand-cell img{max-width:100%; max-height:44px; width:auto; height:auto; object-fit:contain; display:block}

/* ---------- Blog ---------- */
.blog-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.post{border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--surface);
  transition:box-shadow var(--dur),border-color var(--dur); cursor:pointer}
.post:hover{box-shadow:var(--shadow-2); border-color:transparent}
.post .pmedia{height:170px; position:relative; display:grid; place-items:center; color:#fff}
.post .pmedia .tg{position:absolute; top:14px; left:14px; background:rgba(255,255,255,.95); color:var(--ink);
  font-size:11px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; padding:5px 11px; border-radius:6px}
.post .pbody{padding:20px}
.post .pdate{font-size:12px; color:var(--muted-2); font-weight:600; margin-bottom:9px}
.post h3{font-size:17px; font-weight:800; line-height:1.22; letter-spacing:-.015em; margin-bottom:10px}
.post:hover h3{color:var(--accent)}
.post p{font-size:13.5px; color:var(--muted); line-height:1.5}
.post .rd{display:inline-flex; align-items:center; gap:7px; font-weight:700; font-size:13px; color:var(--accent); margin-top:14px}

/* ---------- Catalog + newsletter ---------- */
.dual{display:grid; grid-template-columns:1fr 1fr; gap:20px}
.panel-cat{background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-l); padding:38px 40px; display:flex; align-items:center; gap:26px}
.panel-cat .doc{width:88px; height:108px; border-radius:10px; background:var(--surface); border:1px solid var(--line);
  box-shadow:var(--shadow-2); display:grid; place-items:center; color:var(--accent); flex:none; position:relative}
.panel-cat .doc::before{content:''; position:absolute; inset:8px; border:1.5px dashed var(--line-2); border-radius:6px}
.panel-cat h3{font-size:24px; font-weight:800; letter-spacing:-.02em; margin-bottom:8px}
.panel-cat p{color:var(--muted); font-size:14px; margin-bottom:18px}
.panel-news{background:var(--accent); color:#fff; border-radius:var(--radius-l); padding:38px 40px; position:relative; overflow:hidden}
.panel-news .eyebrow{color:rgba(255,255,255,.85)}
.panel-news h3{font-size:24px; font-weight:800; letter-spacing:-.02em; margin:12px 0 8px}
.panel-news p{font-size:14px; opacity:.92; margin-bottom:18px; max-width:340px}
.news-form{display:flex; gap:10px; max-width:430px}
.news-form input{flex:1; height:50px; border:none; border-radius:var(--radius); padding:0 16px; font-size:14.5px; font-family:inherit; outline:none}
.news-form .sb{background:var(--ink); color:#fff; height:50px}
.panel-news .fine{font-size:12px; opacity:.8; margin-top:12px}

/* ---------- Footer ---------- */
.footer{background:var(--navy); color:#AEB9C6; padding:56px 0 0; margin-top:20px}
.foot-top{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.1)}
.footer .logo .wordmark{color:#fff}
.footer .fabout{font-size:13.5px; line-height:1.6; margin:18px 0; max-width:300px}
.footer .fcontact{font-size:13.5px; line-height:1.9}
.footer .fcontact a{color:#fff; font-weight:600}
.footer h5{color:#fff; font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:16px}
.footer ul{list-style:none; padding:0; margin:0}
.footer ul li{margin-bottom:11px}
.footer ul a{font-size:13.5px; transition:color var(--dur)}
.footer ul a:hover{color:#fff}
.foot-mid{display:flex; align-items:center; justify-content:space-between; gap:20px; padding:22px 0; border-bottom:1px solid rgba(255,255,255,.1); flex-wrap:wrap}
.pay{display:flex; align-items:center; gap:9px}
.pay .pc{height:30px; min-width:46px; padding:0 9px; border-radius:6px; background:#fff; display:grid; place-items:center; font-weight:800; font-size:11px; color:var(--ink); font-family:'Archivo'}
.anpc{display:flex; gap:10px}
.anpc .ab{height:34px; padding:0 14px; border-radius:6px; background:rgba(255,255,255,.1); display:grid; place-items:center; font-size:11px; font-weight:600; color:#D7DEE8}
.foot-bot{display:flex; align-items:center; justify-content:space-between; padding:20px 0 30px; font-size:12.5px; flex-wrap:wrap; gap:14px}
.foot-bot .socials{display:flex; gap:10px}
.foot-bot .socials a{width:36px; height:36px; border-radius:9px; background:rgba(255,255,255,.1); display:grid; place-items:center; color:#fff; transition:background var(--dur)}
.foot-bot .socials a:hover{background:var(--accent)}

/* ---------- Cart dropdown (anchored under the cart button) ---------- */
.drawer-ov{position:fixed; inset:0; background:transparent; z-index:45; opacity:0; pointer-events:none}
.drawer-ov.show{opacity:1; pointer-events:auto}
.drawer{position:fixed; width:392px; max-width:calc(100vw - 24px); max-height:calc(100vh - 120px); background:var(--surface); z-index:91;
  display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius-l); overflow:hidden;
  transform:translateY(-10px) scale(.98); transform-origin:top right; opacity:0; pointer-events:none;
  transition:transform .2s var(--ease), opacity .2s var(--ease); box-shadow:var(--shadow-3)}
.drawer.show{transform:none; opacity:1; pointer-events:auto}
.drawer .dh{display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom:1px solid var(--line)}
.drawer .dh h3{font-size:18px; font-weight:800}
.drawer .dh .cl{width:38px; height:38px; border-radius:50%; display:grid; place-items:center; color:var(--ink-2); transition:background var(--dur)}
.drawer .dh .cl:hover{background:var(--paper)}
.ship-bar{padding:14px 18px; background:var(--paper); border-bottom:1px solid var(--line)}
.ship-bar .txt{font-size:13px; margin-bottom:9px; color:var(--ink-2)}
.ship-bar .txt b{color:var(--accent)}
.ship-bar .track{height:7px; border-radius:4px; background:var(--line); overflow:hidden}
.ship-bar .track i{display:block; height:100%; background:var(--accent); border-radius:4px; transition:width .3s var(--ease)}
.ship-bar .done{color:var(--ok); font-weight:600; display:flex; align-items:center; gap:6px; font-size:13px}
.drawer .items{flex:1; overflow:auto; padding:4px 18px; min-height:0}
.litem{display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--line-2)}
.litem .lm{width:72px; height:72px; border-radius:9px; background:var(--paper); display:grid; place-items:center; color:var(--ink-2); flex:none}
.litem .lm svg{width:54%; height:54%; opacity:.55}
.litem .li{flex:1; min-width:0}
.litem .lb{font-size:10.5px; font-weight:800; letter-spacing:.07em; text-transform:uppercase; color:var(--muted-2)}
.litem .ln{font-size:13.5px; font-weight:600; line-height:1.3; margin:2px 0 8px}
.litem .lr{display:flex; align-items:center; justify-content:space-between; gap:10px}
.qty{display:flex; align-items:center; border:1.5px solid var(--line); border-radius:var(--radius-s); overflow:hidden}
.qty button{width:30px; height:30px; display:grid; place-items:center; color:var(--ink-2); transition:background var(--dur)}
.qty button:hover{background:var(--paper); color:var(--accent)}
.qty .n{width:34px; text-align:center; font-weight:700; font-size:13.5px}
.litem .lp{font-weight:800; font-size:15px; font-family:'Archivo'}
.litem .rm{color:var(--muted-2); transition:color var(--dur)}
.litem .rm:hover{color:var(--sale)}
.drawer .empty{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:13px; color:var(--muted); text-align:center; padding:32px 28px}
.drawer .empty .ec{width:78px; height:78px; border-radius:50%; background:var(--paper); display:grid; place-items:center; color:var(--muted-2)}
.drawer .dfoot{border-top:1px solid var(--line); padding:16px 18px; background:var(--surface)}
.drawer .row{display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; font-size:13.5px; color:var(--muted)}
.drawer .row.total{margin:12px 0 16px; font-size:16px; color:var(--ink); font-weight:800}
.drawer .row.total .v{font-size:24px; font-family:'Archivo'}
.drawer .drawer-checkout{width:100%; justify-content:center; height:44px; font-size:14px; padding:0 18px}
.drawer .cont{width:100%; justify-content:center; margin-top:8px; height:40px; font-size:13.5px; padding:0 18px}

/* ---------- toast ---------- */
.toast{position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(20px); background:var(--ink); color:#fff;
  padding:13px 20px; border-radius:var(--radius); display:flex; align-items:center; gap:11px; font-weight:600; font-size:14px;
  box-shadow:var(--shadow-3); z-index:95; opacity:0; pointer-events:none; transition:opacity var(--dur),transform var(--dur)}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}
.toast .tc{width:26px; height:26px; border-radius:50%; background:var(--ok); display:grid; place-items:center; flex:none}

/* ---------- Season banners ---------- */
.season-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.season-card{position:relative; display:block; border-radius:var(--radius-l); overflow:hidden;
  aspect-ratio:432/458; cursor:pointer; box-shadow:var(--shadow-1); background:var(--paper)}
.season-card img{width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--ease)}
.season-card:hover img{transform:scale(1.045)}
.season-card::after{content:''; position:absolute; inset:0; border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(20,24,30,.06); transition:box-shadow var(--dur)}
.season-card:hover{box-shadow:var(--shadow-2)}
.season-card:hover::after{box-shadow:inset 0 0 0 2px var(--accent)}
@media(max-width:820px){ .season-grid{grid-template-columns:1fr} }

/* ---------- Banner editor ---------- */
.banner-editor{margin-top:14px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); box-shadow:var(--shadow-1); overflow:hidden}
.banner-editor .be-head{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px 18px; background:var(--paper); border-bottom:1px solid var(--line); font-size:14px}
.banner-editor .be-head .muted{color:var(--muted); font-weight:400}
.banner-editor .be-done{display:inline-flex; align-items:center; gap:7px; font-weight:700; font-size:13.5px; color:#fff; background:var(--accent); padding:8px 15px; border-radius:var(--radius-s); transition:background var(--dur)}
.banner-editor .be-done:hover{background:var(--accent-d)}
.be-body{display:flex; flex-wrap:wrap; gap:30px; padding:20px}
.be-group{display:flex; flex-direction:column; gap:9px; min-width:210px}
.be-group > label{font-size:11px; font-weight:800; letter-spacing:.07em; text-transform:uppercase; color:var(--muted)}
.be-hint{font-size:12.5px; color:var(--muted); max-width:200px; line-height:1.5}
.seg{display:inline-flex; border:1.5px solid var(--line); border-radius:var(--radius-s); overflow:hidden; width:fit-content}
.seg button{padding:8px 15px; font-size:13px; font-weight:600; color:var(--ink-2); background:var(--surface); transition:background var(--dur)}
.seg button:hover{background:var(--paper)}
.seg button.on{background:var(--ink); color:#fff}
.colorpick{display:flex; align-items:center; gap:9px; flex-wrap:wrap}
input[type=color].swatch{width:42px; height:34px; border:1.5px solid var(--line); border-radius:8px; padding:2px; background:var(--surface); cursor:pointer}
.presets{display:flex; gap:7px; flex-wrap:wrap}
.preset{width:32px; height:32px; border-radius:8px; border:1.5px solid var(--line); cursor:pointer; transition:transform var(--dur),box-shadow var(--dur)}
.preset:hover{transform:scale(1.08); box-shadow:var(--shadow-1)}
.dropzone{display:flex; align-items:center; gap:13px; border:1.5px dashed #D4D4D4; border-radius:var(--radius-s); padding:13px 14px; cursor:pointer; min-width:300px; transition:border-color var(--dur),background var(--dur)}
.dropzone:hover,.dropzone.drag{border-color:var(--accent); background:var(--accent-soft)}
.dropzone .thumb{width:68px; height:46px; border-radius:6px; object-fit:cover; flex:none; background:var(--paper)}
.dropzone .dz-icon{width:48px; height:46px; border-radius:6px; background:var(--paper); display:grid; place-items:center; color:var(--muted-2); flex:none}
.dropzone .dz-txt{font-size:12.5px; color:var(--muted)}
.range{width:210px; accent-color:var(--accent)}
.dz-remove{display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600; color:var(--sale); width:fit-content}
@media(max-width:820px){ .be-body{gap:18px} .be-group,.dropzone{min-width:0} }

/* ---------- Coupons editor ---------- */
.coupon-rows{display:flex; flex-direction:column}
.cpr-head,.cpr-row{display:grid; grid-template-columns:1.4fr 1fr 1.2fr .8fr 1.4fr; align-items:center; gap:12px; padding:11px 4px}
.cpr-head{font-size:11px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--line)}
.cpr-row{border-bottom:1px solid var(--line-2); font-size:13.5px}
.cpr-code{font-weight:800; font-size:14px; letter-spacing:.04em}
.cpr-toggle{width:42px; height:24px; border-radius:999px; background:var(--line); position:relative; transition:background var(--dur); flex:none}
.cpr-toggle.on{background:var(--ok)}
.cpr-toggle .knob{position:absolute; top:3px; left:3px; width:18px; height:18px; border-radius:50%; background:#fff; box-shadow:var(--shadow-1); transition:left var(--dur)}
.cpr-toggle.on .knob{left:21px}
.cpr-act{display:flex; gap:7px; justify-content:flex-end}
@media(max-width:820px){ .cpr-head{display:none} .cpr-row{grid-template-columns:1fr 1fr; row-gap:6px} }

/* ---------- Orders & Users ---------- */
.dash-badge{font-size:11px; font-weight:800; background:var(--accent); color:#fff; padding:3px 9px; border-radius:999px; margin-left:8px; vertical-align:middle}
.ofilters{display:flex; flex-wrap:wrap; gap:7px}
.ochip{font-size:12.5px; font-weight:600; color:var(--ink-2); border:1.5px solid var(--line); border-radius:999px; padding:7px 13px; background:var(--surface); transition:all var(--dur)}
.ochip:hover{border-color:var(--accent); color:var(--accent)}
.ochip.on{background:var(--ink); border-color:var(--ink); color:#fff}
.ot-head,.ot-row{display:grid; grid-template-columns:1fr 1.6fr 1.3fr .9fr 1.1fr .8fr; align-items:center; gap:12px; padding:12px 18px}
.ut-head,.ut-row{display:grid; grid-template-columns:1.3fr 1.6fr 1.1fr .7fr 1fr .5fr; align-items:center; gap:12px; padding:12px 18px}
.ot-head,.ut-head{background:var(--paper); font-size:11px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--muted)}
.ot-row,.ut-row{border-top:1px solid var(--line-2); font-size:13.5px}
.ot-id{font-weight:700}
.ot-cust,.ut-contact{display:flex; flex-direction:column; min-width:0}
.ot-cust b,.ut-contact{font-weight:600}
.ot-cust em,.ut-contact em{font-style:normal; font-size:11.5px; color:var(--muted-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.ot-date{font-size:12.5px; color:var(--muted)}
.opill{font-size:11px; font-weight:800; padding:4px 10px; border-radius:999px}
.ostatus{border:1.5px solid var(--line); border-radius:999px; padding:6px 10px; font-size:12px; font-weight:700; font-family:inherit; cursor:pointer; outline:none; background:var(--surface)}
.st-new,.ostatus.st-new{background:var(--accent-soft); color:var(--accent); border-color:transparent}
.st-proc,.ostatus.st-proc{background:#FFF4DB; color:#B7791F; border-color:transparent}
.st-ship,.ostatus.st-ship{background:#E6F0FF; color:#2563EB; border-color:transparent}
.st-done,.ostatus.st-done{background:var(--ok-soft); color:var(--ok); border-color:transparent}
.st-cancel,.ostatus.st-cancel{background:var(--sale-soft); color:var(--sale); border-color:transparent}
.ut-name{display:flex; align-items:center; gap:11px}
.ut-av{width:34px; height:34px; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-weight:800; font-size:14px; flex:none}
/* order detail modal */
.od-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px}
.od-box{background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-s); padding:14px 16px}
.od-box h4{font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-bottom:9px}
.od-box p{font-size:13.5px; line-height:1.55; margin:0 0 7px}
.od-firm{color:var(--ink-2); font-size:12.5px}
.od-meta{color:var(--muted); font-size:12.5px}
.od-notes{font-size:13px; background:#FFF9E8; border:1px solid #F0E2B8; border-radius:var(--radius-s); padding:10px 13px; margin-bottom:14px}
.od-items{border:1px solid var(--line); border-radius:var(--radius-s); overflow:hidden; margin-bottom:14px}
.od-item{display:flex; align-items:center; gap:12px; padding:11px 14px; border-bottom:1px solid var(--line-2)}
.od-item:last-child{border-bottom:none}
.od-img{width:42px; height:42px; border-radius:7px; background:var(--paper); display:grid; place-items:center; color:var(--muted-2); flex:none; overflow:hidden}
.od-img img{width:100%; height:100%; object-fit:contain; padding:3px}
.od-name{flex:1; display:flex; flex-direction:column; min-width:0}
.od-name b{font-size:13.5px; font-weight:600}
.od-name em{font-style:normal; font-size:12px; color:var(--muted)}
.od-line{font-weight:800; font-size:14px}
.od-totals{max-width:300px; margin-left:auto}
.od-totals .cs-row{display:flex; justify-content:space-between; font-size:13.5px; color:var(--muted); margin-bottom:6px}
.od-totals .cs-total{display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--line); padding-top:10px; margin-top:6px; font-weight:800}
.od-totals .cs-total .v{font-size:20px; font-family:'Archivo'}
.od-status-set{display:flex; align-items:center; gap:10px; font-size:13.5px; font-weight:600; color:var(--muted)}
.od-status-set select{border:1.5px solid var(--line); border-radius:var(--radius-s); padding:9px 12px; font-size:13.5px; font-family:inherit; font-weight:700; color:var(--ink); cursor:pointer}
@media(max-width:820px){ .ot-head,.ut-head{display:none} .ot-row,.ut-row{grid-template-columns:1fr 1fr; row-gap:6px} .od-grid{grid-template-columns:1fr} }

/* variant editor in product form */
.var-editor{border:1px solid var(--line); border-radius:var(--radius-s); padding:14px 16px; background:var(--paper)}
.var-rh6,.var-row6{grid-template-columns:46px 1fr 1.3fr .9fr 1.1fr 40px !important}
.var-img{width:42px; height:42px; border-radius:7px; border:1.5px dashed var(--line); background:var(--surface); display:grid; place-items:center; color:var(--muted-2); position:relative; overflow:visible; flex:none}
.var-img.has{border-style:solid; border-color:var(--accent)}
.var-img img{width:100%; height:100%; object-fit:contain; border-radius:5px}
.var-img-x{position:absolute; top:-6px; right:-6px; width:18px; height:18px; border-radius:50%; background:var(--sale); color:#fff; display:grid; place-items:center; box-shadow:var(--shadow-1)}

/* multi-image picker */
.mip-grid{display:flex; flex-wrap:wrap; gap:10px}
.mip-thumb{position:relative; width:92px; height:92px; border-radius:var(--radius-s); border:1.5px solid var(--line); overflow:hidden; background:var(--paper)}
.mip-thumb.main{border-color:var(--accent)}
.mip-thumb img{width:100%; height:100%; object-fit:contain; padding:4px}
.mip-badge{position:absolute; left:0; bottom:0; right:0; background:var(--accent); color:#fff; font-size:9.5px; font-weight:800; text-align:center; padding:2px; letter-spacing:.03em}
.mip-ov{position:absolute; top:4px; right:4px; display:flex; gap:4px; opacity:0; transition:opacity var(--dur)}
.mip-thumb:hover .mip-ov{opacity:1}
.mip-ov button{width:24px; height:24px; border-radius:6px; background:rgba(255,255,255,.95); box-shadow:var(--shadow-1); display:grid; place-items:center; color:var(--ink-2)}
.mip-ov button:hover{color:var(--accent)}
.mip-add{width:92px; height:92px; border-radius:var(--radius-s); border:1.5px dashed var(--line); background:var(--paper); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px; color:var(--muted); font-size:12px; font-weight:600; transition:all var(--dur)}
.mip-add:hover,.mip-add.drag{border-color:var(--accent); color:var(--accent); background:var(--accent-soft)}
.var-head{display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:12px}
.var-head b{font-size:14px; display:block}
.var-head em{font-style:normal; font-size:12px; color:var(--muted)}
.var-head .fld{max-width:180px}
.var-rows{display:flex; flex-direction:column; margin-bottom:12px}
.var-rh,.var-row{display:grid; grid-template-columns:1fr 1.4fr 1fr 1.1fr 40px; gap:9px; align-items:center}
.var-rh{font-size:10.5px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--muted-2); padding:0 2px 7px}
.var-row{padding:5px 0; border-top:1px solid var(--line-2)}
.var-row input,.var-row select{border:1.5px solid var(--line); border-radius:6px; padding:8px 9px; font-size:13px; font-family:inherit; outline:none; background:var(--surface); width:100%}
.var-row input:focus,.var-row select:focus{border-color:var(--accent)}
.var-badge{display:inline-block; margin-left:8px; font-size:10.5px; font-weight:800; color:var(--accent); background:var(--accent-soft); padding:2px 8px; border-radius:999px; vertical-align:middle; letter-spacing:.02em}

/* complementary products picker (admin) */
.rel-chips{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:10px}
.rel-empty{font-size:13px; color:var(--muted-2)}
.rel-chip{display:inline-flex; align-items:center; gap:8px; background:var(--surface); border:1.5px solid var(--line); border-radius:999px; padding:5px 9px 5px 5px; font-size:12.5px; font-weight:600; color:var(--ink-2)}
.rel-chip-img{width:24px; height:24px; border-radius:50%; background:var(--paper); display:grid; place-items:center; color:var(--muted-2); overflow:hidden; flex:none}
.rel-chip-img img{width:100%; height:100%; object-fit:cover}
.rel-chip button{display:grid; place-items:center; color:var(--muted-2); width:18px; height:18px; border-radius:50%}
.rel-chip button:hover{background:var(--sale-soft); color:var(--sale)}
.rel-search{display:flex; align-items:center; gap:8px; border:1.5px solid var(--line); border-radius:var(--radius-s); padding:0 12px; height:42px; color:var(--muted)}
.rel-search input{border:none; outline:none; flex:1; font-size:13.5px; font-family:inherit; background:none}
.rel-results{border:1px solid var(--line); border-radius:var(--radius-s); margin-top:7px; overflow:hidden}
.rel-res{width:100%; display:flex; align-items:center; gap:11px; padding:9px 12px; text-align:left; border-bottom:1px solid var(--line-2); transition:background var(--dur)}
.rel-res:last-child{border-bottom:none}
.rel-res:hover{background:var(--accent-soft)}
.rel-res-name{flex:1; font-size:13px; font-weight:500; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.rel-res .mono{font-size:12.5px; font-weight:700; color:var(--muted)}
.rel-res svg{color:var(--accent); flex:none}

/* ---------- Static content page ---------- */
.page-wrap{padding:34px 24px 64px; min-height:52vh}
.bread{font-size:13px; color:var(--muted); margin-bottom:14px}
.bread a{color:var(--accent)} .bread a:hover{text-decoration:underline}
.page-title{font-size:38px; font-weight:800; letter-spacing:-.025em; margin-bottom:24px; padding-bottom:18px; border-bottom:2px solid var(--ink)}
.page-body{max-width:760px; font-size:16px; line-height:1.7; color:var(--ink-2)}
.page-body h2{font-size:25px; font-weight:800; margin:30px 0 10px; letter-spacing:-.02em; color:var(--ink)}
.page-body h3{font-size:19px; font-weight:800; margin:24px 0 8px; color:var(--ink)}
.page-body p{margin:0 0 16px}
.page-body ul,.page-body ol{margin:0 0 16px; padding-left:22px}
.page-body li{margin-bottom:7px}
.page-body a{color:var(--accent); text-decoration:underline}
.page-body strong{font-weight:700; color:var(--ink)}
.page-404{text-align:center; padding:80px 0; display:flex; flex-direction:column; gap:20px; align-items:center}

/* ---------- Category page ---------- */
.cat-page{padding:28px 24px 56px; min-height:60vh}
.cat-hero{display:flex; align-items:center; gap:18px; padding:22px 24px; border-radius:var(--radius-l);
  background:linear-gradient(120deg, var(--accent), var(--accent-d)); color:#fff; margin:6px 0 18px}
.cat-hero-ic{width:60px; height:60px; border-radius:15px; background:rgba(255,255,255,.16); display:grid; place-items:center; flex:none}
.cat-hero h1{font-size:30px; font-weight:800; letter-spacing:-.02em; line-height:1.12}
.cat-hero-sub{display:block; font-size:13.5px; opacity:.9; font-weight:500; margin-top:5px}
.subchips{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:22px}
.subchip{font-size:12.5px; font-weight:600; color:var(--ink-2); background:var(--paper); border:1px solid var(--line); padding:7px 13px; border-radius:var(--radius-pill); cursor:pointer; transition:all var(--dur)}
.subchip:hover{border-color:var(--accent); color:var(--accent)}
.cat-layout{display:grid; grid-template-columns:248px 1fr; gap:26px; align-items:start}
.filters{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:6px 18px 18px; position:sticky; top:150px;
  max-height:calc(100vh - 170px); overflow-y:auto; overscroll-behavior:contain}
.filters-head{display:flex; align-items:center; justify-content:space-between; padding:14px 0 12px; border-bottom:1px solid var(--line-2)}
.filters-head b{font-size:15px; font-weight:800}
.clearf{font-size:12.5px; font-weight:600; color:var(--accent)}
.filter-group{padding:15px 0; border-bottom:1px solid var(--line-2)}
.filter-group:last-child{border-bottom:none}
.fg-title{font-size:11.5px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-bottom:11px}
.fg-scroll{max-height:220px; overflow:auto; overscroll-behavior:auto; display:flex; flex-direction:column; gap:9px; padding-right:4px}
.chk{display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-2); cursor:pointer; padding:3px 0}
.chk input{width:16px; height:16px; accent-color:var(--accent); cursor:pointer; flex:none}
.chk + .chk{margin-top:2px}
.price-row{display:flex; align-items:center; gap:9px}
.price-row input{width:100%; border:1.5px solid var(--line); border-radius:var(--radius-s); padding:9px 10px; font-size:13.5px; font-family:inherit; outline:none}
.price-row input:focus{border-color:var(--accent)}
.cat-main{min-width:0}
.sortbar{display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:18px; flex-wrap:wrap}
.sb-count{font-size:13.5px; color:var(--muted); font-weight:600}
.sb-sort{font-size:13px; color:var(--muted); display:flex; align-items:center; gap:9px}
.sb-sort select{border:1.5px solid var(--line); border-radius:var(--radius-s); padding:9px 12px; font-size:13.5px; font-family:inherit; font-weight:600; color:var(--ink); background:var(--surface); outline:none; cursor:pointer}
.sb-sort select:focus{border-color:var(--accent)}
.cat-grid-p{grid-template-columns:repeat(3,1fr)}
.cat-empty{text-align:center; padding:60px 20px; color:var(--muted); display:flex; flex-direction:column; align-items:center; gap:14px}
.pagination{display:flex; align-items:center; justify-content:center; gap:7px; margin-top:34px}
.pg-btn{min-width:40px; height:40px; padding:0 12px; border-radius:var(--radius-s); border:1.5px solid var(--line); background:var(--surface); font-weight:700; font-size:14px; color:var(--ink-2); display:inline-flex; align-items:center; justify-content:center; transition:all var(--dur)}
.pg-btn:hover:not([disabled]){border-color:var(--accent); color:var(--accent)}
.pg-btn.on{background:var(--ink); border-color:var(--ink); color:#fff}
.pg-btn[disabled]{opacity:.4; cursor:default}
.pg-dots{color:var(--muted-2); padding:0 2px}
@media(max-width:1000px){ .cat-grid-p{grid-template-columns:repeat(2,1fr)} }
@media(max-width:820px){
  .cat-layout{grid-template-columns:1fr} .filters{position:static}
  .cat-grid-p{grid-template-columns:repeat(2,1fr)}
}

/* ---------- Product detail page (PDP) ---------- */
.pdp{padding:24px 24px 56px; min-height:60vh}
.pdp-top{display:grid; grid-template-columns:1fr 1fr; gap:44px; margin:16px 0 40px}
.pdp-gallery{display:flex; flex-direction:column; gap:14px}
.pdp-main{position:relative; aspect-ratio:1/1; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-l); display:grid; place-items:center; overflow:hidden}
.pdp-main img{width:100%; height:100%; object-fit:contain; padding:24px}
.pdp-ph{color:var(--muted-2); opacity:.5}
.pdp-bdg{position:absolute; top:16px; left:16px; z-index:2; font-size:13px}
.pdp-thumbs{display:flex; gap:10px; flex-wrap:wrap}
.pdp-thumb{width:74px; height:74px; border:1.5px solid var(--line); border-radius:var(--radius-s); overflow:hidden; background:var(--surface); transition:border-color var(--dur)}
.pdp-thumb img{width:100%; height:100%; object-fit:contain; padding:6px}
.pdp-thumb.on{border-color:var(--accent)}
.pdp-thumb:hover{border-color:var(--accent)}
.pdp-info{padding-top:4px}
.pdp-brand{font-size:12px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); margin-bottom:9px}
.pdp-name{font-size:30px; font-weight:800; letter-spacing:-.02em; line-height:1.15; margin-bottom:14px}
.pdp-meta{display:flex; align-items:center; gap:16px; margin-bottom:18px; font-size:13px}
.pdp-meta .sku{color:var(--muted)}
.pdp-meta .stk{display:inline-flex; align-items:center; gap:6px; color:var(--ok); font-weight:600}
.pdp-meta .stk.low{color:var(--gold)} .pdp-meta .stk.out{color:var(--sale)}
.pdp-meta .stk i{width:8px; height:8px; border-radius:50%; background:currentColor}
.pdp-short{font-size:15px; line-height:1.6; color:var(--ink-2); margin-bottom:22px; padding-bottom:22px; border-bottom:1px solid var(--line)}
.pdp-variants{margin-bottom:22px}
.pdp-var-label{font-size:13px; font-weight:700; color:var(--ink-2); margin-bottom:10px}
.pdp-var-hint{color:var(--accent); font-weight:600}
.pdp-var-opts{display:flex; flex-wrap:wrap; gap:9px}
.pdp-var{min-width:48px; height:44px; padding:0 14px; border:1.5px solid var(--line); border-radius:var(--radius-s); background:var(--surface); font-weight:700; font-size:14.5px; color:var(--ink-2); transition:all var(--dur)}
.pdp-var:hover:not(:disabled){border-color:var(--accent); color:var(--accent)}
.pdp-var.on{background:var(--ink); border-color:var(--ink); color:#fff}
.pdp-var.out{opacity:.4; text-decoration:line-through; cursor:not-allowed}
.pdp-price{display:flex; flex-direction:column; gap:2px; margin-bottom:18px}
.pdp-price .old{font-size:15px; color:var(--muted-2); text-decoration:line-through; font-weight:600}
.pdp-price .now{font-size:38px; font-weight:800; font-family:'Archivo'; letter-spacing:-.02em; color:var(--ink); line-height:1}
.pdp-price .now .cur{font-size:18px}
.pdp-price .tva{font-size:12.5px; color:var(--muted); margin-top:4px}
.pdp-actions{display:flex; align-items:center; gap:12px; margin-bottom:24px; flex-wrap:wrap}
.qty.big{height:54px}
.qty.big button{width:46px; height:54px}
.qty.big .n{width:46px; font-size:16px}
.pdp-add{height:54px; flex:1; min-width:200px; justify-content:center; font-size:15.5px}
.pdp-wish{width:54px; height:54px; border:1.5px solid var(--line); border-radius:var(--radius); display:grid; place-items:center; color:var(--muted); transition:all var(--dur); flex:none}
.pdp-wish:hover{border-color:var(--sale); color:var(--sale)}
.pdp-wish.on{border-color:var(--sale); color:var(--sale)} .pdp-wish.on svg{fill:var(--sale)}
.pdp-wish[data-tip]{position:relative}
.pdp-wish[data-tip]::after{content:attr(data-tip); position:absolute; bottom:calc(100% + 9px); left:50%; transform:translateX(-50%);
  background:var(--accent); color:#fff; font-size:11.5px; font-weight:600; padding:5px 10px; border-radius:6px; white-space:nowrap;
  opacity:0; pointer-events:none; transition:opacity var(--dur); z-index:5}
.pdp-wish[data-tip]::before{content:''; position:absolute; bottom:calc(100% + 4px); left:50%; transform:translateX(-50%);
  border:5px solid transparent; border-top-color:var(--accent); opacity:0; transition:opacity var(--dur)}
.pdp-wish:hover[data-tip]::after,.pdp-wish:hover[data-tip]::before{opacity:1}
.pdp-trust{list-style:none; padding:18px 0 0; margin:0; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:11px}
.pdp-trust li{display:flex; align-items:center; gap:11px; font-size:13.5px; color:var(--ink-2); font-weight:500}
.pdp-trust svg{color:var(--accent); flex:none}

.pdp-detail{margin-bottom:44px}
.pdp-tabs{display:flex; gap:4px; border-bottom:2px solid var(--line); margin-bottom:22px}
.pdp-tabs button{padding:13px 22px; font-weight:700; font-size:15px; color:var(--muted); position:relative; transition:color var(--dur)}
.pdp-tabs button.on{color:var(--ink)}
.pdp-tabs button.on::after{content:''; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--accent)}
.pdp-desc{max-width:none}
.pdp-desc h2{font-size:22px; margin:22px 0 10px}
.pdp-nodesc{color:var(--muted)}
.pdp-specs{width:100%; max-width:none; border-collapse:collapse; font-size:14px}
.pdp-specs tr{border-bottom:1px solid var(--line-2)}
.pdp-specs th{text-align:left; padding:13px 16px 13px 0; font-weight:600; color:var(--muted); width:240px; vertical-align:top}
.pdp-specs td{padding:13px 0; color:var(--ink); font-weight:500}
.pdp-related .sec-head{margin-bottom:20px}

/* product reviews */
.pdp-rate{display:inline-flex; align-items:center; gap:6px; color:var(--muted)}
.pdp-rate .rev-stars{color:var(--gold)}
.pdp-rate b{color:var(--ink)}
.pdp-rate a{color:var(--accent); font-weight:600}
.pdp-rate a:hover{text-decoration:underline}
.pdp-reviews{max-width:none}
.rev-summary{margin-bottom:20px}
.rev-big{display:flex; align-items:center; gap:14px}
.rev-big .rev-avg{font-family:'Archivo'; font-weight:800; font-size:40px; line-height:1; letter-spacing:-.02em}
.rev-big .rev-stars{color:var(--gold)}
.rev-big .rev-count{color:var(--muted); font-size:14px; font-weight:600}
.rev-cols{display:grid; grid-template-columns:1fr 360px; gap:32px; align-items:start}
.rev-list{display:flex; flex-direction:column; gap:18px}
.rev-empty{color:var(--muted); font-size:14.5px; padding:14px 0}
.rev-item{border:1px solid var(--line); border-radius:var(--radius); padding:16px 18px}
.rev-h{display:flex; align-items:center; gap:11px; margin-bottom:9px}
.rev-av{width:38px; height:38px; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-weight:800; font-size:15px; flex:none}
.rev-h b{font-size:14px; display:block; line-height:1.2}
.rev-h .rev-stars{color:var(--gold)}
.rev-h .rev-date{margin-left:auto; font-size:12px; color:var(--muted-2)}
.rev-title{font-weight:700; font-size:14.5px; margin-bottom:4px}
.rev-text{font-size:14px; line-height:1.6; color:var(--ink-2); margin:0}
.rev-form-wrap{background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:20px; position:sticky; top:150px}
.rev-form h4{font-size:16px; font-weight:800; margin-bottom:14px}
.rev-field{display:flex; flex-direction:column; gap:6px; margin-bottom:13px}
.rev-field label{font-size:12px; font-weight:700; letter-spacing:.03em; text-transform:uppercase; color:var(--muted)}
.rev-field input,.rev-field textarea{border:1.5px solid var(--line); border-radius:var(--radius-s); padding:10px 12px; font-size:14px; font-family:inherit; color:var(--ink); outline:none; background:var(--surface)}
.rev-field input:focus,.rev-field textarea:focus{border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.rev-field input.rev-err,.rev-field textarea.rev-err{border-color:var(--sale)}
.star-input{display:flex; gap:4px}
.star-input button{color:var(--gold); display:grid; place-items:center; padding:2px}
.rev-err-msg{color:var(--sale); font-size:13px; font-weight:600; margin-bottom:10px}
.rev-sent{display:flex; align-items:center; gap:13px; color:var(--ok)}
.rev-sent svg{flex:none; background:var(--ok-soft); border-radius:50%; padding:8px; width:38px; height:38px}
.rev-sent b{display:block; color:var(--ink); font-size:14.5px}
.rev-sent span{font-size:13px; color:var(--muted)}
@media(max-width:760px){ .rev-cols{grid-template-columns:1fr} .rev-form-wrap{position:static} }
@media(max-width:900px){
  .pdp-top{grid-template-columns:1fr; gap:24px} .pdp-name{font-size:25px}
  .pdp-related .cat-grid-p{grid-template-columns:repeat(2,1fr)}
}

/* ---------- Cart page ---------- */
.cartpage{padding:24px 24px 60px; min-height:60vh}
.cart-empty-page{text-align:center; padding:60px 20px; display:flex; flex-direction:column; align-items:center; gap:14px}
.cart-empty-page .ec{width:90px; height:90px; border-radius:50%; background:var(--paper); display:grid; place-items:center; color:var(--muted-2)}
.cart-empty-page h2{font-size:24px; font-weight:800}
.cart-empty-page p{color:var(--muted); max-width:420px}
.cart-layout{display:grid; grid-template-columns:1fr 360px; gap:28px; align-items:start}
.cart-thead{display:grid; grid-template-columns:1fr 110px 130px 110px 40px; gap:14px; padding:0 0 12px; border-bottom:2px solid var(--ink);
  font-size:11px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--muted)}
.cart-thead span:nth-child(2),.cart-thead span:nth-child(3),.cart-thead span:nth-child(4){text-align:center}
.cart-line{display:grid; grid-template-columns:1fr 110px 130px 110px 40px; gap:14px; align-items:center; padding:18px 0; border-bottom:1px solid var(--line)}
.cl-prod{display:flex; align-items:center; gap:15px; min-width:0}
.cl-img{width:74px; height:74px; border:1px solid var(--line); border-radius:var(--radius-s); display:grid; place-items:center; flex:none; overflow:hidden; background:var(--surface); color:var(--muted-2)}
.cl-img img{width:100%; height:100%; object-fit:contain; padding:7px}
.cl-info{display:flex; flex-direction:column; gap:3px; min-width:0}
.cl-brand{font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2)}
.cl-name{font-weight:600; font-size:14px; line-height:1.35; color:var(--ink)}
.cl-name:hover{color:var(--accent)}
.cl-sku{font-size:11.5px; color:var(--muted-2)}
.cl-price,.cl-total{text-align:center; font-weight:700; font-size:14px}
.cl-total{font-weight:800}
.cl-qty{display:flex; justify-content:center}
.cl-rm{color:var(--muted-2); display:grid; place-items:center; transition:color var(--dur)}
.cl-rm:hover{color:var(--sale)}
.cart-actions{display:flex; justify-content:space-between; gap:12px; margin-top:18px; flex-wrap:wrap}
.cart-summary{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px; position:sticky; top:150px}
.cart-summary h3{font-size:17px; font-weight:800; margin-bottom:16px}
.cs-row{display:flex; align-items:center; justify-content:space-between; font-size:14px; color:var(--muted); margin-bottom:10px}
.cs-row.disc{color:var(--ok)}
.cs-ship{margin:6px 0 14px}
.cs-ship-txt{font-size:12.5px; color:var(--ink-2); margin-bottom:8px}
.cs-ship-txt b{color:var(--accent)}
.cs-ship .track{height:7px; border-radius:4px; background:var(--line); overflow:hidden}
.cs-ship .track i{display:block; height:100%; background:var(--accent); border-radius:4px; transition:width .3s var(--ease)}
.coupon{display:flex; gap:8px; margin:14px 0 0}
.coupon input{flex:1; border:1.5px solid var(--line); border-radius:var(--radius-s); padding:11px 13px; font-size:14px; font-family:inherit; outline:none}
.coupon input:focus{border-color:var(--accent)}
.coupon .btn-dark{padding:0 18px}
.coupon-err{color:var(--sale); font-size:12.5px; margin-top:8px}
.coupon-ok{color:var(--ok); font-size:12.5px; font-weight:600; margin-top:8px; display:flex; align-items:center; gap:6px}
.coupon-hint{font-size:12px; color:var(--muted-2); margin-top:9px}
.coupon-hint button{color:var(--accent); font-weight:700; font-family:'JetBrains Mono'; font-size:11.5px}
.cs-total{display:flex; align-items:center; justify-content:space-between; margin:16px 0 2px; padding-top:16px; border-top:1px solid var(--line); font-size:16px; font-weight:800}
.cs-total .v{font-size:24px; font-family:'Archivo'}
.cs-tva{font-size:12px; color:var(--muted-2); margin-bottom:16px}
.cs-checkout{width:100%; justify-content:center; height:52px}
.cs-pay{display:flex; align-items:center; gap:7px; justify-content:center; font-size:12px; color:var(--muted); margin-top:12px}
.cs-pay svg{color:var(--ok)}

/* ---------- Checkout ---------- */
.checkout{padding:24px 24px 60px; min-height:60vh}
.ck-layout{display:grid; grid-template-columns:1fr 380px; gap:28px; align-items:start}
.ck-block{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px; margin-bottom:16px}
.ck-block h3{font-size:17px; font-weight:800; margin-bottom:16px; display:flex; align-items:center; gap:11px}
.ck-step{width:26px; height:26px; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-size:13px; font-weight:800; font-family:'Inter'}
.checkout .fld{display:flex; flex-direction:column; gap:6px; flex:1; min-width:0}
.checkout .fld.wide{width:100%}
.checkout .fld-l{font-size:11.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--muted)}
.checkout .fld input,.checkout .fld textarea{width:100%; border:1.5px solid var(--line); border-radius:var(--radius-s); padding:11px 13px; font-size:14.5px; font-family:inherit; color:var(--ink); outline:none; transition:border-color var(--dur),box-shadow var(--dur)}
.checkout .fld input:focus,.checkout .fld textarea:focus{border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.checkout .fld.err input{border-color:var(--sale); box-shadow:0 0 0 3px var(--sale-soft)}
.checkout .fld textarea{resize:vertical}
.checkout .fld-row{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:14px}
.checkout .fld-row:last-child{margin-bottom:0}
.checkout .fld-row > .fld{flex:1; min-width:150px}
.ck-opts,.ck-pays{display:flex; flex-direction:column; gap:10px}
.ck-opt{display:flex; align-items:center; gap:14px; padding:15px 16px; border:1.5px solid var(--line); border-radius:var(--radius-s); cursor:pointer; transition:border-color var(--dur),background var(--dur); color:var(--ink-2)}
.ck-opt:hover{border-color:var(--accent)}
.ck-opt.on{border-color:var(--accent); background:var(--accent-soft)}
.ck-opt input{width:18px; height:18px; accent-color:var(--accent); flex:none}
.ck-opt svg{color:var(--accent); flex:none}
.ck-opt b{font-size:14.5px; display:block}
.ck-opt em{font-style:normal; font-size:12.5px; color:var(--muted)}
.ck-addr{margin-top:16px}
.ck-card-mock{margin-top:16px; padding:16px; background:var(--paper); border-radius:var(--radius-s)}
.ck-card-note{font-size:12px; color:var(--muted); display:flex; align-items:center; gap:7px; margin-top:6px}
.ck-card-note svg{color:var(--ok)}
.ck-invoice{display:flex; align-items:center; gap:11px; font-size:14.5px; font-weight:600; cursor:pointer; margin-top:16px; padding-top:16px; border-top:1px solid var(--line-2)}
.ck-invoice input{width:18px; height:18px; accent-color:var(--accent)}
.ck-addr-first{margin-top:0; margin-bottom:18px; padding-bottom:18px; border-bottom:1px solid var(--line-2)}
.ck-invoice.ck-invoice-top{margin-top:0; padding-top:0; border-top:none}
.ck-shipfirst{margin-bottom:18px; padding-bottom:18px; border-bottom:1px solid var(--line-2)}
.ck-shipform{padding:16px; background:var(--paper); border-radius:var(--radius-s); border:1px solid var(--line)}
.ck-shipform-t{font-size:12px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); margin-bottom:13px}
.ck-shipnote{margin-top:14px; display:flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; color:var(--ok); background:var(--ok-soft); padding:11px 14px; border-radius:var(--radius-s)}
.ck-summary{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px; position:sticky; top:150px}
.ck-summary h3{font-size:17px; font-weight:800; margin-bottom:16px}
.ck-items{display:flex; flex-direction:column; gap:13px; max-height:280px; overflow:auto; margin-bottom:18px; padding-bottom:16px; border-bottom:1px solid var(--line)}
.ck-item{display:flex; align-items:center; gap:12px}
.ck-item-img{position:relative; width:48px; height:48px; border:1px solid var(--line); border-radius:8px; display:grid; place-items:center; flex:none; overflow:hidden; background:var(--surface); color:var(--muted-2)}
.ck-item-img img{width:100%; height:100%; object-fit:contain; padding:5px}
.ck-item-q{position:absolute; top:-7px; right:-7px; background:var(--ink); color:#fff; font-size:11px; font-weight:800; min-width:19px; height:19px; border-radius:10px; display:grid; place-items:center; font-family:'Inter'; padding:0 4px}
.ck-item-name{flex:1; font-size:13px; line-height:1.35; color:var(--ink-2); min-width:0}
.ck-item-p{font-weight:700; font-size:13px; white-space:nowrap}
.ck-back{display:flex; align-items:center; gap:6px; justify-content:center; font-size:13px; font-weight:600; color:var(--muted); margin-top:14px}
.ck-back:hover{color:var(--accent)}

/* ---------- Order confirmation ---------- */
.confirm{padding:40px 24px 70px; min-height:60vh; display:grid; place-items:center}
.confirm-card{max-width:560px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:14px}
.confirm-ic{width:84px; height:84px; border-radius:50%; background:var(--ok-soft); color:var(--ok); display:grid; place-items:center}
.confirm-card h1{font-size:32px; font-weight:800; letter-spacing:-.02em}
.confirm-card > p{color:var(--muted); font-size:15px; line-height:1.6; max-width:460px}
.confirm-box{width:100%; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px 22px; margin:8px 0}
.cb-row{display:flex; align-items:center; justify-content:space-between; padding:9px 0; font-size:14px; color:var(--muted); border-bottom:1px solid var(--line-2)}
.cb-row:last-child{border-bottom:none}
.cb-row b{color:var(--ink)}
.confirm-actions{display:flex; gap:12px; flex-wrap:wrap; justify-content:center}

@media(max-width:900px){
  .cart-layout,.ck-layout{grid-template-columns:1fr}
  .cart-summary,.ck-summary{position:static}
  .cart-thead{display:none}
  .cart-line{grid-template-columns:1fr auto; gap:12px 14px; position:relative}
  .cl-prod{grid-column:1 / -1}
  .cl-price,.cl-total{text-align:left}
  .cl-price::before,.cl-total::before{content:attr(data-lbl); font-size:11px; color:var(--muted); font-weight:600; margin-right:6px; text-transform:uppercase}
  .cl-rm{position:absolute; top:18px; right:0}
}

.fav-head{display:flex; align-items:center; gap:16px; margin:8px 0 22px; flex-wrap:wrap}
.fav-head h1{font-size:30px; font-weight:800; letter-spacing:-.02em}
.fav-count{font-size:14px; color:var(--muted); font-weight:600}
.fav-head .btn{margin-left:auto; height:40px}
.fav-empty-ic{width:78px; height:78px; border-radius:50%; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; margin-bottom:6px}

/* ---------- account hover menu ---------- */
.acct-menu-wrap{position:relative}
.acct-menu{position:absolute; top:calc(100% + 8px); right:0; min-width:210px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow-3); padding:7px; z-index:70; opacity:0; transform:translateY(-8px); pointer-events:none; transition:opacity var(--dur),transform var(--dur)}
.acct-menu.show{opacity:1; transform:none; pointer-events:auto}
.am-hi{padding:9px 12px 10px; font-size:13.5px; color:var(--muted); border-bottom:1px solid var(--line-2); margin-bottom:5px}
.am-hi b{color:var(--ink); font-weight:700}
.am-item{display:flex; align-items:center; gap:11px; width:100%; padding:10px 12px; border-radius:var(--radius-s); font-size:13.5px; font-weight:600; color:var(--ink-2); text-align:left; transition:background var(--dur)}
.am-item:hover{background:var(--paper); color:var(--accent)}
.am-item svg{color:var(--muted-2); flex:none}
.am-item:hover svg{color:var(--accent)}

/* ---------- Customer account ---------- */
.acct-page{padding:28px 24px 60px; min-height:60vh}
.acct-login{max-width:440px; margin:30px auto; text-align:center; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-l); padding:40px 36px}
.acct-ic{width:64px; height:64px; border-radius:50%; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; margin:0 auto 18px}
.acct-login h1{font-size:26px; font-weight:800; margin-bottom:10px}
.acct-login p{color:var(--muted); font-size:14.5px; line-height:1.55; margin-bottom:22px}
.acct-login form{display:flex; flex-direction:column; gap:11px}
.acct-login input{height:50px; border:1.5px solid var(--line); border-radius:var(--radius); padding:0 16px; font-size:15px; font-family:inherit; outline:none; text-align:center}
.acct-login input:focus{border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.acct-login .btn{justify-content:center; height:50px}
.acct-hint{display:block; margin-top:14px; font-size:12.5px; color:var(--muted-2)}
.auth-tabs{display:flex; gap:6px; background:var(--paper); border-radius:var(--radius); padding:4px; margin-bottom:18px}
.auth-tabs button{flex:1; height:38px; border-radius:var(--radius-s); font-weight:700; font-size:13.5px; color:var(--muted); transition:all var(--dur)}
.auth-tabs button.on{background:var(--surface); color:var(--ink); box-shadow:var(--shadow-1)}
.auth-err{background:var(--sale-soft); color:var(--sale); font-size:13px; font-weight:600; padding:9px 13px; border-radius:var(--radius-s); margin-bottom:13px}
.auth-namerow{display:flex; gap:10px}
.auth-namerow input{flex:1; min-width:0; width:auto}
.acct-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin:8px 0 24px; flex-wrap:wrap}
.acct-head h1{font-size:28px; font-weight:800; letter-spacing:-.02em}
.acct-email{font-size:13.5px; color:var(--muted); font-weight:600}
.acct-orders{display:flex; flex-direction:column; gap:18px}
.acct-tabs{display:flex; gap:6px; border-bottom:2px solid var(--line); margin-bottom:22px}
.acct-tabs button{display:flex; align-items:center; gap:8px; padding:12px 18px; font-weight:700; font-size:14.5px; color:var(--muted); position:relative}
.acct-tabs button svg{color:var(--muted-2)}
.acct-tabs button.on{color:var(--ink)} .acct-tabs button.on svg{color:var(--accent)}
.acct-tabs button.on::after{content:''; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--accent)}
.acct-details{display:flex; flex-direction:column; gap:16px; max-width:none}
.acct-cont-grid{display:grid; grid-template-columns:1fr 320px; gap:22px; align-items:start}
.acct-side{display:flex; flex-direction:column; gap:16px; position:sticky; top:150px}
.acct-side-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:24px 20px; display:flex; flex-direction:column; align-items:center; text-align:center; gap:4px}
.acct-side-av{width:64px; height:64px; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-weight:800; font-size:26px; margin-bottom:8px}
.acct-side-card b{font-size:17px; font-weight:800}
.acct-side-mail{font-size:13px; color:var(--muted)}
.acct-side-since{font-size:12px; color:var(--muted-2); margin-top:4px}
.acct-side-stats{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.acct-side-stats > button,.acct-side-stats > a{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:16px 12px; text-align:center; display:block; transition:border-color var(--dur),box-shadow var(--dur); cursor:pointer}
.acct-side-stats > button:hover,.acct-side-stats > a:hover{border-color:var(--accent); box-shadow:var(--shadow-1)}
.acct-side-stats b{display:block; font-family:'Archivo'; font-weight:800; font-size:22px; line-height:1.1; color:var(--ink)}
.acct-side-stats span{font-size:12px; color:var(--muted); font-weight:600}
.acct-side-links{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:7px}
.asl-item{display:flex; align-items:center; gap:11px; width:100%; padding:12px 14px; border-radius:var(--radius-s); font-size:14px; font-weight:600; color:var(--ink-2); text-align:left; transition:background var(--dur)}
.asl-item:hover{background:var(--paper); color:var(--accent)}
.asl-item svg:first-child{color:var(--muted-2)} .asl-item:hover svg:first-child{color:var(--accent)}
.asl-item svg:last-child{margin-left:auto; color:var(--muted-2)}
@media(max-width:820px){ .acct-cont-grid{grid-template-columns:1fr} .acct-side{position:static} }
.adt-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px 22px}
.adt-card h3{display:flex; align-items:center; gap:10px; font-size:16px; font-weight:800; margin-bottom:16px}
.adt-card h3 svg{color:var(--accent)}
.adt-row{display:flex; gap:14px; margin-bottom:14px; flex-wrap:wrap}
.adt-row:last-child{margin-bottom:0}
.adt-fld{flex:1; min-width:150px; display:flex; flex-direction:column; gap:6px}
.adt-fld span{font-size:11.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--muted)}
.adt-fld input{border:1.5px solid var(--line); border-radius:var(--radius-s); padding:10px 12px; font-size:14px; font-family:inherit; color:var(--ink); outline:none; background:var(--surface)}
.adt-fld input:focus{border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}
.adt-fld input:disabled{background:var(--paper); color:var(--muted)}
.adt-save{display:flex; justify-content:flex-end}
.adt-save .btn{height:46px; min-width:200px; justify-content:center}
.acct-order{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px 22px}
.ao-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:18px}
.ao-id{font-weight:800; font-size:15px; margin-right:12px}
.ao-date{font-size:13px; color:var(--muted)}
.opill{font-size:11px; font-weight:800; padding:4px 11px; border-radius:999px}
.st-new{background:var(--accent-soft); color:var(--accent)} .st-proc{background:#FFF4DB; color:#B7791F}
.st-ship{background:#E6F0FF; color:#2563EB} .st-done{background:var(--ok-soft); color:var(--ok)} .st-cancel{background:var(--sale-soft); color:var(--sale)}
/* tracker */
.tracker{display:flex; align-items:center; padding:6px 0 20px; margin-bottom:16px; border-bottom:1px solid var(--line-2)}
.trk-step{display:flex; align-items:center; flex:1; position:relative}
.trk-step:last-child{flex:none}
.trk-dot{width:38px; height:38px; border-radius:50%; background:var(--paper); border:2px solid var(--line); color:var(--muted-2); display:grid; place-items:center; flex:none; transition:all var(--dur)}
.trk-step.done .trk-dot{background:var(--ok); border-color:var(--ok); color:#fff}
.trk-lbl{font-size:12.5px; font-weight:600; color:var(--muted); margin:0 10px}
.trk-step.done .trk-lbl{color:var(--ink)}
.trk-line{flex:1; height:2.5px; background:var(--line); min-width:24px}
.trk-line.done{background:var(--ok)}
.trk-cancel{display:flex; align-items:center; gap:8px; color:var(--sale); font-weight:700; font-size:14px; padding:10px 0 18px; margin-bottom:16px; border-bottom:1px solid var(--line-2)}
.ao-items{display:flex; flex-direction:column; gap:10px; margin-bottom:16px}
.ao-item{display:flex; align-items:center; gap:13px}
.ao-img{width:46px; height:46px; border-radius:8px; background:var(--paper); display:grid; place-items:center; color:var(--muted-2); flex:none; overflow:hidden}
.ao-img img{width:100%; height:100%; object-fit:contain; padding:3px}
.ao-name{flex:1; font-size:13.5px; font-weight:500; display:flex; flex-direction:column; color:var(--ink); transition:color var(--dur)}
.ao-item:hover .ao-name{color:var(--accent)}
.ao-name em{font-style:normal; font-size:12px; color:var(--muted)}
.ao-lp{font-weight:700; font-size:14px}
.ao-foot{display:flex; align-items:flex-start; justify-content:space-between; gap:14px; padding-top:16px; border-top:1px solid var(--line-2); flex-wrap:wrap}
.ao-lines{display:flex; flex-direction:column; gap:9px}
.ao-awb-on{display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--ink-2)}
.ao-awb-on svg{color:var(--ok)} .ao-awb-on b{font-size:13.5px}
.ao-awb-on em{font-style:normal; color:var(--muted-2); font-size:12px; margin-left:4px}
.ao-awb-off{display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted)}
.ao-invlink{color:var(--accent); font-weight:700; text-decoration:underline; font-size:13.5px}
.ao-invlink:hover{color:var(--accent-d)}
.ao-actions{display:flex; align-items:center; gap:16px}
.ao-total{font-size:14px; color:var(--muted); white-space:nowrap} .ao-total b{font-size:16px; color:var(--ink)}
.ao-actions .btn{height:40px}
/* invoice */
.invoice-sheet{background:var(--paper); max-width:760px; width:100%; max-height:92vh; overflow:auto; border-radius:var(--radius-l); padding:18px}
.inv-actions{display:flex; gap:10px; justify-content:flex-end; margin-bottom:14px}
.invoice{background:#fff; border-radius:var(--radius-s); padding:38px 40px; color:#15181E}
.inv-head{display:flex; justify-content:space-between; gap:20px; padding-bottom:22px; border-bottom:2px solid var(--ink)}
.inv-logo{display:flex; align-items:center; gap:9px; margin-bottom:10px}
.inv-logo .mark{width:34px; height:34px; border-radius:8px; background:var(--accent); color:#fff; display:grid; place-items:center}
.inv-logo b{font-family:'Archivo'; font-weight:800; font-size:19px}
.inv-firm{font-size:12px; color:var(--muted); line-height:1.6}
.inv-meta{text-align:right}
.inv-meta h2{font-size:26px; font-weight:800; margin-bottom:8px}
.inv-meta div{font-size:12.5px; color:var(--ink-2); line-height:1.7}
.inv-bill{display:grid; grid-template-columns:1fr 1fr; gap:24px; padding:22px 0}
.inv-lbl{display:block; font-size:10.5px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-bottom:7px}
.inv-bill b{font-size:14px}
.inv-bill div{font-size:13px; line-height:1.6}
.inv-table{width:100%; border-collapse:collapse; margin-bottom:18px}
.inv-table th{text-align:left; font-size:11px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); padding:10px 8px; border-bottom:1.5px solid var(--line)}
.inv-table th:nth-child(n+2),.inv-table td:nth-child(n+2){text-align:right}
.inv-table td{font-size:13px; padding:11px 8px; border-bottom:1px solid var(--line-2)}
.inv-totals{max-width:280px; margin-left:auto}
.inv-trow{display:flex; justify-content:space-between; font-size:13px; padding:5px 8px; color:var(--muted)}
.inv-grand{border-top:1.5px solid var(--ink); margin-top:6px; padding-top:11px; font-size:15px; font-weight:800; color:var(--ink)}
.inv-foot{margin-top:26px; padding-top:16px; border-top:1px solid var(--line-2); font-size:12px; color:var(--muted); text-align:center}
.od-awb-inp{border:1.5px solid var(--line); border-radius:var(--radius-s); padding:9px 12px; font-size:13.5px; font-family:'JetBrains Mono'; outline:none; width:200px}
.od-awb-inp:focus{border-color:var(--accent)}
@media(max-width:700px){ .inv-bill{grid-template-columns:1fr} .tracker{overflow-x:auto} }
@media print{ body *{visibility:hidden} .invoice, .invoice *{visibility:visible} .invoice{position:absolute; left:0; top:0; width:100%; padding:20px} .no-print{display:none} }

/* ---------- header dark variant (tweak) ---------- */
.app.head-dark .header{background:var(--navy); border-bottom-color:rgba(255,255,255,.1)}
.app.head-dark .header .logo .wordmark{color:#fff}
.app.head-dark .header .logo .tag{color:rgba(255,255,255,.5)}
.app.head-dark .searchbar{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.16)}
.app.head-dark .searchbar .scope{background:rgba(255,255,255,.06); color:#E6EBF1; border-right-color:rgba(255,255,255,.14)}
.app.head-dark .searchbar input{color:#fff}
.app.head-dark .searchbar input::placeholder{color:rgba(255,255,255,.5)}
.app.head-dark .iconbtn{color:#D7DEE8}
.app.head-dark .iconbtn:hover{background:rgba(255,255,255,.08); color:#fff}
.app.head-dark .iconbtn.cart{background:rgba(255,255,255,.08)}
.app.head-dark .iconbtn.cart .ct .v{color:#fff}
.app.head-dark .iconbtn.cart:hover{background:rgba(255,255,255,.14)}
.app.head-dark .nav{background:var(--navy); border-bottom-color:rgba(255,255,255,.1)}
.app.head-dark .nav .navlink{color:#CAD3DE}
.app.head-dark .nav .navlink:hover{color:#fff}
.app.head-dark .nav .phone span{color:rgba(255,255,255,.55)}
.app.head-dark .nav .phone b{color:#fff}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .hero-grid{grid-template-columns:1fr} .hero-side{grid-template-rows:none; grid-template-columns:1fr 1fr}
  .prod-grid{grid-template-columns:repeat(3,1fr)} .brand-grid{grid-template-columns:repeat(4,1fr)}
  .bleed .wrap{grid-template-columns:1fr} .bleed .art2{display:none}
}
@media(max-width:820px){
  .cat-grid{grid-template-columns:repeat(2,1fr)} .prod-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr} .dual{grid-template-columns:1fr} .foot-top{grid-template-columns:1fr 1fr}
  .trust{grid-template-columns:1fr 1fr} .trust .t:nth-child(2){border-right:none}
  .searchbar,.topbar .promos{display:none} .header .wrap{height:70px}
  .hero-main h1{font-size:34px}
}
