:root{
  --blue:#65A5C5; --blue-deep:#51778B; --blue-ink:#3C5B6B;
  --yellow:#FACD60; --yellow-deep:#C4993F; --red:#E56156;
  --beige:#F4E9D8; --cream:#FBF4E7; --cream-2:#FFFCF5;
  --ink:#211C17; --ink-soft:#5A5048;
  --shadow:5px 6px 0 var(--ink); --shadow-sm:3px 3px 0 var(--ink); --shadow-lg:8px 9px 0 var(--ink);
  --radius:22px; --bw:2.5px; --font:"Readex Pro", system-ui, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
/* ===== retro loading indicators ===== */
/* chunky candy-striped top progress bar with a hard black underline */
.ldr-bar{position:fixed;top:0;left:0;height:7px;width:0;z-index:9999;pointer-events:none;
  background:repeating-linear-gradient(45deg,var(--yellow) 0,var(--yellow) 10px,var(--red) 10px,var(--red) 20px);
  background-size:28px 28px;border-bottom:var(--bw) solid var(--ink);opacity:0;
  animation:ldrstripe .6s linear infinite}
.ldr-bar.on{opacity:1;width:82%;transition:width 5s cubic-bezier(.12,.78,.28,1),opacity .12s ease}
.ldr-bar.done{width:100%;opacity:0;transition:width .22s ease,opacity .35s ease .1s}
@keyframes ldrstripe{to{background-position:28px 0}}

/* first-load splash: blocky retro card with bouncing square dots */
.splash{position:fixed;inset:0;z-index:10000;background:var(--beige);display:grid;place-items:center;
  transition:opacity .45s ease,visibility .45s ease}
.splash.hide{opacity:0;visibility:hidden}
.splash-card{display:flex;flex-direction:column;align-items:center;gap:22px;
  background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:34px 44px}
.splash-logo{width:84px;height:84px;animation:ldrwobble 1.4s ease-in-out infinite}
.splash-logo img{width:100%;height:100%}
.splash-dots{display:flex;gap:10px}
.splash-dots i{width:16px;height:16px;border:var(--bw) solid var(--ink);
  animation:ldrbounce 1s ease-in-out infinite}
.splash-dots i:nth-child(1){background:var(--blue)}
.splash-dots i:nth-child(2){background:var(--yellow);animation-delay:.16s}
.splash-dots i:nth-child(3){background:var(--red);animation-delay:.32s}
.splash-word{font-weight:700;font-size:1.2rem;letter-spacing:.08em;color:var(--ink)}
@keyframes ldrbounce{0%,100%{transform:translateY(0)}40%{transform:translateY(-14px) rotate(8deg)}}
@keyframes ldrwobble{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
@media (prefers-reduced-motion:reduce){
  .splash-logo,.splash-dots i{animation:none}
  .ldr-bar{animation:none}.ldr-bar.on{transition:opacity .12s ease}}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--beige);color:var(--ink);line-height:1.65;word-spacing:.03em;overflow-x:hidden;
  -webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}
/* keep text selectable only inside form fields */
input,textarea,select,[contenteditable="true"]{-webkit-user-select:text;user-select:text}
#dotfield{position:fixed;inset:0;z-index:-1;pointer-events:none;display:block}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:none}
.wrap{max-width:1200px;margin-inline:auto;padding-inline:22px}
.section{padding:64px 0}
.page{padding:30px 0 20px;min-height:60vh}
h1,h2,h3{line-height:1.3;font-weight:700;letter-spacing:0;word-spacing:.05em}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.82rem;background:var(--yellow);
  border:var(--bw) solid var(--ink);border-radius:999px;padding:6px 15px;box-shadow:var(--shadow-sm)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:32px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(1.7rem,3.6vw,2.6rem);margin-top:10px}
.sec-head p{color:var(--ink-soft);max-width:46ch;margin-top:10px}
.page-title{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:8px}
.page-sub{color:var(--ink-soft);font-size:1.1rem;margin-bottom:34px;max-width:54ch}

/* cursor — classic retro pointer */
@media (hover:hover) and (pointer:fine){
  body.cur *{cursor:none !important}
  /* the cursor element is moved instantly via JS transform (classic, no lag) */
  .pcursor{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;will-change:transform;opacity:0;transition:opacity .18s ease}
  .pcursor svg{display:block;max-width:none;filter:drop-shadow(2px 2.5px 0 var(--ink));transition:transform .1s ease;transform-origin:top left}
  /* default = arrow (tip at viewBox 4,3) */
  .pcursor .pc-arrow{margin:-3px 0 0 -4px}
  /* hover state = pointing hand (fingertip at viewBox 9,3), hidden by default */
  .pcursor .pc-hand{display:none;margin:-3px 0 0 -9px}
  /* hover over interactive targets: swap arrow -> hand */
  body.cur-hot .pcursor .pc-arrow{display:none}
  body.cur-hot .pcursor .pc-hand{display:block}
  /* pressing down: a little retro pop */
  body.cur-down .pcursor svg{transform:scale(.84)}
}
.pcursor{display:none}
@media (hover:hover) and (pointer:fine){.pcursor{display:block}}
@media (hover:none),(pointer:coarse){
  .pcursor{display:none !important}
  body.cur *{cursor:auto !important}
}
body:not(.cur) button,body:not(.cur) a,body:not(.cur) .chip,body:not(.cur) .fsw,body:not(.cur) .psw,body:not(.cur) .sugg,body:not(.cur) .ci-remove,body:not(.cur) .auth-btn,body:not(.cur) .pay-opt,body:not(.cur) .pf-nav button,body:not(.cur) .mini-btn,body:not(.cur) .toggle,body:not(.cur) .gthumb,body:not(.cur) .cat{cursor:pointer !important}
body:not(.cur) input,body:not(.cur) textarea,body:not(.cur) select{cursor:auto !important}

/* header */
header{position:sticky;top:0;z-index:600;background:var(--beige);border-bottom:var(--bw) solid var(--ink)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:76px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:46px;height:46px;background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:13px;display:grid;place-items:center;box-shadow:var(--shadow-sm);overflow:hidden}
.brand .mark img{width:80%;height:80%;object-fit:contain}
.brand .word{font-weight:700;font-size:1.5rem;line-height:1.12}
.brand .word small{display:block;font-size:.58rem;font-weight:600;color:var(--blue-ink);letter-spacing:.26em;margin-top:6px}
.menu{display:flex;align-items:center;gap:12px}
.menu a{font-weight:500;font-size:.98rem;padding:9px 17px;border-radius:999px;transition:.18s;white-space:nowrap}
.menu a:hover{background:var(--cream-2)}
.menu a.active{background:var(--blue);color:#fff;border:var(--bw) solid var(--ink);box-shadow:var(--shadow-sm)}
.actions{display:flex;align-items:center;gap:10px}
.icon-btn{width:44px;height:44px;border:var(--bw) solid var(--ink);background:var(--cream-2);border-radius:12px;display:grid;place-items:center;box-shadow:var(--shadow-sm);transition:.15s;position:relative}
.icon-btn:hover{transform:translate(-1px,-1px);box-shadow:4px 5px 0 var(--ink)}
.icon-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.icon-btn svg{width:21px;height:21px;stroke:var(--ink);stroke-width:2;fill:none}
.cart-count{position:absolute;top:-8px;left:-8px;background:var(--red);color:#fff;border:2px solid var(--ink);border-radius:999px;min-width:21px;height:21px;font-size:.72rem;font-weight:700;display:grid;place-items:center;padding:0 4px}
.cart-count.pop{animation:pop .35s}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.5)}100%{transform:scale(1)}}

/* mobile bottom nav */
.mobnav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:700;background:var(--cream-2);border-top:var(--bw) solid var(--ink);
  padding:8px 6px calc(8px + env(safe-area-inset-bottom));justify-content:space-around}
.mobnav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.68rem;font-weight:600;color:var(--ink-soft);padding:4px 8px;border-radius:12px;flex:1;text-align:center}
.mobnav a svg{width:24px;height:24px;stroke:var(--ink-soft);stroke-width:2;fill:none}
.mobnav a.active{color:var(--blue-ink)}
.mobnav a.active svg{stroke:var(--blue-ink)}
.mobnav a.active{background:var(--beige)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:600;font-size:1.02rem;border:var(--bw) solid var(--ink);border-radius:999px;padding:14px 26px;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease,background .2s ease;cursor:none}
.btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}
.btn:active{transform:translate(2px,3px);box-shadow:var(--shadow-sm)}
/* smooth click feedback that always plays in full, even on a fast tap */
.btn.pressfx,.add.pressfx{animation:pressFx .32s ease-out}
@keyframes pressFx{
  0%{transform:translate(0,0);box-shadow:var(--shadow)}
  40%{transform:translate(2px,3px) scale(.97);box-shadow:var(--shadow-sm)}
  100%{transform:translate(0,0);box-shadow:var(--shadow)}
}
.btn-blue{background:var(--blue);color:#fff}
.btn-yellow{background:var(--yellow)}
.btn-cream{background:var(--cream-2)}
.btn svg{width:20px;height:20px}

.stars{display:flex;gap:2px;align-items:center}
.stars svg{width:18px;height:18px;display:block}
.rev-n{font-size:.78rem;color:var(--ink-soft);margin-inline-start:6px;font-weight:500}

/* hero */
.hero{position:relative;padding:48px 0 20px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:34px;align-items:center}
.hero h1{font-size:clamp(2.6rem,6.4vw,4.7rem);margin:20px 0 26px;line-height:1.18}
.hero h1 .hl{position:relative;color:var(--blue-ink);white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.32em;background:var(--yellow);z-index:-1;border-radius:4px;transform:rotate(-1.2deg)}
.hero .lead{font-size:1.18rem;color:var(--ink-soft);max-width:44ch;margin-bottom:28px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;display:grid;place-items:center;min-height:360px}
.sun{position:absolute;width:118%;aspect-ratio:1;animation:spin 40s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.mascot-disc{position:relative;width:min(360px,82%);aspect-ratio:1;background:var(--blue);border:3px solid var(--ink);border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-lg)}
.mascot-disc img{width:74%;animation:bob 4.5s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-12px) rotate(1.5deg)}}
.chip-float{position:absolute;background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:999px;padding:8px 15px;font-weight:600;font-size:.85rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:8px}
.chip-1{top:8%;right:0;animation:bob 5s ease-in-out infinite}
.chip-2{bottom:12%;left:-4%;background:var(--yellow);animation:bob 5.6s ease-in-out .6s infinite}
.dot{width:11px;height:11px;border-radius:50%;border:2px solid var(--ink)}

/* perks */
.perks{background:var(--ink);color:var(--cream);border-block:var(--bw) solid var(--ink)}
.perks .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:22px}
.perk{display:flex;align-items:center;gap:13px;font-weight:500;font-size:.95rem}
.perk .pi{width:42px;height:42px;border-radius:12px;background:var(--blue);border:2px solid var(--cream);display:grid;place-items:center;flex:none}
.perk:nth-child(2) .pi{background:var(--yellow)}
.perk:nth-child(3) .pi{background:var(--red)}
.perk:nth-child(4) .pi{background:var(--cream)}
.perk .pi svg{width:22px;height:22px;stroke:var(--ink);stroke-width:2;fill:none}

/* categories */
.cats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.cat{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);padding:24px 14px;text-align:center;box-shadow:var(--shadow);transition:.16s;position:relative}
.cat:hover{transform:translate(-2px,-3px);box-shadow:var(--shadow-lg)}
.cat .ci{width:64px;height:64px;margin:0 auto 14px;border-radius:50%;border:var(--bw) solid var(--ink);display:grid;place-items:center;background:var(--blue)}
.cat:nth-child(2) .ci{background:var(--yellow)}
.cat:nth-child(3) .ci{background:var(--red)}
.cat:nth-child(4) .ci{background:var(--cream)}
.cat:nth-child(5) .ci{background:var(--ink)}
.cat .ci svg{width:34px;height:34px}
.cat h3{font-size:1.02rem}
.cat .soon{position:absolute;top:10px;left:10px;background:var(--red);color:#fff;font-size:.66rem;font-weight:700;border:2px solid var(--ink);border-radius:999px;padding:2px 10px}

/* filters + grid */
.filters{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);margin-bottom:30px;display:flex;gap:28px;flex-wrap:wrap;align-items:center}
.fgroup{display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.fgroup .lbl{font-weight:600;font-size:.9rem;color:var(--ink-soft)}
.chip{border:2px solid var(--ink);background:var(--beige);border-radius:999px;padding:8px 16px;font-weight:500;font-size:.88rem;transition:.14s;cursor:none}
.chip:hover{background:var(--cream)}
.chip.on{background:var(--ink);color:var(--cream)}
.fsw{width:30px;height:30px;border-radius:50%;border:2.5px solid var(--ink);transition:.14s;cursor:none;position:relative}
.fsw.on{transform:scale(1.16)}
.fsw.on::after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-weight:700;text-shadow:0 0 3px rgba(0,0,0,.5)}
.fsw.all{background:conic-gradient(var(--blue),var(--yellow),var(--red),var(--cream),var(--blue))}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.18s;display:flex;flex-direction:column}
.card:hover{transform:translate(-3px,-4px);box-shadow:var(--shadow-lg)}
.card .thumb{aspect-ratio:1;background:var(--cream);border-bottom:var(--bw) solid var(--ink);display:grid;place-items:center;position:relative}
.card .thumb svg{width:62%}
.card:hover .thumb svg{animation:wiggle .5s ease}
@keyframes wiggle{0%,100%{transform:rotate(0)}25%{transform:rotate(-7deg)}75%{transform:rotate(7deg)}}
/* real product images / animated gifs fill their square container in any context */
.prod-img{width:100%;height:100%;object-fit:cover;display:block}
.card .thumb .prod-img{position:absolute;inset:0}
.main-img .prod-img{border-radius:inherit}
.ci-img .prod-img,.gthumb .prod-img,.rev-prod-ic .prod-img,.oi .prod-img{border-radius:inherit}
.tag{position:absolute;top:12px;right:12px;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;border:2px solid var(--ink);border-radius:999px;padding:3px 11px}
.card .body{padding:16px;display:flex;flex-direction:column;gap:9px;flex:1}
.card h3{font-size:1.08rem}
.card .price{font-weight:700;font-size:1.12rem;margin-top:auto}
.card .price .cur{font-size:.78rem;font-weight:500;color:var(--ink-soft)}
.add{margin-top:6px;width:100%;justify-content:center;padding:11px;font-size:.95rem;background:var(--yellow)}
.empty{grid-column:1/-1;text-align:center;padding:40px;color:var(--ink-soft);font-weight:500}

/* banner */
.custom{background:var(--blue);border:var(--bw) solid var(--ink);border-radius:30px;box-shadow:var(--shadow-lg);color:#fff;padding:46px;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;position:relative;overflow:hidden}
.custom.showcase{grid-template-columns:1.1fr .9fr}
.custom::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.16) 1.4px,transparent 1.4px);background-size:20px 20px;pointer-events:none}
.custom-art{position:relative;display:grid;place-items:center;min-height:250px}
.custom-art .ring{position:absolute;width:235px;height:235px;border:3px dashed rgba(255,255,255,.55);border-radius:50%;animation:spin 26s linear infinite}
.custom-art .charm{position:relative;width:150px;height:150px;background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:30px;display:grid;place-items:center;box-shadow:var(--shadow);animation:bob 4.5s ease-in-out infinite}
.custom-art .charm svg{width:72%}
.custom-art .opt{position:absolute;width:54px;height:54px;border-radius:50%;border:var(--bw) solid var(--ink);box-shadow:var(--shadow-sm);display:grid;place-items:center}
.custom-art .opt svg{width:58%}
.custom-art .o1{top:6%;right:12%;background:var(--yellow);animation:bob 5s ease-in-out infinite}
.custom-art .o2{bottom:14%;right:4%;background:var(--red);animation:bob 5.4s ease-in-out .5s infinite}
.custom-art .o3{bottom:10%;left:6%;background:var(--blue-deep);animation:bob 5.8s ease-in-out .9s infinite}
.custom-art .o4{top:12%;left:10%;background:var(--yellow);animation:bob 5.2s ease-in-out .3s infinite}
.custom-art .swatchset{position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);display:flex;gap:8px;background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:999px;padding:8px 12px;box-shadow:var(--shadow-sm)}
.custom-art .swatchset i{width:18px;height:18px;border-radius:50%;border:2px solid var(--ink);display:block}
.custom>*{position:relative}
.custom h2{font-size:clamp(1.6rem,3.4vw,2.4rem);margin-bottom:10px}
.custom p{max-width:48ch;opacity:.95}
.custom .soon-pill{background:var(--yellow);color:var(--ink);border:var(--bw) solid var(--ink);border-radius:999px;padding:14px 28px;font-weight:700;box-shadow:var(--shadow);white-space:nowrap}

/* reviews */
.reviews-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:.16s;display:flex;flex-direction:column;min-height:210px}
.review:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.review .stars{margin-bottom:12px}
.review p{font-size:.98rem;flex:1 0 auto}
.review .who{display:flex;align-items:center;gap:11px;font-weight:600;font-size:.92rem;margin-top:18px}
.review .av{width:46px;height:46px;border-radius:50%;border:3px solid var(--ink);overflow:hidden;flex:none;background:var(--cream)}
.review .av img{width:100%;height:100%;object-fit:cover;display:block}
.review p{flex:none}
.rev-prod{display:flex;align-items:center;gap:12px;width:100%;margin-top:16px;padding:10px 12px;background:var(--cream);border:2.5px solid var(--ink);border-radius:16px;box-shadow:var(--shadow-sm);cursor:none;text-align:start;font-family:inherit;transition:.14s}
.rev-prod:hover{background:var(--yellow);transform:translate(-2px,-2px);box-shadow:5px 6px 0 var(--ink)}
.rev-prod-ic{width:44px;height:44px;flex:none;background:#fff;border:2px solid var(--ink);border-radius:11px;display:grid;place-items:center;overflow:hidden}
.rev-prod-ic svg{width:100%;height:100%}
.rev-prod-info{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}
.rev-prod-label{font-size:.7rem;font-weight:600;color:var(--ink-soft)}
.rev-prod-info b{font-size:.96rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rev-prod-price{font-size:.84rem;font-weight:700;color:var(--blue-ink)}
.rev-prod-go{width:20px;height:20px;flex:none}
.review .who{margin-top:14px}

/* about */
.about{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:30px;box-shadow:var(--shadow-lg);padding:44px;display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:center}
.about .ph{width:170px;height:170px;border-radius:24px;border:3px solid var(--ink);background:var(--yellow);display:grid;place-items:center;flex:none;box-shadow:var(--shadow)}
.about .ph img{width:78%}
.about h2{font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:12px}
.about p{color:var(--ink-soft);max-width:60ch;margin-bottom:20px}
.flag{display:inline-flex;gap:6px;align-items:center;font-weight:600;font-size:.9rem;background:var(--beige);border:2px solid var(--ink);border-radius:999px;padding:6px 15px}
.iq{display:inline-block;width:20px;height:13px;border-radius:2px;border:1.5px solid var(--ink);overflow:hidden;flex:none;vertical-align:-1px;
  background:linear-gradient(to bottom,#ce1126 0 33.3%,#fff 33.3% 66.6%,#000 66.6% 100%)}
.about-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.about-step{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.about-step .n{width:42px;height:42px;border-radius:50%;background:var(--blue);color:#fff;border:var(--bw) solid var(--ink);display:grid;place-items:center;font-weight:700;margin-bottom:12px}
.about-step:nth-child(2) .n{background:var(--yellow);color:var(--ink)}
.about-step:nth-child(3) .n{background:var(--red);color:#fff}
.about-step h3{margin-bottom:6px}
.about-step p{color:var(--ink-soft);font-size:.95rem}

/* footer */
footer{background:var(--ink);color:var(--cream);margin-top:30px;border-top:var(--bw) solid var(--ink)}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;padding:54px 0 30px}
.foot h4{color:#fff;font-size:1rem;margin-bottom:16px}
.foot a{display:block;color:#cbbfae;padding:6px 0;font-size:.92rem;transition:.15s}
.foot a:hover{color:var(--yellow)}
.foot .word{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.foot .word .mark{width:42px;height:42px;background:var(--cream-2);border:2px solid var(--cream);border-radius:11px;display:grid;place-items:center;overflow:hidden}
.foot .word .mark img{width:80%}
.foot .word b{font-size:1.4rem;color:#fff}
.foot p{color:#cbbfae;font-size:.92rem;max-width:34ch}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.badge{background:#2e2820;border:2px solid #4a4236;border-radius:10px;padding:8px 12px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:7px}
.socials{display:flex;gap:10px;margin-top:10px}
.socials a{width:40px;height:40px;border:2px solid #4a4236;border-radius:11px;display:grid;place-items:center;background:#2e2820}
.socials a:hover{background:var(--blue);border-color:var(--cream)}
.socials svg{width:20px;height:20px;stroke:var(--cream);stroke-width:2;fill:none}
.copy{border-top:1px solid #3a342b;padding:18px 0;text-align:center;font-size:.85rem;color:#9c917f}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(140%);background:var(--ink);color:var(--cream);border-radius:999px;padding:13px 24px;font-weight:600;box-shadow:var(--shadow-lg);z-index:9000;display:flex;align-items:center;gap:10px;transition:transform .4s cubic-bezier(.2,1.3,.4,1)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast svg{width:20px;height:20px;stroke:var(--yellow);stroke-width:2.5;fill:none}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .55s ease,transform .55s cubic-bezier(.2,.8,.3,1)}
.reveal.in{opacity:1;transform:none}

/* product */
.breadcrumb{padding:22px 0 4px;font-size:.9rem;color:var(--ink-soft);font-weight:500}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb span{margin:0 7px}
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:46px;padding:18px 0 30px;align-items:start}
.gallery{position:sticky;top:100px}
.main-img{background:var(--cream);border:var(--bw) solid var(--ink);border-radius:30px;box-shadow:var(--shadow-lg);aspect-ratio:1;display:grid;place-items:center;position:relative;overflow:hidden;transition:background .25s}
.main-img svg{width:62%}
.main-img img{width:100%;height:100%;object-fit:cover}
.main-img .tag{position:absolute;top:18px;right:18px;background:var(--red);color:#fff;font-size:.8rem;font-weight:700;border:var(--bw) solid var(--ink);border-radius:999px;padding:5px 14px}
.thumbs{display:flex;gap:12px;margin-top:16px}
.gthumb{width:74px;height:74px;border:var(--bw) solid var(--ink);border-radius:16px;display:grid;place-items:center;background:var(--cream-2);transition:.14s;overflow:hidden}
.gthumb svg{width:64%}
.gthumb:hover{transform:translate(-1px,-2px)}
.gthumb.on{outline:3px solid var(--blue);outline-offset:0}
.pinfo .cat-line{font-weight:600;color:var(--blue-ink);font-size:.92rem;margin-bottom:8px}
.pinfo h1{font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:14px}
.rate-row{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.price-big{font-size:2.2rem;font-weight:700}
.price-big .cur{font-size:1rem;font-weight:500;color:var(--ink-soft)}
.price-old{color:var(--ink-soft);text-decoration:line-through;font-size:1.1rem;margin-inline-start:10px;font-weight:500}
.pinfo .lead{color:var(--ink-soft);margin:16px 0 26px;max-width:46ch}
.opt-label{font-weight:600;margin-bottom:11px;font-size:.96rem}
.pswatches{display:flex;gap:14px;margin-bottom:26px}
.psw{width:42px;height:42px;border-radius:50%;border:var(--bw) solid var(--ink);transition:.14s;cursor:none}
.psw:hover{transform:translateY(-2px)}
.psw.on{outline:3px solid var(--ink);outline-offset:3px}
.qty-row{display:flex;gap:14px;align-items:center;margin-bottom:26px;flex-wrap:wrap}
.stepper{display:flex;align-items:center;border:var(--bw) solid var(--ink);border-radius:999px;overflow:hidden;box-shadow:var(--shadow-sm)}
.stepper button{width:46px;height:48px;font-size:1.4rem;font-weight:700;background:var(--cream-2);border:none;display:grid;place-items:center}
.stepper button:hover{background:var(--yellow)}
.stepper .q{width:54px;text-align:center;font-weight:700;font-size:1.1rem}
.buy-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.buy-row .btn{flex:1;min-width:170px}
.miniperks{display:flex;gap:24px;flex-wrap:wrap;padding-top:24px;border-top:2px dashed #d8c7a8}
.mp{display:flex;align-items:center;gap:10px;font-weight:500;font-size:.92rem}
.mp svg{width:26px;height:26px;stroke:var(--blue-ink);stroke-width:2;fill:none;flex:none}
.panel{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px}
.specs{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.spec{display:flex;align-items:center;gap:12px;background:var(--beige);border:2px solid var(--ink);border-radius:14px;padding:12px 16px;font-weight:500}
.spec b{color:var(--blue-ink)}
.spec .si{width:38px;height:38px;border-radius:10px;background:var(--yellow);border:2px solid var(--ink);display:grid;place-items:center;flex:none}
.spec .si svg{width:20px;height:20px;stroke:var(--ink);stroke-width:2;fill:none}
.desc-p{color:var(--ink-soft);max-width:70ch;margin-bottom:16px}
.rev-summary{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:24px}
.rev-score{font-size:3rem;font-weight:700;line-height:1}

/* search */
.searchbar{display:flex;align-items:center;gap:12px;background:var(--cream-2);border:var(--bw) solid var(--ink);
  border-radius:999px;padding:6px 8px 6px 20px;box-shadow:var(--shadow);max-width:640px;margin-bottom:14px}
.searchbar svg{width:24px;height:24px;stroke:var(--ink-soft);stroke-width:2;fill:none;flex:none}
.searchbar input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:1.1rem;font-weight:500;color:var(--ink);outline:none;padding:10px 0}
.searchbar input::placeholder{color:#a89a82}
.searchbar .clr{width:40px;height:40px;border-radius:50%;border:2px solid var(--ink);background:var(--beige);display:grid;place-items:center;flex:none}
.searchbar .clr svg{width:18px;height:18px;stroke:var(--ink)}
.search-meta{color:var(--ink-soft);font-weight:500;margin-bottom:26px}
.chipsrow{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.sugg{border:2px solid var(--ink);background:var(--cream-2);border-radius:999px;padding:8px 16px;font-weight:500;font-size:.9rem;box-shadow:var(--shadow-sm);transition:.14s;cursor:none}
.sugg:hover{background:var(--yellow);transform:translate(-1px,-1px)}
.sugg .sd{display:inline-block;width:13px;height:13px;border-radius:50%;border:2px solid var(--ink);vertical-align:-1px;margin-inline-end:3px}

/* cart */
.cart-grid{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start}
.cart-list{display:flex;flex-direction:column;gap:16px}
.citem{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:16px;display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center}
.citem .ci-img{width:86px;height:86px;border:var(--bw) solid var(--ink);border-radius:16px;background:var(--cream);display:grid;place-items:center;flex:none;overflow:hidden}
.citem .ci-img svg{width:66%}
.citem .ci-mid h3{font-size:1.05rem;margin-bottom:4px}
.citem .ci-color{font-size:.85rem;color:var(--ink-soft);font-weight:500;display:flex;align-items:center;gap:7px}
.citem .ci-color .d{width:15px;height:15px;border-radius:50%;border:2px solid var(--ink)}
.citem .ci-price{font-weight:700;margin-top:8px}
.citem .ci-price .cur{font-size:.74rem;font-weight:500;color:var(--ink-soft)}
.citem .ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.mini-step{display:flex;align-items:center;border:2px solid var(--ink);border-radius:999px;overflow:hidden}
.mini-step button{width:34px;height:34px;font-size:1.1rem;font-weight:700;background:var(--cream-2);border:none;display:grid;place-items:center}
.mini-step button:hover{background:var(--yellow)}
.mini-step .q{width:38px;text-align:center;font-weight:700}
.ci-remove{background:var(--red);border:2.5px solid var(--ink);border-radius:999px;color:#fff;
  font-family:var(--font);font-weight:600;font-size:.82rem;display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;box-shadow:2px 2px 0 var(--ink);transition:.14s;cursor:none}
.ci-remove:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink);filter:brightness(.93)}
.ci-remove:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}
.ci-remove svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none}
.summary{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;position:sticky;top:100px}
.summary h3{margin-bottom:18px;font-size:1.2rem}
.sumrow{display:flex;justify-content:space-between;padding:9px 0;font-weight:500;color:var(--ink-soft)}
.sumrow.total{border-top:2px dashed #d8c7a8;margin-top:8px;padding-top:14px;font-size:1.25rem;font-weight:700;color:var(--ink)}
.sumrow.total .cur{font-size:.8rem;font-weight:500;color:var(--ink-soft)}
.summary .btn{width:100%;margin-top:18px}
.ship-note{font-size:.82rem;color:var(--ink-soft);margin-top:12px;text-align:center}
.empty-cart{text-align:center;padding:60px 20px}
.empty-cart .ec-ico{width:90px;height:90px;margin:0 auto 18px;border:var(--bw) solid var(--ink);border-radius:24px;background:var(--cream-2);display:grid;place-items:center;box-shadow:var(--shadow)}
.empty-cart .ec-ico svg{width:46px;height:46px;stroke:var(--ink);stroke-width:1.8;fill:none}
.empty-cart h2{margin-bottom:8px}
.empty-cart p{color:var(--ink-soft);margin-bottom:22px}
@media(max-width:980px){.cart-grid{grid-template-columns:1fr}.summary{position:static}}

/* checkout */
.co-grid{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start}
.co-block{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;margin-bottom:22px}
.co-block h3{font-size:1.15rem;margin-bottom:4px;display:flex;align-items:center;gap:10px}
.co-block .step-n{width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;border:2.5px solid var(--ink);display:grid;place-items:center;font-size:.9rem;font-weight:700;flex:none}
.co-block .sub{color:var(--ink-soft);font-size:.9rem;margin-bottom:18px}
.auth-row{display:flex;gap:12px;flex-wrap:wrap}
.auth-btn{flex:1;min-width:160px;display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--cream-2);
  border:var(--bw) solid var(--ink);border-radius:14px;padding:13px;font-weight:600;font-size:.96rem;box-shadow:var(--shadow-sm);transition:.14s;cursor:none}
.auth-btn:hover{transform:translate(-1px,-1px);box-shadow:4px 5px 0 var(--ink)}
.auth-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.auth-btn svg{width:22px;height:22px;flex:none}
.auth-divider{display:flex;align-items:center;gap:14px;margin:18px 0;color:var(--ink-soft);font-size:.85rem;font-weight:500}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:2px;background:#e2d3b8;border-radius:2px}
.field{margin-bottom:16px}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px}
.field .req{color:var(--red)}
.field input,.field select,.field textarea{width:100%;font-family:var(--font);font-size:1rem;color:var(--ink);background:var(--beige);
  border:2.5px solid var(--ink);border-radius:13px;padding:12px 15px;outline:none;transition:.14s}
.field input::placeholder,.field textarea::placeholder{color:#a89a82}
.field input:focus,.field select:focus,.field textarea:focus{box-shadow:var(--shadow-sm);background:var(--cream-2)}
.field textarea{resize:vertical;min-height:70px}
.field select{cursor:none}
.field .hint{font-size:.78rem;color:var(--ink-soft);margin-top:6px}
.field.invalid input,.field.invalid select{border-color:var(--red);background:#fbe9e7}
.field .err{color:var(--red);font-size:.78rem;margin-top:6px;font-weight:500;display:none}
.field.invalid .err{display:block}
.pay-opt{display:flex;align-items:center;gap:14px;border:2.5px solid var(--ink);border-radius:14px;padding:15px 16px;margin-bottom:12px;
  box-shadow:var(--shadow-sm);transition:.14s;cursor:none;background:var(--cream-2)}
.pay-opt:hover{transform:translate(-1px,-1px)}
.pay-opt.on{background:var(--yellow)}
.pay-opt .radio{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--ink);flex:none;display:grid;place-items:center;background:#fff}
.pay-opt.on .radio::after{content:"";width:11px;height:11px;border-radius:50%;background:var(--ink)}
.pay-opt .pi{width:40px;height:40px;border-radius:10px;border:2px solid var(--ink);display:grid;place-items:center;flex:none;background:var(--blue)}
.pay-opt:nth-of-type(2) .pi{background:var(--red)}
.pay-opt .pi svg{width:22px;height:22px;stroke:#fff;stroke-width:2;fill:none}
.pay-opt .pt{font-weight:600}
 .pay-opt .pd{font-size:.82rem;color:var(--ink-soft)}
 .pay-opt.disabled{opacity:.6;background:var(--cream-2)}
 .pay-opt.disabled:hover{transform:none}
 .pay-opt.disabled .radio{border-style:dashed}
 .pay-soon{margin-inline-start:auto;background:var(--yellow);color:var(--ink);border:2px solid var(--ink);border-radius:999px;padding:3px 12px;font-size:.74rem;font-weight:700;white-space:nowrap;align-self:center}
.co-summary{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;position:sticky;top:100px}
.co-summary h3{margin-bottom:16px;font-size:1.15rem}
.co-line{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px dashed #e2d3b8}
.co-line .ci-img{width:50px;height:50px;border:2px solid var(--ink);border-radius:11px;background:var(--cream);display:grid;place-items:center;flex:none;overflow:hidden}
.co-line .ci-img svg{width:66%}
.co-line .cl-mid{flex:1;font-size:.88rem;font-weight:500}
.co-line .cl-mid small{color:var(--ink-soft);font-weight:500}
.co-line .cl-price{font-weight:700;font-size:.9rem;white-space:nowrap}
.sumrow{display:flex;justify-content:space-between;padding:9px 0;font-weight:500;color:var(--ink-soft)}
.sumrow.total{border-top:2px dashed #d8c7a8;margin-top:8px;padding-top:14px;font-size:1.25rem;font-weight:700;color:var(--ink)}
.sumrow.total .cur{font-size:.8rem;font-weight:500;color:var(--ink-soft)}
.co-summary .btn{width:100%;margin-top:18px}
.trust{display:flex;align-items:center;justify-content:center;gap:7px;font-size:.8rem;color:var(--ink-soft);margin-top:12px;font-weight:500}
.trust svg{width:16px;height:16px;stroke:var(--blue-ink);stroke-width:2;fill:none}
.co-done{text-align:center;padding:50px 20px;max-width:560px;margin:0 auto}
.co-done .check{width:96px;height:96px;margin:0 auto 22px;border-radius:50%;background:var(--blue);border:var(--bw) solid var(--ink);display:grid;place-items:center;box-shadow:var(--shadow)}
.co-done .check svg{width:50px;height:50px;stroke:#fff;stroke-width:3;fill:none}
.co-done h2{font-size:2rem;margin-bottom:10px}
.co-done p{color:var(--ink-soft);margin-bottom:8px}
.co-done .order-no{display:inline-block;background:var(--yellow);border:2.5px solid var(--ink);border-radius:999px;padding:8px 20px;font-weight:700;margin:14px 0 24px;box-shadow:var(--shadow-sm)}
@media(max-width:980px){.co-grid{grid-template-columns:1fr}.co-summary{position:static}.field.row2{grid-template-columns:1fr}}

/* profile */
.pf-grid{display:grid;grid-template-columns:260px 1fr;gap:30px;align-items:start}
.pf-side{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;position:sticky;top:100px}
.pf-user{display:flex;align-items:center;gap:12px;padding-bottom:16px;margin-bottom:14px;border-bottom:2px dashed #e2d3b8}
.pf-user .av{width:54px;height:54px;border-radius:50%;border:var(--bw) solid var(--ink);overflow:hidden;flex:none;background:var(--blue)}
.pf-user .av img{width:100%;height:100%;object-fit:cover}
.pf-user .nm{font-weight:700}
.pf-user .ph{font-size:.82rem;color:var(--ink-soft)}
.pf-nav{display:flex;flex-direction:column;gap:4px}
.pf-nav button{display:flex;align-items:center;gap:11px;width:100%;text-align:right;background:none;border:2.5px solid transparent;
  border-radius:13px;padding:11px 14px;font-family:var(--font);font-weight:600;font-size:.96rem;color:var(--ink);transition:.14s;cursor:none}
.pf-nav button:hover{background:var(--beige)}
.pf-nav button.on{background:var(--blue);color:#fff;border-color:var(--ink);box-shadow:var(--shadow-sm)}
.pf-nav button svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;fill:none;flex:none}
.pf-nav .logout{color:var(--red);margin-top:6px}
.pf-nav .logout:hover{background:#fbe9e7}
.pf-panel{min-height:300px}
.pf-panel h2{font-size:1.5rem;margin-bottom:6px}
.pf-panel .psub{color:var(--ink-soft);margin-bottom:22px}
.order-card{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:16px}
.order-top{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding-bottom:14px;margin-bottom:14px;border-bottom:2px dashed #e2d3b8}
.order-top .onum{font-weight:700}
.order-top .odate{font-size:.84rem;color:var(--ink-soft)}
.ostatus{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:700;border:2px solid var(--ink);border-radius:999px;padding:4px 12px}
.ostatus .d{width:9px;height:9px;border-radius:50%;border:1.5px solid var(--ink)}
.ostatus.delivered{background:#dff0e1}.ostatus.delivered .d{background:#4caf50}
.ostatus.transit{background:var(--yellow)}.ostatus.transit .d{background:var(--yellow-deep)}
.ostatus.processing{background:#e4eef4}.ostatus.processing .d{background:var(--blue)}
.order-items{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.oi{width:54px;height:54px;border:2px solid var(--ink);border-radius:12px;background:var(--cream);display:grid;place-items:center;overflow:hidden;position:relative}
.oi svg{width:66%}
.oi .q{position:absolute;bottom:-6px;left:-6px;background:var(--ink);color:#fff;font-size:.66rem;font-weight:700;border-radius:999px;min-width:18px;height:18px;display:grid;place-items:center;padding:0 4px}
.order-bot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.order-bot .ot{font-weight:700}
.order-bot .ot .cur{font-size:.74rem;font-weight:500;color:var(--ink-soft)}
.addr-card{background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:16px;display:flex;justify-content:space-between;gap:14px}
.addr-card .label{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.85rem;background:var(--yellow);border:2px solid var(--ink);border-radius:999px;padding:3px 12px;margin-bottom:10px}
.addr-card .at{font-weight:600;margin-bottom:3px}
.addr-card .ad{color:var(--ink-soft);font-size:.92rem}
.addr-actions{display:flex;flex-direction:column;gap:8px}
.mini-btn{background:var(--cream-2);border:2.5px solid var(--ink);border-radius:11px;padding:8px 12px;font-family:var(--font);font-weight:600;font-size:.82rem;box-shadow:2px 2px 0 var(--ink);transition:.14s;cursor:none;white-space:nowrap}
.mini-btn:hover{transform:translate(-1px,-1px);background:var(--yellow)}
.mini-btn.del{color:var(--red)}.mini-btn.del:hover{background:var(--red);color:#fff}
.set-row{display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 20px;margin-bottom:12px}
.set-row .st{font-weight:600}.set-row .sd{font-size:.84rem;color:var(--ink-soft)}
.toggle{width:50px;height:28px;border-radius:999px;border:2.5px solid var(--ink);background:var(--beige);position:relative;flex:none;transition:.16s;cursor:none}
.toggle::after{content:"";position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:var(--ink);transition:.16s}
.toggle.on{background:var(--blue)}.toggle.on::after{right:auto;left:2px;background:#fff}
.login-gate{max-width:440px;margin:10px auto;background:var(--cream-2);border:var(--bw) solid var(--ink);border-radius:30px;box-shadow:var(--shadow-lg);padding:38px;text-align:center}
.login-gate .lg-ico{width:80px;height:80px;margin:0 auto 18px;border-radius:50%;background:var(--blue);border:var(--bw) solid var(--ink);display:grid;place-items:center;box-shadow:var(--shadow)}
.login-gate .lg-ico svg{width:40px;height:40px;stroke:#fff;stroke-width:2;fill:none}
.login-gate h2{margin-bottom:8px}
.login-gate p{color:var(--ink-soft);margin-bottom:24px}
.login-gate .auth-btn{width:100%;margin-bottom:12px}
@media(max-width:980px){.pf-grid{grid-template-columns:1fr}.pf-side{position:static}.pf-nav{flex-direction:row;flex-wrap:wrap}.pf-nav button{flex:1;justify-content:center;min-width:120px}}

@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-grid .cta-row{justify-content:center}.hero .lead{margin-inline:auto}
  .hero-art{order:-1;min-height:300px}
  .cats{grid-template-columns:repeat(3,1fr)}.grid{grid-template-columns:repeat(3,1fr)}
  .reviews-wrap{grid-template-columns:1fr}.perks .wrap{grid-template-columns:repeat(2,1fr)}
  .about{grid-template-columns:1fr;text-align:center}.about .ph{margin-inline:auto}.about p{margin-inline:auto}
  .about-steps{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr 1fr}
  .pdp{grid-template-columns:1fr;gap:28px}.gallery{position:static}.specs{grid-template-columns:1fr}
}
@media(max-width:760px){
  .menu{display:none}
  .mobnav{display:flex}
  body{padding-bottom:78px}
  .wrap{padding-inline:18px}
  .grid,.cats{grid-template-columns:repeat(2,1fr)}
  .custom{grid-template-columns:1fr;text-align:center;padding:30px 22px}.custom.showcase{grid-template-columns:1fr}.custom .soon-pill{justify-self:center}.custom-art{margin-top:10px}
  .about{padding:28px 22px}
  .panel,.co-block,.co-summary,.summary,.pf-side,.login-gate{padding:22px}
  .login-gate{padding:30px 24px}
  .citem{padding:14px;gap:12px}
  .foot{grid-template-columns:1fr;gap:26px;padding:40px 0 26px;text-align:right}
  .foot p{max-width:none}
  .foot>div{padding-bottom:22px;border-bottom:2px dashed #3a342b}
  .foot>div:last-child{border-bottom:none;padding-bottom:0}
  .socials{justify-content:flex-start}
  .copy{font-size:.8rem;line-height:1.7;padding:16px 18px}
  .section{padding:42px 0}.page{padding:24px 0 16px}
  .nav{height:62px;justify-content:flex-start}
  .actions{gap:10px}
  .actions .icon-btn{width:42px;height:42px;border:2.5px solid var(--ink);background:var(--cream-2);box-shadow:2px 2px 0 var(--ink);border-radius:12px}
  .actions .icon-btn svg{width:20px;height:20px}
  .cart-count{top:-7px;left:-7px;min-width:19px;height:19px;font-size:.68rem}
}
@media(max-width:420px){
  .wrap{padding-inline:16px}
  .grid,.cats{grid-template-columns:repeat(2,1fr);gap:14px}
  .citem{grid-template-columns:auto 1fr;gap:12px}
  .citem .ci-right{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center;margin-top:4px}
}

/* ===== Sharp corners: remove all rounded borders ===== */
:root{--radius:0px}
*,*::before,*::after{border-radius:0 !important}
/* keep genuinely circular elements round so the UI stays intact */
  .mascot-disc,.dot,.cat .ci,.fsw,.custom-art .ring,.custom-art .opt,
.custom-art .swatchset i,.review .av,.about-step .n,.psw,.searchbar .clr,
.sugg .sd,.citem .ci-color .d,.co-block .step-n,.pay-opt .radio,
.pay-opt.on .radio::after,.co-done .check,.pf-user .av,.ostatus .d,
.toggle,.toggle::after,.login-gate .lg-ico{border-radius:999px !important}
