/* ============================================================
   Rocketplan Design Tokens
   ============================================================
   Copied from infra/new-project/templates/design-tokens.css
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --color-bg:           #0f172a;
  --color-surface:      rgba(255, 255, 255, 0.04);
  --color-surface-hover: rgba(99, 102, 241, 0.10);
  --color-border:       rgba(255, 255, 255, 0.06);
  --color-border-hover: rgba(99, 102, 241, 0.25);
  --color-overlay:      #0f172a;

  --color-text:         #e2e8f0;
  --color-text-muted:   #64748b;
  --color-text-faint:   #334155;

  --color-accent:       #6366f1;
  --color-accent-hover: #4f46e5;
  --color-accent-light: #818cf8;

  --color-success:      #10b981;
  --color-warning:      #f59e0b;
  --color-error:        #ef4444;

  --color-icon-accent:  rgba(99, 102, 241, 0.20);
  --color-icon-success: rgba(16, 185, 129, 0.20);
  --color-icon-warning: rgba(245, 158, 11, 0.20);
  --color-icon-error:   rgba(239, 68, 68, 0.15);

  --font-family:        'Inter', ui-sans-serif, -apple-system, system-ui, sans-serif;
  --font-size-xs:       0.68rem;
  --font-size-sm:       0.72rem;
  --font-size-base:     0.82rem;
  --font-size-md:       0.88rem;
  --font-size-lg:       1.1rem;
  --font-size-xl:       1.4rem;

  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semi:   600;
  --font-weight-bold:   700;
  --font-weight-extra:  800;

  --letter-spacing-tight: -0.02em;
  --letter-spacing-normal: 0;

  --radius-sm:          8px;
  --radius-md:          10px;
  --radius-lg:          12px;

  --spacing-xs:         4px;
  --spacing-sm:         8px;
  --spacing-md:         14px;
  --spacing-lg:         20px;
  --spacing-xl:         24px;
  --spacing-2xl:        28px;
  --spacing-3xl:        32px;

  --icon-size-sm:       20px;
  --icon-size-md:       24px;
  --icon-block-sm:      40px;
  --icon-block-lg:      48px;

  --content-max-width:  420px;
  --content-padding:    24px;

  --transition-fast:    all 0.2s ease;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-family);
  background: var(--color-bg);
  color: var(--color-text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* --- Components from design system --- */
.rp-logo {
  width: var(--icon-block-lg);
  height: var(--icon-block-lg);
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--color-accent), var(--color-accent-light));
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--spacing-lg);
}
.rp-logo svg {
  color: #fff;
  width: var(--icon-size-md);
  height: var(--icon-size-md);
}

.rp-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-extra);
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--spacing-xs);
}

.rp-subtitle {
  color: var(--color-text-muted);
  font-size: var(--font-size-base);
  margin-bottom: var(--spacing-2xl);
}

.rp-card {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-md) 16px;
  margin-bottom: var(--spacing-sm);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: var(--color-text);
  transition: var(--transition-fast);
}
.rp-card:hover {
  background: var(--color-surface-hover);
  border-color: var(--color-border-hover);
  transform: translateY(-1px);
}

.rp-card-icon {
  width: var(--icon-block-sm);
  height: var(--icon-block-sm);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rp-card-icon svg {
  color: #fff;
  opacity: 0.9;
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
}
.rp-card-icon--accent  { background: var(--color-icon-accent); }
.rp-card-icon--success { background: var(--color-icon-success); }
.rp-card-icon--warning { background: var(--color-icon-warning); }
.rp-card-icon--error   { background: var(--color-icon-error); }

.rp-card-title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semi);
  letter-spacing: -0.01em;
}
.rp-card-desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-top: 1px;
}

.rp-overlay {
  position: fixed;
  inset: 0;
  background: var(--color-overlay);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rp-overlay-box {
  text-align: center;
  width: 300px;
}
.rp-overlay-box h2 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin-bottom: 16px;
  color: var(--color-text);
}

.rp-input {
  width: 100%;
  padding: 12px;
  font-size: 1rem;
  font-weight: var(--font-weight-bold);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  font-family: var(--font-family);
  transition: var(--transition-fast);
}
.rp-input:focus {
  border-color: var(--color-accent);
}
.rp-input::placeholder {
  color: var(--color-text-muted);
}

.rp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 32px;
  background: var(--color-accent);
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semi);
  font-family: var(--font-family);
  cursor: pointer;
  transition: var(--transition-fast);
  text-decoration: none;
}
.rp-btn:hover {
  background: var(--color-accent-hover);
}

.rp-error {
  color: var(--color-error);
  font-size: 0.78rem;
  margin-top: var(--spacing-sm);
  min-height: 20px;
}
