/* OSEION Salon — lean styling, tokens distilled from the launch site. */
:root {
  --void:#0A0A0B; --ink:#141415; --bone:#ECECEA; --bone-dim:#C4C4C2;
  --quiet:#5E5F62; --tertiary:#8C8C8D; --champagne:#E4DBCB; --line:#26262a;
  --font-display:'Michroma','Helvetica Neue',Arial,sans-serif;
  --font-body:'Montserrat','Helvetica Neue',Arial,sans-serif;
}
* { box-sizing:border-box; }
html,body { margin:0; }
body {
  min-height:100vh; background:var(--void); color:var(--bone);
  font-family:var(--font-body); font-weight:300; -webkit-font-smoothing:antialiased;
}
.brand__mark { font-family:var(--font-display); letter-spacing:.32em; font-size:.95rem; }
.brand__sub, .topbar__tag { color:var(--tertiary); letter-spacing:.28em; font-size:.65rem; text-transform:uppercase; margin-left:.7em; }

/* ============================================================
   Auth pages (door / activate) — match the launch landing
   ============================================================ */
.salon-bg { position:fixed; inset:0; z-index:0; width:100%; height:100%; display:block; background:var(--void); }
.salon-vig { position:fixed; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(132% 112% at 50% 44%, rgba(10,10,11,0) 48%, rgba(10,10,11,.72) 100%); }

.room {
  position:relative; z-index:1;
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:20px; padding:32px;
}
.logo-home { display:inline-block; line-height:0; border:0; cursor:pointer; }
.logo__mark { height:30px; width:auto; display:block; filter:drop-shadow(0 0 22px rgba(10,10,11,.85)); transition:opacity .3s ease; }
.logo-home:hover .logo__mark { opacity:.82; }
.rule { width:36px; height:1px; background:rgba(236,236,234,.4); }

.panel { width:100%; max-width:360px; text-align:center; }
.panel__title { font-family:var(--font-body); font-weight:200; font-size:1.5rem; letter-spacing:.03em; margin:6px 0 12px; color:var(--bone); text-shadow:0 0 18px rgba(10,10,11,.9); }
.panel__lead { color:var(--bone-dim); font-size:clamp(0.95rem, 0.9rem + 0.35vw, 1.05rem); font-weight:300; line-height:1.55; letter-spacing:.01em; margin:2px 0 28px; text-shadow:0 0 14px rgba(10,10,11,.92); }

/* form controls — scoped to .room so the gallery/studio keep their own styling */
.room .form { gap:22px; text-align:left; }
.room .field { gap:9px; font-size:.68rem; letter-spacing:.24em; color:#B8BABD; text-shadow:0 0 12px rgba(10,10,11,.92); }
/* Hairline fields — a line, not a box (mirrors the landing capture) */
.room input {
  background:transparent; border:0; border-radius:0;
  border-bottom:1px solid rgba(236,236,234,0.26);
  padding:11px 2px; font-weight:300;
  font-size:1rem; /* 16px — at/over the iOS focus-zoom threshold */
  color:var(--bone); outline:none;
  transition:border-color .35s ease;
}
.room input:focus {
  border-bottom-color:rgba(245,232,205,.85);
  box-shadow:0 1px 0 0 rgba(245,232,205,.5), 0 12px 26px -18px rgba(245,232,205,.45);
}
/* The way through — a quiet champagne outline that fills on intent */
.room .btn {
  width:100%; margin-top:14px;
  background:transparent; color:var(--champagne);
  border:1px solid rgba(228,219,203,0.5); border-radius:4px;
  padding:15px 22px; font-weight:500; letter-spacing:.24em; font-size:.7rem;
  text-transform:uppercase;
  transition:background .3s ease, color .3s ease, border-color .3s ease, transform .12s ease;
}
.room .btn:hover { background:var(--champagne); color:#1A1714; border-color:var(--champagne); }
.room .btn:active { transform:translateY(1px); }

/* Footer — one constant design across the project (mirrors the landing) */
.foot {
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; flex-wrap:wrap;
  padding:clamp(22px,5vw,40px) clamp(24px,6vw,48px);
  border-top:1px solid rgba(236,236,234,0.08);
}
.salon-foot { position:fixed; bottom:0; left:0; right:0; z-index:1; }
.foot__copy { margin:0; font-size:.7rem; letter-spacing:.1em; color:#B8BABD; text-shadow:0 0 12px rgba(10,10,11,.95); }
.foot__legal {
  margin:0; display:flex; align-items:center; gap:10px;
  font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:#B8BABD;
  text-shadow:0 0 12px rgba(10,10,11,.95);
}
.foot__legal a { color:#B8BABD; border:0; text-decoration:none; }
.foot__legal a:hover { color:var(--bone); }
.foot__dot { color:var(--quiet); }

.form { display:flex; flex-direction:column; gap:14px; }
.form--row { flex-direction:row; flex-wrap:wrap; align-items:center; }
.field { display:flex; flex-direction:column; gap:6px; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--tertiary); }
input, .form--row input {
  background:#0f0f11; border:1px solid var(--line); color:var(--bone);
  border-radius:6px; padding:11px 13px; font-family:inherit; font-size:.95rem;
}
.form--row input { flex:1 1 160px; }
input:focus { outline:none; border-color:var(--champagne); }
.btn {
  background:var(--bone); color:#161310; border:0; border-radius:6px;
  padding:12px 22px; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  font-size:.72rem; cursor:pointer;
}
.btn:hover { background:#fff; }
.link { background:none; border:0; color:var(--bone-dim); cursor:pointer; font:inherit; font-size:.82rem; text-decoration:underline; }
.link.danger { color:#E2675C; }
.msg { color:#E2675C; font-size:.8rem; margin:4px 0 0; }
.fineprint { color:#B8BABD; font-size:.78rem; margin-top:24px; line-height:1.6; text-align:center; text-shadow:0 0 12px rgba(10,10,11,.92); }
.fineprint p { margin:0; }
.fineprint p + p { margin-top:8px; }
.fineprint a { color:var(--champagne); border:0; text-decoration:none; transition:color .3s; }
.fineprint a:hover { color:#FBF4E6; }

/* Top bar (gallery / studio) */
.topbar { display:flex; align-items:center; gap:14px; padding:18px 24px; border-bottom:1px solid var(--line); }
.topbar__nav { margin-left:auto; display:flex; align-items:center; gap:18px; }

/* Customer gallery */
.gallery, .studio { max-width:1080px; margin:0 auto; padding:40px 24px 80px; }
.gallery__title { font-family:var(--font-display); font-weight:400; font-size:1.3rem; margin:0 0 8px; }
.gallery__lead { color:var(--bone-dim); margin:0 0 28px; font-size:.9rem; }
.grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:22px; }
.card {
  border:1px solid var(--line); border-radius:10px; overflow:hidden; background:var(--ink);
  text-decoration:none; color:inherit; display:block;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
a.card:hover { transform:translateY(-3px); border-color:#3a3a40; box-shadow:0 14px 40px rgba(0,0,0,.45); }
.card__media { aspect-ratio:3/4; background:#0f0f11; display:flex; }
.card__media img { width:100%; height:100%; object-fit:cover; }
.card__body { padding:14px 16px 18px; }
.card__name { font-size:1rem; margin:0 0 4px; font-weight:400; }
.card__code { color:var(--tertiary); font-size:.72rem; letter-spacing:.12em; margin:0 0 8px; }
.card__desc { color:var(--bone-dim); font-size:.82rem; line-height:1.55; margin:0; }

/* Garment detail page */
.detail { max-width:920px; margin:0 auto; padding:32px 24px 96px; }
.detail__hero { margin:0 0 26px; border-radius:12px; overflow:hidden; background:#0f0f11; }
.detail__hero img { width:100%; display:block; cursor:zoom-in; }
.detail__head { display:flex; align-items:center; gap:12px; }
.detail__name { font-family:var(--font-display); font-weight:400; font-size:clamp(1.5rem,4vw,2.3rem); margin:0; }
.detail__code { color:var(--tertiary); letter-spacing:.14em; font-size:.8rem; margin:8px 0 0; text-transform:uppercase; }
.detail__desc { color:var(--bone-dim); line-height:1.75; max-width:62ch; margin:20px 0 0; font-size:.95rem; }
.detail__section { font-family:var(--font-display); font-weight:400; font-size:.95rem; letter-spacing:.04em; margin:42px 0 16px; }
.media-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:16px; }
.media-grid img { width:100%; aspect-ratio:3/4; object-fit:cover; border-radius:8px; cursor:zoom-in; transition:opacity .2s; }
.media-grid img:hover { opacity:.85; }

/* Lightbox */
.lightbox { position:fixed; inset:0; background:rgba(0,0,0,.92); display:none; align-items:center; justify-content:center; padding:5vh 5vw; z-index:50; cursor:zoom-out; }
.lightbox.open { display:flex; }
.lightbox img { max-width:100%; max-height:100%; object-fit:contain; }

/* Studio list */
.studio__team { margin-bottom:48px; padding-bottom:40px; border-bottom:1px solid var(--line); }
.role-select {
  margin-left:auto; background:#0f0f11; border:1px solid var(--line); color:var(--bone);
  border-radius:6px; padding:7px 10px; font-family:inherit; font-size:.8rem; text-transform:capitalize; cursor:pointer;
}
.role-select:focus { outline:none; border-color:var(--champagne); }
.studio__new { margin-bottom:40px; }
.studio__list { display:flex; flex-direction:column; gap:14px; }
.gitem { border:1px solid var(--line); border-radius:10px; padding:16px 18px; background:var(--ink); }
.gitem__head { display:flex; align-items:center; gap:10px; }
.gitem__cover { width:40px; height:50px; object-fit:cover; border-radius:5px; flex:0 0 auto; background:#0f0f11; }
.gitem__cover--empty { display:inline-block; border:1px dashed var(--line); }
.gitem__code { color:var(--tertiary); font-size:.75rem; }
.gitem__media { margin-top:14px; }
.gitem__media summary { cursor:pointer; color:var(--bone-dim); font-size:.82rem; }
.media-strip { display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; align-items:center; }
.media-thumb { position:relative; width:64px; height:80px; border-radius:6px; overflow:hidden; background:#0f0f11; }
.media-thumb img { width:100%; height:100%; object-fit:cover; }
.media-thumb button {
  position:absolute; top:2px; right:2px; width:18px; height:18px; line-height:1; border:0; border-radius:50%;
  background:rgba(10,10,11,.8); color:var(--bone); cursor:pointer; font-size:13px; display:flex; align-items:center; justify-content:center;
}
.media-add {
  width:64px; height:80px; display:flex; align-items:center; justify-content:center;
  border:1px dashed var(--line); border-radius:6px; color:var(--tertiary); font-size:1.3rem;
}
.pill { margin-left:auto; font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; padding:3px 9px; border-radius:20px; border:1px solid var(--line); color:var(--tertiary); }
.pill.published { color:#0A0A0B; background:var(--champagne); border-color:transparent; }
.gitem__actions { display:flex; align-items:center; gap:18px; margin-top:14px; flex-wrap:wrap; }
.upload { font-size:.78rem; color:var(--bone-dim); cursor:pointer; }
.upload input { display:none; }
.gitem__access { margin-top:14px; }
.gitem__access summary { cursor:pointer; color:var(--bone-dim); font-size:.82rem; }
.access-list { display:flex; flex-direction:column; gap:8px; margin-top:12px; font-size:.85rem; color:var(--bone-dim); }
.access-list label { display:flex; align-items:center; gap:9px; cursor:pointer; }
