/* ============================================================================
   Wellpaged — Generated bio page + theme library
   The link-in-bio unit (DESIGN.md §6.4) + 5 themes from the theme library (§7),
   grounded in real Wellpaged pages. The link block is the constant; the theme
   owns the feeling. Scoped via [data-theme] on .bio.
   ============================================================================ */

/* ---- base bio page (theme-agnostic structure) ---- */
.bio { --b-radius: 16px; font-family: var(--b-body); background: var(--b-bg); color: var(--b-text);
  min-height: 100%; padding: 40px 22px 28px; display: flex; flex-direction: column; align-items: center;
  position: relative; overflow: hidden; }
.bio * { box-sizing: border-box; }
.bio-inner { width: 100%; max-width: 360px; display: flex; flex-direction: column; align-items: center; position: relative; z-index: 2; }
.bio-avatar { width: 96px; height: 96px; border-radius: 50%; border: var(--b-avatar-border);
  background: var(--b-avatar-bg); display: flex; align-items: center; justify-content: center;
  font-family: var(--b-display); font-size: 40px; color: var(--b-avatar-fg); overflow: hidden; }
.bio-name { font-family: var(--b-display); font-size: 30px; line-height: 1.05; margin: 16px 0 0;
  text-align: center; letter-spacing: -.02em; font-weight: var(--b-name-weight, 500); font-style: var(--b-name-style, normal); }
.bio-handle { font-family: var(--b-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--b-dim); margin-top: 8px; }
.bio-cat { font-family: var(--b-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--b-text); border: 1px solid currentColor; border-radius: 999px; padding: 4px 11px; margin-top: 4px; opacity: .9; }
.bio-about { font-family: var(--b-body); font-size: 13px; line-height: 1.6; color: var(--b-muted);
  text-align: center; margin: 12px 0 0; max-width: 32ch; }
.bio-tag { font-family: var(--b-tagfont, var(--b-body)); font-style: var(--b-tag-style, normal);
  font-size: 14px; line-height: 1.5; color: var(--b-muted); text-align: center; margin: 14px 0 0; max-width: 30ch; }
.bio-links { width: 100%; display: flex; flex-direction: column; gap: 12px; margin-top: 28px; }
.bio-link { display: flex; align-items: center; gap: 12px; min-height: 56px; padding: 0 18px;
  border-radius: var(--b-link-radius); background: var(--b-link-bg); color: var(--b-link-fg);
  border: var(--b-link-border); box-shadow: var(--b-link-shadow); font-weight: 500; font-size: 15px;
  transition: transform 200ms var(--ease-out), box-shadow 200ms; cursor: pointer; }
.bio-link .ic { width: 22px; height: 22px; fill: currentColor; flex-shrink: 0; }
.bio-link .lbl { flex: 1; font-weight: 700; }
.bio-link .arr { opacity: .6; }
.bio-link:hover { transform: translateY(-2px); box-shadow: var(--b-link-shadow-hover, var(--b-link-shadow)); }
.bio-link.feat { background: var(--b-feat-bg); color: var(--b-feat-fg); border: var(--b-feat-border, var(--b-link-border)); }
.bio-socials { display: flex; gap: 20px; margin-top: 26px; }
.bio-socials a { color: var(--b-text); opacity: .85; transition: opacity 160ms, transform 160ms; }
.bio-socials a:hover { opacity: 1; transform: translateY(-2px); }
.bio-socials svg { width: 22px; height: 22px; fill: currentColor; }
.bio-foot { margin-top: 34px; font-family: var(--b-mono); font-size: 9.5px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--b-dim); }

/* ===================== THEME: Soft Asymmetry (house) ===================== */
.bio[data-theme="soft"] {
  --b-bg: #FAF7F2; --b-text: #0B0B12; --b-muted: #3A3A45; --b-dim: #5C5852;
  --b-display: 'Fraunces', serif; --b-body: 'Switzer', sans-serif; --b-mono: 'JetBrains Mono', monospace;
  --b-avatar-bg: #9748D6; --b-avatar-fg: #FAF7F2; --b-avatar-border: 2px solid #0B0B12;
  --b-link-bg: #FAF7F2; --b-link-fg: #0B0B12; --b-link-border: 1.5px solid #0B0B12; --b-link-radius: 9999px;
  --b-link-shadow: 4px 5px 0 #0B0B12; --b-link-shadow-hover: 6px 8px 0 #0B0B12;
  --b-feat-bg: #FF5E3A; --b-feat-fg: #0B0B12;
}
.bio[data-theme="soft"] .bio-num { position: absolute; top: 10px; left: -10px; font-family: var(--font-cond);
  font-size: 200px; color: #9748D6; opacity: .1; line-height: .8; }

/* ===================== THEME: Pastel Dream (rissa-asmr) ===================== */
.bio[data-theme="pastel"] {
  --b-bg: #fdf5f3; --b-text: #2d2a44; --b-muted: #5f5b7c; --b-dim: #8b869f;
  --b-display: 'Fraunces', serif; --b-body: 'Instrument Sans', sans-serif; --b-mono: 'JetBrains Mono', monospace;
  --b-name-style: italic; --b-name-weight: 600; --b-tag-style: italic; --b-tagfont: 'Fraunces', serif;
  --b-avatar-bg: #f5e1e8; --b-avatar-fg: #d27aa0; --b-avatar-border: 2px solid #ead8dd;
  --b-link-bg: #fdf5f3; --b-link-fg: #2d2a44; --b-link-border: 1px solid #ead8dd; --b-link-radius: 24px;
  --b-link-shadow: 0 14px 28px -18px rgba(45,42,68,.3); --b-link-shadow-hover: 0 22px 36px -20px rgba(45,42,68,.35);
  --b-feat-bg: #e89ab5; --b-feat-fg: #fff;
}
.bio[data-theme="pastel"] .blob { position: absolute; border-radius: 50%; filter: blur(70px); z-index: 0; }
.bio[data-theme="pastel"] .blob.p { width: 280px; height: 280px; top: -60px; right: -80px; background: #f5bccd; opacity: .7; }
.bio[data-theme="pastel"] .blob.b { width: 300px; height: 300px; bottom: -90px; left: -90px; background: #b3ccea; opacity: .65; }

/* ===================== THEME: Velvet Dark (medusa-whispers) ===================== */
.bio[data-theme="velvet"] {
  --b-bg: #0a0712; --b-text: #f2e9db; --b-muted: #cdbfae; --b-dim: #8b7f93;
  --b-display: 'Cormorant Garamond', serif; --b-body: 'Manrope', sans-serif; --b-mono: 'Manrope', sans-serif;
  --b-name-style: italic; --b-name-weight: 500; --b-tag-style: italic; --b-tagfont: 'Cormorant Garamond', serif;
  --b-avatar-bg: linear-gradient(160deg,#1a1125,#0a0712); --b-avatar-fg: #d4b77a; --b-avatar-border: 1px solid #d4b77a;
  --b-link-bg: linear-gradient(160deg,#1a1125,#120c1c); --b-link-fg: #f2e9db;
  --b-link-border: 1px solid rgba(212,183,122,.4); --b-link-radius: 6px;
  --b-link-shadow: none; --b-link-shadow-hover: 0 0 24px -4px rgba(236,182,189,.4);
  --b-feat-bg: linear-gradient(160deg,#2a1c33,#1a1125); --b-feat-fg: #d4b77a; --b-feat-border: 1px solid #d4b77a;
}
.bio[data-theme="velvet"] .orb { position: absolute; border-radius: 50%; filter: blur(60px); z-index: 0; }
.bio[data-theme="velvet"] .orb.r { width: 240px; height: 240px; top: -40px; right: -70px; background: rgba(236,182,189,.3); }
.bio[data-theme="velvet"] .orb.g { width: 220px; height: 220px; bottom: -60px; left: -70px; background: rgba(212,183,122,.22); }
.bio[data-theme="velvet"] .bio-tag { font-size: 17px; }

/* ===================== THEME: Neon Night (club flyer) ===================== */
.bio[data-theme="neon"] {
  --b-bg: #0a0a0f; --b-text: #f5f5f7; --b-muted: #b8b8c2; --b-dim: #6e6e7a;
  --b-display: 'Anton', sans-serif; --b-body: 'JetBrains Mono', monospace; --b-mono: 'JetBrains Mono', monospace;
  --b-avatar-bg: #15151c; --b-avatar-fg: #C6FF3D; --b-avatar-border: 2px solid #C6FF3D;
  --b-link-bg: #101016; --b-link-fg: #f5f5f7; --b-link-border: 1.5px solid #C6FF3D; --b-link-radius: 12px;
  --b-link-shadow: none; --b-link-shadow-hover: 0 0 18px -2px rgba(198,255,61,.6);
  --b-feat-bg: #C6FF3D; --b-feat-fg: #0a0a0f;
}
.bio[data-theme="neon"] .bio-name { text-transform: uppercase; letter-spacing: 0; font-size: 40px; }
.bio[data-theme="neon"] .bio-link { text-transform: uppercase; letter-spacing: .04em; font-size: 13px; }

/* ===================== THEME: Press (editorial broadsheet) ===================== */
.bio[data-theme="press"] {
  --b-bg: #f6f4ef; --b-text: #15110d; --b-muted: #46403a; --b-dim: #6b6359;
  --b-display: 'Anton', sans-serif; --b-body: 'Cormorant Garamond', serif; --b-mono: 'JetBrains Mono', monospace;
  --b-avatar-bg: #15110d; --b-avatar-fg: #f6f4ef; --b-avatar-border: 2px solid #15110d;
  --b-link-bg: #f6f4ef; --b-link-fg: #15110d; --b-link-border: 1.5px solid #15110d; --b-link-radius: 2px;
  --b-link-shadow: none;
  --b-feat-bg: #d32f2f; --b-feat-fg: #fff;
}
.bio[data-theme="press"] .bio-name { text-transform: uppercase; font-size: 38px; letter-spacing: .01em; }
.bio[data-theme="press"] .bio-tag { font-size: 17px; font-style: italic; }
.bio[data-theme="press"] .bio-link { border-left: 0; border-right: 0; border-radius: 0;
  border-top: 1.5px solid #15110d; border-bottom: 1.5px solid #15110d; }
.bio[data-theme="press"] .bio-link:hover { color: #d32f2f; }
