/* HubOP — tokens base */
:root {
  /* Inspirado en dark theme de HubOP.app */
  --bg-0: #0b0f1a;
  --bg-1: #111827;
  --bg-2: #1f2937;
  --bg-card: #151b27;
  --border: #1f2937;
  --border-hi: #334155;

  --fg-0: #f8fafc;
  --fg-1: #e2e8f0;
  --fg-2: #94a3b8;
  --fg-3: #64748b;

  --accent: #ff6b35;        /* Morph orange */
  --accent-hi: #ff854d;
  --accent-dim: rgba(255, 107, 53, 0.12);

  --blue: #3b82f6;
  --blue-dim: rgba(59, 130, 246, 0.12);

  --success: #22c55e;
  --warning: #eab308;
  --danger: #ef4444;

  --radius: 10px;
  --radius-sm: 6px;
  --radius-lg: 16px;

  --shadow-1: 0 1px 2px rgba(0,0,0,.3), 0 4px 12px rgba(0,0,0,.15);
  --shadow-2: 0 4px 16px rgba(0,0,0,.35);

  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
}

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

html, body {
  background: var(--bg-0);
  color: var(--fg-1);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hi); }

button { cursor: pointer; font-family: inherit; }

h1, h2, h3, h4 { color: var(--fg-0); font-weight: 600; letter-spacing: -0.01em; }
h1 { font-size: 2.25rem; line-height: 1.15; letter-spacing: -0.02em; }
h2 { font-size: 1.5rem; line-height: 1.25; }
h3 { font-size: 1.125rem; }

.btn-primary {
  background: var(--accent);
  color: #fff;
  border: 0;
  padding: 12px 20px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 0.95rem;
  transition: background 120ms ease;
  width: 100%;
}
.btn-primary:hover { background: var(--accent-hi); }
.btn-primary:disabled { background: var(--bg-2); color: var(--fg-3); cursor: not-allowed; }

.btn-ghost {
  background: transparent;
  color: var(--fg-1);
  border: 1px solid var(--border-hi);
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  font-weight: 500;
}
.btn-ghost:hover { background: var(--bg-2); }

input[type="text"],
input[type="email"],
input[type="password"] {
  width: 100%;
  padding: 11px 14px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--fg-0);
  font-size: 0.95rem;
  font-family: inherit;
  transition: border-color 120ms ease;
}
input:focus {
  outline: none;
  border-color: var(--accent);
}

label {
  display: block;
  font-size: 0.825rem;
  color: var(--fg-2);
  margin-bottom: 6px;
  margin-top: 14px;
  font-weight: 500;
}
label:first-child { margin-top: 0; }
