/* =========================================================
   Huellas Plus - Panel  ·  estilos
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap');

:root{
  --ink:#2B2A5E; --muted:#6E6D88;
  --primary:#E6177A; --primary-d:#C40F66;
  --accent:#F2994A; --accent-d:#E07B2E;
  --bg:#FBF1F6; --surface:#FFFFFF; --line:#EBD9E3;
  --bronce:#B07B4F; --plata:#7E8A95; --oro:#C99A2E;
  --danger:#C0392B; --ok:#4C9A2A; --warn:#D98A1F;
  --radius:16px; --shadow:0 10px 30px rgba(43,42,94,.12);
  --font:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font);font-size:15px;line-height:1.5}
h1{font-size:26px;margin:0 0 4px;letter-spacing:-.5px}
h2{font-size:19px;margin:0 0 14px;letter-spacing:-.3px}
h3{font-size:13px;margin:18px 0 10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:800}
.muted{color:var(--muted)} .small{font-size:12.5px}
.green{color:var(--ok)} .warn{color:var(--warn)}
.link{color:var(--primary);font-weight:800;text-decoration:none}
.right{text-align:right}

/* huella */
.paw{display:inline-block;width:34px;height:34px;border-radius:10px;vertical-align:middle;
     background:var(--primary) url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%20512%20512%27%20fill%3D%27%2523ffffff%27%3E%3Cpath%20d%3D%27M226%20124c0%2036-22%2065-49%2065s-49-29-49-65%2022-65%2049-65%2049%2029%2049%2065zm158%200c0%2036-22%2065-49%2065s-49-29-49-65%2022-65%2049-65%2049%2029%2049%2065zM118%20246c0%2031-19%2056-43%2056s-43-25-43-56%2019-56%2043-56%2043%2025%2043%2056zm362%200c0%2031-19%2056-43%2056s-43-25-43-56%2019-56%2043-56%2043%2025%2043%2056zM256%20268c52%200%2096%2058%2096%20104%200%2036-30%2052-66%2052-14%200-20-4-30-4s-16%204-30%204c-36%200-66-16-66-52%200-46%2044-104%2096-104z%27%2F%3E%3C%2Fsvg%3E") center/19px no-repeat}

/* botones */
.btn{border:0;border-radius:11px;padding:10px 16px;font-family:inherit;font-weight:800;font-size:14px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px;text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff} .btn-primary:hover{background:var(--primary-d)}
.btn-accent{background:var(--accent);color:#3a2410} .btn-accent:hover{background:var(--accent-d);color:#fff}
.btn-ghost{background:transparent;color:var(--muted);border:1.5px solid var(--line)} .btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-ok{background:var(--ok);color:#fff}
.btn-danger{background:#fff;color:var(--danger);border:1.5px solid var(--danger)} .btn-danger:hover{background:var(--danger);color:#fff}
.btn-sm{padding:7px 11px;font-size:13px;border-radius:9px}

/* contraseña con mostrar/ocultar */
.pw-wrap{position:relative;display:block}
.pw-wrap input{width:100%;padding-right:64px}
.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);border:0;background:transparent;color:var(--primary);font-family:inherit;font-weight:800;font-size:12.5px;cursor:pointer;padding:6px 8px}
.pw-toggle:hover{text-decoration:underline}

/* layout */
.topbar{background:var(--surface);border-bottom:1px solid var(--line);padding:12px 18px;display:flex;align-items:center;justify-content:space-between}
.brand-row{display:flex;align-items:center;gap:10px;font-size:18px;letter-spacing:-.3px}
.wrap{max-width:1080px;margin:0 auto;padding:22px 16px 60px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.pad{padding:22px}
.row-end{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.back{display:inline-block;color:var(--primary);font-weight:800;text-decoration:none;margin-bottom:14px}
.empty{text-align:center;color:var(--muted);padding:34px 16px}

/* formularios */
label{display:block;font-weight:700;font-size:13px;margin:0 0 5px;color:var(--ink)}
input,select,textarea{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:14.5px;background:#fff;color:var(--ink);margin-bottom:14px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0 14px}

/* tablas */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:10px 12px;border-bottom:2px solid var(--line)}
td{padding:12px;border-bottom:1px solid var(--line);font-size:14.5px;vertical-align:middle}
tr:last-child td{border-bottom:0}
.inline{display:inline} .inline button{margin-left:4px}

/* etiquetas */
.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:800}
.tag-bronce{background:#f3e6d8;color:var(--bronce)} .tag-plata{background:#e7ebef;color:#56616c} .tag-oro{background:#f7edcf;color:#9a7415}
.tag-pend{background:#fdf0d8;color:var(--warn)} .tag-apro{background:#dbeede;color:var(--ok)}
.tag-pag{background:#d6ebf5;color:#1d6fa5} .tag-rech{background:#f6dcd8;color:var(--danger)}
.tag-aldia{background:#dbeede;color:var(--ok)} .tag-deuda{background:#fdf0d8;color:var(--warn)}
.pill{font-size:12px;background:#f6eaf1;border:1px solid var(--line);padding:4px 10px;border-radius:999px;color:var(--muted);font-weight:800}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px;display:block;text-decoration:none;color:var(--ink);transition:border-color .12s,box-shadow .12s}
a.stat:hover{border-color:var(--primary);box-shadow:0 4px 14px rgba(15,118,110,.10)}
.stat .n{font-size:26px;font-weight:900;letter-spacing:-.5px}
.stat .l{font-size:12.5px;color:var(--muted);font-weight:700}

/* alertas */
.alert{padding:11px 14px;border-radius:11px;margin-bottom:16px;font-weight:700;font-size:14px}
.alert.ok{background:#dbeede;color:#0f5132;border:1px solid #b6d8bf}
.alert.err{background:#f8d7da;color:#842029;border:1px solid #f1aeb5}
.note{font-size:13px;background:#fef6e9;border:1px solid #f3dcae;color:#7a5a16;padding:10px 12px;border-radius:10px}

/* detalle */
.detail{display:grid;grid-template-columns:360px 1fr;gap:20px}
.col-side{min-width:0}
.datos{font-size:14px;line-height:1.9}
.acceso-box{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.cuota-form{display:flex;gap:8px} .cuota-form button{margin:0}
.calcbox{background:#fbf1f6;border:1px solid var(--line);border-radius:12px;padding:14px}
.calcbox .big{font-size:24px;font-weight:900;color:var(--primary)}

/* auth */
.auth-bg{background:linear-gradient(135deg,#fde4f0,#fbf1f6);display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.auth-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;width:100%;max-width:400px}
.auth-card .brand-row{justify-content:center;margin-bottom:18px;font-size:20px;font-weight:900}
.tabs{display:flex;gap:6px;background:#eef4f2;border-radius:11px;padding:5px;margin-bottom:18px}
.tab{flex:1;border:0;background:transparent;padding:9px;border-radius:8px;font-family:inherit;font-weight:800;font-size:14px;color:var(--muted);cursor:pointer}
.tab.on{background:#fff;color:var(--primary);box-shadow:0 2px 6px rgba(0,0,0,.06)}

/* credencial */
.cred{width:340px;max-width:100%;border-radius:18px;overflow:hidden;position:relative;color:#fff;background:linear-gradient(145deg,var(--primary),var(--primary-d));box-shadow:0 14px 34px rgba(11,90,84,.35)}
.cred-bronce{background:linear-gradient(145deg,#c08a5a,#8a5e36)}
.cred-plata{background:linear-gradient(145deg,#9aa4ae,#69737d)}
.cred-oro{background:linear-gradient(145deg,#e0b955,#b8881c)}
.cred-paw{position:absolute;right:-22px;top:-22px;width:150px;height:150px;opacity:.13;
          background:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%20512%20512%27%20fill%3D%27%2523ffffff%27%3E%3Cpath%20d%3D%27M226%20124c0%2036-22%2065-49%2065s-49-29-49-65%2022-65%2049-65%2049%2029%2049%2065zm158%200c0%2036-22%2065-49%2065s-49-29-49-65%2022-65%2049-65%2049%2029%2049%2065zM118%20246c0%2031-19%2056-43%2056s-43-25-43-56%2019-56%2043-56%2043%2025%2043%2056zm362%200c0%2031-19%2056-43%2056s-43-25-43-56%2019-56%2043-56%2043%2025%2043%2056zM256%20268c52%200%2096%2058%2096%20104%200%2036-30%2052-66%2052-14%200-20-4-30-4s-16%204-30%204c-36%200-66-16-66-52%200-46%2044-104%2096-104z%27%2F%3E%3C%2Fsvg%3E") center/contain no-repeat}
.cred-in{padding:20px;position:relative}
.cred-brand{display:flex;align-items:center;gap:8px;font-weight:900;font-size:17px;margin-bottom:18px}
.cred-p{width:24px;height:24px;border-radius:7px;background:rgba(255,255,255,.22) url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%20512%20512%27%20fill%3D%27%2523ffffff%27%3E%3Cpath%20d%3D%27M226%20124c0%2036-22%2065-49%2065s-49-29-49-65%2022-65%2049-65%2049%2029%2049%2065zm158%200c0%2036-22%2065-49%2065s-49-29-49-65%2022-65%2049-65%2049%2029%2049%2065zM118%20246c0%2031-19%2056-43%2056s-43-25-43-56%2019-56%2043-56%2043%2025%2043%2056zm362%200c0%2031-19%2056-43%2056s-43-25-43-56%2019-56%2043-56%2043%2025%2043%2056zM256%20268c52%200%2096%2058%2096%20104%200%2036-30%2052-66%2052-14%200-20-4-30-4s-16%204-30%204c-36%200-66-16-66-52%200-46%2044-104%2096-104z%27%2F%3E%3C%2Fsvg%3E") center/15px no-repeat}
.cred-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;opacity:.85;font-weight:800}
.cred-pet{font-size:25px;font-weight:900;letter-spacing:-.4px;line-height:1.1}
.cred-owner{font-size:13.5px;opacity:.92;margin-top:2px}
.cred-row{display:flex;justify-content:space-between;gap:10px;margin-top:18px}
.cred-row .k{font-size:10px;text-transform:uppercase;letter-spacing:.8px;opacity:.8;font-weight:800}
.cred-row .v{font-size:14px;font-weight:800}
.cred-band{margin-top:16px;background:rgba(255,255,255,.16);border-radius:10px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-weight:900;font-size:13px}
.cred-pend{filter:grayscale(.35);opacity:.92}
.cred-ribbon{position:absolute;top:14px;right:-34px;transform:rotate(40deg);background:#15302B;color:#fff;font-size:11px;font-weight:800;letter-spacing:.5px;padding:5px 40px;box-shadow:0 4px 10px rgba(0,0,0,.25);z-index:2}

code{background:#eef4f2;padding:2px 6px;border-radius:5px;font-size:13px}

/* selector de mascotas */
.mtabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.mtab{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1.5px solid var(--line);border-radius:11px;padding:9px 15px;font-weight:800;font-size:14px;color:var(--ink);text-decoration:none}
.mtab:hover{border-color:var(--primary)}
.mtab.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.mtab.add{color:var(--muted);border-style:dashed}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.warn-dot{background:var(--warn)}

/* portal con menú lateral derecho */
.portal-grid{display:grid;grid-template-columns:1fr 230px;gap:18px;align-items:start}
.portal-menu{grid-column:2;grid-row:1;position:sticky;top:16px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:2px}
.portal-main{grid-column:1;grid-row:1;min-width:0}
.pm-title{font-weight:900;font-size:15px;padding:6px 10px;color:var(--primary)}
.portal-menu a{display:block;padding:9px 10px;border-radius:9px;text-decoration:none;color:var(--ink);font-weight:700;font-size:14px}
.portal-menu a:hover{background:#eef4f2}
.portal-menu hr{border:none;border-top:1px solid var(--line);margin:6px 0}
.pm-add{color:var(--accent)!important}
.resumen-grid{display:grid;grid-template-columns:300px 1fr;gap:20px;align-items:start}
.mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.ms{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px;text-align:center}
.ms .n{font-size:18px;font-weight:900}
.ms .l{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.2}
.cred-top{display:flex;align-items:center;gap:12px;margin-top:6px}
.cred-foto{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.7);flex-shrink:0}
.cred-foto-empty{background:rgba(255,255,255,.25)}
@media(max-width:820px){
    .portal-grid{grid-template-columns:1fr}
    .portal-menu{grid-column:1;grid-row:1;position:static;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;top:0}
    .portal-main{grid-column:1;grid-row:2}
    .portal-menu hr,.pm-title{display:none}
    .portal-menu a{white-space:nowrap}
    .resumen-grid{grid-template-columns:1fr}
}

@media(max-width:820px){.detail{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.grid2,.grid3{grid-template-columns:1fr}.hide-sm{display:none}}
@media print{body *{visibility:hidden}#cred-print,#cred-print *{visibility:visible}#cred-print{position:absolute;left:0;top:0}}
