:root {
  --sage: #7a8d6f;
  --sage-dark: #5a6d52;
  --sage-light: #e8ede3;
  --terracotta: #c97b5a;
  --terracotta-dark: #b3503a;
  --cream: #faf6f0;
  --sand: #f0e9d9;
  --ink: #2c2a26;
  --ink-soft: #5a574f;
  --muted: #9a9388;
  --line: #d8d0bf;
  --line-soft: #ebe5d4;
  --white: #ffffff;
  --danger: #b3503a;
  --danger-bg: #f7e0d6;
  --success: #5a6d52;
  --success-bg: #e0e8d6;
  --warning: #c97b5a;
  --warning-bg: #fbf3ec;
  --radius: 6px;
  --radius-lg: 10px;
  --shadow-lg: 0 20px 50px rgba(44,42,38,0.12);
  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  font-family: var(--font-body);
  background: linear-gradient(180deg, var(--cream) 0%, #f6f0e3 100%);
  color: var(--ink);
  min-height: 100vh;
  font-size: 15px;
  line-height: 1.5;
}
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 500; color: var(--ink); }
a { color: var(--sage-dark); }
.hidden { display: none !important; }

/* Form */
.field { margin-bottom: 14px; }
label { display: block; font-size: 0.78rem; font-weight: 600; color: var(--ink-soft);
  letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 6px; }
input[type="text"], input[type="email"], input[type="password"], input[type="tel"],
input[type="date"], input[type="time"], input[type="number"], select, textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--radius);
  font-family: var(--font-body); font-size: 0.95rem; background: var(--white); color: var(--ink);
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--sage); box-shadow: 0 0 0 3px rgba(122,141,111,0.15); }
textarea { resize: vertical; min-height: 60px; }

/* Botones */
.btn {
  display: inline-block; padding: 9px 16px; border: 1px solid transparent; border-radius: var(--radius);
  font-family: var(--font-body); font-size: 0.92rem; font-weight: 500; cursor: pointer;
  transition: all 0.15s; text-decoration: none; line-height: 1.2;
}
.btn-primary { background: var(--ink); color: var(--cream); }
.btn-primary:hover:not(:disabled) { background: #1a1816; }
.btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }
.btn-secondary { background: var(--white); color: var(--ink); border-color: var(--line); }
.btn-secondary:hover { background: var(--sage-light); border-color: var(--sage); }
.btn-success { background: var(--sage); color: var(--cream); }
.btn-success:hover { background: var(--sage-dark); }
.btn-danger { background: var(--danger); color: var(--cream); }
.btn-danger:hover { background: #8a3a28; }
.btn-ghost { background: transparent; color: var(--ink-soft); }
.btn-ghost:hover { background: var(--sage-light); color: var(--ink); }
.btn-sm { padding: 5px 10px; font-size: 0.78rem; }

/* Cards */
.card { background: var(--white); border-radius: var(--radius-lg); padding: 24px; border: 1px solid var(--line-soft); margin-bottom: 14px; }

/* Mensajes */
.msg { padding: 10px 14px; border-radius: var(--radius); margin-bottom: 14px; font-size: 0.9rem; }
.msg-success { background: var(--success-bg); color: var(--success); border-left: 3px solid var(--success); }
.msg-error { background: var(--danger-bg); color: var(--danger); border-left: 3px solid var(--danger); }
.msg-info { background: var(--sage-light); color: var(--ink); border-left: 3px solid var(--sage); }
