/* == RESET == */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;}
input,button,select,textarea{-webkit-appearance:none;appearance:none;border-radius:0;font-family:inherit;}
input[type="file"]{display:none;}

/* == TOKENS == */
:root{
  --app-max-width:520px;
  --bg:#0A0A0A;--bg2:#111111;--bg3:#1A1A1A;--bg4:#242424;--bg5:#2C2C2C;
  --line:#2C2C2C;--mid:#5A5A5A;--text:#E8E4DC;--white:#F5F2EC;
  --accent:#E8834A;--green:#6BAA7C;--amber:#D4A843;--red:#C45252;--blue:#7A9CC4;
  --fd:'Cormorant Garamond',Georgia,serif;
  --fu:'Syne','SF Pro Display',-apple-system,sans-serif;
  /* iOS safe areas */
  --sat:env(safe-area-inset-top,48px);
  --sar:env(safe-area-inset-right,0px);
  --sab:env(safe-area-inset-bottom,34px);
  --sal:env(safe-area-inset-left,0px);
  --nav:58px;
  --r:16px;
  /* spacing scale */
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;
}

/* == BASE == */
html{height:100%;width:100%;}
body{
  height:100%;
  min-height:100vh;
  width:100%;
  background:var(--bg);
  color:var(--text);
  font-family:var(--fu);
  -webkit-font-smoothing:antialiased;
  display:flex;
  justify-content:center;
  overscroll-behavior:none;
}

.page{min-height:calc(100vh - 70px);}

img{
  max-width:100%;
  height:auto;
  display:block;
  image-rendering:auto;
}

/* == SHELL == */
.shell{
  width:100%;
  max-width:var(--app-max-width);
  height:100%;
  margin:0 auto;
  background:var(--bg);

  display:flex;
  flex-direction:column;

  padding-top:var(--sat);
  position:relative;
  overflow:hidden;
  border-radius:18px;
}

/* == PAGES == */
.page{
  flex:1;min-height:0;
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-y:contain;
  scrollbar-width:none;
  display:none;
  padding-bottom:calc(var(--nav) + var(--sab) + 16px);
  transform:translateZ(0);
}
.page::-webkit-scrollbar{display:none;}
.page.active{display:block;animation:pageIn .24s cubic-bezier(.2,.8,.2,1) both;}
#pg-feed.active{display:flex;flex-direction:column;overflow:hidden;animation:pageIn .24s cubic-bezier(.2,.8,.2,1) both;}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.page-exit{animation:pageOut .2s ease forwards!important;pointer-events:none;}
@keyframes pageOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}

/* Respect user's motion preferences (accessibility + App Store requirement) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  /* Explicitly zero out named animations that rely on transform */
  .page.active, #pg-feed.active, .page-exit { animation: none !important; }
  .offline-banner { animation: none !important; }
  .fls-shimmer, .skel-block { animation: none !important; }
  .stack-card-img { transition: none !important; }
  .soc-skeleton .sk-line, .soc-skeleton .sk-rect,
  .soc-skeleton .sk-av, .soc-skeleton .sk-badge { animation: none !important; opacity: .35; }
}

/* == OFFLINE BANNER == */
.offline-banner{
  position:absolute;top:var(--sat);left:0;right:0;z-index:600;
  background:rgba(212,168,67,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  padding:9px 16px;text-align:center;
  font-size:11px;font-family:var(--fu);font-weight:700;letter-spacing:.06em;
  color:#0A0A0A;line-height:1.4;
  animation:slideDown .25s ease;
}
@keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}

/* == BOTTOM NAV == */
.bnav{
  position:absolute;bottom:0;left:0;right:0;
  height:calc(var(--nav) + var(--sab));
  padding-bottom:var(--sab);
  background:rgba(14,14,14,.97);
  backdrop-filter:saturate(180%) blur(24px);
  -webkit-backdrop-filter:saturate(180%) blur(24px);
  border-top:1px solid rgba(255,255,255,.06);
  display:none;align-items:stretch;z-index:50;
  flex-shrink:0;
}
.bnav.show{display:flex;}
.bnav-btn{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:3px;background:none;border:none;cursor:pointer;
  color:var(--mid);transition:color .18s;
  padding-top:6px;padding-bottom:0;
  -webkit-user-select:none;user-select:none;
}
.bnav-btn.on{color:var(--accent);}
.bnav-btn:active{opacity:.7;}
.bnav-icon{font-size:21px;line-height:1;transition:transform .18s;}
.bnav-btn.on .bnav-icon{transform:scale(1.1);}
/* 5 items — shrink label slightly so they all fit */
.bnav-label{font-size:8px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;font-family:var(--fu);}
.bnav-icon{font-size:18px;}
/* Active indicator dot */
.bnav-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:0;transition:opacity .18s;margin-top:2px;}
.bnav-btn.on .bnav-dot{opacity:1;}

/* == KEY SCREEN == */
#pg-key{
  display:none;flex-direction:column;
  align-items:center;justify-content:center;
  min-height:calc(100dvh - var(--sat));
  padding:36px 24px;gap:24px;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
#pg-key.active{display:flex;}

.logo-wrap{text-align:center;}
.logo{font-family:var(--fd);font-size:52px;font-weight:300;color:var(--white);letter-spacing:.03em;line-height:1;}
.logo span{color:var(--accent);}
.logo-tag{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--mid);margin-top:7px;}

.key-card{
  width:100%;background:var(--bg2);
  border:1px solid var(--line);border-radius:22px;
  padding:22px;display:flex;flex-direction:column;gap:14px;
}
.kc-head{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;}
.kc-desc{font-size:13px;color:var(--mid);line-height:1.65;}
.kc-desc a{color:var(--accent);text-decoration:none;}

.ki-wrap{position:relative;}
.ki{
  width:100%;background:var(--bg3);border:1.5px solid var(--line);
  border-radius:12px;padding:15px 46px 15px 16px;
  font-family:var(--fu);font-size:16px;color:var(--white);
  outline:none;letter-spacing:.03em;transition:border-color .2s;
}
.ki:focus{border-color:var(--accent);}
.ki::placeholder{color:var(--mid);}
.ki-eye{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--mid);cursor:pointer;
  font-size:17px;padding:4px;line-height:1;
}

/* Saved key indicator */
.key-saved-banner{
  background:rgba(107,170,124,.1);border:1px solid rgba(107,170,124,.25);
  border-radius:12px;padding:12px 16px;
  font-size:13px;color:var(--green);line-height:1.5;
  display:none;align-items:center;gap:10px;
}
.key-saved-banner.show{display:flex;}
.key-saved-banner button{margin-left:auto;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);background:none;border:none;cursor:pointer;font-family:var(--fu);font-weight:700;white-space:nowrap;}

.key-btn{
  width:100%;padding:16px;border-radius:100px;
  background:var(--accent);color:#0A0A0A;
  font-family:var(--fu);font-size:13px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  border:none;cursor:pointer;
  transition:opacity .15s,transform .1s;
}
.key-btn:active{opacity:.85;transform:scale(.98);}
.key-btn:disabled{opacity:.3;cursor:not-allowed;transform:none;}

.key-note{font-size:11px;color:var(--mid);text-align:center;line-height:1.75;padding:0 8px;}
.key-note a{color:var(--accent);text-decoration:none;}
.key-err{
  width:100%;background:rgba(196,82,82,.08);border:1px solid rgba(196,82,82,.25);
  border-radius:12px;padding:12px 16px;font-size:13px;color:var(--red);
  line-height:1.5;display:none;
}
.key-err.show{display:block;}

/* == SHARED HEADER == */
.hdr{
  padding:14px 20px 0;
  padding-right:190px;
  display:flex;justify-content:space-between;align-items:center;
  flex-shrink:0;
}
.hdr-left{}
.hdr-logo{font-family:var(--fd);font-size:26px;font-weight:300;color:var(--white);line-height:1;}
.hdr-logo span{color:var(--accent);}
.hdr-sub{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-top:2px;}
.hdr-right{display:flex;gap:8px;align-items:center;}
.hdr-btn{
  font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--mid);background:var(--bg3);border:1px solid var(--line);
  border-radius:100px;padding:7px 13px;cursor:pointer;
  font-family:var(--fu);font-weight:700;
  transition:color .15s,border-color .15s;
}
.hdr-btn:hover{color:var(--text);border-color:var(--mid);}

/* == CONTEXT PILLS == */
.ctx-row{
  display:flex;gap:7px;padding:12px 16px 0;
  overflow-x:auto;scrollbar-width:none;flex-shrink:0;
}
.ctx-row::-webkit-scrollbar{display:none;}
.ctx-pill{
  flex-shrink:0;background:var(--bg2);border:1px solid var(--line);
  border-radius:10px;padding:8px 12px;
  display:flex;align-items:center;gap:7px;
}
.cp-icon{font-size:14px;line-height:1;}
.cp-v{font-size:11px;font-weight:700;color:var(--white);}
.cp-s{font-size:10px;color:var(--mid);margin-top:1px;}

/* == OCCASION == */
.occ-wrap{margin:12px 16px 0;flex-shrink:0;}
.occ-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:7px;}
.occ-input{
  width:100%;background:var(--bg2);border:1.5px solid var(--line);
  border-radius:12px;padding:12px 16px;
  font-family:var(--fu);font-size:16px;color:var(--white);
  outline:none;transition:border-color .2s;
}
.occ-input:focus{border-color:var(--accent);}
.occ-input::placeholder{color:var(--mid);}

/* == UPLOAD ZONE == */
.upload-zone{
  margin:12px 16px 0;border-radius:22px;
  background:var(--bg2);border:1.5px dashed rgba(255,255,255,.08);
  aspect-ratio:3/4;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;position:relative;overflow:hidden;
  transition:border-color .25s;
  /* iOS momentum fix */
  -webkit-overflow-scrolling:auto;
}
.upload-zone:active{border-color:rgba(232,131,74,.5);}
.upload-zone.has-photo{border-style:solid;border-color:rgba(255,255,255,.06);}

#outfit-img{width:100%;height:100%;object-fit:cover;display:none;}
.upload-zone.has-photo #outfit-img{display:block;}

.upload-ph{display:flex;flex-direction:column;align-items:center;gap:14px;padding:0 32px;text-align:center;}
.upload-zone.has-photo .upload-ph{display:none;}
.upload-icon{width:66px;height:66px;border-radius:50%;background:var(--bg3);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:28px;}
.upload-title{font-family:var(--fd);font-size:22px;color:var(--white);font-weight:300;}
.upload-sub{font-size:12px;color:var(--mid);line-height:1.6;}

.photo-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.95) 0%,rgba(10,10,10,.1) 50%,transparent 100%);
  display:none;flex-direction:column;justify-content:flex-end;padding:18px;
}
.upload-zone.has-photo .photo-overlay{display:flex;}
.pov-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(232,228,220,.4);margin-bottom:4px;}
.pov-vibe{font-family:var(--fd);font-size:19px;color:var(--white);font-style:italic;font-weight:300;line-height:1.2;}

.score-badge{
  position:absolute;top:14px;right:14px;
  background:rgba(10,10,10,.75);
  transform:scale(0);
  opacity:0;
  transition:all .35s cubic-bezier(.2,.8,.2,1);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:14px;padding:8px 14px;text-align:center;
  border:1px solid rgba(255,255,255,.07);display:none;
}
.sb-num{font-family:var(--fd);font-size:40px;font-weight:300;line-height:1;}
.sb-den{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);margin-top:2px;}

/* == ACTION BUTTONS == */
.cta-row{display:flex;gap:10px;margin:10px 16px 0;flex-shrink:0;}
.btn{
  flex:1;padding:14px 16px;border-radius:100px;
  font-family:var(--fu);font-size:12px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  border:none;cursor:pointer;transition:all .15s;
  /* iOS active state */
  -webkit-user-select:none;user-select:none;
}
.btn:active{transform:scale(.96);}
.btn:disabled{opacity:.3;cursor:not-allowed;transform:none !important;}
.btn-accent{background:var(--accent);color:#0A0A0A;}
.btn-ghost{background:var(--bg3);color:var(--text);border:1px solid var(--line);}

/* == ANALYSING == */
.analysing-wrap{
  margin:14px 16px 0;border-radius:22px;
  background:var(--bg2);border:1px solid var(--line);
  padding:28px 22px;
  display:none;flex-direction:column;align-items:center;gap:18px;
  flex-shrink:0;
}
.analysing-wrap.show{display:flex;}
.aimg-box{position:relative;border-radius:14px;overflow:hidden;width:120px;height:152px;flex-shrink:0;}
.aimg{width:100%;height:100%;object-fit:cover;display:block;}
.scan-bar{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  animation:scandown 1.8s ease-in-out infinite;
}
@keyframes scandown{0%{top:0;opacity:1}100%{top:152px;opacity:.1}}
.a-text{font-family:var(--fd);font-size:20px;color:var(--white);font-weight:300;text-align:center;}
.analysing-msg{
  font-family:var(--fu);
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--mid);
  opacity:.9;
  margin-top:-2px;
  transition:opacity .25s ease, transform .25s ease;
}
.a-sub{font-size:11px;color:var(--mid);text-align:center;}
.prog-track{width:100%;height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;}
.prog-fill{
  height:100%;
  background:linear-gradient(90deg,var(--accent),#f09a63);
  border-radius:2px;
  width:0%;
  transition:width .6s ease;
  box-shadow:0 0 6px rgba(232,131,74,.35);
}
/* == ERROR == */
.err-wrap{
  margin:14px 16px 0;border-radius:16px;
  background:rgba(196,82,82,.07);border:1px solid rgba(196,82,82,.22);
  padding:18px;display:none;flex-shrink:0;
}
.err-wrap.show{display:block;}
.err-title{font-size:14px;font-weight:700;color:var(--red);margin-bottom:5px;}
.err-msg{font-size:12px;color:var(--mid);line-height:1.6;}
.err-retry{margin-top:14px;width:100%;}

/* == RESULTS == */
.results-wrap{margin:14px 16px 0;display:none;flex-direction:column;gap:10px;}
.results-wrap.show{display:flex;}

.score-card{
  background:var(--bg2);border:1px solid var(--line);
  border-radius:var(--r);padding:18px;
  display:flex;align-items:center;gap:14px;
  animation:fadeUp .35s ease .04s both;
}
.sc-nums{display:flex;align-items:baseline;gap:2px;}
.sc-n{font-family:var(--fd);font-size:60px;font-weight:300;line-height:1;}
.sc-d{font-family:var(--fd);font-size:22px;color:var(--mid);padding-bottom:3px;}
.sc-meta{flex:1;}
.sc-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:4px;}
.sc-vibe{font-family:var(--fd);font-size:17px;color:var(--white);font-style:italic;line-height:1.25;}
.sc-bar-track{height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-top:10px;}
.sc-bar{
  height:100%;
  border-radius:2px;
  width:0%;
  background:linear-gradient(90deg,var(--accent),#f09a63);
  transition:width 1.1s cubic-bezier(.2,.8,.2,1) .12s;
}
.sec{
  background:var(--bg2);border:1px solid var(--line);
  border-radius:var(--r);padding:16px;
}
.sec-title{
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mid);font-weight:700;margin-bottom:11px;
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.sec-saved{color:var(--green);}
.pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:pa 2.2s infinite;}
@keyframes pa{0%,100%{opacity:1}50%{opacity:.2}}

.narrative{font-family:var(--fd);font-size:15px;font-style:italic;line-height:1.8;color:var(--text);}

.items-grid{display:flex;flex-wrap:wrap;gap:6px;}
.item-chip{
  background:var(--bg3);border:1px solid var(--line);
  border-radius:8px;padding:6px 11px;font-size:11px;
  color:var(--text);display:flex;align-items:center;gap:6px;
}
.item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.item-type{color:var(--mid);}

.sug-list{display:flex;flex-direction:column;gap:7px;}
.sug{
  background:var(--bg3);border:1px solid var(--line);
  border-radius:12px;padding:11px 13px;
  display:flex;align-items:flex-start;gap:10px;
}
.sug-icon{
  width:22px;height:22px;border-radius:6px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#0A0A0A;margin-top:1px;
}
.sug-text{font-size:12px;color:var(--text);line-height:1.55;}
.overall{font-size:13px;line-height:1.65;color:var(--text);}

/* fade-up animations on results */
.results-wrap .sec:nth-child(2){animation:fadeUp .35s ease .10s both;}
.results-wrap .sec:nth-child(3){animation:fadeUp .35s ease .16s both;}
.results-wrap .sec:nth-child(4){animation:fadeUp .35s ease .22s both;}
.results-wrap .sec:nth-child(5){animation:fadeUp .35s ease .28s both;}

/* == TOAST == */
.toast{
  position:fixed;
  bottom:calc(var(--nav) + var(--sab) + 14px);
  left:50%;transform:translateX(-50%) translateY(18px);
  background:var(--green);color:#0A0A0A;
  padding:10px 22px;border-radius:100px;
  font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  opacity:0;transition:opacity .25s,transform .25s;
  pointer-events:none;white-space:nowrap;z-index:200;
  max-width:calc(100vw - 32px);
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.amber{background:var(--amber);}

/* ======================================
   WARDROBE PAGE
====================================== */
.w-hdr{
  padding:14px 20px 0;
  display:flex;justify-content:space-between;align-items:flex-end;
  flex-shrink:0;
}
.w-title{font-family:var(--fd);font-size:26px;font-weight:300;color:var(--white);}
.w-count{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-top:3px;}
.w-clear{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);background:none;border:none;cursor:pointer;font-family:var(--fu);font-weight:700;opacity:.5;padding:4px;}

.filter-row{
  display:flex;gap:7px;padding:11px 16px 0;
  overflow-x:auto;scrollbar-width:none;flex-shrink:0;
}
.filter-row::-webkit-scrollbar{display:none;}
.fchip{
  white-space:nowrap;flex-shrink:0;padding:7px 15px;border-radius:100px;
  font-size:11px;font-weight:700;cursor:pointer;
  background:var(--bg3);color:var(--mid);
  border:1px solid var(--line);letter-spacing:.06em;
  font-family:var(--fu);transition:all .15s;
}
.fchip.on{background:var(--accent);color:#0A0A0A;border-color:var(--accent);}
.fchip:active{opacity:.75;}

.w-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:10px 16px 0;}
.w-card{
  border-radius:14px;background:var(--bg2);border:1px solid var(--line);
  padding:14px 12px 12px;display:flex;flex-direction:column;gap:7px;
  position:relative;animation:fadeUp .32s ease both;
}
.w-thumb-wrap{width:100%;border-radius:9px;overflow:hidden;background:var(--bg4);aspect-ratio:3/4;margin-bottom:2px;}
.w-thumb{width:100%;height:100%;object-fit:cover;display:block;}
.w-card-top{display:flex;align-items:center;gap:9px;}
.w-dot{width:28px;height:28px;border-radius:50%;flex-shrink:0;border:2px solid rgba(255,255,255,.07);}
.w-type{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);font-weight:700;line-height:1.2;}
.w-desc{font-size:12px;color:var(--text);line-height:1.4;}
.w-tags{display:flex;gap:5px;flex-wrap:wrap;}
.w-tag{background:var(--bg4);border-radius:5px;padding:2px 7px;font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--mid);}
.w-tag.occ{color:var(--accent);}
.w-date{font-size:10px;color:rgba(90,90,90,.8);}
.w-del{position:absolute;top:7px;right:7px;background:none;border:none;color:var(--mid);cursor:pointer;font-size:13px;opacity:.35;padding:5px;line-height:1;}
.w-del:active{opacity:1;color:var(--red);}

/* ── Wardrobe AI sections ── */
.w-ai-section{padding:14px 16px;animation:fadeUp .3s ease both;}
.wai-section-title{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--accent);margin-bottom:3px;}
.wai-section-sub{font-size:12px;color:var(--mid);margin-bottom:10px;}

.wai-outfit-card{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:14px 14px 12px;margin-top:8px;}
.wai-outfit-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px;}
.wai-outfit-title{font-size:15px;font-weight:700;color:var(--white);}
.wai-outfit-sub{font-size:11px;color:var(--mid);margin-top:2px;}
.wai-ctx-badge{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(232,131,74,.12);color:var(--accent);border:1px solid rgba(232,131,74,.25);border-radius:20px;padding:3px 9px;flex-shrink:0;}
.wai-items{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:8px;}
.wai-item{display:flex;align-items:center;gap:6px;background:var(--bg3);border-radius:8px;padding:5px 10px;font-size:12px;color:var(--text);}
.wai-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.1);}
.wai-vars-label{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:6px;}
.wai-vars{display:flex;flex-wrap:wrap;gap:6px;}
.wai-var-chip{background:var(--bg4);border:1px solid var(--line);border-radius:20px;padding:5px 12px;font-size:11px;color:var(--text);cursor:pointer;font-family:var(--fu);display:flex;align-items:center;gap:5px;transition:background .15s;}
.wai-var-chip:active{background:var(--bg3);}

.w-gen-row{padding:4px 16px 8px;}
.w-gen-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--accent);margin-bottom:8px;}
.w-gen-chips{display:flex;gap:7px;flex-wrap:wrap;}
.w-gen-chip{background:var(--bg2);border:1px solid var(--line);border-radius:20px;padding:6px 14px;font-size:12px;color:var(--text);cursor:pointer;font-family:var(--fu);font-weight:600;transition:background .15s,border-color .15s;}
.w-gen-chip:active,.w-gen-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;}
.w-outfit-result-inner{padding:0 16px 16px;}

.wai-gaps{display:flex;flex-direction:column;gap:7px;margin-top:8px;}
.wai-gap-row{display:flex;align-items:flex-start;gap:9px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;}
.wai-gap-icon{font-size:14px;flex-shrink:0;line-height:1.4;}
.wai-gap-msg{font-size:12px;color:var(--text);line-height:1.45;}
.wai-gap-row.missing .wai-gap-msg{color:var(--white);}
.wai-gap-row.info{opacity:.7;}

.wai-shop-slot{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin:12px 0 6px;}
.wai-shop-item{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:7px;}
.wai-shop-name{font-size:13px;font-weight:600;color:var(--white);}
.wai-shop-meta{font-size:11px;color:var(--mid);margin-top:3px;}
.wai-shop-meta em{color:var(--accent);font-style:normal;}

.w-empty{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:56px 32px;text-align:center;gap:13px;
}
.we-icon{font-size:50px;opacity:.2;}
.we-title{font-family:var(--fd);font-size:26px;color:var(--white);font-weight:300;}
.we-sub{font-size:13px;color:var(--mid);line-height:1.65;}

/* == ANIMATIONS == */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* == SETTINGS PAGE == */
.s-section{margin:16px 16px 0;}
.s-section-title{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:8px;}
.s-card{background:var(--bg2);border:1px solid var(--line);border-radius:16px;overflow:hidden;}
.s-row{
  display:flex;align-items:center;gap:14px;padding:16px;
  border-bottom:1px solid var(--line);cursor:pointer;
  transition:background .15s;
}
.s-row:last-child{border-bottom:none;}
.s-row:active{background:var(--bg3);}
.s-row-icon{font-size:18px;width:28px;text-align:center;flex-shrink:0;}
.s-row-body{flex:1;}
.s-row-title{font-size:14px;color:var(--white);font-weight:600;}
.s-row-sub{font-size:12px;color:var(--mid);margin-top:2px;}
.s-row-right{font-size:12px;color:var(--mid);}
.s-row-arrow{color:var(--mid);font-size:16px;margin-left:4px;}
.s-key-display{
  font-size:11px;color:var(--green);
  font-family:'Courier New',monospace;letter-spacing:.05em;
}
.s-key-none{font-size:12px;color:var(--red);}

.s-danger-btn{
  width:100%;padding:15px;border-radius:100px;
  background:rgba(196,82,82,.1);color:var(--red);
  font-family:var(--fu);font-size:12px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  border:1px solid rgba(196,82,82,.25);cursor:pointer;
  transition:all .15s;margin-top:10px;
}
.s-danger-btn:active{background:rgba(196,82,82,.2);}

.s-app-info{text-align:center;padding:24px 16px 8px;color:var(--mid);font-size:12px;line-height:1.7;}
.s-app-name{font-family:var(--fd);font-size:20px;color:var(--white);font-weight:300;margin-bottom:2px;}
.s-app-slogan{font-family:var(--fd);font-size:12px;font-weight:300;color:rgba(255,255,255,.38);font-style:italic;letter-spacing:.04em;margin-bottom:6px;}

/* ======================================
   PROFILE PAGE
====================================== */
.prof-hero{
  margin:14px 16px 0;border-radius:22px;
  background:linear-gradient(135deg,var(--bg3) 0%,var(--bg2) 50%,var(--bg3) 100%);
  border:1px solid var(--line);padding:24px 20px 20px;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  position:relative;overflow:hidden;
}
.prof-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 0%,rgba(232,131,74,.12) 0%,transparent 60%),
             radial-gradient(ellipse at 80% 100%,rgba(107,170,124,.08) 0%,transparent 50%);
  pointer-events:none;
}
.prof-avatar-wrap{position:relative;}
.prof-avatar{
  width:84px;height:84px;border-radius:50%;
  background:var(--bg4);border:3px solid var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:36px;overflow:hidden;cursor:pointer;
  position:relative;
}
.prof-avatar img{width:100%;height:100%;object-fit:cover;display:none;}
.prof-avatar img.loaded{display:block;}
.prof-avatar-edit{
  position:absolute;bottom:0;right:0;
  width:26px;height:26px;border-radius:50%;
  background:var(--accent);border:2px solid var(--bg);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;cursor:pointer;
}
.prof-name{font-family:var(--fd);font-size:26px;font-weight:300;color:var(--white);text-align:center;line-height:1.1;}
.prof-handle{font-size:11px;color:var(--mid);letter-spacing:.1em;margin-top:2px;}
.prof-stats{display:flex;gap:0;width:100%;}
.prof-stat{
  flex:1;text-align:center;padding:12px 8px;
  border-right:1px solid var(--line);
}
.prof-stat:last-child{border-right:none;}
.ps-num{font-family:var(--fd);font-size:26px;font-weight:300;color:var(--white);}
.ps-lbl{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-top:2px;}
.prof-edit-btn{
  width:100%;padding:11px;border-radius:100px;
  background:transparent;color:var(--text);
  border:1px solid var(--line);font-family:var(--fu);
  font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;transition:all .15s;
}
.prof-edit-btn:active{background:var(--bg3);}

/* Style Profile card */
.style-profile-card{
  margin:10px 16px 0;border-radius:18px;
  background:var(--bg2);border:1px solid var(--line);
  padding:18px;
}
.sp-title{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:6px;}
.sp-vibe{
  font-family:var(--fd);font-size:22px;font-weight:300;
  color:var(--white);font-style:italic;margin-bottom:14px;
}
.sp-colours{display:flex;gap:6px;margin-bottom:14px;}
.sp-dot{
  width:32px;height:32px;border-radius:50%;
  border:2px solid rgba(255,255,255,.1);
  flex-shrink:0;cursor:pointer;transition:transform .15s;
}
.sp-dot:hover{transform:scale(1.1);}
.sp-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.sp-row:last-child{margin-bottom:0;}
.sp-label{font-size:12px;color:var(--mid);}
.sp-val{font-size:12px;color:var(--white);font-weight:600;}
.sp-bar-row{margin-bottom:10px;}
.sp-bar-label{display:flex;justify-content:space-between;margin-bottom:5px;}
.sp-bar-name{font-size:11px;color:var(--mid);}
.sp-bar-pct{font-size:11px;color:var(--text);font-weight:600;}
.sp-bar-track{height:4px;background:var(--bg4);border-radius:2px;overflow:hidden;}
.sp-bar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width 1s ease .2s;}
.sp-coherence{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);}
.sp-coh-row{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.sp-coh-track{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.sp-coh-fill{height:100%;border-radius:3px;transition:width 1.2s ease .3s;}
.sp-coh-score{font-size:15px;font-weight:700;min-width:28px;text-align:right;}
.sp-coh-label{font-size:11px;color:var(--mid);}

/* ── Style Hub ── */
.sp-hub{margin:12px 16px 0;display:flex;flex-direction:column;gap:0;}
.sp-hub-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);font-weight:700;margin:18px 0 10px;}
.sp-hub-identity{background:var(--bg2);border:1px solid var(--line);border-radius:18px;padding:20px;margin-bottom:4px;}
.sp-hub-eyebrow{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:8px;}
.sp-hub-vibe{font-family:var(--fd);font-size:28px;font-weight:300;color:var(--white);font-style:italic;margin-bottom:10px;}
.sp-hub-dna{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;}
.sp-hub-insight{font-size:12px;color:var(--mid);line-height:1.6;}

.sp-hub-signals{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.sp-signal-card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:14px 10px;text-align:center;}
.sp-sig-icon{font-size:18px;margin-bottom:4px;}
.sp-sig-name{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:6px;}
.sp-sig-val{font-family:var(--fd);font-size:24px;font-weight:300;color:var(--white);line-height:1;}
.sp-sig-sub{font-size:9px;color:var(--mid);margin-top:3px;}

.sp-hub-opts{background:var(--bg2);border:1px solid var(--line);border-radius:14px;overflow:hidden;}
.sp-opt-row{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);}
.sp-opt-row:last-child{border-bottom:none;}
.sp-opt-dot{width:8px;height:8px;border-radius:50%;background:var(--bg4);border:1px solid var(--line);margin-top:4px;flex-shrink:0;}
.sp-opt-dot.on{background:var(--accent);border-color:var(--accent);box-shadow:0 0 6px rgba(232,131,74,.5);}
.sp-opt-title{font-size:12px;font-weight:700;color:var(--white);margin-bottom:2px;}
.sp-opt-desc{font-size:11px;color:var(--mid);line-height:1.5;}

/* Wardrobe style match badge */
.w-style-match{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:rgba(232,131,74,.1);border:1px solid rgba(232,131,74,.25);border-radius:20px;padding:2px 8px;margin-top:4px;}

/* Recent fit checks on profile */
.prof-fits-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3px;padding:0 16px;margin-top:10px;}
.pf-cell{
  aspect-ratio:1;background:var(--bg3);border-radius:8px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;cursor:pointer;position:relative;overflow:hidden;
}
.pf-score{
  position:absolute;top:5px;right:6px;
  font-family:var(--fd);font-size:14px;font-weight:300;color:var(--white);
  text-shadow:0 1px 4px rgba(0,0,0,.8);
}
.pf-vibe{
  font-size:9px;color:rgba(232,228,220,.8);
  text-align:center;padding:0 4px;
  font-style:italic;font-family:var(--fd);
  position:absolute;bottom:5px;left:0;right:0;
  text-shadow:0 1px 3px rgba(0,0,0,.9);
}
.pf-empty-icon{font-size:22px;opacity:.25;}
.pf-empty-txt{font-size:9px;color:var(--mid);text-align:center;padding:0 6px;line-height:1.4;}

/* ======================================
   SOCIAL PAGE
====================================== */
.soc-hdr{
  padding:14px 20px 0;
  display:flex;justify-content:space-between;align-items:center;
}
.soc-title{font-family:var(--fd);font-size:26px;font-weight:300;color:var(--white);}
.soc-add-btn{
  font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);background:rgba(232,131,74,.1);
  border:1px solid rgba(232,131,74,.3);
  border-radius:100px;padding:7px 13px;cursor:pointer;
  font-family:var(--fu);font-weight:700;
}

/* Friend list */
.friends-scroll{
  display:flex;gap:12px;padding:12px 16px 4px;
  overflow-x:auto;scrollbar-width:none;
}
.friends-scroll::-webkit-scrollbar{display:none;}
.friend-bubble{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  cursor:pointer;flex-shrink:0;
}
.fb-ring{
  width:58px;height:58px;border-radius:50%;
  padding:2px;
  background:linear-gradient(135deg,var(--accent),var(--amber));
}
.fb-ring.seen{background:var(--bg4);}
.fb-inner{
  width:100%;height:100%;border-radius:50%;
  background:var(--bg3);border:2px solid var(--bg);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;overflow:hidden;
}
.fb-inner img{width:100%;height:100%;object-fit:cover;}
.fb-name{font-size:9px;color:var(--mid);font-weight:700;letter-spacing:.04em;text-align:center;max-width:58px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* Social feed */
.soc-section-title{
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mid);font-weight:700;
  padding:14px 16px 8px;
}
.soc-card{
  margin:0 16px 10px;border-radius:18px;
  background:var(--bg2);border:1px solid var(--line);
  overflow:hidden;animation:fadeUp .3s ease both;
}
.soc-card-hdr{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
}
.sc-av{
  width:36px;height:36px;border-radius:50%;
  background:var(--bg4);display:flex;align-items:center;
  justify-content:center;font-size:16px;flex-shrink:0;overflow:hidden;
}
.sc-av img{width:100%;height:100%;object-fit:cover;}
.sc-meta{flex:1;}
.sc-name{font-size:13px;font-weight:700;color:var(--white);}
.sc-time{font-size:10px;color:var(--mid);margin-top:1px;}
.sc-score-badge{
  background:var(--bg3);border:1px solid var(--line);
  border-radius:8px;padding:4px 8px;text-align:center;
}
.sc-score-n{font-family:var(--fd);font-size:18px;font-weight:300;line-height:1;}
.sc-score-d{font-size:8px;color:var(--mid);}

.soc-outfit-img{
  width:100%;aspect-ratio:4/5;background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  font-size:48px;position:relative;overflow:hidden;
}
.soc-outfit-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.9) 0%,transparent 50%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:14px;
}
.soc-vibe{font-family:var(--fd);font-size:17px;font-style:italic;color:var(--white);}
.soc-occ{font-size:10px;color:rgba(232,228,220,.5);letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px;}

.soc-items{
  display:flex;gap:5px;padding:10px 14px;
  overflow-x:auto;scrollbar-width:none;
}
.soc-items::-webkit-scrollbar{display:none;}
.soc-item-chip{
  flex-shrink:0;background:var(--bg3);border:1px solid var(--line);
  border-radius:7px;padding:5px 10px;font-size:10px;
  color:var(--text);display:flex;align-items:center;gap:5px;
}
.soc-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}

.soc-actions{
  display:flex;align-items:center;gap:0;
  border-top:1px solid var(--line);
}
.soc-action{
  flex:1;padding:11px 8px;display:flex;align-items:center;
  justify-content:center;gap:5px;cursor:pointer;
  background:none;border:none;color:var(--mid);
  font-family:var(--fu);font-size:10px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  transition:color .15s;border-right:1px solid var(--line);
}
.soc-action:last-child{border-right:none;}
.soc-action:active{color:var(--accent);}
.soc-action.liked{color:var(--red);}
.soc-action-icon{font-size:14px;}

/* Friend profile modal */
.friend-modal{
  position:absolute;inset:0;background:var(--bg);
  z-index:90;display:none;flex-direction:column;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding-bottom:calc(var(--nav) + var(--sab) + 16px);
}
.friend-modal.open{display:flex;}
.fm-hdr{
  padding:14px 20px;
  display:flex;align-items:center;gap:12px;
  border-bottom:1px solid var(--line);flex-shrink:0;
}
.fm-back{
  background:none;border:none;color:var(--accent);
  font-size:20px;cursor:pointer;padding:4px;line-height:1;
}
.fm-title{font-family:var(--fd);font-size:22px;font-weight:300;color:var(--white);}

/* Borrow section */
.borrow-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:0 16px;}
.borrow-card{
  border-radius:14px;background:var(--bg2);border:1px solid var(--line);
  padding:12px;display:flex;flex-direction:column;gap:7px;position:relative;
}
.borrow-dot{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.07);}
.borrow-type{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);font-weight:700;}
.borrow-desc{font-size:11px;color:var(--text);line-height:1.35;}
.borrow-btn{
  width:100%;padding:8px;border-radius:100px;
  background:rgba(232,131,74,.1);color:var(--accent);
  border:1px solid rgba(232,131,74,.25);font-family:var(--fu);
  font-size:9px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;margin-top:2px;
  transition:all .15s;
}
.borrow-btn:active{background:rgba(232,131,74,.2);}

/* Add friend modal */
.add-friend-sheet{
  position:absolute;bottom:0;left:0;right:0;
  background:var(--bg2);border-radius:24px 24px 0 0;
  border-top:1px solid var(--line);padding:20px 20px calc(var(--sab) + 20px);
  z-index:95;transform:translateY(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
}
.add-friend-sheet.open{transform:translateY(0);}
.afs-handle{width:36px;height:4px;border-radius:2px;background:var(--bg5);margin:0 auto 16px;}
.afs-title{font-family:var(--fd);font-size:22px;color:var(--white);font-weight:300;margin-bottom:4px;}
.afs-sub{font-size:12px;color:var(--mid);margin-bottom:16px;line-height:1.5;}
.afs-input{
  width:100%;background:var(--bg3);border:1.5px solid var(--line);
  border-radius:12px;padding:13px 16px;font-family:var(--fu);
  font-size:16px;color:var(--white);outline:none;
  transition:border-color .2s;margin-bottom:12px;
}
.afs-input:focus{border-color:var(--accent);}
.afs-input::placeholder{color:var(--mid);}
.afs-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.6);
  z-index:94;display:none;
}
.afs-overlay.open{display:block;}

/* Profile edit sheet */
.edit-profile-sheet{
  position:absolute;bottom:0;left:0;right:0;
  background:var(--bg2);border-radius:24px 24px 0 0;
  border-top:1px solid var(--line);padding:20px 20px calc(var(--sab) + 20px);
  z-index:95;transform:translateY(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  max-height:85dvh;overflow-y:auto;
}
.edit-profile-sheet.open{transform:translateY(0);}
.eps-handle{width:36px;height:4px;border-radius:2px;background:var(--bg5);margin:0 auto 16px;}
.eps-title{font-family:var(--fd);font-size:22px;color:var(--white);font-weight:300;margin-bottom:16px;}
.eps-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:6px;margin-top:14px;}
.eps-label:first-of-type{margin-top:0;}
.eps-input{
  width:100%;background:var(--bg3);border:1.5px solid var(--line);
  border-radius:12px;padding:13px 16px;font-family:var(--fu);
  font-size:16px;color:var(--white);outline:none;
  transition:border-color .2s;
}
.eps-input:focus{border-color:var(--accent);}
.eps-input::placeholder{color:var(--mid);}

/* Profile setup card */
.prof-setup-card{background:var(--bg2);border:1px solid rgba(232,131,74,.3);border-radius:18px;padding:20px 18px 22px;cursor:pointer;transition:background .15s;}
.prof-setup-card:active{background:var(--bg3);}
.psc-eyebrow{font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;}
.psc-title{font-family:var(--fd);font-size:24px;font-weight:300;color:var(--white);margin-bottom:8px;font-style:italic;}
.psc-body{font-size:13px;color:var(--mid);line-height:1.6;margin-bottom:14px;}
.psc-cta{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.06em;}

/* Vibe chips in edit profile */
.eps-vibes{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px;}
.eps-vibe-chip{background:var(--bg3);border:1.5px solid var(--line);border-radius:20px;padding:7px 16px;font-size:12px;font-weight:600;color:var(--mid);cursor:pointer;font-family:var(--fu);transition:background .15s,border-color .15s,color .15s;}
.eps-vibe-chip.on{background:rgba(232,131,74,.12);border-color:var(--accent);color:var(--accent);}

/* == LIGHT MODE == */
[data-theme="light"]{
  --bg:#F7F5F0;--bg2:#EFEFEA;--bg3:#E8E5DF;--bg4:#DEDAD2;--bg5:#D0CCC3;
  --line:#D8D4CC;--mid:#8A8680;--text:#1A1814;--white:#0A0A08;
  --accent:#D4692A;--green:#4A8A5C;--amber:#B8920E;--red:#A83838;--blue:#4A7AA0;
}
[data-theme="light"] html,[data-theme="light"] body{background:#F7F5F0;}
[data-theme="light"] .bnav{background:rgba(242,240,234,.97);}
[data-theme="light"] .score-badge,[data-theme="light"] .soc-outfit-overlay{background:rgba(247,245,240,.85);}
[data-theme="light"] .scan-bar{background:linear-gradient(90deg,transparent,var(--accent),transparent);}
[data-theme="light"] .toast{color:#fff;}
[data-theme="light"] .btn-accent{color:#fff;}
[data-theme="light"] .key-btn{color:#fff;}

/* == THEME TOGGLE == */
.theme-seg{
  display:flex;background:var(--bg3);border:1px solid var(--line);
  border-radius:10px;overflow:hidden;
}
.theme-opt{
  flex:1;padding:9px 6px;text-align:center;
  font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--mid);background:none;border:none;cursor:pointer;
  font-family:var(--fu);transition:all .18s;
}
.theme-opt.on{background:var(--accent);color:#fff;}

/* == QR CODE SECTION == */
.qr-wrap{
  display:flex;flex-direction:column;align-items:center;
  gap:10px;padding:16px;
}
.qr-box{
  background:var(--white);border-radius:16px;
  padding:14px;display:inline-flex;
}
.qr-box canvas{display:block;border-radius:6px;}
.qr-label{font-size:11px;color:var(--mid);text-align:center;line-height:1.6;}
.qr-uid{
  font-size:10px;font-family:'Courier New',monospace;
  color:var(--mid);letter-spacing:.08em;
  background:var(--bg3);border:1px solid var(--line);
  border-radius:8px;padding:6px 12px;
}

/* == SHARE FIT CARD (on fit check page) == */
.share-fit-section{
  margin:10px 16px 0;border-radius:var(--r);
  background:var(--bg2);border:1px solid var(--line);
  padding:16px;display:none;animation:fadeUp .3s ease both;
}
.share-fit-section.show{display:block;}
.sfs-title{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:12px;}
.sfs-friends{display:flex;gap:10px;flex-wrap:wrap;}
.sfs-friend{
  display:flex;align-items:center;gap:7px;
  background:var(--bg3);border:1px solid var(--line);
  border-radius:100px;padding:6px 12px 6px 7px;
  cursor:pointer;transition:all .15s;
}
.sfs-friend:active{border-color:var(--accent);}
.sfs-friend.sent{border-color:var(--green);background:rgba(107,170,124,.1);}
.sfs-av{width:24px;height:24px;border-radius:50%;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;overflow:hidden;}
.sfs-av img{width:100%;height:100%;object-fit:cover;}
.sfs-name{font-size:11px;font-weight:700;color:var(--text);}
.sfs-sent{font-size:10px;color:var(--green);}
.sfs-empty{font-size:12px;color:var(--mid);line-height:1.6;}
.sfs-wa-btn{
  margin-top:12px;width:100%;padding:11px;border-radius:100px;
  background:rgba(37,211,102,.12);color:#25D366;
  border:1px solid rgba(37,211,102,.3);font-family:var(--fu);
  font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;
}

/* == ADD FRIEND via QR == */
.scan-qr-btn{
  width:100%;padding:13px;border-radius:100px;
  background:var(--bg3);color:var(--text);
  border:1px solid var(--line);font-family:var(--fu);
  font-size:12px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .15s;margin-top:10px;
}
.scan-qr-btn:active{background:var(--bg4);}

/* == PENDING REQUESTS == */
.req-card{
  margin:0 16px 8px;border-radius:14px;
  background:rgba(232,131,74,.06);border:1px solid rgba(232,131,74,.2);
  padding:14px;display:flex;align-items:center;gap:12px;
}
.req-av{width:40px;height:40px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.req-body{flex:1;}
.req-name{font-size:13px;font-weight:700;color:var(--white);}
.req-sub{font-size:11px;color:var(--mid);margin-top:2px;}
.req-actions{display:flex;gap:7px;}
.req-accept{padding:7px 14px;border-radius:100px;background:var(--accent);color:#fff;border:none;font-family:var(--fu);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;}
.req-decline{padding:7px 10px;border-radius:100px;background:var(--bg3);color:var(--mid);border:1px solid var(--line);font-family:var(--fu);font-size:10px;font-weight:700;cursor:pointer;}


/* == SIGN-IN SCREEN == */
/* (First duplicate #pg-signin block removed) */

.signin-logo{text-align:center;}
.signin-tagline{font-size:12px;color:var(--mid);text-align:center;line-height:1.7;max-width:280px;}

.google-btn{
  display:flex;align-items:center;justify-content:center;gap:12px;
  width:100%;max-width:300px;padding:16px 24px;
  background:#fff;color:#1a1a1a;
  border:none;border-radius:100px;cursor:pointer;
  font-family:var(--fu);font-size:13px;font-weight:700;
  letter-spacing:.05em;transition:all .15s;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.google-btn:active{transform:scale(.97);opacity:.9;}
.google-icon{width:20px;height:20px;flex-shrink:0;}

.signin-note{font-size:11px;color:var(--mid);text-align:center;line-height:1.75;padding:0 8px;}
.signin-err{
  width:100%;max-width:300px;background:rgba(196,82,82,.08);
  border:1px solid rgba(196,82,82,.25);border-radius:12px;
  padding:12px 16px;font-size:13px;color:var(--red);
  line-height:1.5;display:none;
}
.signin-err.show{display:block;}
.signin-escape{
  background:none;border:none;color:var(--mid);
  font-family:var(--fu);font-size:11px;cursor:pointer;
  text-decoration:underline;padding:4px;margin-top:4px;
}

.signin-loading{
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.spin{
  width:32px;height:32px;border-radius:50%;
  border:3px solid var(--bg4);
  border-top-color:var(--accent);
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.spin-label{font-size:12px;color:var(--mid);}

/* User chip in header */
.user-chip{
  display:flex;align-items:center;gap:6px;
  background:var(--bg3);border:1px solid var(--line);
  border-radius:100px;padding:5px 10px 5px 5px;
  cursor:pointer;transition:all .15s;
}
.user-chip:active{opacity:.7;}
.uc-av{width:24px;height:24px;border-radius:50%;background:var(--bg4);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;}
.uc-av img{width:100%;height:100%;object-fit:cover;}
.uc-name{font-size:10px;font-weight:700;color:var(--text);letter-spacing:.04em;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}



/* ==================================
   EDITORIAL FEED PAGE
================================== */
#pg-magazine{padding:0;overflow-y:auto;background:var(--bg);}
.feed-hdr{padding:28px 20px 0;display:flex;justify-content:space-between;align-items:flex-end;}
.feed-masthead{font-family:var(--fd);font-size:38px;font-weight:300;color:var(--white);line-height:1;letter-spacing:.06em;text-transform:uppercase;}
.feed-masthead-sub{font-family:var(--fu);font-size:10px;font-weight:700;letter-spacing:.2em;vertical-align:middle;color:var(--accent);margin-left:6px;}

/* ── Feed sort toggle ── */
.feed-sort-toggle{display:flex;gap:4px;background:var(--bg3);border-radius:100px;padding:3px;}
.feed-sort-btn{
  padding:5px 14px;border-radius:100px;border:none;cursor:pointer;
  font-family:var(--fu);font-size:10px;font-weight:700;letter-spacing:.06em;
  background:transparent;color:var(--mid);transition:all .18s;
}
.feed-sort-btn.active{background:var(--bg);color:var(--white);box-shadow:0 1px 4px rgba(0,0,0,.3);}

/* ── Feed loading skeleton ── */
.feed-load-skeleton{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;background:var(--bg);pointer-events:none;}
.fls-stack{position:relative;width:min(320px,88vw);aspect-ratio:3/4;}
.fls-card{position:absolute;inset:0;border-radius:22px;background:var(--bg2);transform-origin:bottom center;}
.fls-card-back {transform:scale(.92) translateY(28px);z-index:1;opacity:.5;}
.fls-card-mid  {transform:scale(.96) translateY(14px);z-index:2;opacity:.75;}
.fls-card-front{transform:scale(1)   translateY(0);   z-index:3;overflow:hidden;}
.fls-shimmer{position:absolute;inset:0;background:linear-gradient(110deg,transparent 25%,rgba(255,255,255,.05) 50%,transparent 75%);background-size:250% 100%;animation:shimmer 1.5s ease-in-out infinite;}
@keyframes shimmer{0%{background-position:250% 0}100%{background-position:-250% 0}}

/* ── Universal skeleton shimmer ── */
@keyframes skelPulse{0%,100%{opacity:.45}50%{opacity:.85}}
.soc-skeleton{animation:skelPulse 1.4s ease-in-out infinite;}
.sk-av{width:36px;height:36px;border-radius:50%;background:var(--bg4);flex-shrink:0;}
.sk-badge{width:36px;height:22px;border-radius:100px;background:var(--bg4);flex-shrink:0;}
.sk-line{height:10px;border-radius:6px;background:var(--bg4);}
.sk-line.sk-wide{width:85%;}
.sk-line.sk-med{width:60%;}
.sk-line.sk-short{width:38%;}
.sk-rect{background:var(--bg4);}
.feed-date{font-family:var(--fu);font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--mid);padding-bottom:6px;}
.feed-rule{height:1px;background:linear-gradient(90deg,var(--accent) 0%,var(--line) 60%,transparent 100%);margin:10px 20px 0;}
.feed-list{padding:16px 0 100px;}

/* ── FEED SEARCH BAR ── */
.feed-search-bar{display:flex;align-items:center;gap:8px;padding:10px 14px 0;animation:fadeUp .2s ease both;}
.feed-search-icon{font-size:14px;flex-shrink:0;color:var(--mid);}
.feed-search-input{flex:1;font-size:14px;padding-left:10px;}
.feed-search-clear{background:none;border:none;color:var(--mid);font-size:16px;cursor:pointer;padding:4px 6px;line-height:1;flex-shrink:0;}
.feed-search-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:18px;font-style:italic;color:var(--mid);pointer-events:none;}

/* ── TINDER STACK FEED ── */
.feed-stack-wrap{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;padding:12px 10px 0;overflow:hidden;}
.feed-stack{position:relative;width:100%;max-width:480px;flex:1;min-height:0;}
.stack-card{position:absolute;inset:0;border-radius:20px;overflow:hidden;box-shadow:0 12px 48px rgba(0,0,0,.55);cursor:grab;will-change:transform;touch-action:none;user-select:none;-webkit-user-select:none;}
.stack-card:active{cursor:grabbing;}
/* Image fade-in — start invisible, transition to full opacity on load */
.stack-card-img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;-webkit-user-drag:none;opacity:0;transition:opacity .3s ease;will-change:opacity;}
.stack-card-img.img-loaded{opacity:1;}
/* Prevent content flash while image loads — show palette-tinted bg */
.stack-card{background:var(--bg2);}

/* Universal skeleton block */
.skel-block{background:var(--bg4);border-radius:6px;animation:skelPulse 1.4s ease-in-out infinite;}
.w-card-skel{pointer-events:none;opacity:.7;}

/* Performance hints */
.stack-card{will-change:transform;}
.page{will-change:opacity,transform;}
.stack-card-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.18) 0%,transparent 30%,transparent 50%,rgba(0,0,0,.82) 100%);display:flex;flex-direction:column;justify-content:space-between;padding:18px;pointer-events:none;}
.stack-card-badge{align-self:flex-start;background:rgba(255,255,255,.16);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-family:var(--fu);font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:5px 12px;border-radius:20px;}
.stack-card-info{color:#fff;}
.stack-card-title{font-family:var(--fd);font-size:24px;font-weight:300;font-style:italic;line-height:1.2;margin-bottom:4px;}
.stack-card-vibe{font-size:13px;opacity:.7;margin-bottom:6px;letter-spacing:.02em;}
.stack-card-wardrobe{font-size:11px;color:var(--accent);font-weight:700;letter-spacing:.05em;}
.stack-ctx-label{display:inline-flex;align-items:center;font-family:var(--fu);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:20px;margin-bottom:7px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);max-width:fit-content;}
.stack-ctx-style{background:rgba(232,131,74,.18);border:1px solid rgba(232,131,74,.4);color:#e8834a;}
.stack-ctx-trend{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.9);}
.stack-ctx-because{background:rgba(120,180,255,.14);border:1px solid rgba(120,180,255,.3);color:#8bbfff;}
.stack-card-cta-wrap{position:absolute;bottom:20px;left:0;right:0;display:flex;justify-content:center;pointer-events:none;z-index:4;}
.stack-card-cta{pointer-events:auto;background:rgba(20,20,20,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.18);color:#fff;font-family:var(--fu);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:11px 26px;border-radius:40px;cursor:pointer;box-shadow:0 0 18px rgba(232,131,74,.35),0 2px 12px rgba(0,0,0,.4);transition:transform .15s ease,box-shadow .15s ease;}
.stack-card-cta:active{transform:scale(.96);box-shadow:0 0 10px rgba(232,131,74,.2),0 1px 6px rgba(0,0,0,.3);}

/* ── Smart card panel ───────────────────────────────────────────────────── */
.stack-explain-btn{
  pointer-events:auto;margin-top:8px;
  background:rgba(255,255,255,.1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2);color:#fff;
  font-family:var(--fu);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:6px 14px;border-radius:20px;cursor:pointer;align-self:flex-start;
  transition:background .15s;
}
.stack-explain-btn:active{background:rgba(255,255,255,.18);}

.smart-card-panel{
  position:absolute;bottom:0;left:0;right:0;
  max-height:0;overflow:hidden;
  background:linear-gradient(to top, rgba(8,8,8,.97) 0%, rgba(8,8,8,.88) 100%);
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border-top:1px solid rgba(255,255,255,.08);
  transition:max-height .38s cubic-bezier(.4,0,.2,1);
  z-index:5;border-radius:0 0 20px 20px;
}
.stack-card.smart-expanded .smart-card-panel{max-height:46%;overflow-y:auto;}
.stack-card.smart-expanded .stack-card-cta-wrap{display:none;}

/* Close handle inside panel */
.scp-close-btn{
  position:absolute;top:10px;right:12px;
  background:rgba(255,255,255,.08);border:none;color:rgba(255,255,255,.6);
  width:26px;height:26px;border-radius:50%;font-size:13px;line-height:1;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  pointer-events:auto;transition:background .15s;z-index:10;
}
.scp-close-btn:active{background:rgba(255,255,255,.18);}
.scp-inner{position:relative;padding:16px;}
.scp-match{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;color:var(--accent);
  letter-spacing:.06em;margin-bottom:12px;
}
.scp-match-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);}
.scp-section-title{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:8px;}
.scp-why{font-size:13px;color:rgba(255,255,255,.8);line-height:1.6;margin-bottom:10px;font-style:italic;}
.scp-breakdown{display:flex;flex-direction:column;gap:5px;margin-bottom:10px;}
.scp-bd-row{display:flex;gap:8px;font-size:12px;}
.scp-bd-cat{color:var(--mid);min-width:70px;font-weight:600;}
.scp-bd-item{color:var(--white);}
.scp-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;}
.scp-tag{font-size:10px;padding:3px 9px;border-radius:20px;background:rgba(255,255,255,.07);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.1);}

.scp-products{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;}
.scp-products::-webkit-scrollbar{display:none;}
.scp-product{flex-shrink:0;width:96px;background:var(--bg2);border-radius:12px;overflow:hidden;border:1px solid var(--line);}
.scp-prod-img{width:96px;height:96px;object-fit:cover;display:block;}
.scp-prod-name{font-size:10px;font-weight:600;color:var(--white);padding:6px 7px 2px;line-height:1.3;}
.scp-prod-brand{font-size:9px;color:var(--mid);padding:0 7px;}
.scp-prod-price{font-size:11px;font-weight:700;color:var(--accent);padding:3px 7px 8px;}

.scp-remix-chips{display:flex;flex-wrap:wrap;gap:7px;}
.scp-remix-chip{
  font-size:11px;font-weight:600;padding:7px 13px;border-radius:20px;cursor:pointer;
  background:var(--bg2);border:1px solid var(--line);color:var(--text);
  transition:all .15s;font-family:var(--fu);letter-spacing:.04em;
}
.scp-remix-chip.active,.scp-remix-chip:active{background:var(--accent);border-color:var(--accent);color:#fff;}
.scp-remix-result{margin-top:12px;}
.scp-remix-out{background:rgba(232,131,74,.07);border:1px solid rgba(232,131,74,.2);border-radius:12px;padding:12px;}
.scp-remix-title{font-size:13px;font-weight:700;color:var(--white);margin-bottom:4px;}
.scp-remix-note{font-size:12px;color:var(--mid);line-height:1.5;margin-bottom:8px;}

/* ── Try-on credit badge ─────────────────────────────────────────────────── */
.tryon-credit-badge{background:var(--bg2);border:1px solid var(--line);color:var(--white);font-family:var(--fu);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:20px;cursor:pointer;transition:background .15s;white-space:nowrap;}
.tryon-credit-badge[data-empty="1"]{border-color:rgba(232,131,74,.5);color:var(--accent);}
@keyframes creditPop{0%{transform:scale(1)}40%{transform:scale(1.25)}100%{transform:scale(1)}}
.credit-flash{animation:creditPop .4s ease;}

/* ── No-credits modal ────────────────────────────────────────────────────── */
#credits-modal{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .26s ease;}
#credits-modal.cm-open{opacity:1;}
.cm-sheet{width:100%;max-width:480px;background:var(--bg);border-radius:24px 24px 0 0;padding:32px 24px 44px;position:relative;text-align:center;transform:translateY(40px);transition:transform .26s ease;}
#credits-modal.cm-open .cm-sheet{transform:translateY(0);}
.cm-icon{font-size:32px;color:var(--accent);margin-bottom:12px;}
.cm-title{font-family:var(--fd);font-size:26px;font-weight:300;color:var(--white);margin-bottom:8px;}
.cm-sub{font-size:13px;color:var(--mid);line-height:1.6;margin-bottom:28px;}
.cm-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;}
.cm-btn{display:flex;align-items:center;justify-content:center;gap:10px;border-radius:14px;padding:16px 20px;font-family:var(--fu);font-size:13px;font-weight:700;letter-spacing:.06em;cursor:pointer;border:none;transition:transform .15s,opacity .15s;}
.cm-btn:active{transform:scale(.97);}
.cm-btn:disabled{opacity:.55;cursor:wait;}
.cm-btn-icon{font-size:16px;}
.cm-btn-primary{background:var(--accent);color:#fff;box-shadow:0 0 20px rgba(232,131,74,.35);}
.cm-btn-secondary{background:var(--bg2);color:var(--white);border:1px solid var(--line);}
.cm-note{font-size:11px;color:var(--mid);opacity:.7;}

/* ── Try-On Quick Modal ──────────────────────────────────────────────────── */
#tom-modal{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .28s ease;}
#tom-modal.tom-open{opacity:1;}
#tom-sheet{width:100%;max-width:480px;background:var(--bg);border-radius:24px 24px 0 0;padding:24px 20px 40px;position:relative;max-height:92dvh;overflow-y:auto;transform:translateY(40px);transition:transform .28s ease;}
#tom-modal.tom-open #tom-sheet{transform:translateY(0);}
.tom-close{position:absolute;top:16px;right:16px;background:var(--bg2);border:none;color:var(--mid);width:32px;height:32px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.tom-outfit-strip{display:flex;align-items:center;gap:14px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line);}
.tom-outfit-thumb{width:58px;height:74px;object-fit:cover;border-radius:10px;flex-shrink:0;}
.tom-outfit-title{font-family:var(--fd);font-size:17px;color:var(--white);font-weight:300;line-height:1.3;}
.tom-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;}
.tom-step-heading{font-size:15px;font-weight:700;color:var(--white);margin-bottom:2px;}
.tom-step-sub{font-size:12px;color:var(--mid);margin-bottom:16px;}
.tom-error{font-size:12px;color:#e07070;margin-bottom:10px;}
.tom-photo-btns{display:flex;gap:12px;width:100%;justify-content:center;margin-top:4px;}
.tom-photo-btn{flex:1;max-width:160px;background:var(--bg2);border:1px solid var(--line);border-radius:16px;color:var(--white);padding:18px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s;}
.tom-photo-btn:active{background:var(--bg4);}
.tom-pbtn-icon{font-size:26px;}
.tom-spinner{width:42px;height:42px;border:3px solid var(--bg4);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:18px auto 0;}
.tom-loading-text{font-family:var(--fd);font-size:20px;color:var(--white);font-weight:300;margin-top:14px;}
.tom-loading-sub{font-size:12px;color:var(--mid);margin-bottom:18px;}
/* Result title */
.tom-result-hero-title{font-family:var(--fd);font-size:28px;font-weight:300;color:var(--white);letter-spacing:.02em;margin-bottom:6px;font-style:italic;}
.tom-style-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:4px;}
.tom-works-because{font-size:12px;color:var(--mid);line-height:1.6;margin-bottom:16px;max-width:320px;}

/* Friend landing step */
.tom-shared-pill{display:inline-block;background:rgba(232,131,74,.12);border:1px solid rgba(232,131,74,.3);color:var(--accent);font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;border-radius:20px;padding:4px 12px;}
.tom-shared-cta-wrap{width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:18px;padding:18px 16px 20px;margin-top:6px;text-align:center;}
.tom-shared-cta-text{font-size:14px;font-weight:600;color:var(--white);margin-bottom:2px;}
.tom-results-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;margin-bottom:18px;}
.tom-result-cell{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:3/4;background:var(--bg2);}
.tom-result-cell img{width:100%;height:100%;object-fit:cover;display:block;}
.tom-save-btn{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);color:#fff;font-size:11px;font-weight:700;padding:5px 10px;border-radius:20px;text-decoration:none;letter-spacing:.06em;}
.tom-share-btn{width:100%;background:var(--accent);border:none;color:#fff;border-radius:30px;padding:14px 24px;font-family:var(--fu);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;box-shadow:0 0 22px rgba(232,131,74,.4);transition:transform .15s,box-shadow .15s;margin-bottom:10px;}
.tom-share-btn:active{transform:scale(.97);box-shadow:0 0 10px rgba(232,131,74,.2);}
.tom-share-btn:disabled{opacity:.6;cursor:wait;}
.tom-retry-btn{background:none;border:1px solid var(--line);color:var(--mid);border-radius:30px;padding:10px 24px;font-size:12px;font-weight:600;cursor:pointer;width:100%;}
.tom-retry-btn:active{background:var(--bg2);}
.swipe-label{position:absolute;font-family:var(--fu);font-size:26px;font-weight:900;letter-spacing:.08em;border:4px solid;border-radius:8px;padding:6px 16px;opacity:0;pointer-events:none;transition:opacity .08s;}
.swipe-label-like{top:26px;left:16px;color:#5eff8a;border-color:#5eff8a;transform:rotate(-14deg);}
.swipe-label-pass{top:26px;right:16px;color:#ff5e5e;border-color:#ff5e5e;transform:rotate(14deg);}
.swipe-label-save{bottom:26px;left:50%;transform:translateX(-50%) rotate(-4deg);color:var(--accent);border-color:var(--accent);}
.swipe-label-skip{top:26px;left:50%;transform:translateX(-50%) rotate(4deg);color:#aaa;border-color:#aaa;}
.feed-flag-btn{position:absolute;top:14px;right:14px;z-index:10;background:rgba(0,0,0,.45);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:100px;color:rgba(255,255,255,.55);font-size:13px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s;}
.feed-flag-btn:hover,.feed-flag-btn:active{background:rgba(196,82,82,.6);color:#fff;border-color:transparent;}
.stack-hint{display:flex;justify-content:center;gap:20px;padding:14px 0 4px;flex-shrink:0;}
.sh-item{font-family:var(--fu);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);display:flex;align-items:center;gap:4px;}
.sh-arrow{font-size:11px;}
.sh-left{color:#ff5e5e;}.sh-right{color:#5eff8a;}.sh-down{color:var(--accent);}.sh-up{color:#888;}

.feed-skeleton{padding:16px;animation:skelPulse 1.5s ease-in-out infinite;}
.fsk-img{width:100%;aspect-ratio:16/9;background:var(--bg3);border-radius:12px;margin-bottom:12px;}
.fsk-line{height:11px;background:var(--bg3);border-radius:6px;margin-bottom:8px;}
.fsk-line.wide{width:88%;}.fsk-line.med{width:62%;}.fsk-line.short{width:40%;}

.article-overlay{position:absolute;inset:0;background:var(--bg);z-index:120;display:none;flex-direction:column;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);overflow:hidden;}
.article-overlay.open{display:flex;transform:translateY(0);}
.article-close{position:absolute;top:calc(var(--sat) + 14px);right:18px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;z-index:10;color:var(--white);}
.article-inner{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:calc(var(--nav) + var(--sab) + 24px);}
.article-inner::-webkit-scrollbar{display:none;}

.art-hero{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;filter:brightness(.8);background:var(--bg3);}
.art-hero-wrap{position:relative;}
.art-cat{position:absolute;bottom:16px;left:16px;font-family:var(--fu);font-size:8px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;background:var(--accent);color:#0A0A0A;padding:4px 10px;border-radius:100px;}
.art-body{padding:22px 20px 0;}
.art-title{font-family:var(--fd);font-size:28px;font-weight:300;color:var(--white);line-height:1.15;font-style:italic;margin-bottom:10px;}
.art-byline{font-family:var(--fu);font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--mid);margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.art-byline-dot{width:3px;height:3px;border-radius:50%;background:var(--mid);}
.art-rule{height:1px;background:var(--line);margin-bottom:18px;}
.art-para{font-size:14px;color:var(--text);line-height:1.8;margin-bottom:16px;}
.art-subhead{font-family:var(--fd);font-size:20px;font-weight:300;color:var(--white);font-style:italic;margin:22px 0 10px;}
.art-tip{background:var(--bg2);border-left:2px solid var(--accent);border-radius:0 12px 12px 0;padding:14px 16px;margin:16px 0;}
.art-tip-label{font-family:var(--fu);font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:6px;}
.art-tip-text{font-size:13px;color:var(--text);line-height:1.6;}
.art-items-grid{display:flex;flex-wrap:wrap;gap:7px;margin:14px 0;}
.art-item-chip{background:var(--bg3);border:1px solid var(--line);border-radius:8px;padding:7px 12px;font-size:12px;color:var(--text);}
.art-shop-row{display:flex;gap:7px;flex-wrap:wrap;padding:14px 0 0;}




/* == ONBOARDING == */
#pg-signin{
  display:none;flex-direction:column;align-items:center;justify-content:center;
  min-height:calc(100dvh - var(--sat));padding:32px 24px;gap:18px;
  position:fixed;inset:0;z-index:200;background:var(--bg);overflow-y:auto;
}
#pg-signin.active{display:flex;}
.ob-steps{display:flex;gap:8px;align-items:center;}
.ob-step{width:8px;height:8px;border-radius:50%;background:var(--bg4);transition:all .3s;}
.ob-step.active{width:24px;border-radius:4px;background:var(--accent);}
.ob-card{
  width:100%;max-width:360px;background:var(--bg2);
  border:1px solid var(--line);border-radius:22px;padding:24px;
  display:flex;flex-direction:column;gap:14px;
  animation:fadeUp .3s ease both;
}
.ob-step-label{font-family:var(--fu);font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.ob-card-title{font-family:var(--fd);font-size:26px;font-weight:300;color:var(--white);line-height:1.1;}
.ob-card-body{font-size:13px;color:var(--mid);line-height:1.65;}
.ob-get-key-btn{
  display:flex;align-items:center;justify-content:center;
  padding:14px 20px;border-radius:100px;
  background:rgba(232,131,74,.12);border:1px solid rgba(232,131,74,.35);
  color:var(--accent);font-family:var(--fu);font-size:13px;font-weight:700;
  letter-spacing:.05em;text-decoration:none;transition:all .15s;
}
.ob-get-key-btn:active{background:rgba(232,131,74,.22);}
.ob-key-hint{font-size:11px;color:var(--green);font-weight:700;text-align:center;letter-spacing:.04em;}
.ob-skip{
  background:none;border:none;color:var(--mid);font-family:var(--fu);
  font-size:11px;cursor:pointer;padding:4px;text-decoration:underline;
  text-underline-offset:3px;align-self:center;
}
.ob-guest-btn{
  width:100%;padding:13px 20px;border-radius:14px;cursor:pointer;
  background:var(--bg3);border:1px solid var(--line);
  color:var(--text);font-family:var(--fu);font-weight:700;
  font-size:13px;letter-spacing:.04em;margin-bottom:4px;
  transition:background .15s;
}
.ob-guest-btn:active{background:var(--bg4);}
.ob-done-icon{font-size:48px;text-align:center;color:var(--accent);font-family:var(--fd);}

/* == TRY THE LOOK == */
.try-zones{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  padding:12px 16px 0;
}
.try-zone{
  aspect-ratio:3/4;border-radius:16px;
  background:var(--bg2);border:1.5px dashed rgba(255,255,255,.1);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;position:relative;overflow:hidden;
  transition:border-color .2s;
}
.try-zone:active{border-color:rgba(232,131,74,.5);}
.try-zone.has-img{border-style:solid;border-color:rgba(255,255,255,.06);}
.try-zone-ph{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;text-align:center;}
.try-zone-icon{font-size:28px;}
.try-zone-label{font-family:var(--fu);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text);}
.try-zone-sub{font-size:10px;color:var(--mid);line-height:1.4;}
.try-clear{
  position:absolute;top:6px;right:6px;
  width:24px;height:24px;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;border:none;
  font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.try-sources{padding:12px 16px 0;}
.try-source-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:8px;}
.try-source-row{display:flex;gap:7px;flex-wrap:wrap;}
.try-src-btn{
  padding:8px 14px;border-radius:100px;
  background:var(--bg3);border:1px solid var(--line);
  color:var(--text);font-family:var(--fu);font-size:11px;font-weight:700;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.try-src-btn:active{background:var(--bg4);border-color:var(--accent);}

/* Occasion quick-chips */
.occ-chips-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;}
.occ-chip{
  padding:6px 12px;border-radius:100px;
  background:var(--bg3);border:1.5px solid var(--line);
  color:var(--mid);font-family:var(--fu);font-size:10px;font-weight:700;
  cursor:pointer;transition:all .18s;white-space:nowrap;letter-spacing:.04em;
}
.occ-chip:active,.occ-chip.active{
  background:rgba(232,131,74,.12);border-color:var(--accent);color:var(--accent);
}

/* Try results */
.try-result-sec{
  background:var(--bg2);border:1px solid var(--line);
  border-radius:var(--r);padding:16px;
}
.try-result-sec + .try-result-sec{margin-top:10px;}
.feed-new-badge{
  position:absolute;top:12px;right:12px;
  background:var(--green);color:#0a0a0a;
  font-family:var(--fu);font-size:8px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:3px 9px;border-radius:100px;
}
.try-note-input{
  width:100%;background:var(--bg3);border:1.5px solid var(--line);
  border-radius:12px;padding:12px 14px;font-family:var(--fu);
  font-size:16px;color:var(--white);outline:none;resize:none;
  transition:border-color .2s;min-height:80px;line-height:1.6;
}
.try-note-input:focus{border-color:var(--accent);}
.try-note-input::placeholder{color:var(--mid);}


/* == PROFILE PHOTOS (try-on base) == */
.prof-photos-section{margin:10px 16px 0;}
.prof-photos-title{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:6px;}
.prof-photos-sub{font-size:11px;color:var(--mid);line-height:1.5;margin-bottom:12px;}
.prof-photos-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.prof-photo-slot{
  aspect-ratio:2/3;border-radius:14px;
  background:var(--bg2);border:1.5px dashed rgba(255,255,255,.1);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;position:relative;overflow:hidden;transition:border-color .2s;
}
.prof-photo-slot:active{border-color:rgba(232,131,74,.5);}
.prof-photo-slot.has-img{border-style:solid;border-color:rgba(255,255,255,.06);}
.prof-photo-slot img{width:100%;height:100%;object-fit:cover;display:none;}
.prof-photo-slot.has-img img{display:block;}
.prof-photo-slot-icon{font-size:22px;margin-bottom:5px;}
.prof-photo-slot-label{font-family:var(--fu);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);}
.prof-photo-del{
  position:absolute;top:5px;right:5px;
  width:22px;height:22px;border-radius:50%;
  background:rgba(0,0,0,.65);color:#fff;border:none;
  font-size:10px;cursor:pointer;display:none;
  align-items:center;justify-content:center;
}
.prof-photo-slot.has-img .prof-photo-del{display:flex;}
.prof-photo-slot.storage-full{opacity:.5;cursor:not-allowed;}
.prof-photos-storage-warning{font-size:11px;color:var(--amber,#D4A843);background:rgba(212,168,67,.08);border:1px solid rgba(212,168,67,.2);border-radius:10px;padding:8px 12px;margin-bottom:10px;display:none;}

/* == TRY REQUEST FORM == */
.try-request-card{
  margin:12px 16px 0;background:var(--bg2);border:1px solid var(--line);
  border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:14px;
}
.try-req-title{font-family:var(--fd);font-size:22px;font-weight:300;color:var(--white);}
.try-req-sub{font-size:12px;color:var(--mid);line-height:1.55;}
.try-profile-photos-row{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;}
.try-profile-photos-row::-webkit-scrollbar{display:none;}
.try-prof-thumb{
  width:60px;height:80px;border-radius:10px;
  object-fit:cover;flex-shrink:0;border:2px solid var(--line);
}
.try-prof-thumb.selected{border-color:var(--accent);}
.try-no-photos{
  padding:14px;background:rgba(232,131,74,.06);border:1px solid rgba(232,131,74,.2);
  border-radius:12px;font-size:12px;color:var(--mid);line-height:1.55;cursor:pointer;
}

/* Request status cards */
.try-requests-section{margin:14px 16px 0;display:flex;flex-direction:column;gap:10px;}
.try-req-card{
  background:var(--bg2);border:1px solid var(--line);border-radius:16px;
  overflow:hidden;
}
.try-req-card-hdr{display:flex;align-items:center;gap:12px;padding:14px;}
.try-req-status{
  font-family:var(--fu);font-size:9px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
}
.try-req-status.pending{background:rgba(212,168,67,.12);color:var(--amber);}
.try-req-status.processing{background:rgba(122,156,196,.12);color:var(--blue);}
.try-req-status.ready{background:rgba(107,170,124,.12);color:var(--green);}
.try-req-status.failed{background:rgba(220,80,80,.12);color:var(--red);}
.try-req-outfit-thumb{
  width:48px;height:64px;object-fit:cover;border-radius:8px;
  background:var(--bg3);flex-shrink:0;
}
.try-req-info{flex:1;}
.try-req-vibe{font-size:13px;color:var(--white);font-weight:600;margin-bottom:2px;}
.try-req-date{font-size:10px;color:var(--mid);}
.try-req-result{
  width:100%;aspect-ratio:3/4;object-fit:cover;display:block;
  border-top:1px solid var(--line);
}
.try-req-note{
  padding:10px 14px;font-size:12px;color:var(--mid);
  font-family:var(--fd);font-style:italic;line-height:1.5;
  border-top:1px solid var(--line);
}


/* Try-on status timeline */
.try-timeline{padding:14px 16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:0;}
.try-tl-step{display:flex;align-items:flex-start;gap:12px;padding:8px 0;position:relative;}
.try-tl-step:not(:last-child)::after{content:'';position:absolute;left:11px;top:28px;bottom:-8px;width:1px;background:var(--line);}
.try-tl-dot{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;margin-top:1px;}
.try-tl-dot.done{background:var(--green);color:#0a0a0a;}
.try-tl-dot.active{background:var(--accent);color:#0a0a0a;animation:tldotpulse 1.5s ease-in-out infinite;}
.try-tl-dot.waiting{background:var(--bg4);color:var(--mid);}
@keyframes tldotpulse{0%,100%{box-shadow:0 0 0 0 rgba(232,131,74,.4)}50%{box-shadow:0 0 0 6px rgba(232,131,74,0)}}
.try-tl-label{font-size:12px;font-weight:700;color:var(--text);margin-bottom:2px;font-family:var(--fu);}
.try-tl-sub{font-size:11px;color:var(--mid);line-height:1.5;}

/* Appearance card in analysis */
.try-appearance{padding:12px 14px;border-top:1px solid var(--line);background:rgba(255,255,255,.02);}
.try-appearance-title{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:8px;}
.try-appearance-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.try-app-pill{background:var(--bg3);border:1px solid var(--line);border-radius:8px;padding:7px 10px;}
.try-app-key{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:2px;}
.try-app-val{font-size:12px;color:var(--text);}

/* Result reveal */
.try-result-reveal{position:relative;overflow:hidden;}
.try-result-reveal img{width:100%;display:block;border-top:1px solid var(--line);}
.try-result-download{
  position:absolute;bottom:12px;right:12px;
  background:rgba(10,10,10,.75);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.12);border-radius:100px;
  padding:8px 16px;font-size:10px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--white);cursor:pointer;
  font-family:var(--fu);text-decoration:none;display:inline-flex;align-items:center;gap:6px;
}
.try-result-download:active{opacity:.8;}

/* Waiting state card */
.try-waiting-card{
  padding:18px;text-align:center;border-top:1px solid var(--line);
}
.try-waiting-spinner{
  width:28px;height:28px;border-radius:50%;
  border:2px solid var(--bg4);border-top-color:var(--accent);
  animation:spin .8s linear infinite;margin:0 auto 10px;
}
.try-waiting-label{font-size:12px;color:var(--mid);line-height:1.6;}
.try-waiting-eta{font-size:10px;color:var(--mid);margin-top:4px;font-style:italic;}

/* ── Try page tab switcher ── */
.try-tabs{
  display:flex;margin:12px 16px 0;
  background:var(--bg3);border-radius:14px;padding:4px;gap:4px;
  flex-shrink:0;
}
.try-tab{
  flex:1;padding:9px 8px;border-radius:10px;
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  font-family:var(--fu);cursor:pointer;border:none;
  background:transparent;color:var(--mid);transition:all .2s;
}
.try-tab.active{background:var(--bg);color:var(--white);box-shadow:0 1px 4px rgba(0,0,0,.3);}

/* ── Saved Looks grid ── */
.saved-looks-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px;padding:14px 16px;
}
.saved-look-card{
  border-radius:14px;overflow:hidden;
  background:var(--bg2);border:1px solid var(--line);
  cursor:pointer;position:relative;
  transition:transform .18s;
}
.saved-look-card:active{transform:scale(.97);}
.saved-look-img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;}
.saved-look-img-ph{width:100%;aspect-ratio:3/4;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:32px;}
.saved-look-meta{padding:8px 10px 10px;}
.saved-look-occasion{font-size:11px;font-weight:700;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.saved-look-verdict{font-size:10px;color:var(--mid);margin-top:2px;}
.saved-look-badge{
  position:absolute;top:8px;right:8px;
  background:rgba(10,10,10,.75);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12);border-radius:100px;
  padding:3px 8px;font-size:9px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--green);font-family:var(--fu);
}

/* ── Saved Look detail overlay ── */
.saved-look-overlay{
  position:fixed;inset:0;z-index:350;
  background:var(--bg);
  display:none;flex-direction:column;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding-bottom:calc(var(--nav) + var(--sab) + 16px);
}
.saved-look-overlay.open{display:flex;}
.saved-look-overlay-hdr{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:var(--bg);z-index:10;
  flex-shrink:0;
}
.saved-look-back{
  background:none;border:none;color:var(--accent);
  font-size:22px;cursor:pointer;padding:4px;line-height:1;
}
.saved-look-title{font-family:var(--fd);font-size:20px;color:var(--white);font-weight:300;flex:1;}


/* Broken image fallback */
img[src*="unsplash.com"]{background:var(--bg3);}

/* ── First-launch tour ── */
/* ── Onboarding splash ───────────────────────────────────────────────────── */
#ob-screen{position:fixed;inset:0;z-index:800;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .5s ease;}
#ob-screen.ob-visible{opacity:1;}
#ob-screen.ob-exit{opacity:0;pointer-events:none;transform:scale(1.03);transition:opacity .45s ease,transform .45s ease;}
.ob-bg{position:absolute;inset:0;background:#080808;overflow:hidden;}
.ob-glow{position:absolute;top:20%;left:50%;transform:translate(-50%,-50%);width:480px;height:480px;background:radial-gradient(circle,rgba(232,131,74,.18) 0%,transparent 70%);pointer-events:none;}
.ob-grain{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;}
.ob-content{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 32px;gap:0;max-width:360px;width:100%;}
.ob-wordmark{font-family:var(--fu);font-size:11px;font-weight:700;letter-spacing:.35em;color:rgba(255,255,255,.35);margin-bottom:6px;}
.ob-tagline{font-family:var(--fd);font-size:13px;font-weight:300;color:rgba(255,255,255,.45);letter-spacing:.04em;font-style:italic;margin-bottom:24px;}
.ob-rule{width:32px;height:1px;background:var(--accent);opacity:.7;margin-bottom:28px;}
.ob-title{font-family:var(--fd);font-size:clamp(38px,10vw,52px);font-weight:300;color:#fff;line-height:1.15;margin:0 0 18px;letter-spacing:.01em;}
.ob-sub{font-family:var(--fu);font-size:13px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin:0 0 44px;}
.ob-cta{background:var(--accent);border:none;color:#fff;font-family:var(--fu);font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:17px 52px;border-radius:50px;cursor:pointer;box-shadow:0 0 36px rgba(232,131,74,.45),0 4px 16px rgba(0,0,0,.4);transition:transform .18s ease,box-shadow .18s ease;width:100%;max-width:280px;}
.ob-cta:active{transform:scale(.97);box-shadow:0 0 18px rgba(232,131,74,.25);}
.ob-hint{font-size:11px;color:rgba(255,255,255,.2);letter-spacing:.06em;margin-top:18px;}
.tour-dot.active{width:24px;border-radius:4px;background:var(--accent);}

.top-actions{
  position:absolute;
  top:calc(var(--sat) + 8px);
  right:12px;
  z-index:60;
  display:flex;
  align-items:center;
  gap:8px;
}

.ta-btn{
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid var(--line);
  background:var(--bg2);
  color:var(--text);
  font-size:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .15s ease;
}

.ta-btn:hover{
  border-color:var(--accent);
  color:var(--accent);
}

.ta-btn:active{
  transform:scale(.92);
  background:var(--bg3);
}
#ta-credits-btn[data-empty="1"]{
  border-color:rgba(232,131,74,.6);
  color:var(--accent);
}

/* ===== Tablet layout ===== */

@media (min-width:600px){
  :root{
    --app-max-width:720px;
  }

  body{
    align-items:center;
  }
}

/* ===== Desktop layout ===== */

@media (min-width:1024px){
  :root{
    --app-max-width:860px;
  }

  body{
    align-items:center;
  }
}

/* ===== Ultra-wide screens ===== */

@media (min-width:1400px){
  :root{
    --app-max-width:1000px;
  }

  body{
    align-items:center;
  }
}


/* ===== Render-error fallback ===== */
.render-error{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px 24px;text-align:center;gap:14px;
}
.render-error-icon{font-size:32px;line-height:1;}
.render-error-msg{font-size:13px;color:var(--mid);line-height:1.6;}
.render-error-btn{
  background:none;border:1px solid var(--line);border-radius:100px;
  color:var(--accent);font-family:var(--fu);font-weight:700;
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  padding:8px 18px;cursor:pointer;
}
.render-error-btn:active{opacity:.7;}

/* ===== Failed try-on card state ===== */
.try-failed-banner{
  display:flex;align-items:flex-start;gap:10px;
  background:rgba(220,80,80,.07);border:1px solid rgba(220,80,80,.2);
  border-radius:10px;padding:12px 14px;margin:12px 16px;
}
.try-failed-icon{font-size:20px;line-height:1;flex-shrink:0;}
.try-failed-body{flex:1;}
.try-failed-title{font-size:12px;font-weight:700;color:var(--red);margin-bottom:4px;}
.try-failed-sub{font-size:11px;color:var(--mid);line-height:1.5;margin-bottom:10px;}
.try-failed-retry{
  background:rgba(220,80,80,.12);border:1px solid rgba(220,80,80,.3);
  border-radius:100px;color:var(--red);
  font-family:var(--fu);font-weight:700;font-size:10px;letter-spacing:.08em;
  text-transform:uppercase;padding:6px 14px;cursor:pointer;
}

/* ===== Accessibility ===== */

/* Focus styles — visible on keyboard nav, hidden on mouse click */
:focus-visible {
  outline: 2px solid var(--accent, #8b5cf6);
  outline-offset: 2px;
  border-radius: 4px;
}
:focus:not(:focus-visible) { outline: none; }

/* Skip-to-content link — injected by a11y.js */
.skip-link {
  position: fixed;
  top: -100%;
  left: 0;
  z-index: 9999;
  padding: 10px 20px;
  background: var(--acc, #8b5cf6);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  border-radius: 0 0 8px 0;
  transition: top 0.15s;
}
.skip-link:focus { top: 0; }

/* Reduced-motion: disable all CSS animations */
.reduced-motion *,
.reduced-motion *::before,
.reduced-motion *::after {
  animation-duration: 0.001ms !important;
  transition-duration: 0.001ms !important;
  scroll-behavior: auto !important;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* ===== Try-On generation steps ===== */
.tgs-step {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 14px;
  transition: border-color .3s, background .3s;
}
.tgs-step.tgs-active {
  border-color: var(--accent, #8b5cf6);
  background: rgba(139,92,246,.06);
}
.tgs-step.tgs-done {
  border-color: rgba(107,170,124,.4);
  background: rgba(107,170,124,.05);
}
.tgs-step.tgs-error {
  border-color: rgba(220,80,80,.35);
  background: rgba(220,80,80,.05);
}
.tgs-dot {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--bg4);
  border: 2px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  margin-top: 1px;
  transition: background .3s, border-color .3s;
  position: relative;
}
/* spinning ring on active */
.tgs-step.tgs-active .tgs-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--accent, #8b5cf6);
  animation: tgs-spin .8s linear infinite;
}
@keyframes tgs-spin { to { transform: rotate(360deg); } }
.tgs-step.tgs-done   .tgs-dot { background: rgba(107,170,124,.2); border-color: rgba(107,170,124,.6); }
.tgs-step.tgs-error  .tgs-dot { background: rgba(220,80,80,.15); border-color: rgba(220,80,80,.5); }
.tgs-body { flex: 1; min-width: 0; }
.tgs-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 2px;
}
.tgs-sub {
  font-size: 11px;
  color: var(--mid);
  line-height: 1.5;
}


/* ╔══════════════════════════════════════════════════════════════════╗
   ║              RESPONSIVE LAYOUT — TABLET & DESKTOP               ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ─── Tablet (≥ 768px) ─────────────────────────────────────────── */
@media (min-width: 768px) {
  :root {
    --app-max-width: 700px;
    --sat: 20px;
    --sab: 0px;
  }

  body { align-items: center; }

  .shell {
    border-radius: 20px;
    margin: 16px auto;
    height: calc(100vh - 32px);
    min-height: 600px;
    overflow: hidden;
  }

  /* Wider padding on headers */
  .hdr { padding: 20px 24px 0; padding-right: 180px; }
  .w-hdr { padding: 20px 24px 0; }
  .feed-hdr { padding: 22px 24px 0; }
  .feed-rule { margin: 10px 24px 0; }

  /* Wardrobe: 3-column on tablet */
  .w-grid { grid-template-columns: repeat(3, 1fr); gap: 12px; padding: 12px 20px 0; }

  /* Filter rows */
  .filter-row, .ctx-row { padding-left: 20px; padding-right: 20px; }

  /* Bottom nav — bigger tap targets */
  .bnav-label { font-size: 9px; }
  .bnav-btn { padding-top: 8px; }

  /* Profile grid */
  .prof-fits-grid { grid-template-columns: repeat(4, 1fr); }
  .prof-photos-grid { grid-template-columns: repeat(4, 1fr); }

  /* Borrow grid */
  .borrow-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ─── Desktop (≥ 1024px) — sidebar nav + wide content ─────────── */
@media (min-width: 1024px) {
  :root {
    --app-max-width: 100%;
    --sat: 0px;
    --sab: 0px;
    --sidenav-w: 240px;
  }

  body {
    align-items: stretch;
    justify-content: center;
  }

  /* ── Shell: horizontal layout ── */
  .shell {
    flex-direction: row;
    max-width: 1440px;
    width: 100%;
    margin: 0 auto;
    border-radius: 0;
    padding-top: 0;
    height: 100vh;
    overflow: hidden;
  }

  /* ── Sidebar nav (was bottom nav) ── */
  .bnav {
    order: -1;                /* visually leftmost */
    position: relative;       /* override absolute */
    inset: auto;              /* clear bottom/left/right */
    width: var(--sidenav-w);
    height: 100vh;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    flex-shrink: 0;
    padding: 0 0 24px;
    border-top: none;
    border-right: 1px solid var(--line);
    background: var(--bg);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    overflow-y: auto;
    scrollbar-width: none;
  }
  .bnav::-webkit-scrollbar { display: none; }

  /* Brand mark at top of sidebar */
  .bnav::before {
    content: 'Vawa';
    display: block;
    font-family: var(--fd);
    font-size: 30px;
    font-weight: 300;
    color: var(--white);
    letter-spacing: .05em;
    padding: 28px 24px 24px;
    border-bottom: 1px solid var(--line);
    margin-bottom: 8px;
    flex-shrink: 0;
  }

  /* Nav items: horizontal rows */
  .bnav-btn {
    flex: 0 0 auto;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    padding: 13px 24px;
    gap: 14px;
    border-radius: 0;
    height: auto;
    border-right: 3px solid transparent;
    transition: background .15s, color .15s, border-color .15s;
  }
  .bnav-btn:hover { background: var(--bg2); color: var(--text); }
  .bnav-btn.on {
    background: rgba(232,131,74,.08);
    color: var(--accent);
    border-right-color: var(--accent);
  }

  .bnav-icon { font-size: 20px; width: 26px; text-align: center; flex-shrink: 0; }
  .bnav-label { font-size: 12px; letter-spacing: .09em; font-weight: 700; }
  .bnav-dot { display: none; }

  /* ── Pages: fill remaining width ── */
  .page {
    flex: 1;
    height: 100vh;
    min-height: 0;
    overflow-y: auto;
    padding-bottom: 40px;
    display: none;
  }
  .page.active { display: block; }
  #pg-feed.active {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
  }

  /* Remove top-action bar safe-area offset, reposition cleanly */
  .top-actions {
    top: 18px;
    right: 18px;
  }

  /* ── Headers — remove the big right padding (no floating top-actions overlap) ── */
  .hdr {
    padding: 28px 32px 0;
    padding-right: 120px; /* still leave room for top-actions */
  }
  .w-hdr { padding: 28px 32px 0; }
  .feed-hdr {
    padding: 28px 32px 0;
    max-width: 640px;
    margin: 0 auto;
    width: 100%;
    box-sizing: border-box;
  }
  .feed-rule { margin: 12px 32px 0; max-width: 640px; margin-left: auto; margin-right: auto; }
  .filter-row, .ctx-row { padding-left: 32px; padding-right: 32px; }

  /* ── Wardrobe: 3 columns ── */
  .w-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; padding: 14px 32px 0; }

  /* ── Feed: center the card stack in the content area ── */
  .feed-stack-wrap { max-width: 520px; margin: 0 auto; width: 100%; padding: 12px 0 0; }
  .feed-stack { max-width: 480px; }

  /* ── Borrow / try grid: 3 columns ── */
  .borrow-grid { grid-template-columns: repeat(3, 1fr); padding: 0 32px; gap: 12px; }

  /* ── Profile ── */
  .prof-hero { padding: 28px 32px 0; }
  .prof-stats { max-width: 700px; margin: 0 auto; }
  .prof-fits-grid { grid-template-columns: repeat(4, 1fr); padding: 0 32px; }
  .prof-photos-grid { grid-template-columns: repeat(4, 1fr); }
  .prof-photos-section { margin: 14px 32px 0; }
  .prof-setup-card { margin: 16px 32px; }

  /* ── Wardrobe AI sections ── */
  .w-ai-section { padding: 16px 32px; }

  /* ── Fitcheck / result section ── */
  .result-section { max-width: 680px; margin: 0 auto; }

  /* ── Try-on / style expert ── */
  .try-tabs { padding: 0 32px; }
  #try-subpage-new,
  #try-subpage-saved { max-width: 720px; margin: 0 auto; }

  /* ── Key screen ── */
  #pg-key { padding: 60px 32px; max-width: 480px; margin: 0 auto; }

  /* ── Toast — avoid sidebar overlap ── */
  .toast { left: calc(var(--sidenav-w) + 16px); }

  /* ── Modals still cover full screen ── */
  .tom-modal, .look-overlay, .search-overlay { z-index: 200; }
}

/* ─── Wide desktop (≥ 1400px) ─────────────────────────────────── */
@media (min-width: 1400px) {
  :root { --sidenav-w: 280px; }

  .w-grid { grid-template-columns: repeat(4, 1fr); gap: 16px; padding: 16px 40px 0; }
  .hdr, .w-hdr { padding: 32px 40px 0; }
  .feed-stack-wrap { max-width: 560px; }
  .borrow-grid { grid-template-columns: repeat(4, 1fr); padding: 0 40px; }
  .prof-fits-grid { padding: 0 40px; }
}

/* ─── Touch / hover helpers ────────────────────────────────────── */
@media (hover: hover) {
  .w-card:hover { border-color: var(--mid); background: var(--bg3); }
  .stack-card-cta:hover { transform: scale(1.04); }
  .fchip:hover { border-color: var(--mid); color: var(--text); }
  .ta-btn:hover { border-color: var(--accent); color: var(--accent); }
  .key-btn:hover:not(:disabled) { opacity: .88; }
}

/* ─── Pull-to-refresh indicator (was missing CSS) ─────────────── */
.ptr-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 0;
  overflow: hidden;
  opacity: 0;
  transition: height .2s ease, opacity .2s ease;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--mid);
  font-family: var(--fu);
}
.ptr-indicator.visible {
  height: 44px;
  opacity: 1;
}
.ptr-spin {
  width: 14px; height: 14px;
  border: 2px solid var(--line);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: ptr-rotate .7s linear infinite;
}
@keyframes ptr-rotate { to { transform: rotate(360deg); } }

/* ─── Desktop content-width fixes ─────────────────────────────── */
@media (min-width: 1024px) {
  /* Narrow the shell so content area isn't overwhelming */
  .shell { max-width: 1220px; }

  /* Every page on desktop: limit readable width via inner padding */
  .page { padding-left: 0; padding-right: 0; }

  /* Content wrapper pattern — limit inner content columns */
  .hdr         { max-width: 900px; }
  .w-hdr       { max-width: 900px; }
  .filter-row  { max-width: 900px; }
  .ctx-row     { max-width: 900px; }
  .w-grid      { max-width: 900px; }
  .w-ai-section { max-width: 900px; }

  /* Fit Check — center upload area */
  #pg-fitcheck .hdr ~ * { max-width: 860px; margin-left: auto; margin-right: auto; }
  .upload-zone, .occ-row, .ctx-row, .result-section,
  .fc-meta-row, .fc-score-row, .fc-insights,
  .fc-wardrobe-matches { max-width: 860px; margin-left: auto; margin-right: auto; }

  /* Try-On — better tab sizing */
  .try-tabs {
    max-width: 600px;
    margin: 12px auto 0;
    border-radius: 100px;
    padding: 0;
  }
  #try-subpage-new, #try-subpage-saved {
    max-width: 680px;
    margin: 0 auto;
    padding: 0 24px;
  }

  /* Profile — constrain hero and cards */
  .prof-hero   { max-width: 780px; margin-left: auto; margin-right: auto; }
  .prof-stats  { max-width: 780px; }
  .prof-setup-card { max-width: 780px; }
  #pg-profile .hdr { max-width: 780px; }

  .prof-identity-section,
  .prof-dna-section,
  .prof-signals-section,
  .prof-fits-section {
    max-width: 780px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 32px;
    padding-right: 32px;
  }

  /* Pull-to-refresh: disable on desktop (it's touch-only) */
  .ptr-indicator { display: none !important; }

  /* Top-actions: position relative to content area, not full shell */
  .top-actions {
    position: fixed;
    top: 16px;
    right: calc(50vw - 610px + 16px); /* aligns to content area right edge */
    z-index: 300;
  }

  /* Feed: slightly constrain card width */
  .feed-stack { max-width: 440px; }

  /* Settings page content */
  #pg-settings .hdr ~ * { max-width: 860px; margin-left: auto; margin-right: auto; }
  .sett-section { max-width: 720px; margin-left: auto; margin-right: auto; }
}

@media (min-width: 1400px) {
  .shell { max-width: 1380px; }

  .top-actions {
    right: calc(50vw - 690px + 16px);
  }
}

/* ─── Fit Check desktop tightening ────────────────────────────── */
@media (min-width: 1024px) {
  #pg-fitcheck.active {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  #pg-fitcheck > * {
    width: 100%;
    max-width: 640px;
    box-sizing: border-box;
  }
  #pg-fitcheck .hdr {
    max-width: 640px;
    padding-right: 32px;
  }
  .upload-zone {
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }
  .cta-row {
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }
  .occ-wrap {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
  }
  .analysing-wrap, .err-wrap, .results-wrap {
    max-width: 640px;
    width: 100%;
  }

  /* Wardrobe header CLEAR ALL button — stays in flow, not floating */
  .w-hdr {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    max-width: 900px;
    padding-right: 32px;
  }

  /* Feed: remove black side gaps — content fills properly */
  #pg-feed {
    background: var(--bg);
  }
}
