:root{
  --bg:#f4f7fb;
  --card:#ffffff;
  --text:#172033;
  --muted:#667085;
  --primary:#146c5c;
  --primary-dark:#0f5146;
  --soft:#e8f5f2;
  --danger:#c83349;
  --dark:#111827;
  --border:#e5e7eb;
  --shadow:0 18px 45px rgba(15,23,42,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
main{width:min(1180px,92%);margin:0 auto 50px}
.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:14px 4%;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.brand{display:flex;gap:10px;align-items:center}.brand-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:var(--primary);color:#fff;font-size:22px}.brand small{display:block;color:var(--muted);font-weight:500}.topbar nav{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.topbar nav a{font-weight:700;color:#263548}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;padding:11px 16px;font-weight:800;cursor:pointer;transition:.2s;font-size:14px}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-light{background:#eef2f7;color:#172033}.btn-dark{background:var(--dark);color:#fff}.btn-danger{background:var(--danger);color:#fff}
.hero{display:grid;grid-template-columns:1.35fr .9fr;gap:28px;align-items:center;padding:56px 0 34px}.hero-content{background:linear-gradient(135deg,#0c3f39,#16806d);color:#fff;border-radius:32px;padding:42px;box-shadow:var(--shadow)}.hero h1{font-size:clamp(32px,5vw,58px);line-height:1.02;margin:12px 0}.hero p{font-size:18px;color:rgba(255,255,255,.85);max-width:720px}.pill{display:inline-flex;padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.16);font-weight:800}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.stats-grid div{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:24px;box-shadow:var(--shadow)}.stats-grid strong{display:block;font-size:42px;color:var(--primary)}.stats-grid span{color:var(--muted);font-weight:700}.admin-stats{grid-template-columns:repeat(4,1fr);margin-bottom:22px}.panel{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:24px;box-shadow:var(--shadow)}.filters{margin-bottom:22px}.filter-form{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:12px}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:14px;padding:13px 14px;font:inherit;background:#fff;color:var(--text)}textarea{min-height:120px;resize:vertical}label{display:grid;gap:7px;font-weight:800;color:#27364a}.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.case-card{overflow:hidden;background:var(--card);border:1px solid var(--border);border-radius:26px;box-shadow:var(--shadow)}.case-card img,.placeholder-img{width:100%;height:210px;object-fit:cover;background:linear-gradient(135deg,#d9f2ec,#eef2f7);display:grid;place-items:center;font-size:48px;color:var(--primary)}.case-body{padding:20px}.case-top{display:flex;justify-content:space-between;gap:12px;align-items:center}.case-top h3,.case-top h1{margin:0}.urgent{background:#fff1f2;color:#b42318;border:1px solid #fecdd3;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.muted{color:var(--muted)}.desc{color:#3f4d63;min-height:58px}.case-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.page-head{padding:36px 0 18px}.page-head h1{font-size:42px;margin:0 0 8px}.form-panel{max-width:980px;margin:0 auto}.smart-form{display:grid;gap:18px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.upload-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.notice{background:var(--soft);border:1px solid #bbebe0;color:#0f5146;border-radius:18px;padding:16px}.case-detail{display:grid;grid-template-columns:.8fr 1.2fr;gap:24px;padding:34px 0}.case-media img,.placeholder-big{width:100%;height:460px;object-fit:cover;border-radius:20px;background:linear-gradient(135deg,#d9f2ec,#eef2f7);display:grid;place-items:center;font-size:80px;color:var(--primary)}.case-info h1{font-size:42px}.case-description{font-size:17px;line-height:1.65}.progress{height:13px;background:#e7edf3;border-radius:999px;overflow:hidden}.progress span{display:block;height:100%;background:var(--primary);border-radius:999px}.donation-list{display:grid;gap:10px}.donation-row{display:grid;gap:5px;border:1px solid var(--border);border-radius:16px;padding:14px;background:#fafafa}.report-box form{display:grid;gap:12px}.login-wrap{min-height:70vh;display:grid;place-items:center}.login-card{width:min(430px,100%);display:grid;gap:15px}.admin-head{display:flex;justify-content:space-between;align-items:center;gap:16px}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px}.admin-list{display:grid;gap:12px}.admin-item{display:flex;justify-content:space-between;gap:14px;align-items:center;border:1px solid var(--border);border-radius:18px;padding:14px;background:#fbfcff}.admin-item small{display:block;color:var(--muted);margin-top:4px}.admin-actions{display:flex;gap:8px;flex-wrap:wrap}.admin-actions form{margin:0}.admin-detail-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:22px}.detail-list{display:grid;grid-template-columns:190px 1fr;gap:10px 16px}.detail-list dt{font-weight:900;color:#334155}.detail-list dd{margin:0;color:#475569}.file-grid{display:grid;gap:12px}.file-grid a{display:block;background:#f1f5f9;border:1px solid var(--border);border-radius:14px;padding:14px;font-weight:900;color:var(--primary)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:13px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}th{background:#f8fafc;font-size:13px;color:#475569}.empty{text-align:center;margin:30px auto;max-width:760px}.flash-wrap{padding-top:18px}.flash{border-radius:16px;padding:14px 16px;margin-bottom:10px;font-weight:800}.flash.success{background:#ecfdf5;color:#067647;border:1px solid #abefc6}.flash.error{background:#fff1f3;color:#b42318;border:1px solid #fecdd3}.footer{text-align:center;color:var(--muted);padding:28px 4%;border-top:1px solid var(--border)}.wrap{flex-wrap:wrap}
@media(max-width:900px){.hero,.case-detail,.admin-grid,.admin-detail-grid{grid-template-columns:1fr}.cards-grid{grid-template-columns:1fr 1fr}.filter-form,.form-grid,.upload-grid{grid-template-columns:1fr}.admin-stats{grid-template-columns:repeat(2,1fr)}.topbar{align-items:flex-start;gap:12px;flex-direction:column}.case-media img,.placeholder-big{height:320px}}
@media(max-width:620px){main{width:94%}.hero-content{padding:28px;border-radius:24px}.cards-grid,.stats-grid,.admin-stats{grid-template-columns:1fr}.admin-item{align-items:flex-start;flex-direction:column}.page-head h1,.case-info h1{font-size:32px}.detail-list{grid-template-columns:1fr}}
.section-title{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:16px}.section-title h2{margin:0 0 6px}.progress-meta{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:13px;font-weight:800;margin-top:7px}.mini-metric{color:#334155}.completed-panel{margin-top:28px}.completed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.completed-card{border:1px solid var(--border);border-radius:20px;padding:18px;background:#fbfcff}.completed-badge{background:#ecfdf5;color:#067647;border:1px solid #abefc6;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.badge-stack{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.surplus{color:#067647;font-weight:900}.completed-notice{margin-top:14px}.disabled-btn{opacity:.75;cursor:not-allowed}.admin-progress{margin-top:14px}.block-actions{margin-top:18px}.status-pill{display:inline-flex;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:900;text-transform:capitalize}.status-pendiente{background:#fffbeb;color:#b54708;border:1px solid #fedf89}.status-aprobada{background:#ecfdf5;color:#067647;border:1px solid #abefc6}.status-rechazada{background:#fff1f3;color:#b42318;border:1px solid #fecdd3}
@media(max-width:900px){.completed-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.completed-grid{grid-template-columns:1fr}.progress-meta{display:grid}}
.pagination{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}
.page-indicator{font-weight:900;color:#475569;background:#f8fafc;border:1px solid var(--border);border-radius:999px;padding:10px 14px}
.disabled-link{opacity:.48;cursor:not-allowed;transform:none!important}
.table-scroll{max-height:640px;overflow:auto;border:1px solid var(--border);border-radius:16px}
.table-scroll table{min-width:760px}
.table-scroll thead th{position:sticky;top:0;z-index:2}
.history-scroll{max-height:760px;overflow-y:auto;padding-right:6px}
.list-scroll{max-height:620px;overflow-y:auto;padding-right:6px}
.panel[id]{scroll-margin-top:92px}
@media(max-width:620px){.pagination{align-items:stretch}.pagination .btn,.page-indicator{width:100%;text-align:center}}
.btn-paypal{background:linear-gradient(135deg,#0070ba,#1546a0);color:#fff;box-shadow:0 10px 25px rgba(0,112,186,.22)}
.btn-paypal:hover{filter:brightness(1.05)}

/* ===== Botón premium para apoyar mantenimiento ===== */
.btn-gold-shine{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  border:1.5px solid #f6d365;
  background:
    linear-gradient(135deg,#006fc9 0%,#0b4db3 48%,#073489 100%);
  color:#fff;
  text-shadow:0 1px 0 rgba(0,0,0,.18);
  box-shadow:
    0 10px 25px rgba(0,112,186,.24),
    0 0 0 1px rgba(255,221,108,.22),
    0 0 18px rgba(246,211,101,.28);
}
.btn-gold-shine::before{
  content:"";
  position:absolute;
  inset:-2px;
  z-index:-1;
  background:
    radial-gradient(circle at 15% 20%,rgba(255,240,171,.55),transparent 24%),
    linear-gradient(135deg,rgba(255,215,0,.38),transparent 32%,rgba(255,215,0,.28));
  opacity:.55;
}
.btn-gold-shine::after{
  content:"";
  position:absolute;
  top:-60%;
  left:-45%;
  width:34%;
  height:220%;
  transform:rotate(25deg);
  background:linear-gradient(90deg,transparent,rgba(255,243,179,.88),rgba(255,215,0,.55),transparent);
  animation:goldShine 3.8s ease-in-out infinite;
}
.btn-gold-shine:hover{
  filter:none;
  transform:translateY(-2px) scale(1.015);
  box-shadow:
    0 14px 30px rgba(0,112,186,.30),
    0 0 0 1px rgba(255,225,107,.36),
    0 0 26px rgba(255,215,0,.48);
}
.btn-gold-shine .maintenance-icon{
  display:inline-flex;
  filter:drop-shadow(0 0 5px rgba(255,215,0,.75));
}
@keyframes goldShine{
  0%{left:-50%;opacity:0}
  18%{opacity:.9}
  48%{left:118%;opacity:0}
  100%{left:118%;opacity:0}
}
@media(prefers-reduced-motion:reduce){
  .btn-gold-shine::after{animation:none;display:none}
}
.btn-whatsapp{background:#25D366;color:#071b10;box-shadow:0 10px 24px rgba(37,211,102,.25)}
.btn-whatsapp:hover{background:#1fbd5b}
.maintenance-modal{position:fixed;inset:0;z-index:80;display:none;place-items:center;background:rgba(15,23,42,.55);padding:20px}
.maintenance-modal.open{display:grid}
.modal-card{position:relative;width:min(560px,100%);background:#fff;border-radius:28px;padding:28px;box-shadow:0 28px 80px rgba(15,23,42,.28)}
.modal-close{position:absolute;right:16px;top:14px;width:38px;height:38px;border:0;border-radius:999px;background:#eef2f7;font-size:24px;cursor:pointer}
.pill-blue{display:inline-flex;padding:8px 12px;border-radius:999px;background:#e7f3ff;color:#005ea8;font-weight:900;border:1px solid #b9ddff}
.payment-box{white-space:normal;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:18px;padding:16px;line-height:1.7;color:#27364a}
.payment-public-box{margin-bottom:22px}.small-note{font-size:13px}.account-notice{margin-bottom:4px}.whatsapp-card{margin-top:18px;background:#f0fff5;border:1px solid #bbf7d0;border-radius:18px;padding:16px}.admin-payment{margin:14px 0}.status-aprobado{background:#ecfdf5;color:#067647;border:1px solid #abefc6}.status-rechazado{background:#fff1f3;color:#b42318;border:1px solid #fecdd3}button:disabled{opacity:.55;cursor:not-allowed}.admin-stats{grid-template-columns:repeat(6,1fr)}
@media(max-width:1100px){.admin-stats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.admin-stats{grid-template-columns:1fr}.modal-card{padding:22px}}
.stats-grid-wide{grid-template-columns:repeat(2,1fr)}
.animal-note{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:14px;padding:12px}
@media(max-width:620px){.stats-grid-wide{grid-template-columns:1fr}}
.hidden-block{display:none}.dynamic-help{font-size:14px}.data-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.status-card{display:grid;gap:8px;border:1px solid var(--border);background:#fbfcff;border-radius:18px;padding:14px}.status-card small{white-space:pre-line;color:var(--muted);line-height:1.45}.isolated-data-form #bloquePagoUsuario,.isolated-data-form #bloqueDireccionUsuario{gap:14px}.delivery-box{margin:12px 0;padding:14px;border:1px dashed #86efac;border-radius:16px;background:#f0fdf4;color:#14532d;line-height:1.65}.mini-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}.mini-actions .btn{padding:7px 10px;font-size:12px;border-radius:10px}.payment-box hr{border:0;border-top:1px solid var(--border);margin:14px 0}input[readonly]{background:#f8fafc;color:#475569}
@media(max-width:820px){.data-status-grid{grid-template-columns:1fr}}
.support-form{margin-bottom:20px}.support-history{margin-top:22px}.support-ticket{align-items:flex-start}.support-ticket p{margin:10px 0;color:#334155;line-height:1.55}.support-reply{margin-top:12px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:16px;padding:14px;color:#14532d}.support-reply p{margin:7px 0}.support-response-form{display:grid;gap:10px;margin-top:14px}.support-response-form textarea{min-height:84px}.admin-support-ticket{display:grid;grid-template-columns:1fr auto}.status-respondido{background:#eff6ff;color:#175cd3;border:1px solid #bfdbfe}.status-cerrado{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.status-pendiente{background:#fffbeb;color:#b54708;border:1px solid #fedf89}
@media(max-width:760px){.admin-support-ticket{grid-template-columns:1fr}}

/* ===== Mejora visual Index: hero centrado y estadísticas en barra horizontal ===== */
.hero{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:22px;
  padding:42px 0 30px;
}
.hero-content{
  width:min(980px,100%);
  min-height:255px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  border-radius:22px;
  padding:38px 48px;
  background:linear-gradient(135deg,#0b4a40,#159077);
  box-shadow:0 22px 55px rgba(15,23,42,.16);
}
.hero h1{
  max-width:860px;
  margin:14px auto 10px;
  font-size:clamp(30px,4.2vw,50px);
  line-height:1.06;
}
.hero p{
  max-width:790px;
  margin:0 auto;
  font-size:17px;
}
.hero-actions{
  justify-content:center;
}
.stats-grid.stats-grid-wide{
  width:100%;
  display:flex;
  flex-wrap:nowrap;
  align-items:stretch;
  gap:10px;
  overflow-x:auto;
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:12px;
  box-shadow:var(--shadow);
  scrollbar-width:thin;
}
.stats-grid.stats-grid-wide div{
  flex:1 0 145px;
  min-width:145px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  gap:4px;
  padding:14px 12px;
  border-radius:16px;
  border:1px solid #edf0f4;
  box-shadow:none;
  background:#fbfcff;
}
.stats-grid.stats-grid-wide strong{
  font-size:28px;
  line-height:1;
}
.stats-grid.stats-grid-wide span{
  font-size:12px;
  line-height:1.2;
  font-weight:800;
}
@media(max-width:900px){
  .hero{padding:30px 0 24px}
  .hero-content{padding:30px 24px;min-height:230px}
  .stats-grid.stats-grid-wide{justify-content:flex-start}
}
@media(max-width:620px){
  .hero-content{border-radius:18px;padding:26px 18px}
  .hero h1{font-size:30px}
  .hero p{font-size:15px}
  .stats-grid.stats-grid-wide{border-radius:18px;padding:10px}
  .stats-grid.stats-grid-wide div{flex:0 0 138px;min-width:138px;padding:13px 10px}
}

/* ===== Paneles por roles: menú vertical y secciones aisladas ===== */
.dashboard-layout{
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:22px;
  align-items:start;
  margin:22px 0 34px;
}
.dashboard-sidebar{
  position:sticky;
  top:18px;
  display:grid;
  gap:10px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:24px;
  padding:16px;
  box-shadow:var(--shadow);
}
.sidebar-title{
  font-size:13px;
  font-weight:900;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:6px 10px 8px;
}
.dash-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 14px;
  border-radius:16px;
  color:#334155;
  font-weight:900;
  border:1px solid transparent;
  background:#fbfcff;
  transition:.18s ease;
}
.dash-link:hover{
  transform:translateX(3px);
  background:#f1f5f9;
}
.dash-link.active{
  color:#fff;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  border-color:rgba(255,255,255,.2);
  box-shadow:0 14px 28px rgba(22,163,74,.20);
}
.dashboard-content{min-width:0}
.dash-section{display:none;margin:0}
.dash-section.active{display:block;animation:dashFade .18s ease}
@keyframes dashFade{from{opacity:.45;transform:translateY(6px)}to{opacity:1;transform:none}}
.admin-subgrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:24px;
}
.subpanel-card{
  border:1px solid var(--border);
  background:#fbfcff;
  border-radius:20px;
  padding:16px;
}
.subpanel-card h3,.subsection-title h3{margin:0 0 8px;color:#1f2937}
.compact-list{max-height:360px;overflow:auto;padding-right:4px}
.subsection-title{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:14px;
  margin:20px 0 12px;
}
.subsection-title p{margin:0}
.subsection-title.separated{
  padding-top:20px;
  border-top:1px solid var(--border);
}
.user-dashboard .dashboard-sidebar{top:18px}
.admin-dashboard .dashboard-sidebar{top:18px}
@media(max-width:980px){
  .dashboard-layout{grid-template-columns:1fr;gap:16px}
  .dashboard-sidebar{
    position:relative;
    top:auto;
    display:flex;
    overflow-x:auto;
    gap:10px;
    padding:12px;
    border-radius:20px;
  }
  .sidebar-title{display:none}
  .dash-link{flex:0 0 auto;white-space:nowrap;min-width:190px;justify-content:center}
  .dash-link:hover{transform:translateY(-1px)}
  .admin-subgrid{grid-template-columns:1fr}
}
@media(max-width:620px){
  .dash-link{min-width:165px;padding:12px;font-size:13px}
  .subsection-title{display:block}
  .dashboard-sidebar{margin-left:-2px;margin-right:-2px}
}


/* ===== Acceso de solicitantes ===== */
.account-create-card{width:min(760px,100%)}
.account-create-card h1,.login-card h1{margin:4px 0 0}
.account-create-card .notice{margin:2px 0}
@media(max-width:620px){.topbar nav .btn{width:auto}.account-create-card{padding:20px}}

/* ===== Modal de iniciar sesión / registro de solicitante ===== */
.auth-modal{
  position:fixed;
  inset:0;
  z-index:90;
  display:none;
  place-items:center;
  background:rgba(15,23,42,.58);
  padding:18px;
}
.auth-modal.open{display:grid}
.auth-card{
  position:relative;
  width:min(620px,100%);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border:1px solid var(--border);
  border-radius:28px;
  padding:28px;
  box-shadow:0 30px 90px rgba(15,23,42,.34);
}
.auth-card h2{margin:14px 0 6px;font-size:30px}
.auth-tabs{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  background:#eef2f7;
  border-radius:16px;
  padding:6px;
  margin:18px 0;
}
.auth-tab{
  border:0;
  border-radius:12px;
  padding:12px 14px;
  font:inherit;
  font-weight:900;
  cursor:pointer;
  color:#334155;
  background:transparent;
}
.auth-tab.active{background:#fff;color:var(--primary);box-shadow:0 8px 20px rgba(15,23,42,.08)}
.auth-form{display:none;gap:14px}
.auth-form.active{display:grid}
.auth-register-grid{grid-template-columns:1fr 1fr}
.auth-register-grid label:nth-last-child(1){grid-column:1 / -1}
@media(max-width:620px){
  .auth-card{padding:22px;border-radius:22px}
  .auth-register-grid{grid-template-columns:1fr}
  .auth-register-grid label:nth-last-child(1){grid-column:auto}
}
