/* ============================================================
   MONOSYSM / OS  —  GARMENT STORE LAYER
   Layers on top of style.css + desktop.css. Owns the commerce
   surfaces that make products the center of the OS:
   design tokens · icon kit · catalog grid · inspection mode ·
   lookbook · release archive · storefront home · toasts · motion.
   Everything reuses the phosphor variables; nothing overrides the
   retro shell. Additive only.
   ============================================================ */

/* ---------------- DESIGN TOKENS (additive) ---------------- */
:root{
  /* 4px spacing scale */
  --sp-1:4px;  --sp-2:8px;  --sp-3:12px; --sp-4:16px;
  --sp-5:24px; --sp-6:32px; --sp-7:48px; --sp-8:64px;
  /* type scale — editorial range from quiet labels to loud display */
  --fs-display:clamp(30px,4.4vw,58px);
  --fs-h1:clamp(20px,2.6vw,32px);
  --fs-h2:clamp(15px,1.7vw,20px);
  --fs-body:13px;
  --fs-sm:11px;
  --fs-label:10px;
  /* motion */
  --ease:cubic-bezier(.2,.7,.2,1);
  --tr:.22s var(--ease);
  --tr-slow:.4s var(--ease);
  /* faint technical grid line */
  --grid-faint:rgba(255,55,10,.06);
}

/* ---------------- ICON KIT ----------------
   Inline SVGs carry currentColor; this just normalises sizing. */
.ico{width:1em;height:1em;display:inline-block;vertical-align:-.12em;flex:none;
  stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:square;stroke-linejoin:miter}
.ico-fill{fill:currentColor;stroke:none}

/* ---------------- SHARED: scanned garment media ----------------
   The loved phosphor-silhouette treatment, generalised so catalog
   cards + inspection + lookbook all render identically. */
.scan{position:relative;background:#000;overflow:hidden}
.scan img{width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(1) invert(1) brightness(.96) contrast(1.22);
  transition:transform var(--tr-slow),filter var(--tr-slow)}
.scan .scan-tint{position:absolute;inset:0;background:var(--phos);mix-blend-mode:multiply;pointer-events:none}
.scan .scan-lines{position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(to bottom,transparent 0 2px,rgba(0,0,0,.32) 2px 3px)}
.scan .scan-grid{position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:linear-gradient(var(--grid-faint),var(--grid-faint)) 50% 0/1px 100% no-repeat,
             linear-gradient(var(--grid-faint),var(--grid-faint)) 0 50%/100% 1px no-repeat}
.scan .scan-ref{position:absolute;top:var(--sp-2);left:var(--sp-2);font-size:9px;letter-spacing:.18em;
  color:var(--phos-dim);background:rgba(0,0,0,.4);padding:2px 5px;z-index:2}
.scan .scan-nofeed{position:absolute;inset:0;display:grid;place-items:center;color:var(--phos-dim);
  font-size:var(--fs-sm);letter-spacing:.2em}
/* ---- progressive scan: light 256px thumb loads first, then reveals ---- */
.scan .scan-img{opacity:0;transition:opacity .35s ease,transform var(--tr-slow),filter var(--tr-slow)}
.scan.loaded .scan-img{opacity:1;animation:scanReveal .6s cubic-bezier(.22,.7,.2,1)}
@keyframes scanReveal{from{clip-path:inset(0 0 100% 0)}to{clip-path:inset(0 0 0 0)}}
/* "RENDERING" construction loader, shown until the image decodes */
.scan .scan-build{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;
  display:grid;place-items:center;transition:opacity .3s ease;background:
    repeating-linear-gradient(to right,var(--grid-faint) 0 1px,transparent 1px 24px),
    repeating-linear-gradient(to bottom,var(--grid-faint) 0 1px,transparent 1px 24px),#000}
.scan.loaded .scan-build{opacity:0}
.scan .scan-build>b{position:absolute;left:0;right:0;top:-16%;height:16%;opacity:.6;
  background:linear-gradient(to bottom,transparent,var(--phos),transparent);
  filter:blur(1px);animation:sbSweep 1.3s linear infinite}
@keyframes sbSweep{from{top:-16%}to{top:100%}}
.scan .scan-build>span{position:relative;z-index:2;font-size:9px;letter-spacing:.32em;color:var(--phos);
  text-shadow:0 0 6px var(--phos);animation:sbBlink 1.1s steps(2,jump-none) infinite}
.scan .scan-build>span::after{content:"";animation:sbDots 1.2s steps(1) infinite}
@keyframes sbBlink{0%,65%{opacity:1}85%,100%{opacity:.4}}
@keyframes sbDots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}
.scan .scan-build>i{position:absolute;left:16%;right:16%;bottom:17%;height:2px;background:var(--grid-faint);z-index:2;overflow:hidden}
.scan .scan-build>i::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--phos);box-shadow:0 0 6px var(--phos);animation:sbFill 1.5s ease-in-out infinite}
@keyframes sbFill{0%{width:0}70%,100%{width:100%}}
/* real-photo records: keep colour, lose the orange wash */
.scan.real{background:radial-gradient(120% 100% at 50% 30%,#dcdcdc 0%,#a9a9a9 48%,#6c6c6c 100%)}
.scan.real img{filter:contrast(1.06) saturate(1.06) brightness(1.02)}
.scan.real .scan-tint{display:none}
.scan.real .scan-lines{opacity:.3}
/* coming-soon records: sealed */
.scan.soon img{filter:grayscale(1) invert(1) brightness(.5) contrast(1.4) blur(3px)}
.scan .soon-band{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);text-align:center;
  font-size:var(--fs-sm);letter-spacing:.4em;color:var(--phos);background:rgba(0,0,0,.45);
  padding:7px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);z-index:2}

/* ---------------- STATUS CHIPS ---------------- */
.chip{display:inline-flex;align-items:center;gap:5px;font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;padding:2px 7px;border:1px solid var(--line);color:var(--phos-dim);white-space:nowrap}
.chip::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;flex:none}
.chip.ok{color:var(--phos);border-color:var(--phos)}
.chip.low{color:var(--phos-hi);border-color:var(--phos-hi)}
.chip.out{color:var(--phos-dim);opacity:.7}
.chip.out::before{background:transparent;box-shadow:inset 0 0 0 1px var(--phos-dim)}
.chip.soon{color:var(--phos);border-color:var(--phos);border-style:dashed}
.chip.plain{border:none;padding:0}
.chip.plain::before{display:none}

/* ============================================================
   PILLAR 1 — GARMENT CATALOG
   ============================================================ */
.cat-head{display:flex;align-items:flex-end;gap:var(--sp-3);flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:var(--sp-3);margin-bottom:var(--sp-4)}
.cat-head .ch-title{font-size:var(--fs-h1);font-weight:800;letter-spacing:.06em;line-height:1}
.cat-head .ch-sub{font-size:var(--fs-label);letter-spacing:.24em;color:var(--phos-dim);text-transform:uppercase}
.cat-head .ch-sp{flex:1}
.cat-head .ch-stat{display:flex;gap:var(--sp-4);font-size:var(--fs-label);letter-spacing:.14em;color:var(--phos-dim)}
.cat-head .ch-stat b{color:var(--phos-hi);font-weight:700}

/* toolbar: search + filters + sort + view toggle */
.cat-bar{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-4)}
.cat-search{display:flex;align-items:center;gap:var(--sp-2);border:1px solid var(--line);
  background:rgba(0,0,0,.3);padding:0 var(--sp-2);flex:1;min-width:180px;transition:border-color var(--tr)}
.cat-search:focus-within{border-color:var(--phos);background:var(--phos-faint)}
.cat-search .ico{font-size:14px;color:var(--phos-dim)}
.cat-search input{flex:1;background:none;border:none;outline:none;color:var(--phos);
  font:inherit;font-size:var(--fs-body);padding:8px 0;text-shadow:0 0 4px var(--glow)}
.cat-search input::placeholder{color:var(--phos-dim);letter-spacing:.08em}
.filterbar{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.fbtn{font:inherit;font-size:var(--fs-label);letter-spacing:.14em;text-transform:uppercase;
  color:var(--phos-dim);border:1px solid var(--line);background:rgba(0,0,0,.2);padding:6px 11px;
  cursor:var(--cur-hand),pointer;transition:all var(--tr);white-space:nowrap}
.fbtn:hover{border-color:var(--phos-dim);color:var(--phos)}
.fbtn.on{background:var(--phos);color:#000;border-color:var(--phos);text-shadow:none;font-weight:700}
.cat-sort{display:flex;align-items:center;gap:6px;font-size:var(--fs-label);letter-spacing:.14em;color:var(--phos-dim)}
.cat-sort select{font:inherit;font-size:var(--fs-label);letter-spacing:.12em;color:var(--phos);
  background:rgba(0,0,0,.35);border:1px solid var(--line);padding:6px 8px;outline:none;cursor:var(--cur-hand),pointer}
.view-toggle{display:flex;border:1px solid var(--line)}
.view-toggle button{width:30px;height:30px;display:grid;place-items:center;color:var(--phos-dim);
  background:rgba(0,0,0,.2);font-size:14px;cursor:var(--cur-hand),pointer;transition:all var(--tr)}
.view-toggle button+button{border-left:1px solid var(--line)}
.view-toggle button.on{background:var(--phos);color:#000}

.filterbar{margin-bottom:var(--sp-4)}
.fb-gap{width:var(--sp-4)}
.fb-sp{flex:1}

/* the grid of garment artifacts */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-3)}
.cat-grid.list{grid-template-columns:1fr;gap:6px}
.cat-empty{border:1px dashed var(--line);padding:var(--sp-7);text-align:center;color:var(--phos-dim);
  letter-spacing:.18em;font-size:var(--fs-sm)}

/* artifact card */
.gcard{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,55,10,.03),rgba(0,0,0,.3));cursor:var(--cur-hand),pointer;
  transition:transform var(--tr),border-color var(--tr),box-shadow var(--tr);overflow:hidden}
.gcard:hover{transform:translateY(-3px);border-color:var(--phos);box-shadow:0 14px 34px rgba(0,0,0,.55)}
.gcard:focus-visible{outline:none;border-color:var(--phos);box-shadow:0 0 0 1px var(--phos)}
.gcard-media{aspect-ratio:4/5}
.gcard:hover .gcard-media img{transform:scale(1.06)}
/* hover scan sweep */
.gcard-media::after{content:"";position:absolute;left:0;right:0;top:-30%;height:30%;z-index:3;
  background:linear-gradient(rgba(255,55,10,.5),transparent);opacity:0;pointer-events:none}
.gcard:hover .gcard-media::after{animation:cardScan .9s var(--ease)}
@keyframes cardScan{0%{opacity:.9;top:-30%}100%{opacity:0;top:115%}}
.gcard .gcard-chip{position:absolute;top:var(--sp-2);right:var(--sp-2);z-index:3;
  background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.gcard-body{padding:var(--sp-3);display:flex;flex-direction:column;gap:3px;flex:1}
.gcard-name{font-size:var(--fs-h2);font-weight:800;letter-spacing:.02em;line-height:1.1}
.gcard-meta{display:flex;align-items:center;gap:8px;font-size:9px;letter-spacing:.16em;
  color:var(--phos-dim);text-transform:uppercase}
.gcard-cw{display:inline-flex;align-items:center;gap:4px}
.gcard-cw i{width:9px;height:9px;border-radius:50%;border:1px solid var(--line);background:var(--sw,#888)}
.gcard-foot{display:flex;align-items:baseline;justify-content:space-between;margin-top:auto;
  padding-top:var(--sp-2);gap:8px}
.gcard-price{font-size:15px;font-weight:800;color:var(--phos-hi);letter-spacing:.01em}
.gcard-price .from{font-size:8px;letter-spacing:.16em;color:var(--phos-dim);font-weight:400;display:block;margin-bottom:1px}
.gcard-inspect{font-size:9px;letter-spacing:.16em;color:var(--phos-dim);text-transform:uppercase;
  display:inline-flex;align-items:center;gap:5px;opacity:0;transition:opacity var(--tr)}
.gcard:hover .gcard-inspect{opacity:1}
.gcard.soon{opacity:.92}
.gcard.out .gcard-media img{opacity:.55}

/* list-mode row variant of the card */
.cat-grid.list .gcard{flex-direction:row;align-items:stretch}
.cat-grid.list .gcard-media{width:92px;aspect-ratio:auto;min-height:108px;flex:none}
.cat-grid.list .gcard-media .scan-ref{display:none}
.cat-grid.list .gcard-media .scan-nofeed{font-size:7px;padding:4px;text-align:center;line-height:1.3}
.cat-grid.list .gcard-body{flex-direction:row;align-items:center;gap:var(--sp-4);flex-wrap:wrap}
.cat-grid.list .gcard-name{min-width:200px;flex:1}
.cat-grid.list .gcard-foot{margin:0;padding:0;flex:none}
.cat-grid.list .gcard-inspect{opacity:1}

/* ============================================================
   PILLAR 2 — PRODUCT INSPECTION MODE
   ============================================================ */
.insp{animation:revealRecord .42s var(--ease) both}
@keyframes revealRecord{0%{opacity:0;clip-path:inset(0 0 100% 0)}
  60%{opacity:1}100%{opacity:1;clip-path:inset(0 0 0 0)}}
.insp-top{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4)}
.insp-back{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-label);letter-spacing:.16em;
  text-transform:uppercase;color:var(--phos-dim);border:1px solid var(--line);padding:7px 12px;
  background:rgba(0,0,0,.2);cursor:var(--cur-hand),pointer;transition:all var(--tr)}
.insp-back:hover{border-color:var(--phos);color:var(--phos)}
.insp-top .insp-div{font-size:var(--fs-label);letter-spacing:.22em;color:var(--phos-dim);text-transform:uppercase}
.insp-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);gap:var(--sp-5);align-items:start}

/* inspection media — large scan with zoom-on-hover */
.insp-media{position:relative}
.insp-stage{aspect-ratio:4/5;border:1px solid var(--line)}
.insp-stage img{cursor:zoom-in}
.insp-stage.zoom img{transform:scale(1.9);cursor:zoom-out}
.insp-corner{position:absolute;width:14px;height:14px;z-index:2;border:1px solid var(--phos);pointer-events:none}
.insp-corner.tl{top:-1px;left:-1px;border-right:none;border-bottom:none}
.insp-corner.tr{top:-1px;right:-1px;border-left:none;border-bottom:none}
.insp-corner.bl{bottom:-1px;left:-1px;border-right:none;border-top:none}
.insp-corner.br{bottom:-1px;right:-1px;border-left:none;border-top:none}
.insp-thumbs{display:flex;gap:6px;margin-top:var(--sp-2);flex-wrap:wrap}
.insp-thumbs i{width:54px;height:54px;border:1px solid var(--line);cursor:var(--cur-hand),pointer;
  background-size:cover;background-position:center;filter:grayscale(1) invert(1);opacity:.55;transition:all var(--tr)}
.insp-thumbs i.on,.insp-thumbs i:hover{opacity:1;border-color:var(--phos)}

/* inspection spec sheet */
.insp-spec{display:flex;flex-direction:column;gap:var(--sp-3)}
.insp-name{font-size:var(--fs-display);font-weight:800;line-height:.95;letter-spacing:-.01em}
.insp-tagrow{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}
.insp-price{font-size:clamp(24px,3vw,38px);font-weight:800;color:var(--phos);letter-spacing:.01em}
.insp-price .cur{font-size:.45em;color:var(--phos-dim);font-weight:400;margin-right:.4em;vertical-align:.18em}
.insp-price .from{font-size:9px;letter-spacing:.18em;color:var(--phos-dim);display:block;margin-bottom:2px}
.specsheet{border:1px solid var(--line);background:rgba(0,0,0,.22)}
.specsheet .ssh{font-size:var(--fs-label);letter-spacing:.22em;color:var(--phos-dim);text-transform:uppercase;
  padding:7px 12px;border-bottom:1px solid var(--line);background:var(--phos-faint)}
.specsheet .ssrow{display:flex;justify-content:space-between;gap:var(--sp-4);font-size:var(--fs-body);
  padding:7px 12px;border-bottom:1px dashed var(--line)}
.specsheet .ssrow:last-child{border-bottom:none}
.specsheet .ssk{color:var(--phos-dim);letter-spacing:.1em}
.specsheet .ssv{font-weight:700;text-align:right}
.insp-block .ibh{font-size:var(--fs-label);letter-spacing:.2em;color:var(--phos-dim);text-transform:uppercase;margin-bottom:var(--sp-2)}
/* colorway picker */
.cwrow{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.cwrow i{width:22px;height:22px;border-radius:50%;border:1px solid var(--line);background:var(--sw,#888);
  cursor:var(--cur-hand),pointer;box-shadow:inset 0 0 0 2px var(--bg);transition:transform var(--tr),box-shadow var(--tr)}
.cwrow i:hover{transform:scale(1.12)}
.cwrow i.on{box-shadow:inset 0 0 0 2px var(--bg),0 0 0 2px var(--phos)}
.cwrow i.depleted{opacity:.35;cursor:not-allowed}
.cwrow .cw-label{margin-left:4px;font-size:var(--fs-sm);letter-spacing:.06em;color:var(--phos)}
/* size matrix (shared visual w/ legacy .smx but cleaner) */
.sizes{display:flex;gap:6px;flex-wrap:wrap}
.sizes i{min-width:42px;text-align:center;border:1px solid var(--line);padding:8px 11px;font-size:var(--fs-sm);
  letter-spacing:.08em;color:var(--phos-dim);transition:all var(--tr)}
.sizes i[data-size]{cursor:var(--cur-hand),pointer}
.sizes i[data-size]:hover{border-color:var(--phos);color:var(--phos)}
.sizes i.on{background:var(--phos);color:#000;border-color:var(--phos);font-weight:700}
.sizes i.depleted{opacity:.3;text-decoration:line-through;cursor:not-allowed}
.insp-notes{font-size:var(--fs-body);line-height:1.7;color:var(--phos-dim);border-left:2px solid var(--line);padding-left:var(--sp-3)}
/* acquisition controls */
.acq-bar{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap;margin-top:var(--sp-2)}
.btn-primary{flex:1;min-width:200px;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  border:none;background:var(--phos);color:#000;font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  padding:14px 18px;font-size:var(--fs-body);cursor:var(--cur-hand),pointer;transition:background var(--tr),transform .08s}
.btn-primary:hover{background:var(--phos-hi)}
.btn-primary:active{transform:translateY(1px)}
.btn-primary.added{background:var(--phos-hi)}

/* ============================================================
   PILLAR 4b — LOOKBOOK EXPLORER
   ============================================================ */
.lookbook{column-count:3;column-gap:var(--sp-3)}
@media(max-width:780px){.lookbook{column-count:2}}
.lb-tile{break-inside:avoid;margin-bottom:var(--sp-3);border:1px solid var(--line);cursor:var(--cur-hand),pointer;
  position:relative;transition:border-color var(--tr);overflow:hidden}
.lb-tile:hover{border-color:var(--phos)}
.lb-tile img{display:block;width:100%;height:auto;object-fit:contain}
.lb-cap{position:absolute;left:0;right:0;bottom:0;padding:var(--sp-3) var(--sp-2) var(--sp-2);z-index:2;
  background:linear-gradient(transparent,rgba(0,0,0,.85));display:flex;justify-content:space-between;
  align-items:flex-end;opacity:0;transition:opacity var(--tr)}
.lb-tile:hover .lb-cap{opacity:1}
.lb-cap .lb-name{font-size:var(--fs-sm);font-weight:800;letter-spacing:.04em}
.lb-cap .lb-ref{font-size:9px;letter-spacing:.16em;color:var(--phos-dim)}

/* ============================================================
   PILLAR 4c — RELEASE ARCHIVE  (drops timeline / inventory)
   ============================================================ */
.rel-wrap{display:flex;flex-direction:column;gap:0}
.rel-item{display:grid;grid-template-columns:120px 1fr;gap:var(--sp-4);padding:var(--sp-4) 0;
  border-bottom:1px solid var(--line);position:relative}
.rel-item:first-child{padding-top:0}
.rel-when{font-size:var(--fs-label);letter-spacing:.18em;color:var(--phos-dim);text-transform:uppercase;padding-top:4px}
.rel-when b{display:block;color:var(--phos);font-size:var(--fs-h2);font-weight:800;letter-spacing:.02em;margin-bottom:3px}
.rel-body{display:flex;align-items:center;gap:var(--sp-4)}
.rel-thumb{width:74px;height:92px;flex:none}
.rel-thumb .scan-ref{display:none}
.rel-thumb .scan-nofeed{font-size:7px;letter-spacing:.04em;padding:4px;text-align:center;line-height:1.3}
.rel-info{display:flex;flex-direction:column;gap:5px}
.rel-info .rel-name{font-size:var(--fs-h2);font-weight:800;letter-spacing:.02em;cursor:var(--cur-hand),pointer}
.rel-info .rel-name:hover{color:var(--phos-hi)}
.rel-info .rel-line{font-size:var(--fs-sm);color:var(--phos-dim);letter-spacing:.06em}

/* ============================================================
   PILLAR 6 — STOREFRONT HOME
   ============================================================ */
.store-home{display:flex;flex-direction:column;gap:var(--sp-6)}
/* featured "latest release" hero */
.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,420px);gap:var(--sp-5);
  border:1px solid var(--line);background:linear-gradient(135deg,rgba(255,55,10,.05),rgba(0,0,0,.35));
  padding:var(--sp-5);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:linear-gradient(var(--grid-faint),var(--grid-faint)) 0 0/100% 28px repeat-y}
.hero-copy{display:flex;flex-direction:column;justify-content:center;gap:var(--sp-3);position:relative;z-index:1}
.hero-kick{font-size:var(--fs-label);letter-spacing:.3em;color:var(--phos-dim);text-transform:uppercase;
  display:flex;align-items:center;gap:9px}
.hero-kick::before{content:"";width:24px;height:1px;background:var(--phos)}
.hero-name{font-size:var(--fs-display);font-weight:800;line-height:.92;letter-spacing:-.01em}
.hero-sub{font-size:var(--fs-body);line-height:1.7;color:var(--phos-dim);max-width:46ch}
.hero-meta{display:flex;gap:var(--sp-4);font-size:var(--fs-label);letter-spacing:.14em;color:var(--phos-dim);margin-top:4px}
.hero-meta b{color:var(--phos-hi);font-weight:700}
.hero-cta{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-top:var(--sp-2)}
.hero-cta .btn-primary{flex:0 1 auto;min-width:0}
.sec-mt{margin-top:var(--sp-6)}
.hero-media{position:relative}
.hero-media .scan{aspect-ratio:4/5;height:100%;border:1px solid var(--line)}
/* section header used across home */
.sec{display:flex;align-items:baseline;gap:var(--sp-3);margin-bottom:var(--sp-3)}
.sec h3{font-size:var(--fs-h2);font-weight:800;letter-spacing:.08em}
.sec .sec-sub{font-size:var(--fs-label);letter-spacing:.2em;color:var(--phos-dim);text-transform:uppercase}
.sec .sec-line{flex:1;height:1px;background:var(--line)}
.sec .sec-all{font-size:var(--fs-label);letter-spacing:.14em;color:var(--phos-dim);text-transform:uppercase;
  cursor:var(--cur-hand),pointer;display:inline-flex;align-items:center;gap:6px}
.sec .sec-all:hover{color:var(--phos)}
/* quick division tiles */
.divtiles{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
@media(max-width:620px){.divtiles{grid-template-columns:1fr}}
.divtile{border:1px solid var(--line);background:rgba(0,0,0,.28);padding:var(--sp-4);cursor:var(--cur-hand),pointer;
  display:flex;flex-direction:column;gap:var(--sp-2);transition:all var(--tr);position:relative;overflow:hidden}
.divtile:hover{border-color:var(--phos);background:var(--phos-faint)}
.divtile .dt-logo{height:26px;background:var(--phos);
  -webkit-mask:var(--m) left center/contain no-repeat;mask:var(--m) left center/contain no-repeat}
.divtile .dt-id{font-size:9px;letter-spacing:.2em;color:var(--phos-dim)}
.divtile .dt-desc{font-size:var(--fs-sm);line-height:1.6;color:var(--phos-dim)}
.divtile .dt-foot{display:flex;justify-content:space-between;font-size:9px;letter-spacing:.16em;color:var(--phos-dim);
  border-top:1px solid var(--line);padding-top:var(--sp-2);margin-top:auto}

/* ============================================================
   SYSTEM NOTIFICATIONS (toast stack)
   ============================================================ */
#toasts{position:absolute;top:14px;right:14px;z-index:90;display:flex;flex-direction:column;gap:8px;
  pointer-events:none;max-width:300px}
.toast{pointer-events:auto;border:1px solid var(--phos);background:rgba(8,4,2,.95);
  box-shadow:0 10px 30px rgba(0,0,0,.6),0 0 0 1px rgba(255,55,10,.15);
  padding:11px 13px;display:flex;gap:10px;align-items:flex-start;
  animation:toastIn .26s var(--ease) both}
.toast.out{animation:toastOut .3s var(--ease) forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateX(24px)}}
.toast .t-ico{color:var(--phos);font-size:15px;line-height:1;margin-top:1px}
.toast .t-tx{display:flex;flex-direction:column;gap:3px;min-width:0}
.toast .t-title{font-size:var(--fs-sm);letter-spacing:.12em;color:var(--phos);font-weight:700;text-transform:uppercase}
.toast .t-sub{font-size:10px;letter-spacing:.06em;color:var(--phos-dim);line-height:1.5}
.toast .t-bar{position:absolute;left:0;bottom:0;height:2px;background:var(--phos);animation:toastBar 2.6s linear forwards}
@keyframes toastBar{from{width:100%}to{width:0}}

/* ============================================================
   RECORD LOADING SEQUENCE  (brief, intentional)
   ============================================================ */
.record-load{position:absolute;inset:0;z-index:20;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:var(--sp-3);animation:fadeQuick .12s ease both}
@keyframes fadeQuick{from{opacity:0}to{opacity:1}}
.record-load .rl-txt{font-size:var(--fs-sm);letter-spacing:.24em;color:var(--phos-dim);text-transform:uppercase}
.record-load .rl-bar{width:min(240px,60%);height:4px;border:1px solid var(--phos-dim);padding:1px}
.record-load .rl-bar i{display:block;height:100%;width:0;background:var(--phos);animation:rlFill .5s var(--ease) forwards}
@keyframes rlFill{to{width:100%}}

/* ============================================================
   MOTION — window open / close transitions
   ============================================================ */
.win{animation:winOpen .2s var(--ease) both}
@keyframes winOpen{from{opacity:0;transform:scale(.985) translateY(8px)}to{opacity:1;transform:none}}
.win.closing{animation:winClose .18s var(--ease) forwards;pointer-events:none}
@keyframes winClose{to{opacity:0;transform:scale(.98) translateY(6px)}}
/* drawers get a smoother slide */
.drawer{animation:drawerSlide .26s var(--ease) both}
@keyframes drawerSlide{from{transform:translateX(28px);opacity:0}to{transform:none;opacity:1}}

/* ============================================================
   CRT GLASS OVERLAYS  (light only — no geometry distortion)
   Flat overlays above the UI (pointer-events:none): a soft static
   sheen, an edge vignette, and phosphor glow. Cheap, and the text
   geometry never distorts so readability is fully preserved.
   ============================================================ */
.desk-area::before{display:none}             /* old per-area glare — superseded */
.crt-aberr{display:none}                     /* harsh colour fringe — off */
.crt-roll{display:none!important}            /* running white scan bar — off */

/* soft, STATIC glass sheen — a restrained reflection, never a moving line */
.crt-glass{position:absolute;inset:0;pointer-events:none;z-index:51;
  background:
    radial-gradient(155% 70% at 50% -10%, rgba(255,255,255,.05), transparent 38%),
    radial-gradient(55% 45% at 80% 10%, rgba(255,255,255,.022), transparent 72%);
}
[data-crt="off"] .crt-glass{display:none}

/* edge vignette — frames the screen; centre stays clear for reading */
.crt-vig{
  background:radial-gradient(140% 135% at 50% 50%, transparent 58%, rgba(0,0,0,.30) 88%, rgba(0,0,0,.5) 100%);
  box-shadow:inset 0 0 80px rgba(0,0,0,.32);
}
/* phosphor glow — subtle */
.crt-glow{opacity:.26}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:780px){
  .insp-grid{grid-template-columns:1fr}
  .hero{grid-template-columns:1fr}
  .hero-media{order:-1;max-height:340px}
  .cat-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .rel-item{grid-template-columns:1fr;gap:var(--sp-2)}
}
@media(max-width:560px){
  .cat-grid{grid-template-columns:1fr 1fr}
  .lookbook{column-count:1}
  .cat-bar{gap:6px}
}
@media(prefers-reduced-motion:reduce){
  .insp,.win,.drawer,.toast,.record-load .rl-bar i,.gcard:hover .gcard-media::after{animation:none}
  .scan img,.gcard,.toast{transition:none}
}

/* ============================================================
   OS SHELL OVERHAUL — boot · login · taskbar console · sidebar ·
   compact cart · fullscreen explorer · polish
   ============================================================ */
:root{ --scan-op:.16; --noise-op:.035; }     /* scanlines/noise dialled down (modern, subtle) */

/* ---------- fixed viewport ---------- */
html,body{height:100%;overflow:hidden;overscroll-behavior:none;touch-action:manipulation}

/* ---------- BOOT (logo only, gentle breathing) ---------- */
.boot-splash{background:radial-gradient(60% 60% at 50% 50%, #15110c 0%, #0a0705 52%, #000 100%)}
.bs-logo{animation:bsBreathe 3.6s ease-in-out infinite}
@keyframes bsBreathe{
  0%,100%{transform:scale(.99);filter:drop-shadow(0 0 12px var(--phos))}
  50%{transform:scale(1.02);filter:drop-shadow(0 0 30px var(--phos))}
}

/* ---------- LOGIN (breathing logo settles left · access panel reveals right) ---------- */
.login-screen{position:absolute;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(60% 60% at 50% 44%, #16120d 0%, #0a0705 56%, #000 100%);animation:fadein .4s ease both}
.login-stage{display:flex;align-items:center;gap:clamp(28px,4.5vw,60px)}
/* slot carries the left-slide; inner logo keeps the gentle breathing (separate transforms).
   Resting state = natural left position; `.intro` seeds it shifted-right (screen-centred). */
.login-logo-slot{flex:none;transform:none;transition:transform .9s cubic-bezier(.22,1,.36,1)}
.login-screen.intro .login-logo-slot{transform:translateX(var(--login-shift,0px));transition:none}
/* same size + glow as the pre-JS boot emblem so the hand-off is invisible and the glide reads as one motion */
.login-logo{width:clamp(100px,12vw,150px);aspect-ratio:1;background:var(--phos);
  -webkit-mask:url("../assets/Monosysm_IconAlt.svg") center/contain no-repeat;
          mask:url("../assets/Monosysm_IconAlt.svg") center/contain no-repeat;
  filter:drop-shadow(0 0 22px var(--phos));animation:bsBreathe 3.6s ease-in-out infinite}
.login-aside{display:flex;flex-direction:column;gap:var(--sp-3);width:min(320px,74vw);
  border-left:1px solid var(--line);padding-left:clamp(22px,3.4vw,42px);
  opacity:1;transform:none;transition:opacity .6s ease .34s, transform .6s ease .34s}
.login-screen.intro .login-aside{opacity:0;transform:translateX(26px);transition:none;pointer-events:none}
.login-sub{font-size:var(--fs-label);letter-spacing:.3em;color:var(--phos-dim);text-transform:uppercase}
.login-actions{display:flex;flex-direction:column;gap:var(--sp-2)}

/* interactive access buttons: a fill / sheen SWEEPS in on hover, arrow nudges, index tag lights */
.login-btn{position:relative;overflow:hidden;isolation:isolate;
  display:flex;align-items:center;gap:11px;width:100%;padding:14px 16px;
  font:inherit;font-size:var(--fs-sm);letter-spacing:.2em;text-transform:uppercase;
  border:1px solid var(--phos-dim);background:rgba(0,0,0,.32);color:var(--phos);
  cursor:var(--cur-hand),pointer;transition:color .22s ease,border-color .22s ease,box-shadow .22s ease}
.login-btn > *{position:relative;z-index:1}
.login-btn::before{content:"";position:absolute;inset:0;z-index:0;background:var(--phos);
  transform:translateX(-101%);transition:transform .32s cubic-bezier(.7,0,.2,1)}
.login-btn .lb-tag{font-size:9px;letter-spacing:.05em;color:var(--phos-dim);
  border:1px solid var(--line);padding:2px 5px;transition:color .22s,border-color .22s}
.login-btn .lb-txt{flex:1;text-align:left}
.login-btn .lb-arrow{opacity:.55;transition:transform .22s ease,opacity .22s ease}
.login-btn:hover{color:#000;border-color:var(--phos);box-shadow:0 0 16px var(--phos-faint)}
.login-btn:hover::before{transform:translateX(0)}
.login-btn:hover .lb-tag{color:#000;border-color:rgba(0,0,0,.4)}
.login-btn:hover .lb-arrow{transform:translateX(5px);opacity:1}
.login-btn:active{transform:translateY(1px)}
.login-btn:focus-visible{outline:2px solid var(--phos);outline-offset:2px}
/* BACK button nudges its arrow LEFT instead */
.login-btn .lb-back{opacity:.7}
.login-btn:hover .lb-back{transform:translateX(-5px)}
/* primary = already lit: a bright sheen sweeps across instead of a solid fill */
.login-btn.primary{background:var(--phos);color:#000;border-color:var(--phos);font-weight:800;text-shadow:none}
.login-btn.primary .lb-tag{color:#000;border-color:rgba(0,0,0,.35)}
.login-btn.primary .lb-arrow{opacity:.85}
.login-btn.primary::before{background:linear-gradient(100deg,transparent 22%,rgba(255,255,255,.6),transparent 78%)}
.login-btn.primary:hover{color:#000;box-shadow:0 0 22px var(--phos)}
.login-btn.primary:hover::before{transform:translateX(101%)}
.login-btn.primary:hover .lb-arrow{transform:translateX(5px);opacity:1}
.login-form{display:flex;flex-direction:column;gap:var(--sp-2);width:100%;animation:fadein .25s ease both}
.login-input{width:100%;padding:12px 14px;font:inherit;font-size:var(--fs-body);letter-spacing:.1em;
  background:rgba(0,0,0,.35);border:1px solid var(--line);color:var(--phos);outline:none;text-shadow:0 0 4px var(--glow)}
.login-input::placeholder{color:var(--phos-dim);letter-spacing:.18em}
.login-input:focus{border-color:var(--phos);background:var(--phos-faint)}
.login-note{font-size:9px;letter-spacing:.1em;margin-top:4px}
@media(prefers-reduced-motion:reduce){
  .login-logo-slot,.login-aside{transition:none!important}
  .login-logo{animation:none}
}

/* ---------- TASKBAR console (a SUNKEN, writable command field — looks typed-into, not a button) ---------- */
.taskbar{align-items:center;gap:0}
.tb-console{flex:1;min-width:0;display:flex;align-items:center;gap:9px;height:64%;margin:0 10px;padding:0 12px;
  border:1px solid var(--line);border-radius:2px;background:rgba(0,0,0,.58);
  box-shadow:inset 0 1px 4px rgba(0,0,0,.65);cursor:text;transition:border-color var(--tr),background var(--tr)}
.tb-console:hover{border-color:var(--phos-dim)}
.tb-console:focus-within{border-color:var(--phos);background:rgba(0,0,0,.5)}
.tb-console .con-icon{flex:none;width:13px;height:13px;background:var(--phos-dim);
  -webkit-mask:var(--icon-mono) center/contain no-repeat;mask:var(--icon-mono) center/contain no-repeat}
.tb-console:focus-within .con-icon{background:var(--phos)}
.tb-console .con-prompt{color:var(--phos);white-space:nowrap;font-size:12px;letter-spacing:.04em;font-weight:700}
.tb-console .cmd-wrap{position:relative;flex:1;display:flex;min-width:0}
.tb-console .cmd-input{width:100%;background:none;border:none;outline:none;color:var(--phos);
  caret-color:var(--phos);text-shadow:0 0 4px var(--glow);font-size:13px}
.tb-console .cmd-ghost{position:absolute;left:0;top:0;color:var(--phos-dim);pointer-events:none;white-space:pre;opacity:.55}
.tb-console .con-hint{flex:none;font-size:8.5px;letter-spacing:.16em;color:var(--phos-dim);border:1px solid var(--line);
  padding:2px 6px;opacity:.7}
.tb-console:focus-within .con-hint{opacity:1;border-color:var(--phos-dim)}
/* terminal scrollback now drops UP from the taskbar */
.console-out{top:auto;bottom:0;border-top:1px solid var(--phos);border-bottom:none;
  box-shadow:0 -14px 36px rgba(0,0,0,.7);max-height:52%}

/* ---------- TRAY cart button (a RAISED pill — clearly pressable, distinct from the sunken console) ---------- */
.tray-cart{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--phos-dim);border-radius:4px;
  background:linear-gradient(180deg,#22110a,#150a06);box-shadow:inset 0 1px 0 rgba(255,120,80,.16);
  padding:7px 13px;font-size:var(--fs-label);letter-spacing:.16em;color:var(--phos);text-transform:uppercase;
  cursor:var(--cur-hand),pointer;transition:all var(--tr)}
.tray-cart .ico{width:15px;height:15px}
.tray-cart .tc-label{font-weight:700}
.tray-cart:hover{border-color:var(--phos);background:var(--phos-faint);box-shadow:inset 0 1px 0 rgba(255,120,80,.3)}
.tray-cart.live{border-color:var(--phos)}
.tray-cart .cart-count{background:var(--phos);color:#000;font-weight:800;font-size:10px;
  min-width:16px;height:16px;padding:0 4px;display:inline-grid;place-items:center;border-radius:2px}

/* ---------- SIDEBAR: tree expands, diagnostics anchored bottom ---------- */
.win.explorer .sidebar{display:flex;flex-direction:column;gap:8px;overflow:hidden}
.win.explorer .sidebar .tree-panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.win.explorer .sidebar .tree-panel .tree{flex:1;overflow:auto;padding:8px 0}
.win.explorer .sidebar .meters{flex:none}
/* a touch more breathing room + clearer active state in the tree */
.tree li{padding:6px 12px}
.tree li.file.active{box-shadow:inset 2px 0 0 #000}

/* ---------- START MENU monitor-mode row ---------- */
.sm-modes-row{display:flex;align-items:center;gap:11px;padding:7px 16px;color:var(--phos)}
.sm-modes-row .sm-modes-lbl{flex:1;font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.sm-modes-row .modes{display:flex;gap:5px;padding:0}
.sm-modes-row .mode-btn{width:17px;height:17px;padding:0;border:1px solid var(--line);border-radius:50%;
  display:grid;place-items:center;transition:all var(--tr)}
.sm-modes-row .mode-btn .mode-sw{width:11px;height:11px;border:none;border-radius:50%}
.sm-modes-row .mode-btn:hover{border-color:var(--phos-dim)}
.sm-modes-row .mode-btn.active{border-color:var(--phos);box-shadow:0 0 0 1px var(--phos)}

/* ---------- CART (compact floating popup above the tray) ---------- */
.drawer.cart-panel{
  right:10px;bottom:10px;left:auto;top:auto;width:min(330px,92vw);height:auto;max-height:72%;
  animation:cartPop .18s var(--ease) both}
@keyframes cartPop{from{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:none}}
.drawer.cart-panel .drawer-head{flex:none}
.drawer-head .dh-title{display:inline-flex;align-items:center;gap:8px}
.drawer-head .dh-title .ico{width:14px;height:14px}
.mc-body{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column}
.mc-empty{padding:30px 18px;text-align:center;color:var(--phos-dim);letter-spacing:.1em;font-size:var(--fs-sm);
  display:flex;flex-direction:column;gap:16px;align-items:center}
.mc-browse{border:1px solid var(--phos);background:var(--phos-faint);color:var(--phos);padding:9px 14px;
  font:inherit;font-size:var(--fs-label);letter-spacing:.16em;cursor:var(--cur-hand),pointer}
.mc-browse:hover{background:var(--phos);color:#000}
.mc-lines{display:flex;flex-direction:column}
.mc-line{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:9px;
  padding:10px 14px;border-bottom:1px solid var(--line)}
.mc-name{font-size:var(--fs-sm);font-weight:700;letter-spacing:.04em;display:flex;flex-direction:column;gap:2px;min-width:0}
.mc-name small{color:var(--phos-dim);font-weight:400;letter-spacing:.05em;font-size:9.5px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-qty{display:flex;align-items:center;border:1px solid var(--line)}
.mc-qty button{width:21px;height:21px;color:var(--phos);font-weight:700;line-height:1;cursor:var(--cur-hand),pointer}
.mc-qty button:hover{background:var(--phos);color:#000}
.mc-qty b{min-width:20px;text-align:center;font-size:var(--fs-sm);font-weight:700}
.mc-price{font-size:var(--fs-sm);font-weight:700;color:var(--phos-hi);white-space:nowrap}
.mc-rm{width:20px;height:20px;color:var(--phos-dim);cursor:var(--cur-hand),pointer;display:grid;place-items:center}
.mc-rm .ico{width:12px;height:12px}
.mc-rm:hover{color:var(--phos)}
.mc-totals{padding:12px 14px;border-bottom:1px solid var(--line)}
.mc-totals .kv{display:flex;justify-content:space-between;gap:10px;padding:3px 0;font-size:var(--fs-sm)}
.mc-totals .kv b{color:var(--phos-hi)}
.mc-totals .kv.grand{border-top:1px solid var(--line);margin-top:5px;padding-top:8px}
.mc-totals .kv.grand b{font-size:var(--fs-h2);font-weight:800}
.mc-actions{padding:12px 14px;display:flex;flex-direction:column;gap:8px;flex:none}
.mc-actions .btn-primary{width:100%;padding:12px}
.mc-clear{border:1px solid var(--line);background:none;color:var(--phos-dim);padding:9px;
  font:inherit;font-size:var(--fs-label);letter-spacing:.16em;text-transform:uppercase;cursor:var(--cur-hand),pointer}
.mc-clear:hover{border-color:var(--phos);color:var(--phos)}

/* ---------- FULLSCREEN EXPLORER polish ---------- */
.win.explorer.max{border:none;box-shadow:none}
.win-bar{padding:10px 14px}
.win-title{font-size:12px;letter-spacing:.24em}
.win-btn{width:34px;height:26px;font-size:14px}
.win.explorer .win-body{padding:10px}
.win.explorer .workspace{gap:10px}
.win.explorer .sidebar{width:240px}
.crumb{padding:12px 18px;letter-spacing:.08em}
.win.explorer .view{padding:clamp(18px,2vw,30px)}

/* fade the wallpaper back (it only shows behind a restored window) */
.wallpaper{opacity:.85}

@media(max-width:780px){
  /* on narrow screens stack the logo over the panel (no horizontal slide) */
  .login-stage{flex-direction:column;gap:22px}
  .login-aside{width:min(320px,86vw);border-left:none;border-top:1px solid var(--line);
    padding-left:0;padding-top:18px;text-align:center}
  .login-logo-slot{transform:none!important}
  .login-actions{align-items:stretch}
  .tb-console .con-prompt{display:none}
  .win.explorer .win-body{padding:6px}
  .win.explorer .workspace{flex-direction:column;gap:6px;min-height:0}
  /* sidebar becomes a short, scrollable strip up top; viewport keeps the rest.
     vh-based caps avoid the percentage-height collapse that flattened the view. */
  .win.explorer .sidebar{width:100%;flex:0 0 auto;flex-direction:column;overflow:visible}
  .win.explorer .sidebar .meters{display:none}      /* reclaim space on mobile */
  .win.explorer .sidebar .tree-panel{min-height:0}
  .win.explorer .sidebar .tree-panel .tree{max-height:22vh}
  .win.explorer .viewport{flex:1 1 auto;min-height:52vh}
  /* cart = full-width bottom-sheet resting on the taskbar (was an off-screen floating popup).
     containing block (#desktop) already ends at the taskbar, so bottom:0 sits flush above it. */
  .drawer.cart-panel{left:0;right:0;bottom:0;top:auto;
    width:100%;max-width:100%;max-height:72vh;
    border-left:none;border-right:none;border-bottom:none}
}
