/* =========================================================================
   XRPL Snap — Design Tokens
   Sources: XRPL Visual Guidelines 2023 (Figma) + XRPL EVM brand cues.
   The Snap surface dynamically swaps between two brand modes:
     [data-brand="xrpl"]      — XRPL primary (green / blue-purple / white)
     [data-brand="xrpl-evm"]  — XRPL EVM (deeper purple + EVM accents)
   ========================================================================= */

/* -------- Fonts -------------------------------------------------------- */
/* Primary: Work Sans   |   Code/numerics: Space Mono
   (Both Google Fonts — 1:1 with the XRPL spec.)                          */
@import url("https://fonts.googleapis.com/css2?family=Work+Sans:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap");

:root {
  /* ---------- XRPL PRIMARY PALETTE (3.1) ------------------------------ */
  --xrpl-green:        #32E685; /* rgb(50,230,133)  */
  --xrpl-white:        #F5F5F7; /* rgb(245,245,247) */
  --xrpl-blue-purple:  #9A52FF; /* rgb(154,82,255)  */
  --xrpl-black:        #111112; /* rgb(17,17,18)    */

  /* ---------- XRPL SECONDARY PALETTE (3.2) ---------------------------- */
  --xrpl-magenta:      #FF198B; /* rgb(255,25,139)  */
  --xrpl-red-purple:   #D919FF; /* rgb(217,25,255)  */
  --xrpl-orange:       #FF6719; /* rgb(255,103,25)  */
  --xrpl-yellow:       #FAFF19; /* rgb(250,255,25)  */
  --xrpl-blue:         #19A3FF; /* rgb(25,163,255)  */

  /* ---------- TINTS / SHADES (3.3) — green ---------------------------- */
  --xrpl-green-20:  #C2F7D9;
  --xrpl-green-40:  #84EEB2;
  --xrpl-green-60:  #50DC8E;
  --xrpl-green-80:  #28B86A;
  --xrpl-green-100: #145C35;

  /* ---------- TINTS / SHADES — blue-purple ---------------------------- */
  --xrpl-bp-20:  #E0D1FF;
  --xrpl-bp-40:  #C2A6FF;
  --xrpl-bp-60:  #9A52FF;
  --xrpl-bp-80:  #6B1FE0;
  --xrpl-bp-100: #2E0966;

  /* ---------- NEUTRALS (extracted from spec backgrounds) -------------- */
  --neutral-0:   #FFFFFF;
  --neutral-50:  #F5F5F7;
  --neutral-100: #E0E0E1;
  --neutral-200: #D4D7DD;
  --neutral-300: #B8BBC2;
  --neutral-400: #838386;
  --neutral-500: #4A4A4D;
  --neutral-600: #343437;
  --neutral-700: #232325;
  --neutral-800: #18181A;
  --neutral-900: #111112;

  /* ---------- GRADIENTS (3.5) ----------------------------------------- */
  --grad-purple-green: linear-gradient(135deg, #B480FF 0%, #5F00E5 33%, #1AA4FF 61%, #19FF83 100%);
  --grad-yellow-purple: linear-gradient(135deg, #FAFF19 0%, #FF198B 50%, #9A52FF 100%);
  --grad-pink-yellow:   linear-gradient(135deg, #FF198B 0%, #FAFF19 100%);
  --grad-blue-green:    linear-gradient(135deg, #19A3FF 0%, #32E685 100%);
  --grad-magenta-blue:  linear-gradient(135deg, #FF198B 0%, #19A3FF 100%);
  --grad-yellow-blue-purple: linear-gradient(135deg, #FAFF19 0%, #19A3FF 50%, #9A52FF 100%);

  /* ---------- TYPE — RAW ---------------------------------------------- */
  --font-sans: "Work Sans", system-ui, -apple-system, sans-serif;
  --font-mono: "Space Mono", ui-monospace, monospace;

  --fw-regular: 400;
  --fw-medium:  500;
  --fw-semibold: 600;
  --fw-bold:    700;

  /* Type scale — derived from spec (67 hero, 38 section, 18/16/12) */
  --fs-hero:    67px;
  --fs-display: 48px;
  --fs-h1:      38px;
  --fs-h2:      28px;
  --fs-h3:      22px;
  --fs-h4:      18px;
  --fs-body:    16px;
  --fs-small:   14px;
  --fs-caption: 12px;
  --fs-micro:   9px;

  --lh-tight:   1.04;
  --lh-snug:    1.2;
  --lh-normal:  1.5;

  /* ---------- SPACING — 4pt base -------------------------------------- */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;

  /* ---------- RADII --------------------------------------------------- */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-pill: 999px;

  /* ---------- ELEVATION (from card shadows in 5.2) -------------------- */
  --elev-1: 0 1px 2px rgba(17,17,18,.06);
  --elev-2: 0 4px 12px rgba(17,17,18,.08);
  --elev-3: 0 8px 32px rgba(17,17,18,.18);
  --elev-card-dark: 0 4px 32px rgba(17,17,18,.85);

  /* ---------- MOTION -------------------------------------------------- */
  --ease-standard: cubic-bezier(.2,.8,.2,1);
  --ease-emphasized: cubic-bezier(.2,.0,0,1);
  --dur-fast: 120ms;
  --dur-base: 200ms;
  --dur-slow: 320ms;

  /* ---------- SEMANTIC TOKENS — DEFAULTS (XRPL brand) ----------------- */
  --bg-app:         var(--neutral-900);
  --bg-surface:     var(--neutral-800);
  --bg-surface-2:   var(--neutral-700);
  --bg-elevated:    var(--neutral-600);
  --fg-primary:     var(--neutral-50);
  --fg-secondary:   var(--neutral-200);
  --fg-muted:       var(--neutral-300);
  --fg-disabled:    var(--neutral-400);
  --fg-on-accent:   var(--xrpl-black);
  --border-subtle:  rgba(255,255,255,.08);
  --border-default: rgba(255,255,255,.14);
  --border-strong:  rgba(255,255,255,.24);

  --accent:         var(--xrpl-green);
  --accent-hover:   var(--xrpl-green-60);
  --accent-press:   var(--xrpl-green-80);
  --accent-soft:    rgba(50,230,133,.14);
  --accent-ring:    rgba(50,230,133,.36);

  --status-success: var(--xrpl-green);
  --status-warning: var(--xrpl-orange);
  --status-error:   var(--xrpl-magenta);
  --status-info:    var(--xrpl-blue);

  --brand-gradient: var(--grad-blue-green);
}

/* ---------- BRAND MODE: XRPL (default, redundant for explicit override) */
[data-brand="xrpl"] {
  --accent:        var(--xrpl-green);
  --accent-hover:  var(--xrpl-green-60);
  --accent-press:  var(--xrpl-green-80);
  --accent-soft:   rgba(50,230,133,.14);
  --accent-ring:   rgba(50,230,133,.36);
  --brand-gradient: var(--grad-blue-green);
  --brand-secondary: var(--xrpl-blue-purple);
}

/* ---------- BRAND MODE: XRPL EVM ------------------------------------- */
[data-brand="xrpl-evm"] {
  --accent:        var(--xrpl-blue-purple);
  --accent-hover:  var(--xrpl-bp-40);
  --accent-press:  var(--xrpl-bp-80);
  --accent-soft:   rgba(154,82,255,.16);
  --accent-ring:   rgba(154,82,255,.40);
  --fg-on-accent:  var(--xrpl-white);
  --brand-gradient: var(--grad-purple-green);
  --brand-secondary: var(--xrpl-blue);
}

/* ---------- LIGHT (alt) MODE ----------------------------------------- */
[data-theme="light"] {
  --bg-app:         var(--neutral-50);
  --bg-surface:     var(--neutral-0);
  --bg-surface-2:   var(--neutral-50);
  --bg-elevated:    var(--neutral-0);
  --fg-primary:     var(--neutral-900);
  --fg-secondary:   var(--neutral-600);
  --fg-muted:       var(--neutral-500);
  --fg-disabled:    var(--neutral-300);
  --border-subtle:  rgba(17,17,18,.06);
  --border-default: rgba(17,17,18,.10);
  --border-strong:  rgba(17,17,18,.18);
}

/* =========================================================================
   SEMANTIC TYPE
   ========================================================================= */
html { font-family: var(--font-sans); color: var(--fg-primary); background: var(--bg-app); }

h1, .h1 { font: var(--fw-bold) var(--fs-h1)/var(--lh-snug) var(--font-sans); letter-spacing: -.01em; }
h2, .h2 { font: var(--fw-bold) var(--fs-h2)/var(--lh-snug) var(--font-sans); letter-spacing: -.005em; }
h3, .h3 { font: var(--fw-semibold) var(--fs-h3)/var(--lh-snug) var(--font-sans); }
h4, .h4 { font: var(--fw-semibold) var(--fs-h4)/var(--lh-snug) var(--font-sans); }
.hero    { font: var(--fw-bold) var(--fs-hero)/var(--lh-tight) var(--font-sans); letter-spacing: -.02em; }
.display { font: var(--fw-bold) var(--fs-display)/var(--lh-tight) var(--font-sans); letter-spacing: -.015em; }

p, .body { font: var(--fw-regular) var(--fs-body)/var(--lh-normal) var(--font-sans); }
.small   { font: var(--fw-regular) var(--fs-small)/var(--lh-normal) var(--font-sans); }
.caption { font: var(--fw-medium) var(--fs-caption)/1.4 var(--font-sans); letter-spacing: .02em; }
.eyebrow { font: var(--fw-semibold) var(--fs-caption)/1 var(--font-sans); letter-spacing: .08em; text-transform: uppercase; }
.mono, code, pre { font-family: var(--font-mono); }
.address { font: var(--fw-regular) var(--fs-small)/1.4 var(--font-mono); letter-spacing: .01em; }
.numeric { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
