:root {
  --azul:#107CB4;
  --azul-osc:#0a5f8c;
  --rojo:#E60000;
  --celeste:#6CA7D4;
  --bg:#eef3f7;
  --texto:#1f2d3d;
  --borde:#dbe3ea;
  --err:#b3261e;
}
* { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; }
html, body { margin:0; padding:0; }
body {
  font-family:'Segoe UI', system-ui, -apple-system, Roboto, sans-serif;
  background:var(--bg);
  color:var(--texto);
  min-height:100vh;
  min-height:100dvh;
}

/* ---- Barra superior con logo ---- */
.topbar {
  background:#fff;
  border-bottom:3px solid var(--azul);
  padding:14px 20px;
  display:flex;
  justify-content:center;
}
.topbar .logo {
  height:42px;
  max-width:80%;
  width:auto;
  object-fit:contain;
  display:block;
}

/* ---- Layout ---- */
.page {
  width:100%;
  max-width:640px;
  margin:0 auto;
  padding:clamp(18px, 4vw, 32px) clamp(14px, 4vw, 20px) 48px;
}
.card {
  background:#fff;
  border:1px solid var(--borde);
  border-radius:16px;
  box-shadow:0 6px 24px rgba(16,124,180,.08);
  padding:clamp(20px, 5vw, 30px) clamp(18px, 5vw, 28px);
}
.card-head { margin-bottom:22px; }
.card-head h1 {
  margin:0 0 6px;
  font-size:clamp(20px, 5vw, 24px);
  color:var(--azul);
  line-height:1.15;
}
.sub {
  margin:0;
  color:#5b6b7b;
  font-size:clamp(13.5px, 3.6vw, 15px);
  line-height:1.45;
}
.cliente-tag {
  display:inline-block;
  margin:2px 0 10px;
  font-size:13px;
  font-weight:700;
  color:#fff;
  background:var(--azul);
  padding:4px 14px;
  border-radius:999px;
  letter-spacing:.3px;
}
.cliente-tag:empty { display:none; }

/* ---- Formulario ---- */
.grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 18px;
}
.field { display:flex; flex-direction:column; min-width:0; }
.field.full { grid-column:1 / -1; }
label { font-size:13.5px; font-weight:600; margin-bottom:6px; }
.req { color:var(--rojo); }
input:not([type="checkbox"]) {
  font-size:16px;            /* 16px evita el zoom automático en iOS */
  padding:12px 13px;
  border:1.5px solid var(--borde);
  border-radius:10px;
  background:#fbfcfd;
  transition:border-color .15s, box-shadow .15s;
  font-family:inherit;
  width:100%;
  -webkit-appearance:none;
  appearance:none;
}
input:not([type="checkbox"]):focus {
  outline:none;
  border-color:var(--azul);
  box-shadow:0 0 0 3px rgba(16,124,180,.15);
  background:#fff;
}
input.invalid { border-color:var(--err); background:#fdf4f3; }
.err { color:var(--err); font-size:12.5px; min-height:16px; margin-top:5px; }

.btn {
  margin-top:22px;
  width:100%;
  background:var(--azul);
  color:#fff;
  border:none;
  padding:15px;
  font-size:16px;
  font-weight:600;
  border-radius:11px;
  cursor:pointer;
  font-family:inherit;
  transition:background .15s;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.btn:hover { background:var(--azul-osc); }
.btn:active { transform:translateY(1px); }
.btn:disabled { opacity:.6; cursor:default; }

.banner {
  border-radius:10px;
  padding:16px 18px;
  font-size:14.5px;
  line-height:1.5;
  margin-top:6px;
}
.banner.success { background:#e7f5ec; color:#1a7d44; border:1px solid #b9e3c8; }
.banner.closed  { background:#fdeaea; color:var(--err); border:1px solid #f3c2c0; margin-bottom:18px; }
.ok-actions { margin-top:10px; }
.link {
  background:none; border:none; color:var(--azul);
  font-weight:600; cursor:pointer; font-size:14px; padding:0; text-decoration:underline;
}
.foot {
  text-align:center; color:#8694a4; font-size:12.5px;
  margin-top:24px; padding:0 12px;
}

/* ---- Mobile: una sola columna ---- */
@media (max-width:560px) {
  .grid { grid-template-columns:1fr; gap:12px; }
  .topbar { padding:12px 16px; }
  .topbar .logo { height:34px; }
  .card { border-radius:14px; }
}

/* ---- Pantallas muy chicas ---- */
@media (max-width:360px) {
  .topbar .logo { height:30px; }
}

.hint {
  display:block;
  color:var(--azul);
  background:#eaf4fb;
  border:1px solid #cfe6f5;
  border-radius:8px;
  padding:8px 11px;
  font-size:12.5px;
  line-height:1.4;
  margin-top:6px;
}
.hint[hidden] { display:none; }

.consent-wrap { margin-top:20px; }
.consent {
  display:flex;
  align-items:center;
  gap:11px;
  font-size:13px;
  line-height:1.5;
  color:#5b6b7b;
  cursor:pointer;
  background:#f7fafc;
  border:1px solid var(--borde);
  border-radius:10px;
  padding:14px 15px;
}
.consent input[type=checkbox] {
  -webkit-appearance:auto;
  appearance:auto;
  width:18px;
  height:18px;
  min-width:18px;
  margin:0;
  accent-color:var(--azul);
  cursor:pointer;
  flex:0 0 auto;
}
.consent a { color:var(--azul); }
.consent strong { color:var(--texto); }
