:root {
  --bg: #faf9f7;
  --graphite: #17171b;
  --ink: #1a1a1c;
  --ink-2: #55555c;
  --faint: #8a8a90;
  --line: #e9e7e1;
  --line-2: #ddd9cf;
  --surface: #fff;
  --gold: #b0832f;
  --gold-2: #d8b15e;
  --green: #2f7d52;
  --blood: #b23a2e;
  --radius: 16px;
  --radius-sm: 11px;
  --font: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font);
  font-size: 15px;
  line-height: 1.6;
  letter-spacing: -.011em;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Barra superior */
.bar {
  display: flex; align-items: center; justify-content: space-between;
  height: 58px; padding: 0 22px; background: var(--graphite); color: #f4f4f6;
  position: sticky; top: 0; z-index: 10;
  padding-top: env(safe-area-inset-top);
}
.brand { display: flex; align-items: center; gap: 9px; }
.brand .logo-img { height: 22px; width: auto; display: block; }
.wm { font-weight: 700; letter-spacing: .2em; font-size: 14px; }
.bar-tag { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: #9a9aa0; }

/* Lienzo (móvil primero) */
.wrap { flex: 1; width: 100%; max-width: 680px; margin: 0 auto; padding: 30px 18px 28px; }

/* Hero de la jornada */
.hero { margin-bottom: 26px; padding-left: 18px; border-left: 3px solid var(--gold); animation: rise .5s cubic-bezier(.16,1,.3,1) both; }
.hero .eyebrow { margin: 0 0 8px; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.hero .caso { margin: 0; font-weight: 700; font-size: clamp(1.5rem, 6vw, 2.1rem); line-height: 1.14; letter-spacing: -.03em; }
.hero .etapa { display: inline-block; margin-top: 12px; font-size: 11px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); }

.cuenta-cap { margin: 0 0 16px; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--faint); font-weight: 600; }

/* ===== Tarjeta de expediente (tarea de campo) ===== */
.exp {
  background: var(--surface); border: 1px solid var(--line-2);
  border-radius: var(--radius); padding: 18px 16px; margin-bottom: 14px;
  animation: rise .5s cubic-bezier(.16,1,.3,1) both;
}
.exp.listo { border-color: var(--green); background: #f6fbf8; }
.exp-head { margin-bottom: 4px; }
.exp-num { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); font-variant-numeric: tabular-nums; }
.exp-cara { margin: 2px 0 0; font-weight: 650; font-size: 1.05rem; letter-spacing: -.01em; line-height: 1.25; }
.exp-obj { margin: 8px 0 0; color: var(--ink-2); font-size: 14px; }

.card-cuerpo { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
.card-label { margin: 0 0 10px; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); font-weight: 600; }

/* Chips de resultado */
.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  font: inherit; font-size: 14px; cursor: pointer; min-height: 44px;
  padding: 9px 15px; border: 1px solid var(--line-2); background: #fff;
  border-radius: 999px; color: var(--ink-2); transition: all .16s ease;
}
.chip:hover { border-color: var(--gold); color: var(--ink); }
.chip.on { background: var(--ink); border-color: var(--ink); color: #fff; }

/* Nueva fecha */
.fecha-wrap { margin-top: 14px; }
.fecha-wrap label { display: block; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); margin-bottom: 8px; }
.fecha-row { display: flex; gap: 10px; }
.in-fecha, .in-hora {
  font: inherit; font-size: 16px; color: var(--ink); background: #fff;
  border: 1px solid var(--line-2); border-radius: var(--radius-sm); padding: 12px 13px; min-height: 48px;
}
.in-fecha { flex: 1.4; } .in-hora { flex: 1; }
.in-fecha:focus, .in-hora:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 4px rgba(176,131,47,.14); }

/* Nota */
.nota {
  margin-top: 14px; width: 100%; font: inherit; font-size: 16px; color: var(--ink);
  background: #fff; border: 1px solid var(--line-2); border-radius: var(--radius-sm);
  padding: 12px 13px; resize: vertical; line-height: 1.5;
}
.nota:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 4px rgba(176,131,47,.14); }

.card-msg { margin: 12px 0 0; font-size: 13px; min-height: 1.1em; }
.card-msg.err { color: var(--blood); }

.enviar {
  margin-top: 14px; width: 100%; font: inherit; font-weight: 600; cursor: pointer;
  font-size: 15px; letter-spacing: .02em; color: #fff; background: var(--ink);
  border: 0; border-radius: var(--radius-sm); padding: 14px; min-height: 50px;
  transition: transform .15s ease, background .2s ease;
}
.enviar:hover { background: #000; transform: translateY(-1px); }
.enviar:disabled { opacity: .45; cursor: default; transform: none; }

/* Estado "reporte enviado" */
.card-hecho { display: flex; align-items: center; gap: 13px; margin-top: 16px; padding-top: 14px; border-top: 1px solid #d9ece1; }
.card-hecho .check {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%; background: var(--green); color: #fff;
  font-weight: 700; flex: none;
}
.card-hecho strong { display: block; color: var(--ink); font-size: 14px; }
.card-hecho .muted { display: block; font-size: 12px; }
.card-hecho .reenviar { margin-left: auto; font: inherit; font-size: 12px; background: none; border: 0; color: var(--gold); cursor: pointer; text-decoration: underline; }

@keyframes rise { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

/* ===== Acceso por PIN / inactivo ===== */
.card { background: none; }
.pin-card { max-width: 380px; margin: 36px auto; padding: 0 4px; text-align: center; }
.pin-card h2 { margin: 0 0 6px; font-weight: 700; font-size: 1.5rem; letter-spacing: -.02em; }
.muted { color: var(--faint); margin: 0 0 22px; font-size: 14px; }
form label { display: block; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); margin-bottom: 10px; }
.pin-card input {
  width: 100%; font: inherit; color: var(--ink); background: #fff; border: 1px solid var(--line-2);
  border-radius: var(--radius-sm); padding: 15px; text-align: center; font-size: 1.5rem; letter-spacing: .4em; min-height: 56px;
}
.pin-card input::placeholder { letter-spacing: .3em; color: #c4c4c8; }
.pin-card input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 4px rgba(176,131,47,.14); }
.pin-card button {
  margin-top: 16px; width: 100%; font: inherit; font-weight: 600; cursor: pointer;
  font-size: 15px; color: #fff; background: var(--ink); border: 0; border-radius: var(--radius-sm); padding: 15px; min-height: 52px;
  transition: transform .15s ease, background .2s ease;
}
.pin-card button:hover { background: #000; transform: translateY(-1px); }
.pin-card button:disabled { opacity: .5; cursor: default; transform: none; }
.msg { margin: 16px 0 0; font-size: 13px; min-height: 1.2em; text-align: center; }
.msg.ok { color: var(--green); } .msg.err { color: var(--blood); }
.estado { text-align: center; color: var(--ink-2); margin-top: 56px; font-size: 14px; }

.inactive-card { max-width: 400px; margin: 52px auto; padding: 0; text-align: center; }
.inactive-card .lock { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: 50%; background: #efece6; color: #8a8a90; margin-bottom: 20px; }
.inactive-card h2 { margin: 0 0 8px; font-weight: 700; font-size: 1.35rem; letter-spacing: -.02em; color: var(--ink); }
.inactive-card .muted { margin: 0; }

/* Pie */
.pie { padding: 36px 22px 40px; text-align: center; color: var(--faint); border-top: 1px solid var(--line); margin-top: 20px; padding-bottom: calc(40px + env(safe-area-inset-bottom)); }
.brandmark { display: inline-flex; align-items: center; gap: 11px; }
.brandmark .logo-img.sm { height: 22px; width: auto; }
.brandmark .bm-txt { text-align: left; }
.brandmark strong { display: block; color: #2a2a2e; font-size: 13px; letter-spacing: .18em; }
.brandmark span { display: block; color: var(--faint); font-size: 11px; letter-spacing: .02em; }
.fine { margin: 14px 0 0; font-size: 11px; letter-spacing: .04em; color: var(--faint); }
body.apagado .bar .logo-img, body.apagado .brandmark .logo-img { filter: grayscale(1); opacity: .5; }

@media (min-width: 560px) {
  .wrap { padding: 44px 26px 32px; }
  .exp { padding: 22px 22px; }
}