:root{
  --navy:#0b2540; --navy2:#1b3c5d; --blue:#2e6fb0; --red:#c0392b; --green:#1e8449;
  --bg:#eef2f6; --card:#ffffff; --ink:#1f2d3d; --muted:#5a6b7b; --line:#cfd8e1;
  --amber:#e8a200;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",system-ui,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
strong{font-weight:700}

/* Topbar */
.topbar{display:flex;align-items:center;gap:16px;background:var(--navy);color:#fff;padding:0 24px;height:64px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-size:18px}
.brand:hover{text-decoration:none}
.brand-dot{width:22px;height:22px;border-radius:50%;background:var(--blue);display:inline-block}
.badge-emergencia{background:var(--red);color:#fff;font-size:12px;font-weight:700;padding:5px 12px;border-radius:14px}
.topnav{margin-left:auto;display:flex;gap:18px}
.topnav a{color:#cdd8e3;font-size:14px}
.topinfo{margin-left:auto;display:inline-flex;align-items:center;gap:7px;background:var(--amber);color:var(--navy);font-size:14px;font-weight:800;padding:8px 16px;border-radius:999px;text-decoration:none;box-shadow:0 2px 10px rgba(232,162,0,.45);transition:transform .15s ease,filter .15s ease,box-shadow .15s ease;animation:topinfo-pulse 2.2s ease-in-out infinite}
.topinfo:hover{color:var(--navy);text-decoration:none;transform:translateY(-1px);filter:brightness(1.06);box-shadow:0 4px 16px rgba(232,162,0,.6);animation:none}
.topinfo .ti-ico{font-size:15px;line-height:1}
@keyframes topinfo-pulse{0%,100%{box-shadow:0 0 0 0 rgba(232,162,0,.55)}50%{box-shadow:0 0 0 7px rgba(232,162,0,0)}}

/* Layout */
.container{max-width:1080px;margin:0 auto;padding:28px 24px 60px}
.muted{color:var(--muted)}
.hero h1{font-size:34px;margin:.2em 0 .1em;color:var(--navy)}
.hero p{font-size:18px;color:var(--muted);margin:.2em 0 1em}

/* Botones / acciones */
.actions{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:20px 0}
@media(max-width:720px){.actions{grid-template-columns:1fr}}
.action-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;border-top:8px solid var(--blue)}
.action-card.perdida{border-top-color:var(--red)}
.action-card.encontrada{border-top-color:var(--green)}
.action-card h2{margin:.1em 0 .3em;color:var(--navy);font-size:22px}
.action-card p{color:var(--muted);margin:.2em 0 1em}
.btn{display:inline-block;border:none;border-radius:10px;padding:13px 22px;font-size:16px;font-weight:700;color:#fff;cursor:pointer}
.btn-red{background:var(--red)} .btn-green{background:var(--green)} .btn-blue{background:var(--blue)}
.btn:hover{filter:brightness(1.05);text-decoration:none;color:#fff}
.btn-block{display:block;width:100%;text-align:center}

/* Stats */
.stats{display:flex;background:var(--navy);border-radius:14px;color:#fff;margin-top:18px}
.stats div{flex:1;text-align:center;padding:18px;border-right:1px solid var(--navy2)}
.stats div:last-child{border-right:none}
.stats .n{font-size:30px;font-weight:800}
.stats .l{font-size:13px;color:#9fb3c8}

/* Formulario */
form.reporte{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-top:18px}
@media(max-width:820px){form.reporte{grid-template-columns:1fr}}
.panel{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px}
.panel.privado{border-color:#e2c7c2}
.panel h3{margin:.1em 0 .6em;font-size:15px;letter-spacing:.02em;text-transform:uppercase;color:var(--navy)}
.panel.privado h3{color:#8a2a1d}
.field{margin-bottom:12px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}
.field input[type=text],.field input[type=number],.field input[type=email],.field input[type=tel],
.field input[type=password],.field input[type=date],
.field select,.field textarea{
  width:100%;padding:10px;border:1px solid var(--line);border-radius:8px;background:#f7f9fb;font:inherit;color:var(--ink)
}
.field textarea{min-height:70px;resize:vertical}
.row{display:flex;gap:10px}.row>.field{flex:1}
.check{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--muted)}
.hint{font-size:12px;color:#8a8f96;margin-top:4px}
.aviso{background:#f3f6f9;border:1px solid var(--line);border-radius:10px;padding:12px;font-size:12px;color:var(--muted);margin-top:10px}

/* Mensajes */
.alert{padding:12px 14px;border-radius:10px;margin:14px 0;font-size:14px}
.alert-ok{background:#e7f4ec;border:1px solid #c2ddc9;color:#1e6b3a}
.alert-err{background:#fbeae7;border:1px solid #e2c7c2;color:#8a2a1d}
.alert-err ul{margin:.4em 0 0;padding-left:18px}

/* Footer */
.sitefooter{border-top:1px solid var(--line);padding:22px 24px;color:var(--muted);font-size:13px;text-align:center}
.sitefooter p{margin:.2em 0}

/* ====== Badges ====== */
.badge{display:inline-block;font-size:11px;font-weight:700;color:#fff;padding:3px 9px;border-radius:11px;margin-right:4px;vertical-align:middle}
.b-rojo{background:var(--red)} .b-verde{background:var(--green)} .b-azul{background:#3a7bbf}
.b-ambar{background:var(--amber)} .b-gris{background:#7a8794}

/* ====== Búsqueda pública ====== */
.filtros{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0}
.filtros input[type=text],.filtros select{padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff;font:inherit}
.filtros input[type=text]{flex:1;min-width:200px}
.grid-cartel{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin-top:8px}
.cartel{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:block;color:inherit}
.cartel:hover{text-decoration:none;box-shadow:0 4px 14px rgba(11,37,64,.12)}
.cartel-foto{position:relative;height:170px;background:#dde6ee;display:flex;align-items:center;justify-content:center}
.cartel-foto img{width:100%;height:100%;object-fit:cover}
.cartel-foto .badge{position:absolute;top:10px;left:10px}
.cartel-foto .b-ambar{left:auto;right:10px}
.cartel-sinfoto{color:#9aa8b6;font-size:14px}
.cartel-sinfoto.grande{display:flex;align-items:center;justify-content:center;height:280px;background:#dde6ee;border-radius:12px}
.cartel-info{padding:12px;display:flex;flex-direction:column;gap:3px}

/* ====== Ficha pública ====== */
.ficha{display:grid;grid-template-columns:280px 1fr;gap:20px;margin-top:10px}
@media(max-width:680px){.ficha{grid-template-columns:1fr}}
.ficha-foto img{width:100%;border-radius:12px}
.ficha-datos h1{margin:.2em 0;color:var(--navy)}
ul.datos{list-style:none;padding:0;margin:.5em 0}
ul.datos li{padding:5px 0;border-bottom:1px solid #eef1f4}

/* ====== Login ====== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy);padding:20px}
.login-card{background:#fff;border-radius:14px;padding:30px;width:360px;max-width:100%}
.login-card h1{margin:.1em 0;color:var(--navy);font-size:24px}

/* ====== Admin ====== */
body.admin{display:flex;min-height:100vh}
.sidebar{width:240px;background:var(--navy);color:#fff;display:flex;flex-direction:column;padding:18px 0}
.sidebar .brand{padding:0 18px 14px;color:#fff}
.sidebar nav{display:flex;flex-direction:column}
.sidebar nav a{color:#cdd8e3;padding:11px 18px;font-size:14px}
.sidebar nav a:hover{background:#16314c;text-decoration:none}
.sidebar nav a.on{background:#1b3c5d;color:#fff;font-weight:600;border-left:3px solid var(--blue)}
.sidebar-foot{margin-top:auto;padding:16px 18px;display:flex;flex-direction:column;gap:6px;font-size:13px;border-top:1px solid #16314c}
.sidebar-foot a{color:#9fb3c8}
.admin-main{flex:1;padding:26px 30px;max-width:1100px}
.admin-main h1{color:var(--navy);margin-top:0}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;color:inherit}
.card .n{font-size:30px;font-weight:800;color:var(--navy)}
.card .l{font-size:13px;color:var(--muted)}
a.card:hover{text-decoration:none;box-shadow:0 4px 14px rgba(11,37,64,.12)}

.btn-sm{padding:7px 13px;font-size:13px;border-radius:8px}
.btn-gris{background:#7a8794}
.inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
form.inline{display:inline-flex}

.modrow{display:grid;grid-template-columns:90px 1fr auto;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}
.modrow-foto{width:90px;height:90px;border-radius:8px;overflow:hidden;background:#dde6ee;display:flex;align-items:center;justify-content:center}
.modrow-foto img{width:100%;height:100%;object-fit:cover}
.modrow-info{display:flex;flex-direction:column;gap:3px}
.modrow-acc{display:flex;flex-direction:column;gap:8px}
.modrow-acc .rechazo{display:flex;gap:6px}
.modrow-acc .rechazo input{width:130px;padding:6px;border:1px solid var(--line);border-radius:7px}

.ficha2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.ficha2{grid-template-columns:1fr}}
.thumb{max-width:160px;border-radius:8px}
.cand{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:10px 0;border-bottom:1px solid #eef1f4}
.cand .par{display:inline-flex;align-items:center;gap:8px}
.cand-foto{width:46px;height:46px;border-radius:8px;object-fit:cover;flex:0 0 auto}
.cand-foto.sinfoto{display:inline-flex;align-items:center;justify-content:center;background:#dde6ee;color:#9aa8b6;font-size:12px}

.tabla{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.tabla th,.tabla td{padding:10px 12px;text-align:left;border-bottom:1px solid #eef1f4;font-size:14px}
.tabla th{background:#f3f6f9;color:#3a4a59;font-size:12px;text-transform:uppercase;letter-spacing:.02em}
.panel.nuevo{border-color:var(--amber);background:#fffdf5}
