/* ============================================================
   STAY SOLID - store design system (shared across shop pages)
   ============================================================ */
:root{
  --bg:#0b0b0b;
  --bg-2:#111110;
  --bg-3:#161614;
  --ink:#ECE7DD;
  --ink-dim:#7d7870;
  --acid:#F9A826;
  --acid-deep:#cf7f12;
  --line:rgba(236,231,221,.14);
  --line-soft:rgba(236,231,221,.07);

  --f-display:'Anton', sans-serif;
  --f-sans:'Archivo', sans-serif;
  --f-mono:'JetBrains Mono', monospace;

  --ease:cubic-bezier(.7,0,.2,1);
  --pad:clamp(20px,4vw,64px);
  --nav-h:72px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;text-size-adjust:100%}
body{touch-action:manipulation}
html,body{background:var(--bg);color:var(--ink)}
body{font-family:var(--f-sans);overflow-x:hidden;min-height:100vh;cursor:none}
::selection{background:var(--acid);color:#0b0b0b}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,select,textarea{font-family:inherit;color:inherit}
button{cursor:none;border:none;background:none}
@media (pointer:coarse){ body{cursor:auto} button,a{cursor:pointer} }

/* ---------- overlays (injected by ui.js) ---------- */
.grain{position:fixed;inset:-50%;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-8%,4%)}40%{transform:translate(6%,-6%)}
  60%{transform:translate(-4%,8%)}80%{transform:translate(8%,2%)}100%{transform:translate(0,0)}}
.vignette{position:fixed;inset:0;z-index:8000;pointer-events:none;box-shadow:inset 0 0 220px 40px rgba(0,0,0,.55)}
.cursor{position:fixed;top:0;left:0;width:13px;height:13px;border-radius:50%;background:var(--acid);
  z-index:10000;pointer-events:none;transform:translate(-50%,-50%);mix-blend-mode:difference;
  transition:width .35s var(--ease),height .35s var(--ease)}
.cursor-ring{position:fixed;top:0;left:0;width:42px;height:42px;border-radius:50%;border:1px solid var(--ink);
  z-index:9999;pointer-events:none;transform:translate(-50%,-50%);mix-blend-mode:difference;
  transition:width .4s var(--ease),height .4s var(--ease),border-color .3s,background .3s}
body.cursor-hover .cursor{width:0;height:0}
body.cursor-hover .cursor-ring{width:74px;height:74px;border-color:var(--acid);background:rgba(249,168,38,.1)}

/* ============================================================
   NAV (shared)
   ============================================================ */
.nav{position:fixed;top:0;left:0;width:100%;z-index:7000;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;padding:0 var(--pad);
  background:rgba(11,11,11,.6);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
.nav__logo{font-family:var(--f-display);font-size:20px;letter-spacing:.04em}
.nav__logo b{color:var(--acid)}
.nav__links{display:flex;gap:30px}
.nav__links a{font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;position:relative}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;height:1px;width:0;background:var(--acid);transition:width .4s var(--ease)}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__links a.active{color:var(--acid)}
.nav__bag{font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;display:flex;align-items:center;gap:6px}
.nav__bag b{color:var(--acid)}
.nav__burger{display:none;flex-direction:column;gap:5px;width:26px}
.nav__burger span{height:1.5px;background:var(--ink);width:100%;transition:.3s var(--ease)}
@media(max-width:780px){
  /* backdrop-filter makes .nav a containing block for fixed children,
     which would trap the fullscreen menu inside the 72px bar — drop it on mobile */
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(11,11,11,.95)}
  .nav__links{position:fixed;top:0;left:0;width:100%;height:100dvh;background:var(--bg);
    flex-direction:column;justify-content:center;align-items:center;gap:30px;
    transform:translateY(-100%);transition:transform .5s var(--ease);z-index:6999}
  .nav__links.open{transform:translateY(0)}
  .nav__links a{font-family:var(--f-display);font-size:34px}
  .nav__links a::after{display:none}
  .nav__burger{display:flex}
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;
  font-family:var(--f-mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  padding:18px 32px;border-radius:100px;transition:transform .4s var(--ease),background .3s,color .3s;will-change:transform}
.btn--solid{background:var(--acid);color:#0b0b0b;font-weight:700}
.btn--solid:hover{background:var(--ink)}
.btn--ghost{border:1px solid var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--acid);color:var(--acid)}
.btn--block{width:100%}
.btn[disabled]{opacity:.4;pointer-events:none}

/* ============================================================
   PAGE SHELL
   ============================================================ */
.page{padding-top:var(--nav-h);min-height:100vh;display:flex;flex-direction:column}
.page__head{padding:clamp(50px,9vw,120px) var(--pad) clamp(28px,4vw,50px);position:relative}
.eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--acid);display:flex;align-items:center;gap:12px;margin-bottom:20px}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--acid)}
.page__title{font-family:var(--f-display);font-size:clamp(60px,14vw,200px);line-height:.84;text-transform:uppercase}
.page__title em{font-style:normal;color:transparent;-webkit-text-stroke:1.5px var(--acid)}
.crumbs{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:24px}
.crumbs a:hover{color:var(--acid)}

/* ============================================================
   SHOP GRID
   ============================================================ */
.filters{display:flex;gap:10px;flex-wrap:wrap;padding:0 var(--pad) 36px}
.filter{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:10px 18px;border:1px solid var(--line);border-radius:100px;transition:.3s var(--ease)}
.filter:hover{border-color:var(--ink-dim)}
.filter.active{background:var(--acid);color:#0b0b0b;border-color:var(--acid)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,30px);padding:0 var(--pad) clamp(60px,9vw,120px)}
@media(max-width:880px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid{grid-template-columns:1fr}}
.pcard{position:relative;display:block}
.pcard__media{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bg-3)}
.pcard__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.86);
  transform:scale(1.03);transition:transform 1s var(--ease),filter .5s}
.pcard:hover .pcard__media img{transform:scale(1.09);filter:grayscale(0) brightness(1)}
.pcard__tag{position:absolute;top:12px;left:12px;font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;background:var(--acid);color:#0b0b0b;padding:5px 9px;z-index:2}
.pcard__quick{position:absolute;left:12px;right:12px;bottom:12px;transform:translateY(120%);opacity:0;
  transition:.45s var(--ease);z-index:2}
.pcard:hover .pcard__quick{transform:translateY(0);opacity:1}
.pcard__info{display:flex;justify-content:space-between;align-items:flex-start;margin-top:16px;
  border-top:1px solid var(--line);padding-top:13px;gap:14px}
.pcard__info h3{font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.01em}
.pcard__cat{font-family:var(--f-mono);font-size:11px;color:var(--ink-dim);margin-top:5px;letter-spacing:.06em;text-transform:uppercase}
.pcard__price{font-family:var(--f-mono);font-size:15px;color:var(--acid);white-space:nowrap}

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.pdp{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(24px,4vw,64px);
  padding:clamp(20px,3vw,40px) var(--pad) clamp(60px,9vw,120px);align-items:start}
@media(max-width:880px){.pdp{grid-template-columns:1fr}}
.pdp__gallery{display:flex;flex-direction:column;gap:14px;position:sticky;top:calc(var(--nav-h) + 20px)}
@media(max-width:880px){.pdp__gallery{position:static}}
.pdp__main{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--bg-3)}
.pdp__main img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15) contrast(1.05)}
.pdp__thumbs{display:flex;gap:12px}
.pdp__thumb{width:84px;aspect-ratio:3/4;overflow:hidden;background:var(--bg-3);opacity:.5;transition:.3s;border:1px solid transparent}
.pdp__thumb.active{opacity:1;border-color:var(--acid)}
.pdp__thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(1)}
.pdp__info{padding-top:clamp(0px,2vw,24px)}
.pdp__cat{font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--acid)}
.pdp__name{font-family:var(--f-display);font-size:clamp(44px,7vw,96px);line-height:.88;text-transform:uppercase;margin:14px 0 10px}
.pdp__code{font-family:var(--f-mono);font-size:12px;color:var(--ink-dim);letter-spacing:.08em}
.pdp__price{font-family:var(--f-display);font-size:38px;margin:26px 0;color:var(--acid)}
.pdp__desc{color:var(--ink-dim);line-height:1.7;font-weight:300;max-width:46ch;margin-bottom:30px}
.opt__label{font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  display:flex;justify-content:space-between;margin-bottom:12px}
.opt__label a{color:var(--ink-dim)}.opt__label a:hover{color:var(--acid)}
.sizes{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.size{min-width:52px;height:52px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);font-family:var(--f-mono);font-size:13px;transition:.25s var(--ease)}
.size:hover{border-color:var(--ink-dim)}
.size.active{background:var(--ink);color:#0b0b0b;border-color:var(--ink)}
.size.sel-error{animation:shake .4s}
@keyframes shake{25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.qtyrow{display:flex;gap:14px;align-items:stretch;margin-bottom:28px}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line)}
.qty button{width:50px;font-size:20px;color:var(--ink)}
.qty button:hover{color:var(--acid)}
.qty span{min-width:46px;text-align:center;font-family:var(--f-mono);font-size:15px}
.pdp__meta{margin-top:36px;border-top:1px solid var(--line)}
.acc{border-bottom:1px solid var(--line)}
.acc__head{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 0;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;text-align:left}
.acc__head .ico{color:var(--acid);transition:transform .3s}
.acc.open .acc__head .ico{transform:rotate(45deg)}
.acc__body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.acc__body p{padding:0 0 18px;color:var(--ink-dim);line-height:1.6;font-weight:300;font-size:14px}

/* ============================================================
   CART DRAWER (injected by store.js)
   ============================================================ */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);z-index:9500;
  opacity:0;visibility:hidden;transition:.45s var(--ease)}
.cart-overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(440px,92vw);background:var(--bg-2);z-index:9600;
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .5s var(--ease);
  border-left:1px solid var(--line)}
.drawer.open{transform:translateX(0)}
.drawer__head{display:flex;justify-content:space-between;align-items:center;padding:24px var(--pad-d,26px);
  border-bottom:1px solid var(--line)}
.drawer__head h3{font-family:var(--f-display);font-size:24px;text-transform:uppercase;letter-spacing:.02em}
.drawer__head h3 b{color:var(--acid)}
.drawer__close{font-family:var(--f-mono);font-size:12px;letter-spacing:.1em}
.drawer__close:hover{color:var(--acid)}
.drawer__items{flex:1;overflow-y:auto;padding:8px 26px}
.drawer__empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;color:var(--ink-dim)}
.drawer__empty p{font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}
.ci{display:grid;grid-template-columns:72px 1fr auto;gap:14px;padding:18px 0;border-bottom:1px solid var(--line-soft)}
.ci__img{width:72px;aspect-ratio:3/4;object-fit:cover;background:var(--bg-3);filter:grayscale(.4)}
.ci__name{font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.01em}
.ci__sub{font-family:var(--f-mono);font-size:11px;color:var(--ink-dim);margin-top:5px;letter-spacing:.05em}
.ci__qty{display:inline-flex;align-items:center;gap:10px;margin-top:10px;font-family:var(--f-mono);font-size:12px}
.ci__qty button{width:22px;height:22px;border:1px solid var(--line);color:var(--ink);font-size:13px;line-height:1}
.ci__qty button:hover{border-color:var(--acid);color:var(--acid)}
.ci__right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between}
.ci__price{font-family:var(--f-mono);font-size:13px;color:var(--acid)}
.ci__rm{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim)}
.ci__rm:hover{color:var(--acid)}
.drawer__foot{padding:22px 26px;border-top:1px solid var(--line)}
.drawer__row{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:13px;margin-bottom:8px}
.drawer__row.total{font-size:16px;color:var(--ink);margin:14px 0}
.drawer__row .muted{color:var(--ink-dim)}
.drawer__note{font-family:var(--f-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim);
  text-align:center;margin-top:12px}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(140%);z-index:9700;
  background:var(--acid);color:#0b0b0b;font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;
  text-transform:uppercase;padding:14px 22px;border-radius:100px;transition:transform .5s var(--ease);font-weight:700}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ============================================================
   CART / CHECKOUT PAGE
   ============================================================ */
.checkout{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(24px,4vw,60px);
  padding:clamp(10px,2vw,30px) var(--pad) clamp(60px,9vw,120px);align-items:start}
@media(max-width:880px){.checkout{grid-template-columns:1fr}}
.cartlist{border-top:1px solid var(--line)}
.cartrow{display:grid;grid-template-columns:100px 1fr auto;gap:20px;padding:24px 0;border-bottom:1px solid var(--line)}
.cartrow__img{width:100px;aspect-ratio:3/4;object-fit:cover;background:var(--bg-3);filter:grayscale(.35)}
.cartrow__name{font-weight:800;font-size:18px;text-transform:uppercase}
.cartrow__sub{font-family:var(--f-mono);font-size:12px;color:var(--ink-dim);margin-top:7px;letter-spacing:.05em}
.cartrow__right{text-align:right;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end}
.cartrow__price{font-family:var(--f-mono);font-size:16px;color:var(--acid)}
.summary{background:var(--bg-2);border:1px solid var(--line);padding:clamp(24px,3vw,38px);position:sticky;top:calc(var(--nav-h) + 20px)}
.summary h3{font-family:var(--f-display);font-size:30px;text-transform:uppercase;margin-bottom:24px}
.summary__row{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:13px;padding:9px 0;color:var(--ink-dim)}
.summary__row.tot{color:var(--ink);font-size:18px;border-top:1px solid var(--line);margin-top:12px;padding-top:18px}
.summary__row.tot b{color:var(--acid)}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:7px}
.field input,.field select{width:100%;background:var(--bg-3);border:1px solid var(--line);padding:14px 16px;font-size:16px;transition:border .3s}
.field input:focus,.field select:focus{outline:none;border-color:var(--acid)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field--ac{position:relative}
.addr-hint{font-family:var(--f-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-dim);margin-top:8px}
.addr-hint.ok{color:var(--acid)}

/* Custom Places autocomplete dropdown (Data API) — inline modal, themed dark */
.ac-wrap{position:relative}
/* in-flow dropdown: pushes the rest of the form down when open */
.addr-dd{display:none;margin-top:6px;background:var(--bg-2);border:1px solid var(--line);
  max-height:300px;overflow-y:auto}
.addr-dd.open{display:block}
.addr-opt{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:12px 14px;border-bottom:1px solid var(--line-soft);transition:background .15s}
.addr-opt:hover,.addr-opt.active{background:var(--bg-3)}
.addr-opt__m{display:block;color:var(--ink);font-size:14px;line-height:1.25}
.addr-opt__s{display:block;color:var(--ink-dim);font-size:12px;margin-top:2px;font-family:var(--f-mono)}
.addr-dd__attr{padding:8px 14px;font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-dim);text-align:right}
.form-section-title{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--acid);margin:30px 0 18px;display:flex;align-items:center;gap:10px}
.form-section-title::before{content:"";width:24px;height:1px;background:var(--acid)}
.empty-state{text-align:center;padding:clamp(60px,12vw,140px) var(--pad)}
.empty-state h2{font-family:var(--f-display);font-size:clamp(40px,8vw,90px);text-transform:uppercase;margin-bottom:18px}
.empty-state p{color:var(--ink-dim);margin-bottom:30px}

/* order confirmation */
.confirm{text-align:center;padding:clamp(60px,12vw,160px) var(--pad)}
.confirm__check{width:78px;height:78px;border-radius:50%;border:2px solid var(--acid);color:var(--acid);
  display:flex;align-items:center;justify-content:center;font-size:34px;margin:0 auto 30px}
.confirm h1{font-family:var(--f-display);font-size:clamp(44px,9vw,110px);text-transform:uppercase;line-height:.9}
.confirm__no{font-family:var(--f-mono);font-size:13px;letter-spacing:.14em;color:var(--acid);margin:22px 0}
.confirm p{color:var(--ink-dim);max-width:44ch;margin:0 auto 30px;line-height:1.6}

/* ============================================================
   FOOTER (shared)
   ============================================================ */
.footer{margin-top:auto;padding:clamp(50px,7vw,90px) var(--pad) 36px;border-top:1px solid var(--line)}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:50px}
.footer__grid h4{font-family:var(--f-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:16px}
.footer__grid a{display:block;padding:6px 0;transition:.3s var(--ease)}
.footer__grid a:hover{color:var(--acid);padding-left:7px}
.footer__brand p{max-width:32ch;color:var(--ink-dim);font-weight:300;line-height:1.6;font-size:14px}
.footer__logo{font-family:var(--f-display);font-size:22px;margin-bottom:14px}
.footer__logo b{color:var(--acid)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-top:24px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim)}
@media(max-width:680px){.footer__grid{grid-template-columns:1fr}}

/* reveal */
.reveal{opacity:0;transform:translateY(40px)}
.reveal.in{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
