/* mod-signup styles — ported from prototype, scoped to #signup-app */
/* Maps prototype vars: --bg->--bg, --bg2->--bg2, --bg3->--bg3, --bdr->--border, --tx->--text, --tx-m->--text-mid, --tx-d->--text-dim, --cyan->--primary, --pink->--red, --fd->--font-head, --fb->inherit */

#signup-app {
  position: relative;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  font-size: 14px;
  line-height: 1.6;
  --bgi: color-mix(in srgb, var(--bg) 60%, var(--bg2));
  --bdr-h: color-mix(in srgb, var(--border) 50%, var(--text-dim));
  --bdr-g: color-mix(in srgb, var(--border) 30%, var(--text-dim));
  --green: #39ff7f;
  --pink: #ff3997;
  --cyan: var(--primary);
  --gold: #f0c040;
  --purple: #9945FF;
}

/* ═══ ADMIN TOGGLE ═══ */
#signup-app .adm-tog { position: absolute; top: 20px; right: 20px; z-index: 200; width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--border); background: var(--bg2); color: var(--text-dim); font-size: 20px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.25s; box-shadow: 0 4px 20px rgba(0,0,0,0.5); }
#signup-app .adm-tog:hover { border-color: var(--pink); color: var(--pink); }
#signup-app.adm .adm-tog { background: var(--pink); color: #fff; border-color: var(--pink); box-shadow: 0 0 20px rgba(255,57,151,0.4); }

/* editables in admin */
#signup-app.adm .e { outline: 1px dashed rgba(255,57,151,0.25); outline-offset: 2px; cursor: text; border-radius: 3px; min-width: 20px; min-height: 1em; }
#signup-app.adm .e:hover { outline-color: var(--pink); background: rgba(255,57,151,0.03); }
#signup-app.adm .e:focus { outline: 2px solid var(--pink); background: rgba(255,57,151,0.05); }

/* admin action btns */
#signup-app .ab { display: none; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; border: 1px solid rgba(255,57,151,0.3); background: rgba(255,57,151,0.08); color: var(--pink); font-size: 13px; font-weight: 700; cursor: pointer; transition: all 0.15s; flex-shrink: 0; line-height: 1; }
#signup-app .ab:hover { background: var(--pink); color: #fff; border-color: var(--pink); }
#signup-app .ab.x { border-color: rgba(255,74,74,0.3); background: rgba(255,74,74,0.08); color: #ff4a4a; }
#signup-app .ab.x:hover { background: #ff4a4a; color: #fff; }
#signup-app.adm .ab { display: flex; }

/* color picker */
#signup-app .cp { display: none; position: absolute; top: -6px; right: -6px; z-index: 50; }
#signup-app.adm .cp { display: block; }
#signup-app .cp input[type="color"] { width: 22px; height: 22px; border: 2px solid var(--border); border-radius: 50%; cursor: pointer; background: none; padding: 0; }
#signup-app .cp input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; }
#signup-app .cp input[type="color"]::-webkit-color-swatch { border: none; border-radius: 50%; }

/* add tier bar */
#signup-app .at-bar { display: none; justify-content: center; margin-top: 16px; }
#signup-app.adm .at-bar { display: flex; }
#signup-app .at-btn { background: rgba(255,57,151,0.06); border: 1px dashed rgba(255,57,151,0.3); border-radius: 10px; padding: 12px 28px; color: var(--pink); font-family: var(--font-head); font-size: 14px; letter-spacing: 0.08em; cursor: pointer; transition: all 0.2s; }
#signup-app .at-btn:hover { background: rgba(255,57,151,0.12); border-color: var(--pink); }

/* add feature btn */
#signup-app .af { display: none; font-size: 14px; color: var(--pink); background: none; border: 1px dashed rgba(255,57,151,0.3); border-radius: 6px; padding: 6px 10px; cursor: pointer; margin-top: 8px; margin-bottom: 14px; width: 100%; }
#signup-app .af:hover { background: rgba(255,57,151,0.08); }
#signup-app.adm .af { display: block; }

/* ═══ HERO ═══ */
#signup-app .su-hero { text-align: center; padding: 14px 20px 7px; position: relative; }
#signup-app .su-hero::before { content: ''; position: absolute; top: -60px; left: 50%; transform: translateX(-50%); width: 500px; height: 300px; background: radial-gradient(ellipse,color-mix(in srgb, var(--primary) 25%, transparent) 0%,transparent 70%); opacity: 0.25; pointer-events: none; }
#signup-app .su-hero h1 { font-family: var(--font-head); font-size: clamp(26px,4.5vw,38px); position: relative; }
#signup-app .su-hero .hl { color: var(--primary); text-shadow: 0 0 30px color-mix(in srgb, var(--primary) 25%, transparent); }
#signup-app .su-hero > p { color: var(--text-mid); font-size: 15px; margin-top: 6px; position: relative; max-width: 624px; margin-left: auto; margin-right: auto; }

/* ═══ STEPPER ═══ */
#signup-app .stepper { display: flex; justify-content: center; align-items: center; gap: 0; margin: 12px auto 16px; max-width: 460px; }
#signup-app .stp-back { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; margin-right: 8px; border: 1px solid var(--border); border-radius: 50%; background: transparent; color: var(--text-mid); font-size: 20px; line-height: 1; padding: 0 0 2px; cursor: pointer; transition: border-color .2s, color .2s; }
#signup-app .stp-back:hover:not(:disabled) { border-color: var(--primary); color: var(--primary); }
#signup-app .stp-back:disabled { opacity: 0.3; cursor: default; }
#signup-app .stp { display: flex; align-items: center; gap: 7px; font-size: 14px; font-weight: 600; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.06em; position: relative; padding: 0 16px; cursor: pointer; }
#signup-app .stp::after { content: ''; position: absolute; right: -4px; top: 50%; transform: translateY(-50%); width: 24px; height: 1px; background: var(--border); }
#signup-app .stp:last-child::after { display: none; }
#signup-app .stp:hover .sn { border-color: var(--text-mid); }
#signup-app .stp:hover { color: var(--text-mid); }
#signup-app .sn { width: 24px; height: 24px; border-radius: 50%; border: 2px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; transition: all 0.3s; }
#signup-app .stp.on .sn { border-color: var(--primary); background: color-mix(in srgb, var(--primary) 6%, transparent); color: var(--primary); box-shadow: 0 0 10px color-mix(in srgb, var(--primary) 25%, transparent); }
#signup-app .stp.on { color: var(--primary); }
#signup-app .stp.ok .sn { border-color: var(--green); background: rgba(57,255,127,0.08); color: var(--green); }
#signup-app .stp.ok { color: var(--green); }

/* ═══ PANELS ═══ */
#signup-app .su-pn { display: none; animation: su-fu 0.3s ease; }
#signup-app .su-pn.on { display: block; }
@keyframes su-fu { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

/* ═══ PLANS ═══ */
#signup-app .plans { display: flex; justify-content: center; gap: 16px; max-width: 1100px; margin: 0 auto; padding: 0 16px; flex-wrap: wrap; }
#signup-app .plan { flex: 1; min-width: 200px; max-width: 250px; background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 26px 20px; display: flex; flex-direction: column; position: relative; transition: all 0.25s; cursor: pointer; }
#signup-app .plan:hover { border-color: var(--bdr-h); transform: translateY(-3px); }
#signup-app .plan.sel { transform: translateY(-4px); }
#signup-app .pp { position: absolute; top: -10px; right: 14px; font-family: var(--font-head); font-size: 11px; letter-spacing: 0.1em; padding: 4px 12px; border-radius: 4px; cursor: default; z-index: 10; }
#signup-app.adm .pp { cursor: grab; outline: 1px dashed rgba(255,57,151,0.4); outline-offset: 2px; }
#signup-app.adm .pp:active { cursor: grabbing; }
/* tier name size control */
#signup-app .nm-sz { display: none; position: absolute; top: 2px; left: -28px; flex-direction: column; gap: 2px; z-index: 10; }
#signup-app.adm .nm-sz { display: flex; }
#signup-app .nm-sz button { width: 20px; height: 16px; border: 1px solid rgba(255,57,151,0.3); background: rgba(255,57,151,0.06); color: var(--pink); font-size: 10px; cursor: pointer; border-radius: 3px; display: flex; align-items: center; justify-content: center; padding: 0; line-height: 1; }
#signup-app .nm-sz button:hover { background: var(--pink); color: #fff; }
#signup-app .ph { display: flex; align-items: flex-start; justify-content: space-between; position: relative; }
#signup-app .pn-nm { font-family: var(--font-head); font-size: 18px; font-weight: 700; margin-bottom: 2px; }
#signup-app .pf li .gh { color: var(--text-dim); opacity: 0.4; }
/* trial badge */
#signup-app .pr-row { display: flex; align-items: baseline; justify-content: space-between; margin: 10px 0 2px; min-height: 36px; }
#signup-app .trial-badge { font-size: 12px; color: var(--green); font-weight: 600; display: none; white-space: nowrap; }
#signup-app .trial-badge.on { display: inline; }
#signup-app .trial-badge.ltd { color: var(--gold); }
/* trial admin control */
#signup-app .trial-ctl { display: none; margin-top: 6px; margin-bottom: 8px; align-items: center; gap: 8px; }
#signup-app.adm .trial-ctl { display: flex; }
#signup-app .trial-ctl label { font-size: 12px; color: var(--pink); font-weight: 600; white-space: nowrap; }
#signup-app .trial-ctl select { background: var(--bgi); border: 1px solid rgba(255,57,151,0.3); border-radius: 6px; color: var(--text); font-size: 14px; padding: 4px 8px; outline: none; cursor: pointer; }
#signup-app .trial-ctl select:focus { border-color: var(--pink); }

/* billing toggle */
#signup-app .bill-tog { display: flex; align-items: center; justify-content: center; gap: 12px; margin: 0 auto 24px; }
#signup-app .bill-tog span { font-size: 14px; color: var(--text-dim); font-weight: 500; cursor: pointer; transition: color 0.2s; }
#signup-app .bill-tog span.on { color: var(--text); }
#signup-app .bill-sw { width: 48px; height: 26px; border-radius: 13px; background: var(--border); cursor: pointer; position: relative; transition: background 0.25s; }
#signup-app .bill-sw.yr { background: var(--green); }
#signup-app .bill-sw::after { content: ''; position: absolute; top: 3px; left: 3px; width: 20px; height: 20px; border-radius: 50%; background: #fff; transition: transform 0.25s; }
#signup-app .bill-sw.yr::after { transform: translateX(22px); }
#signup-app .bill-tog .ann-save { display: inline; font-size: 11px; font-weight: 700; color: #ff6b35 !important; margin-left: 4px; text-shadow: 0 0 12px rgba(255,107,53,0.4); }
/* annual discount admin ctl */
#signup-app .disc-ctl { display: none; margin-top: 4px; margin-bottom: 4px; align-items: center; gap: 8px; }
#signup-app.adm .disc-ctl { display: flex; }
#signup-app .disc-ctl label { font-size: 12px; color: var(--pink); font-weight: 600; white-space: nowrap; }
#signup-app .disc-ctl input { background: var(--bgi); border: 1px solid rgba(255,57,151,0.3); border-radius: 6px; color: var(--text); font-size: 14px; padding: 4px 8px; outline: none; width: 60px; text-align: center; }
#signup-app .disc-ctl input:focus { border-color: var(--pink); }
#signup-app .cancel-note { text-align: center; margin-top: 20px; font-size: 14px; color: var(--text-dim); }
#signup-app .enterprise-note { text-align: center; margin-top: 12px; font-size: 14px; color: var(--text-dim); }
#signup-app .enterprise-note a { color: var(--primary); text-decoration: none; }
#signup-app .enterprise-note a:hover { text-decoration: underline; }
#signup-app .su-info { max-width: 900px; margin: 24px auto 0; text-align: center; font-size: 14px; line-height: 1.7; color: var(--text-dim); padding: 0 20px; }
/* text color picker */
#signup-app .tc-pick { display: none; margin-left: 6px; }
#signup-app.adm .tc-pick { display: inline-block; }
#signup-app .tc-pick input[type="color"] { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 50%; cursor: pointer; background: none; padding: 0; vertical-align: middle; }
#signup-app .tc-pick input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; }
#signup-app .tc-pick input[type="color"]::-webkit-color-swatch { border: none; border-radius: 50%; }
#signup-app .pn-pr { font-size: 30px; font-weight: 700; line-height: 1; }
#signup-app .pn-pr .c { font-size: 16px; font-weight: 600; opacity: 0.6; vertical-align: top; }
#signup-app .pn-pr .p { font-size: 14px; font-weight: 400; color: var(--text-dim); margin-left: 2px; }
#signup-app .alt-pr { display: block; font-size: 12px; font-weight: 400; color: var(--text-dim); margin-top: 2px; pointer-events: none; }
#signup-app.adm .alt-pr { outline: none !important; background: none !important; cursor: default; }
#signup-app .pn-ds { font-size: 14px; color: var(--text-dim); margin-bottom: 18px; min-height: 42px; line-height: 1.45; }
#signup-app .pf { list-style: none; flex: 1; display: flex; flex-direction: column; gap: 6px; margin-bottom: 24px; }
#signup-app .pf li { font-size: 14px; color: var(--text-mid); display: flex; align-items: center; gap: 7px; line-height: 1.4; }
#signup-app .pf .dt { flex-shrink: 0; font-size: 8px; }
#signup-app .pf li.off { color: var(--text-dim); opacity: 0.4; }
#signup-app .pf .fr { display: flex; align-items: center; gap: 5px; flex: 1; }
#signup-app .pb { width: 100%; padding: 11px; border: 1px solid var(--border); border-radius: 8px; background: transparent; color: var(--text-mid); font-family: var(--font-head); font-size: 14px; letter-spacing: 0.06em; cursor: pointer; transition: all 0.2s; }
#signup-app .pb:hover { border-color: var(--bdr-h); color: var(--text); }

/* Role icons — individual transparent PNGs from /_ui/. No sheet so no
   alignment / background drift. */
#signup-app .role-icon {
  display: inline-block; width: 48px; height: 48px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  vertical-align: middle;
}
/* Role PNGs are tenant assets — JS resolves file_ids at init (see
   loadRoleIconUrls in app.js) and sets CSS vars on :root. */
#signup-app .role-icon[data-role="grinder"]     { background-image: var(--role-grinder); }
#signup-app .role-icon[data-role="producer"]    { background-image: var(--role-producer); }
#signup-app .role-icon[data-role="manager"]     { background-image: var(--role-manager); }
#signup-app .role-icon[data-role="designer"]    { background-image: var(--role-designer); }
#signup-app .role-icon[data-role="art"]         { background-image: var(--role-art); }
#signup-app .role-icon[data-role="musician"]    { background-image: var(--role-musician); }
#signup-app .role-icon[data-role="soundfx"],
#signup-app .role-icon[data-role="soundFX"]     { background-image: var(--role-soundfx); }
#signup-app .role-icon[data-role="tester"]      { background-image: var(--role-tester); }
#signup-app .role-icon[data-role="marketing"]   { background-image: var(--role-marketing); }
#signup-app .role-icon[data-role="videography"] { background-image: var(--role-videography); }
#signup-app .role-icon[data-role="social"]      { background-image: var(--role-social); }
#signup-app .role-icon[data-role="brand"]       { background-image: var(--role-brand); }
#signup-app .role-icon[data-role="press"]       { background-image: var(--role-press); }
/* Role-icon chip: vertical stack — icon on top, name below. Selected
   state lights both with the brand-color drop-shadow + label tint. */
#signup-app .gs-chip-icon {
  padding: 4px 6px !important;
  background: transparent !important;
  border: none !important;
  line-height: 1;
  display: inline-flex !important;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  cursor: pointer;
}
#signup-app .gs-chip-icon.on { filter: drop-shadow(0 0 8px var(--primary)); }
#signup-app .gs-chip-icon .gs-chip-label {
  font-size: 11px;
  color: var(--text-mid);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-family: var(--font-head, 'Bungee', cursive);
}
#signup-app .gs-chip-icon.on .gs-chip-label { color: var(--primary); }
#signup-app .gs-chip-icon:hover .gs-chip-label { color: var(--text); }

/* ═══ FORM ═══ */
#signup-app .fw { max-width: 460px; margin: 0 auto; padding: 0 20px; }
/* Two-column variant: avatar iframe on the left, form fields on the
   right. Dev/Studio/Studio-Pro tiers opt in via 'avatar' in tier.form. */
#signup-app .fw.fw-2col { max-width: 880px; }
#signup-app .fw-cols { display: grid; grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.2fr); gap: 24px; align-items: start; }
#signup-app .fw-avatar-col { position: sticky; top: 0; }
#signup-app .fw-fields-col { min-width: 0; }
@media (max-width: 720px) {
  #signup-app .fw-cols { grid-template-columns: 1fr; }
  #signup-app .fw-avatar-col { position: static; }
}
#signup-app .fhd { text-align: center; margin-bottom: 28px; }
#signup-app .fhd h2 { font-family: var(--font-head); font-size: 20px; }
#signup-app .fhd .tb { display: inline-block; padding: 3px 12px; border-radius: 4px; font-family: var(--font-head); font-size: 10px; letter-spacing: 0.08em; margin-top: 8px; }
#signup-app .fg { margin-bottom: 16px; }
#signup-app .fl { display: block; font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-dim); margin-bottom: 5px; }
#signup-app .fi { width: 100%; box-sizing: border-box; padding: 11px 13px; background: var(--bgi); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 14px; outline: none; transition: border-color 0.2s, box-shadow 0.2s; }
#signup-app .fi:focus { border-color: var(--primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 6%, transparent); }
#signup-app .fi::placeholder { color: var(--text-dim); }
#signup-app .fh { font-size: 14px; color: var(--text-dim); margin-top: 4px; }
#signup-app .fh span { color: var(--primary); }
#signup-app .fh.fh-warn { color: var(--red, #ff3997); font-weight: 600; }
#signup-app .fh.fh-warn span { color: inherit; }
/* "Your domain/website:" prefix label — muted gray, regular weight,
   so the domain itself (the .fh-warn red span next to it) stays the
   thing the eye lands on. */
#signup-app .fh.fh-warn .fh-label {
  color: var(--text-dim);
  font-weight: 400;
}
/* "(locks at signup)" suffix in the LABEL row — orange, lowercase,
   sits inline next to the red required marker. Orange is bright
   enough to register as a warning without competing with the red *
   marker for "required" status. */
#signup-app .fl .fl-lock {
  color: #ff8c42;
  font-weight: 600; font-size: 11px;
  text-transform: none; letter-spacing: 0;
  margin-left: 6px;
}
/* Availability status in the label row — pushes to the right of the
   label so the input below can span the whole column. */
#signup-app .fl { display: flex; align-items: center; flex-wrap: wrap; }
#signup-app .fl .fl-status {
  margin-left: auto;
  font-size: 12px; font-weight: 600;
  text-transform: none; letter-spacing: 0;
}
#signup-app .sw { position: relative; }
#signup-app .ss { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-size: 14px; font-weight: 600; }
#signup-app .fr2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
#signup-app .ft { font-size: 14px; color: var(--text-dim); margin: 18px 0; line-height: 1.6; }
#signup-app .ft a { color: var(--primary); text-decoration: none; }
#signup-app .bp { width: 100%; padding: 13px; border: none; border-radius: 8px; font-family: var(--font-head); font-size: 12px; letter-spacing: 0.06em; cursor: pointer; transition: all 0.2s; }
/* Narrower variant for the tier-form submit — full-width looked huge
   across the 2-col Dev/Studio signup layout. */
#signup-app .bp.bp-narrow { width: auto; min-width: 220px; max-width: 320px; padding: 12px 32px; margin: 18px auto 0; display: block; }
#signup-app .bp:hover { transform: translateY(-1px); filter: brightness(1.1); }
#signup-app .bp:disabled { opacity: 0.5; cursor: not-allowed; transform: none; filter: none; }
#signup-app .bb { background: none; border: 1px solid var(--border); border-radius: 8px; color: var(--text-dim); font-size: 12px; padding: 10px 20px; cursor: pointer; transition: all 0.2s; margin-top: 10px; width: 100%; }
#signup-app .bb:hover { border-color: var(--bdr-h); color: var(--text); }
#signup-app .em { background: rgba(255,57,151,0.08); border: 1px solid rgba(255,57,151,0.25); color: var(--pink); font-size: 14px; padding: 10px 14px; border-radius: 8px; margin-bottom: 16px; display: none; }
#signup-app .em.on { display: block; }

/* slug row — username + studio slug use .fi sized like Password
   above, with the availability marker sitting next to the input. */
#signup-app .slug-row { display: flex; align-items: center; gap: 8px; }
#signup-app .slug-row label { font-size: 12px; color: var(--text-dim); font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; }
#signup-app .slug-row .fi { flex: 1; }
#signup-app .slug-input { flex: 1; padding: 8px 10px; background: var(--bgi); border: 1px solid var(--border); border-radius: 6px; color: var(--text); font-size: 13px; font-family: var(--font-mono); outline: none; }
#signup-app .slug-input:focus { border-color: var(--primary); }
#signup-app .slug-status { font-size: 13px; font-weight: 600; white-space: nowrap; }

/* ═══ BILLPAY PLACEHOLDER (v2) ═══ */
#signup-app .bw { max-width: 540px; margin: 0 auto; padding: 0 20px; }
#signup-app .bhd { text-align: center; margin-bottom: 24px; }
#signup-app .bhd h2 { font-family: var(--font-head); font-size: 20px; }
#signup-app .bhd p { color: var(--text-dim); font-size: 14px; margin-top: 6px; }
#signup-app .ps { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; padding: 18px 22px; margin-bottom: 18px; }
#signup-app .pr { display: flex; justify-content: space-between; padding: 5px 0; font-size: 14px; color: var(--text-mid); }
#signup-app .pr.tt { border-top: 1px solid var(--border); margin-top: 6px; padding-top: 10px; font-weight: 700; font-size: 16px; color: var(--text); }

/* ═══ PAYMENT METHOD DISPLAY ═══ */
#signup-app .pm-card { display: flex; align-items: center; gap: 12px; padding: 14px 18px; background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; margin-bottom: 16px; }
#signup-app .pm-icon { width: 38px; height: 38px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
#signup-app .pm-label { font-size: 14px; font-weight: 600; color: var(--text); }
#signup-app .pm-sub { font-size: 12px; color: var(--text-dim); margin-top: 1px; }

/* ═══ SUCCESS ═══ */
#signup-app .sucw { max-width: 460px; margin: 0 auto; padding: 36px 20px; text-align: center; }
#signup-app .si { width: 68px; height: 68px; border-radius: 50%; background: rgba(57,255,127,0.08); border: 2px solid var(--green); display: flex; align-items: center; justify-content: center; font-size: 30px; margin: 0 auto 22px; box-shadow: 0 0 28px rgba(57,255,127,0.2); }
#signup-app .sucw h2 { font-family: var(--font-head); font-size: 22px; color: var(--green); margin-bottom: 6px; }
#signup-app .sucw > p { color: var(--text-mid); font-size: 14px; margin-bottom: 22px; }
#signup-app .sd { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; padding: 18px; text-align: left; margin-bottom: 22px; }
#signup-app .sr { display: flex; justify-content: space-between; padding: 7px 0; font-size: 14px; border-bottom: 1px solid var(--border); }
#signup-app .sr:last-child { border-bottom: none; }
#signup-app .sr .lb { color: var(--text-dim); }
#signup-app .sr .vl { color: var(--text); font-weight: 600; }
#signup-app .su-launch { display: inline-flex; align-items: center; gap: 8px; padding: 13px 28px; border: none; border-radius: 8px; background: var(--primary); color: var(--bg); font-family: var(--font-head); font-size: 14px; cursor: pointer; box-shadow: 0 0 22px color-mix(in srgb, var(--primary) 25%, transparent); transition: all 0.2s; }
#signup-app .su-launch:hover { transform: translateY(-2px); filter: brightness(1.1); }
#signup-app .su-footer { text-align: center; padding: 44px 20px 24px; font-size: 14px; color: var(--text-dim); }

/* ═══ RESPONSIVE ═══ */
@media (max-width: 640px) {
  #signup-app .plans { flex-direction: column; align-items: center; }
  #signup-app .plan { max-width: 360px; width: 100%; }
  #signup-app .stepper { flex-wrap: wrap; gap: 8px; }
  #signup-app .stp::after { display: none; }
  #signup-app .fr2 { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  #signup-app .pn-nm { font-size: 22px; }
  #signup-app .pn-pr { font-size: 36px; }
  #signup-app .fi { font-size: 18px; padding: 14px 16px; }
  #signup-app .bp { font-size: 16px; padding: 16px; }
}

/* ═══ GAMOID-MODE SIGNUP ═══ */
#signup-app .gs-wrap { max-width: 1100px; margin: 0 auto; padding: 32px 20px 60px; }
#signup-app .gs-hero { text-align: center; margin-bottom: 28px; }
#signup-app .gs-hero h1 { font-family: var(--font-head); font-size: 26px; line-height: 1.35; color: var(--text); }
#signup-app .gs-tiers { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; margin-bottom: 24px; }
#signup-app .gs-tier { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 22px 18px; cursor: pointer; transition: all .15s; display: flex; flex-direction: column; }
#signup-app .gs-tier:hover { border-color: var(--primary); transform: translateY(-3px); box-shadow: 0 6px 20px rgba(0,0,0,.3); }
#signup-app .gs-tn { font-family: var(--font-head); font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
#signup-app .gs-tp { font-size: 28px; font-weight: 700; color: var(--primary); margin-bottom: 4px; }
#signup-app .gs-tp .gs-pm { font-size: 13px; color: var(--text-dim); font-weight: 400; }
#signup-app .gs-tt { font-size: 13px; color: var(--text-mid); margin-bottom: 14px; }
#signup-app .gs-tf { list-style: none; padding: 0; margin: 0 0 18px; flex: 1; }
#signup-app .gs-tf li { font-size: 13px; color: var(--text-mid); padding: 4px 0; padding-left: 18px; position: relative; }
#signup-app .gs-tf li::before { content: '✦'; position: absolute; left: 0; color: var(--primary); }
#signup-app .gs-tb { width: 100%; padding: 11px; border: none; border-radius: 8px; background: var(--primary); color: var(--bg); font-family: var(--font-head); font-size: 13px; cursor: pointer; }
#signup-app .gs-blurb { max-width: 720px; margin: 16px auto 0; text-align: center; color: var(--text-mid); font-size: 13px; line-height: 1.55; }
#signup-app .gs-login { text-align: center; margin-top: 24px; font-size: 13px; color: var(--text-dim); }
#signup-app .gs-login a { color: var(--primary); text-decoration: none; }

#signup-app .gs-back-btn { background: transparent; border: 1px solid var(--border); color: var(--text-dim); padding: 8px 14px; border-radius: 8px; cursor: pointer; font-size: 13px; margin-bottom: 18px; }
#signup-app .gs-back-btn:hover { color: var(--text); border-color: var(--primary); }
#signup-app .gs-form-h { font-family: var(--font-head); font-size: 22px; margin-bottom: 18px; display: flex; align-items: center; gap: 10px; }
#signup-app .gs-tag { display: inline-block; padding: 3px 10px; border-radius: 6px; font-size: 11px; color: #0b0b14; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
#signup-app .gs-form { max-width: 540px; margin: 0 auto; }
#signup-app .gs-fg { margin-bottom: 16px; }
#signup-app .gs-fg label { display: block; font-size: 11px; font-weight: 600; color: var(--text-dim); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 5px; }
#signup-app .gs-i { width: 100%; padding: 11px 13px; background: var(--bg2); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 14px; outline: none; }
#signup-app .gs-i:focus { border-color: var(--primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent); }
#signup-app .gs-frow { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
#signup-app .gs-hint { font-size: 12px; color: var(--text-dim); margin-top: 5px; }
#signup-app .gs-hint.gs-hint-warn { color: var(--red, #ff3997); font-weight: 600; }
#signup-app .gs-check { min-height: 16px; font-size: 12px; margin-top: 5px; }
#signup-app .gs-check.available { color: var(--green); }
#signup-app .gs-check.taken { color: var(--red); }
#signup-app .gs-check.checking { color: var(--text-dim); }
#signup-app .gs-chips { display: flex; flex-wrap: wrap; gap: 6px; }
#signup-app .gs-chip { background: var(--bg2); border: 1px solid var(--border); color: var(--text-mid); padding: 6px 12px; border-radius: 14px; cursor: pointer; font-size: 12px; transition: all .12s; }
#signup-app .gs-chip:hover { color: var(--text); border-color: var(--primary); }
#signup-app .gs-chip.on { background: var(--primary); color: var(--bg); border-color: var(--primary); }

#signup-app .gs-av-wrap { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 14px; background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; }
#signup-app .gs-av-themes { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; }
#signup-app .gs-th-btn { padding: 6px 10px; background: var(--bg); border: 1px solid var(--border); color: var(--text-dim); font-family: var(--font-head); font-size: 11px; border-radius: 6px; cursor: pointer; text-transform: uppercase; letter-spacing: .04em; }
#signup-app .gs-th-btn:hover { color: var(--text); border-color: var(--primary); }
#signup-app .gs-th-btn.on { color: var(--primary); border-color: var(--primary); background: color-mix(in srgb, var(--primary) 8%, var(--bg2)); }
#signup-app .gs-av-preview { width: 140px; height: 140px; border-radius: 50%; border: 2px solid var(--border); background: var(--bg); display: flex; align-items: center; justify-content: center; overflow: hidden; position: relative; }
#signup-app .gs-av-btnrow { display: flex; gap: 8px; }
#signup-app .gs-av-btn { padding: 8px 18px; background: var(--bg); border: 1px solid var(--border); color: var(--text); border-radius: 6px; cursor: pointer; font-size: 13px; }
#signup-app .gs-av-btn:hover:not(:disabled) { border-color: var(--primary); color: var(--primary); }
#signup-app .gs-av-btn:disabled { opacity: .35; cursor: default; }
#signup-app .gs-av-colors { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; }
#signup-app .gs-sw { width: 24px; height: 24px; border-radius: 50%; border: 2px solid transparent; cursor: pointer; transition: transform .12s; }
#signup-app .gs-sw:hover { transform: scale(1.15); }
#signup-app .gs-sw.on { border-color: #fff; box-shadow: 0 0 8px rgba(255,255,255,.4); }

#signup-app .gs-err { color: var(--red); font-size: 13px; min-height: 18px; margin: 8px 0; text-align: center; }
#signup-app .gs-submit { display: block; width: 100%; max-width: 540px; margin: 24px auto 0; padding: 14px; background: var(--primary); color: var(--bg); border: none; border-radius: 10px; font-family: var(--font-head); font-size: 14px; cursor: pointer; }
#signup-app .gs-submit:disabled { opacity: .5; cursor: default; }
#signup-app .gs-dz-host { width: 100%; min-height: 110px; }

#signup-app .gs-success { text-align: center; max-width: 520px; }
#signup-app .gs-success-icon { width: 64px; height: 64px; margin: 0 auto 14px; border-radius: 50%; background: color-mix(in srgb, var(--green) 18%, transparent); color: var(--green); font-size: 36px; line-height: 64px; }
#signup-app .gs-success h2 { font-family: var(--font-head); font-size: 22px; color: var(--text); margin-bottom: 10px; }
#signup-app .gs-success p { color: var(--text-mid); font-size: 14px; margin-bottom: 16px; line-height: 1.5; }
#signup-app .gs-recovery { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 14px 22px; margin: 14px auto; display: inline-block; font-family: var(--font-mono); font-size: 16px; letter-spacing: 0.16em; color: var(--text); user-select: all; }
#signup-app .gs-copy { padding: 8px 18px; background: transparent; border: 1px solid var(--border); border-radius: 8px; color: var(--text); cursor: pointer; font-size: 13px; }
#signup-app .gs-copy:hover { border-color: var(--primary); color: var(--primary); }
#signup-app .gs-warn { color: var(--red); font-size: 12px; margin-top: 14px; }
#signup-app .gs-launch { display: block; margin: 22px auto 0; padding: 14px 32px; background: var(--primary); color: var(--bg); border: none; border-radius: 10px; font-family: var(--font-head); font-size: 14px; cursor: pointer; }

/* ── Top-right Sign-in / Sign-up CTA (gamoid mode) ── */
#signup-app .gs-topnav { position: absolute; top: 18px; right: 22px; font-size: 13px; }
#signup-app .gs-topnav a { color: var(--text-dim); text-decoration: none; transition: color .15s; }
#signup-app .gs-topnav a:hover { color: var(--text); }
#signup-app .gs-topnav a strong { color: var(--primary); font-weight: 700; margin-left: 4px; }
#signup-app .gs-wrap { position: relative; }

/* ── Login view ── */
#signup-app .gs-login-wrap { max-width: 480px; }
#signup-app .gs-login-h { font-family: var(--font-head); font-size: 22px; text-align: center; margin-bottom: 18px; }
#signup-app .gs-login-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 26px 24px; }
#signup-app .gs-login-sub { font-family: var(--font-head); font-size: 16px; color: var(--text); margin-bottom: 14px; }
#signup-app .gs-login-blurb { color: var(--text-mid); font-size: 13px; line-height: 1.5; margin-bottom: 14px; }
#signup-app .gs-login-toggle { display: flex; justify-content: space-between; margin-top: 14px; font-size: 13px; }
#signup-app .gs-login-toggle a { color: var(--primary); text-decoration: none; cursor: pointer; }
#signup-app .gs-login-toggle a:hover { text-decoration: underline; }
#signup-app .gs-i-mono { font-family: var(--font-mono); letter-spacing: 0.08em; }

/* Private-beta gate ─────────────────────────────────────────────── */
#signup-app.su-blurred {
  filter: blur(8px);
  pointer-events: none;
  user-select: none;
}
#su-beta-gate {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  background: rgba(7, 11, 20, 0.55);
  backdrop-filter: blur(6px);
}
/* The HTML `hidden` attribute is otherwise overridden by the display:flex
   above, which made the private-beta gate show on EVERY instance (e.g.
   appoid.io) regardless of config.signup.private_beta. Respect `hidden` —
   the attribute selector outranks the base #id rule, so no !important.
   The reveal JS (wirePrivateBetaGate, only run when private_beta) clears
   the attribute, so gamoid's intentional beta gate still shows. */
#su-beta-gate[hidden] { display: none; }
#su-beta-gate .bg-modal {
  width: min(90%, 440px);
  padding: 32px;
  background: #12121f;
  border: 1px solid #353555;
  border-radius: 14px;
  color: #e4e4f0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  box-shadow: 0 24px 64px rgba(0,0,0,.55);
}
#su-beta-gate h2 {
  margin: 0 0 10px;
  font-size: 22px;
  color: #00e6d2;
  letter-spacing: .02em;
}
#su-beta-gate .bg-modal > p {
  margin: 0;
  color: #c4c4d4;
  font-size: 14px;
  line-height: 1.5;
}
#su-beta-gate .bg-tabs {
  display: flex;
  gap: 8px;
  margin: 18px 0 12px;
}
#su-beta-gate .bg-tab {
  flex: 1;
  padding: 9px;
  background: #1a1a2e;
  border: 1px solid #353555;
  color: #c4c4d4;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
#su-beta-gate .bg-tab.on {
  background: #00e6d2;
  color: #0b0b14;
  border-color: #00e6d2;
}
#su-beta-gate .bg-form { display: none; flex-direction: column; gap: 10px; margin-top: 4px; }
#su-beta-gate .bg-form.on { display: flex; }
#su-beta-gate .bg-form input {
  background: #1a1a2e;
  border: 1px solid #353555;
  color: #e4e4f0;
  padding: 11px 14px;
  border-radius: 6px;
  font-size: 14px;
}
#su-beta-gate .bg-form input:focus { outline: 0; border-color: #00e6d2; }
#su-beta-gate .bg-form button {
  padding: 12px;
  background: #00e6d2;
  color: #0b0b14;
  border: 0;
  border-radius: 6px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  margin-top: 4px;
}
#su-beta-gate .bg-form button:hover { background: #2cf4dc; }
#su-beta-gate .bg-form button:disabled { opacity: .6; cursor: wait; }
#su-beta-gate .bg-err, #su-beta-gate .bg-msg {
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 13px;
  margin-top: 6px;
}
#su-beta-gate .bg-err {
  background: rgba(255,70,70,.15);
  border: 1px solid rgba(255,70,70,.35);
  color: #ff8e8e;
}
#su-beta-gate .bg-msg {
  background: rgba(0,230,210,.12);
  border: 1px solid rgba(0,230,210,.35);
  color: #00e6d2;
}
