/* ==========================================================================
   PULSE V2.2 — account.css · "ION ATMOSPHERE"
   account.html — rich functional page (profile / subscription / devices /
   sign-in methods / danger zone). The DOM contract of the VERBATIM v1
   account-page.js + nav-auth.js + avatar-helper.js is preserved in the
   markup; this file reskins around it. Requires tokens.css + base.css.

   The verbatim JS renders fragments via innerHTML that reference v1 token
   names with fallbacks — var(--bg-elev,#1a1a20), var(--border,#2a2a30),
   var(--text-secondary,#aaa), var(--red,#ef4444). The aliases below map
   them onto V2 tokens so JS-rendered UI follows BOTH themes instead of
   falling back to v1's hex constants.
   ========================================================================== */

/* account.css loads ONLY on account.html, so the aliases bind page-wide. */
:root {
  --bg-elev: var(--surface-2);
  --border: var(--line-2);
  --text-secondary: var(--text-3);
  --red: var(--danger);
  --fg: var(--text-1);
}

/* --------------------------------------------------------------------------
   Page frame — quiet aurora, narrow column of instrument cards
   -------------------------------------------------------------------------- */
.acct-main {
  position: relative;
  min-height: 60vh;
}

.acct-hero {
  padding-block: var(--sp-8) var(--sp-5);
}
.acct-hero h1 {
  margin-top: var(--sp-3);
  font-size: var(--fs-h1);
}

.page {
  width: min(46rem, 100% - 2 * var(--gutter));
  margin-inline: auto;
  display: grid;
  gap: var(--sp-5);
  padding-bottom: var(--sp-9);
}

.page .card { box-shadow: var(--shadow-1); }

/* --------------------------------------------------------------------------
   Loading state (visible until the verbatim JS hides it)
   -------------------------------------------------------------------------- */
.loading {
  display: grid;
  justify-items: center;
  gap: var(--sp-4);
  padding: var(--sp-10) var(--sp-4);
}
.spinner {
  width: 28px;
  height: 28px;
  border: 2px solid var(--viz-track);
  border-top-color: var(--accent);
  border-radius: 50%;
}
html.anim .spinner { animation: acct-spin 0.9s linear infinite; }
@keyframes acct-spin { to { transform: rotate(360deg); } }
.loading-text {
  font: 700 var(--fs-micro) / 1 var(--font-mono);
  letter-spacing: var(--track-micro);
  text-transform: uppercase;
  color: var(--text-3);
}

/* Page-level error region (JS flips style.display) */
.error-msg {
  display: none;
  padding: var(--sp-3) var(--sp-4);
  background: var(--danger-tint);
  border: 1px solid var(--danger);
  border-radius: var(--radius-md);
  color: var(--text-1);
  font-size: var(--fs-body-sm);
}

/* --------------------------------------------------------------------------
   Profile card
   -------------------------------------------------------------------------- */
.avatar-row {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-2);
  border-bottom: 1px solid var(--line-1);
}
.profile-avatar {
  width: 64px;
  height: 64px;
  flex: none;
  border-radius: 50%;
  border: 1px solid var(--line-2);
  background: var(--surface-2);
  object-fit: cover;
}
.avatar-row-actions { display: grid; gap: var(--sp-2); justify-items: start; }
.avatar-status { font-size: var(--fs-micro); color: var(--text-3); }
.avatar-status.hint-err { color: var(--danger); }
.avatar-row-actions:has(#profile-avatar-input:focus-visible) .btn {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.profile-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--line-0);
}
.profile-row:last-child { border-bottom: 0; padding-bottom: 0; }

.profile-label {
  font: 700 var(--fs-micro) / 1 var(--font-mono);
  letter-spacing: var(--track-micro);
  text-transform: uppercase;
  color: var(--text-3);
}
.profile-value { color: var(--text-1); font-size: var(--fs-body-sm); overflow-wrap: anywhere; }
.profile-value-group { display: inline-flex; align-items: center; gap: var(--sp-3); }

/* --------------------------------------------------------------------------
   Buttons the verbatim JS injects / the markup uses. base.css owns .btn +
   .btn-primary; these add the v1 variants on V2 tokens.
   -------------------------------------------------------------------------- */
.btn-secondary {
  background: var(--surface-2);
  border-color: var(--line-2);
  color: var(--text-2);
}
.btn-secondary:hover { background: var(--surface-3); border-color: var(--line-3); color: var(--text-1); }

.btn-outline {
  background: transparent;
  border-color: var(--line-2);
  color: var(--text-2);
}
.btn-outline:hover { border-color: var(--line-3); color: var(--text-1); background: var(--wash-1); }

.btn-accent {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}
.btn-accent:hover { filter: brightness(1.07); }

.btn-danger {
  background: transparent;
  border-color: var(--danger);
  color: var(--danger);
}
.btn-danger:hover { background: var(--danger-tint); }

.btn:disabled { opacity: 0.6; cursor: wait; }
.btn-sm-acct { padding: 6px 16px; font-size: 12px; }

/* --------------------------------------------------------------------------
   Subscription card
   -------------------------------------------------------------------------- */
.sub-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-3);
}
.sub-header h3 { font-size: var(--fs-body); color: var(--text-2); }

.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.8rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--line-2);
  font: 700 var(--fs-micro) / 1 var(--font-mono);
  letter-spacing: 0.04em;
  color: var(--text-2);
  background: var(--wash-1);
}
.badge-free { /* token base look */ }
.badge-pro,
.badge-active {
  background: var(--accent-tint-2);
  border-color: var(--accent-line);
  color: var(--accent-bright);
}
.badge-lifetime {
  background: var(--accent-tint-1);
  border-color: var(--accent-line);
  color: var(--accent-bright);
}
.badge-canceled,
.badge-past-due {
  background: var(--danger-tint);
  border-color: var(--danger);
  color: var(--danger);
}

.sub-detail {
  padding: var(--sp-2) 0;
  color: var(--text-3);
  font-size: var(--fs-body-sm);
}
.sub-detail span { color: var(--text-1); }

#sub-actions { margin-top: var(--sp-3); }
#sub-actions:empty { margin-top: 0; }

/* --------------------------------------------------------------------------
   Devices card
   -------------------------------------------------------------------------- */
.devices-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-3);
}
.devices-count {
  font: 700 var(--fs-micro) / 1.6 var(--font-mono);
  letter-spacing: 0.03em;
  color: var(--text-3);
}

.seat-btn {
  display: inline-grid;
  place-items: center;
  width: 1.5rem;
  height: 1.5rem;
  margin-left: 0.2rem;
  padding: 0;
  background: var(--surface-2);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-sm);
  color: var(--text-2);
  font: 700 0.85rem / 1 var(--font-mono);
  cursor: pointer;
  transition: border-color var(--dur-1) ease, color var(--dur-1) ease;
}
.seat-btn:hover { border-color: var(--accent-line); color: var(--accent-bright); }
.seat-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.seat-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.device {
  padding: var(--sp-3);
  border: 1px solid var(--line-1);
  border-radius: var(--radius-md);
  background: var(--panel-tint-1);
}
.device + .device { margin-top: var(--sp-3); }
.device-row { display: flex; align-items: center; gap: var(--sp-3); }
.device-icon {
  display: grid;
  place-items: center;
  width: 2.2rem;
  height: 2.2rem;
  flex: none;
  border-radius: var(--radius-sm);
  background: var(--accent-tint-2);
  border: 1px solid var(--line-1);
  color: var(--accent-bright);
}
.device-name { color: var(--text-1); font-size: var(--fs-body-sm); font-weight: 600; }
.device-meta { color: var(--text-3); font-size: var(--fs-micro); margin-top: 2px; }

.no-devices {
  padding: var(--sp-4) 0;
  color: var(--text-3);
  font-size: var(--fs-body-sm);
}

.devices-title { margin-bottom: 0; }
.danger-actions { display: grid; gap: var(--sp-4); }

/* Sign-in methods rows are fully JS-rendered (inline-styled by the verbatim
   suite); the alias tokens at the top keep them on-theme. */
.linked-accounts-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}
.linked-accounts-status {
  font-size: 12px;
  color: var(--text-3);
  margin-top: 10px;
}

/* --------------------------------------------------------------------------
   Danger zone
   -------------------------------------------------------------------------- */
.danger-card { border-color: var(--danger); }
.danger-card .card-title { color: var(--danger); }
.danger-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.danger-row-title { font-size: 14px; font-weight: 600; margin-bottom: 4px; color: var(--text-1); }
.danger-text { color: var(--text-3); font-size: var(--fs-micro); max-width: 46ch; }

/* --------------------------------------------------------------------------
   Modals (change-username + backfill). JS opens with style.display='flex'.
   -------------------------------------------------------------------------- */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-raised);
  display: none; /* JS contract: opened via el.style.display='flex' */
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  background: var(--veil-78);
}
.modal-card {
  width: min(26rem, 100%);
  padding: var(--sp-6);
  background:
    linear-gradient(var(--slab-grad-1), var(--slab-grad-2)),
    var(--slab-face);
  border: 1px solid var(--slab-edge);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-slab);
}
.modal-text {
  margin-bottom: var(--sp-4);
  color: var(--text-3);
  font-size: var(--fs-body-sm);
  line-height: var(--lh-body);
}
.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
}

/* Modal fields reuse auth.css .field recipe — duplicated here so account.html
   doesn't need auth.css. */
.field { margin-bottom: var(--sp-4); }
.field > label {
  display: block;
  margin-bottom: var(--sp-2);
  font: 700 var(--fs-micro) / 1 var(--font-mono);
  letter-spacing: var(--track-micro);
  text-transform: uppercase;
  color: var(--text-3);
}
.field input[type="text"] {
  width: 100%;
  padding: 0.7rem 0.85rem;
  background: var(--surface-2);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-md);
  color: var(--text-1);
  font: 400 var(--fs-body) / 1.4 var(--font-sans);
  transition: border-color var(--dur-1) ease, box-shadow var(--dur-1) ease;
}
.field input:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-tint-1);
}
.hint {
  margin-top: var(--sp-2);
  font-size: var(--fs-micro);
  line-height: 1.5;
  color: var(--text-3);
}
.hint-ok  { color: var(--accent-bright); }
.hint-err { color: var(--danger); }

/* Auth-aware nav cluster (.nav-auth-link / .nav-user-pill) + the
   centered-links overlap fallback now live in base.css (§8) — shared by
   every shell page and driven by motion.js's measurement guard. */
