/* ============================================================
   DASHWORLD MEMBERS — shared styles
   Matches the DASH HQ roster cards (Blade-Runner LAPD ID style):
   dark void, neon accent, mono type, corner brackets, halftone portrait.
   ============================================================ */
:root {
  --void: #0a0f14; --bone: #e9eff3;
  --bone-dim: rgba(233,239,243,.62); --bone-faint: rgba(233,239,243,.32);
  --bone-ghost: rgba(233,239,243,.10);
  --neon: #a8c2d0; --neon-soft: rgba(70,84,94,.82);
  --amber: #aeb6bd; --pink: #8fa0ab;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  min-height: 100%;
  background: var(--void); color: var(--bone);
  font-family: "Inter Tight", ui-sans-serif, system-ui, sans-serif;
  font-weight: 300; letter-spacing: .005em;
}
.mono { font-family: "JetBrains Mono", ui-monospace, Menlo, monospace; }
button, input, textarea, select { font-family: inherit; color: inherit; }
.hide { display: none !important; }
a { color: var(--neon); }

/* ambient background — radial vignette + dot grid, like HQ */
body::before {
  content:''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(ellipse 60vmax 50vmax at 50% 25%, #232e37 0%, #0a0e12 82%);
}
body::after {
  content:''; position: fixed; inset: 0; pointer-events: none; z-index: 1; opacity: .2;
  background-image: radial-gradient(circle at 1px 1px, rgba(233,239,243,.08) 1px, transparent 1.4px);
  background-size: 5px 5px;
}

/* nav */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 4;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 28px; background: var(--void);
  border-bottom: 1px solid var(--bone-ghost);
}
.brand {
  font-family: "JetBrains Mono", monospace;
  font-size: 14px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase;
  color: var(--bone);
  text-shadow: -1.1px 0 0 rgba(143,160,171,.85), 1.1px 0 0 rgba(111,211,238,.85), 0 0 14px rgba(58,72,80,.4);
  display: inline-flex; align-items: center; gap: 10px;
}
.brand-logo { height: 20px; width: auto; display: block; color: var(--bone); }
.brand::after {
  content: "会員"; font-size: 8.5px; font-weight: 400; letter-spacing: .22em; color: var(--neon);
  padding: 2px 6px; border: 1px solid var(--neon-soft); text-shadow: 0 0 6px rgba(58,72,80,.6);
}
.nav-right { display: flex; gap: 8px; }
.nav-link {
  background: transparent; padding: 7px 12px;
  font-family: "JetBrains Mono", monospace; font-size: 9px;
  letter-spacing: .22em; text-transform: uppercase; cursor: pointer;
  text-decoration: none; border: 1px solid var(--bone-ghost); color: var(--bone-dim);
}
.nav-link:hover { border-color: var(--neon-soft); color: var(--neon); }

/* page shell — center content */
.shell {
  position: relative; z-index: 2;
  min-height: 100vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center; padding: 100px 20px 48px;
}

/* ============================================================
   LOGIN
   ============================================================ */
.login {
  width: 100%; max-width: 420px;
  background: rgba(5,11,18,.55); backdrop-filter: blur(16px) saturate(140%);
  border: 1.5px solid var(--neon-soft);
  box-shadow: 0 6px 22px rgba(0,0,0,.5), 0 0 18px rgba(58,72,80,.18);
  position: relative; padding: 34px 30px;
}
.login::before, .login::after {
  content: ""; position: absolute; width: 14px; height: 14px; border: 2px solid var(--neon-soft);
}
.login::before { top: -2px; left: -2px; border-right: 0; border-bottom: 0; }
.login::after  { bottom: -2px; right: -2px; border-left: 0; border-top: 0; }
.login h1 {
  font-family: "JetBrains Mono", monospace; font-size: 19px; font-weight: 500;
  letter-spacing: .12em; margin-bottom: 6px;
}
.login .sub {
  font-family: "JetBrains Mono", monospace; font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--bone-dim); margin-bottom: 26px;
}
.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
.field label {
  font-family: "JetBrains Mono", monospace; font-size: 9px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--bone-dim);
}
.input {
  width: 100%; padding: 13px 14px; background: rgba(0,2,4,.6);
  border: 1px solid var(--bone-ghost); color: var(--bone);
  font-family: "JetBrains Mono", monospace; font-size: 14px; letter-spacing: .08em;
  outline: none; transition: border-color .2s;
}
.input:focus { border-color: var(--neon); }
.input::placeholder { color: var(--bone-faint); }
.input.code { text-align: center; letter-spacing: .5em; font-size: 20px; }

.btn {
  width: 100%; padding: 13px 14px; cursor: pointer;
  background: var(--neon); color: #042; border: 0;
  font-family: "JetBrains Mono", monospace; font-size: 11px; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase; transition: filter .2s, opacity .2s;
}
.btn:hover { filter: brightness(1.12); }
.btn:disabled { opacity: .5; cursor: default; }
.btn.ghost {
  background: transparent; color: var(--bone-dim);
  border: 1px solid var(--bone-ghost); font-weight: 400;
}
.btn.ghost:hover { color: var(--neon); border-color: var(--neon-soft); filter: none; }

/* primary: Continue with Google */
.btn.google {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: #fff; color: #1f2328; letter-spacing: .16em; margin-bottom: 14px;
}
.btn.google:hover { filter: brightness(.96); }
.btn.google svg { width: 16px; height: 16px; flex: none; }
.or {
  display: flex; align-items: center; gap: 12px; margin: 4px 0 16px;
  font-family: "JetBrains Mono", monospace; font-size: 9px;
  letter-spacing: .22em; text-transform: uppercase; color: var(--bone-faint);
}
.or::before, .or::after { content: ""; flex: 1; height: 1px; background: var(--bone-ghost); }

.msg {
  font-family: "JetBrains Mono", monospace; font-size: 10px; letter-spacing: .12em;
  margin-top: 14px; min-height: 14px; color: var(--bone-dim);
}
.msg.err { color: var(--pink); }
.msg.ok  { color: var(--neon); }

/* ============================================================
   MEMBER CARD  (mirrors HQ .card)
   ============================================================ */
.card {
  --c-accent: var(--neon);
  position: relative; width: 100%; max-width: 460px;
  background: rgba(5,11,18,.55); backdrop-filter: blur(16px) saturate(140%);
  border: 1.5px solid var(--c-accent);
  font-family: "JetBrains Mono", monospace; color: var(--bone);
  display: flex; flex-direction: column;
  box-shadow: 0 6px 22px rgba(0,0,0,.5), 0 0 18px color-mix(in srgb, var(--c-accent) 18%, transparent);
}
.card::before, .card::after {
  content: ""; position: absolute; width: 14px; height: 14px; border: 2px solid var(--c-accent);
}
.card::before { top: -2px; left: -2px; border-right: 0; border-bottom: 0; }
.card::after  { bottom: -2px; right: -2px; border-left: 0; border-top: 0; }

.card-header {
  display: grid; grid-template-columns: 1fr auto; align-items: end;
  padding: 12px 16px; gap: 14px;
  border-bottom: 1.5px solid var(--c-accent); background: rgba(0,2,4,.5);
}
.card-header .agency { font-size: 9px; letter-spacing: .22em; color: var(--bone-dim); }
.card-header .agency .jp { color: var(--bone); margin-right: 4px; }
.card-header .agency b { color: var(--c-accent); font-weight: 700; }
.card-header .name {
  font-size: 22px; font-weight: 500; letter-spacing: .08em; color: var(--bone);
  margin-top: 6px; display: flex; gap: 10px; align-items: baseline;
}
.card-header .name b { font-weight: 700; color: var(--c-accent); }
.card-header .right { text-align: right; }
.card-header .signal {
  font-size: 9px; letter-spacing: .18em; color: var(--bone-dim);
  display: flex; align-items: center; gap: 8px; justify-content: flex-end;
}
.card-header .signal .bars { display: inline-flex; gap: 1px; }
.card-header .signal .bars i { width: 4px; height: 9px; background: var(--c-accent); display: inline-block; }
.card-header .signal .bars i:nth-child(4) { opacity: .35; }
.card-header .access { font-size: 9px; letter-spacing: .22em; color: var(--bone-dim); margin-top: 8px; }
.card-header .access b { color: var(--c-accent); }

.card-body { display: grid; grid-template-columns: 170px 1fr; gap: 0; }
.portrait {
  position: relative; aspect-ratio: 4/5; overflow: hidden;
  border-right: 1.5px solid var(--c-accent); background: var(--void);
}
.portrait::before, .portrait::after {
  content: ""; position: absolute; width: 12px; height: 12px; border: 1.5px solid var(--c-accent); z-index: 3;
}
.portrait::before { top: 6px; left: 6px; border-right: 0; border-bottom: 0; }
.portrait::after  { bottom: 6px; right: 6px; border-left: 0; border-top: 0; }
.portrait img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.55) contrast(1.1) brightness(.97); }
.portrait .ph {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: 60px; font-weight: 700; color: var(--c-accent); opacity: .8;
  background: radial-gradient(circle at 50% 40%, rgba(58,72,80,.12), transparent 70%);
}
.edit-pill {
  position: absolute; bottom: 8px; left: 8px; right: 8px; z-index: 4; text-align: center;
  font-size: 8.5px; letter-spacing: .22em; text-transform: uppercase;
  background: rgba(5,11,18,.78); color: var(--bone-dim);
  border: 1px solid var(--bone-ghost); padding: 6px; cursor: pointer; transition: .2s;
}
.edit-pill:hover { color: var(--c-accent); border-color: var(--c-accent); }

.side { display: flex; flex-direction: column; }
.stat {
  display: flex; flex-direction: column; gap: 3px;
  padding: 12px 16px; border-bottom: 1px solid var(--bone-ghost);
}
.stat .k { font-size: 8.5px; letter-spacing: .22em; text-transform: uppercase; color: var(--bone-dim); }
.stat .v { font-size: 14px; letter-spacing: .06em; color: var(--bone); }
.stat .v em { font-style: normal; color: var(--amber); font-size: 10px; letter-spacing: .12em; }

.tile {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; border-bottom: 1px solid var(--bone-ghost);
}
.tile .k { font-size: 11px; letter-spacing: .12em; color: var(--bone); }
.tile .v { font-size: 8.5px; letter-spacing: .2em; text-transform: uppercase; }
.tile.locked { opacity: .72; }
.tile.locked .v {
  color: var(--amber); border: 1px solid rgba(174,182,189,.3);
  padding: 3px 7px; background: rgba(174,182,189,.06);
}

.card-foot {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
  padding: 13px 16px; border-top: 1.5px dashed var(--c-accent); background: rgba(0,2,4,.55);
}
.card-foot .name-edit { display: flex; gap: 8px; flex: 1 1 100%; }
.card-foot .name-edit .input { padding: 9px 11px; font-size: 12px; }
.card-foot .mini {
  padding: 8px 11px; cursor: pointer; background: transparent;
  border: 1px solid var(--bone-ghost); color: var(--bone-dim);
  font-size: 8.5px; letter-spacing: .2em; text-transform: uppercase; transition: .2s;
}
.card-foot .mini:hover { color: var(--c-accent); border-color: var(--c-accent); }
.card-foot .mini.save { background: var(--neon); color: #042; border-color: var(--neon); font-weight: 700; }
.card-foot .mini.danger:hover { color: var(--pink); border-color: var(--pink); }

.demo-banner {
  position: fixed; top: 54px; left: 0; right: 0; z-index: 5; text-align: center;
  font-family: "JetBrains Mono", monospace; font-size: 9px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--amber);
  background: rgba(174,182,189,.08); border-bottom: 1px solid rgba(174,182,189,.25);
  padding: 6px;
}
.card-note {
  margin-top: 16px; max-width: 460px; text-align: center;
  font-family: "JetBrains Mono", monospace; font-size: 9px; letter-spacing: .14em;
  color: var(--bone-faint); line-height: 1.6;
}
