@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');
:root{--blue:#3446c7;--blue2:#6d43f5;--ink:#11182f;--muted:#66728a;--bg:#f6f8ff;--card:#fff;--line:#e5eaf5;--shadow:0 22px 55px rgba(17,24,47,.10);--r:24px;--green:#16a34a;--orange:#f97316;--red:#ef4444}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--ink)}img{max-width:100%;display:block}a{color:inherit}.btn,.admin-gradient-btn,.admin-mini-btn,.small-btn{border:0;cursor:pointer;text-decoration:none;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn{padding:13px 18px;border-radius:14px}.btn-primary,.admin-gradient-btn,.admin-mini-btn{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;box-shadow:0 14px 32px rgba(78,70,229,.25)}.btn-ghost{background:#fff;color:var(--blue);border:1px solid #cfd7f2}.btn-wide{width:100%;margin-top:12px}.alert{border-radius:16px;padding:12px 14px;margin:12px 0;font-weight:800}.alert-error{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}.success-alert{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0;width:min(1180px,calc(100% - 32px));margin:16px auto}
input,select,textarea{width:100%;border:1px solid #dfe6f3;border-radius:13px;padding:13px 14px;background:#fff;font:inherit;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--blue2);box-shadow:0 0 0 4px rgba(109,67,245,.09)}label{font-weight:800;font-size:.88rem}.eyebrow{display:inline-flex;align-items:center;gap:8px;background:#f1f4ff;border:1px solid #dde4ff;color:var(--blue);border-radius:999px;padding:8px 12px;font-size:.82rem;font-weight:900}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}.mini-stats span{border:1px solid var(--line);background:#f8faff;border-radius:16px;padding:10px;font-size:.72rem;font-weight:800;color:var(--muted)}.mini-stats b{display:block;color:var(--blue);font-size:1.1rem}
/* public */
.public-app-body{overflow-x:hidden}.public-shell{min-height:100vh}.public-sidebar{display:none}.public-main{min-width:0}.public-topbar{position:sticky;top:0;z-index:20;height:76px;background:rgba(255,255,255,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(229,234,245,.8);display:flex;align-items:center;justify-content:space-between;padding:0 18px}.mobile-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--blue);font-weight:900}.mobile-brand img{width:46px;height:46px;object-fit:contain}.public-top-actions{display:flex;gap:8px;overflow:auto}.public-top-actions a{white-space:nowrap;text-decoration:none;color:#33415f;font-weight:800;font-size:.88rem;padding:10px 12px;border-radius:999px}.public-top-actions .top-cta{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;box-shadow:0 12px 28px rgba(78,70,229,.22)}.public-welcome-card{width:min(1240px,calc(100% - 28px));margin:24px auto;background:linear-gradient(135deg,#fff,#f8faff);border:1px solid #fff;border-radius:30px;box-shadow:var(--shadow);padding:24px;display:grid;gap:22px;align-items:center;position:relative;overflow:hidden}.public-welcome-card:before{content:"";position:absolute;right:-110px;top:-110px;width:330px;height:330px;background:rgba(109,67,245,.09);border-radius:999px}.public-welcome-card h1{font-size:clamp(2.3rem,8vw,5rem);line-height:.98;margin:16px 0;letter-spacing:-.075em}.public-welcome-card h1 span{color:var(--blue2)}.public-welcome-card p{color:var(--muted);line-height:1.7;font-weight:600;max-width:690px}.public-hero-copy,.public-logo-panel{position:relative;z-index:1}.public-logo-panel{background:#fff;border:1px solid var(--line);border-radius:28px;padding:18px;text-align:center;box-shadow:0 18px 45px rgba(17,24,47,.08)}.public-logo-panel img{width:min(340px,76vw);margin:auto;filter:drop-shadow(0 20px 38px rgba(52,70,199,.15))}.public-section-card{width:min(1240px,calc(100% - 28px));margin:22px auto;background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:20px}.public-section-card h2{font-size:clamp(1.55rem,5vw,2.4rem);letter-spacing:-.045em;margin:0 0 6px}.public-section-card p{color:var(--muted);line-height:1.6}.table-header,.public-section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}.public-method-grid{display:grid;grid-template-columns:1fr;gap:14px}.donation-card,.public-method-card{appearance:none;border:1px solid var(--line);background:#fff;border-radius:22px;padding:20px;text-align:left;box-shadow:0 14px 32px rgba(17,24,47,.06);transition:.18s;cursor:pointer}.donation-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#cdd5f3}.card-icon{width:54px;height:54px;border-radius:19px;background:#f0edff;display:grid;place-items:center;font-size:1.6rem;margin-bottom:14px}.donation-card strong{display:block}.donation-card small{display:block;color:var(--muted);line-height:1.5;margin-top:7px}.donation-card em{display:inline-flex;margin-top:14px;font-style:normal;color:var(--blue2);font-weight:900}.verify-card{display:grid;gap:20px;align-items:center}.verify-box,.form-shell,.public-form-shell{background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px}.inline-form{display:grid;gap:10px}.status-result{margin-top:14px;border-radius:18px;padding:14px;display:grid;gap:7px}.status-result.ok{background:#ecfdf5;color:#065f46;border:1px solid #bbf7d0}.status-result.wait{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.status-result.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.form-grid{display:grid;gap:14px}.field label{display:block;margin-bottom:8px}.field label span{color:var(--red)}.field.full{grid-column:1/-1}.checks{display:grid;gap:10px;margin-top:14px}.checks label{display:flex;gap:10px;align-items:center;background:#f8faff;border:1px solid var(--line);border-radius:16px;padding:12px}.checks input{width:auto}.checks i{width:20px;height:20px;border-radius:999px;background:#eef0ff;color:var(--blue);display:grid;place-items:center;font-style:normal;position:relative}.checks i:hover:after{content:attr(data-tip);position:absolute;bottom:145%;left:50%;transform:translateX(-50%);width:260px;max-width:78vw;background:#111827;color:#fff;padding:10px;border-radius:12px;font-size:.78rem;line-height:1.4;z-index:10}.admin-footer{text-align:center;color:#7a849a;font-weight:700;font-size:.9rem;padding:28px 14px}.modal{position:fixed;inset:0;background:rgba(15,23,42,.62);z-index:100;display:none;place-items:center;padding:16px}.modal[aria-hidden="false"]{display:grid}.modal-open{overflow:hidden}.modal-panel{width:min(860px,100%);max-height:92vh;overflow:auto;background:#fff;border-radius:28px;padding:22px;box-shadow:0 35px 90px rgba(15,23,42,.28);position:relative}.modal-close{position:absolute;right:14px;top:14px;width:42px;height:42px;border:0;border-radius:999px;background:#f1f5f9;font-size:1.5rem}.modal-head{display:flex;gap:12px;align-items:center}.modal-head span{width:50px;height:50px;border-radius:17px;background:#f0edff;display:grid;place-items:center}.modal-head h2{margin:0}.modal-content{display:grid;gap:18px}.modal-content img{width:260px;max-width:100%;margin:auto;border-radius:18px;border:1px solid var(--line)}.detail-list{display:grid;gap:10px;margin:14px 0}.detail-list div{background:#f8faff;border:1px solid var(--line);border-radius:14px;padding:10px}.detail-list b{display:block;color:var(--muted);font-size:.78rem}.detail-list span{font-weight:900;word-break:break-word}
/* login */
.admin-login-body{min-height:100vh;background:#f6f8ff}.admin-login-page{min-height:100vh;display:grid;grid-template-columns:1fr}.login-visual,.login-form-zone{position:relative;display:grid;place-items:center;padding:36px 20px}.login-visual{background:radial-gradient(circle at 10% 20%,rgba(109,67,245,.10),transparent 32%),#fff}.login-logo-wrap{text-align:center;max-width:460px}.login-main-logo{width:min(230px,58vw);margin:auto;filter:drop-shadow(0 20px 38px rgba(52,70,199,.15))}.login-logo-wrap h1{color:#39539e;letter-spacing:-.06em;line-height:.95;font-size:clamp(2rem,7vw,3.3rem);margin:8px 0}.login-logo-wrap p{font-weight:900;font-size:1.15rem}.login-logo-wrap span{color:var(--muted);line-height:1.6}.login-form-zone{background:linear-gradient(145deg,#fff,#f3f6ff)}.admin-login-card{width:min(520px,100%);background:#fff;border:1px solid var(--line);border-radius:30px;padding:26px;box-shadow:var(--shadow)}.admin-login-card h2{font-size:clamp(1.6rem,5vw,2.3rem);letter-spacing:-.05em;text-align:center;margin:10px 0}.admin-login-card p{text-align:center;color:var(--muted)}.lock-badge{width:64px;height:64px;border-radius:24px;background:#f0edff;display:grid;place-items:center;margin:auto;font-size:1.6rem}.admin-field{margin:16px 0}.admin-field label{display:block;margin-bottom:8px}.input-icon{display:flex;align-items:center;gap:10px;border:1px solid #dfe6f3;border-radius:14px;padding:0 12px;background:#fff}.input-icon input{border:0;box-shadow:none;padding-left:0}.login-options{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-weight:700;margin:12px 0}.login-options input{width:auto}.admin-gradient-btn{width:100%;min-height:52px;border-radius:16px}.copyright,.login-footer-note{text-align:center;color:#7a849a;font-weight:700;font-size:.9rem}.orb{position:absolute;border-radius:999px;background:rgba(109,67,245,.15);filter:blur(.1px)}.orb-one{width:260px;height:260px;right:-120px;top:20%}.orb-two{width:180px;height:180px;left:-80px;bottom:8%}
/* admin dashboard */
.admin-dashboard-body{background:#f6f8ff;min-height:100vh}.dashboard-shell{min-height:100vh;display:grid;grid-template-columns:1fr}.admin-sidebar{display:none;background:#fff;border-right:1px solid var(--line);padding:22px 18px;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#22306f;font-weight:900;margin-bottom:28px}.sidebar-brand img{width:66px;height:66px;object-fit:contain}.sidebar-nav{display:grid;gap:12px}.sidebar-nav a{display:flex;align-items:center;gap:12px;text-decoration:none;padding:14px;border-radius:14px;color:#52617d;font-weight:800}.sidebar-nav a.active,.sidebar-nav a:hover{background:#f0f3ff;color:var(--blue)}.logout-link{position:absolute;bottom:28px;left:18px;right:18px;text-decoration:none;color:#ef4444;font-weight:900;padding:14px}.admin-main{min-width:0}.admin-topbar{height:78px;background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 18px;box-shadow:0 14px 35px rgba(52,70,199,.18)}.admin-topbar>div:first-child{display:flex;align-items:center;gap:18px}.menu-dot{background:transparent;color:#fff;border:0;font-size:1.3rem}.admin-profile{display:flex;align-items:center;gap:10px}.admin-profile>span{width:44px;height:44px;border-radius:999px;background:#fff;color:var(--blue);display:grid;place-items:center;font-weight:900}.admin-profile small{display:block;color:#e5e7ff}.welcome-card,.recent-donations-card{width:min(1180px,calc(100% - 28px));margin:26px auto;background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:24px}.welcome-card{display:flex;justify-content:space-between;gap:20px;align-items:center;overflow:hidden}.welcome-card h1{font-size:clamp(1.8rem,5vw,3rem);letter-spacing:-.055em;margin:0 0 12px}.welcome-card p{color:var(--muted);line-height:1.6;font-weight:600}.welcome-illustration{font-size:5rem}.admin-stats-grid{width:min(1180px,calc(100% - 28px));margin:0 auto 26px;display:grid;grid-template-columns:1fr;gap:16px}.stat-card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:0 16px 38px rgba(17,24,47,.07);padding:22px;min-height:154px;position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;left:22px;right:22px;bottom:18px;height:3px;border-radius:999px;background:#e5e7eb}.stat-card.purple:after{background:#7c3aed}.stat-card.green:after{background:#22c55e}.stat-card.blue:after{background:#3b82f6}.stat-card.orange:after{background:#f97316}.stat-icon{width:56px;height:56px;border-radius:22px;display:grid;place-items:center;font-size:1.45rem;margin-bottom:14px}.purple .stat-icon{background:#eee7ff}.green .stat-icon{background:#dcfce7}.blue .stat-icon{background:#dbeafe}.orange .stat-icon{background:#ffedd5}.stat-card strong{font-size:2rem}.stat-card span{display:block;font-weight:900}.stat-card small{color:var(--muted);font-weight:700}.admin-mini-btn{padding:12px 18px;border-radius:14px;width:auto}.modern-table-wrap{overflow:auto;border:1px solid #edf1f7;border-radius:18px}.modern-admin-table{width:100%;min-width:1040px;border-collapse:separate;border-spacing:0;background:#fff}.modern-admin-table th,.modern-admin-table td{padding:15px 14px;text-align:left;border-bottom:1px solid #eef2f7;vertical-align:middle}.modern-admin-table th{background:#f7f9fd;color:#5f6b82;text-transform:uppercase;font-size:.76rem;letter-spacing:.04em}.modern-badge{display:inline-flex;padding:7px 11px;border-radius:999px;font-weight:900;font-size:.78rem}.modern-badge.pendiente{background:#fff7ed;color:#f97316;border:1px solid #fed7aa}.modern-badge.recibido{background:#ecfdf5;color:#16a34a;border:1px solid #bbf7d0}.view-link{display:inline-flex;text-decoration:none;background:#f8faff;border:1px solid #e3e9ff;border-radius:12px;padding:9px 12px;font-weight:900;color:#3347d2}.modern-actions{display:grid;gap:9px}.modern-actions form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.small-btn{height:42px;border-radius:12px;padding:0 13px}.small-primary{background:var(--blue);color:#fff}.small-success{background:#16a34a;color:#fff}.small-disabled{background:#e5e7eb!important;color:#6b7280!important}.notified-note{display:inline-flex;border-radius:999px;background:#ecfdf5;color:#047857;border:1px solid #bbf7d0;padding:8px 10px;font-weight:900;font-size:.78rem}button:disabled{opacity:.55;cursor:not-allowed}.empty-state{text-align:center;color:var(--muted);font-weight:800;padding:30px!important}
@media(min-width:680px){.public-method-grid{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:repeat(2,1fr)}.inline-form{grid-template-columns:1fr auto}.verify-box,.form-shell{padding:24px}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.public-welcome-card{grid-template-columns:1fr .72fr;padding:44px}.verify-card{grid-template-columns:.8fr 1.2fr}.modal-content{grid-template-columns:1fr 280px}.admin-login-page{grid-template-columns:.85fr 1.15fr}.login-visual,.login-form-zone{min-height:100vh}.admin-sidebar{display:block}.dashboard-shell{grid-template-columns:280px 1fr}.admin-stats-grid{grid-template-columns:repeat(4,1fr)}.welcome-card,.recent-donations-card,.admin-stats-grid{width:min(1180px,calc(100% - 56px))}.admin-topbar{padding:0 38px}}
@media(min-width:1120px){.public-method-grid{grid-template-columns:repeat(5,1fr)}}
@media(max-width:560px){.public-topbar{height:auto;align-items:flex-start;flex-direction:column;padding:14px}.public-top-actions{width:100%;padding-bottom:4px}.hero-actions .btn{width:100%}.table-header{align-items:flex-start;flex-direction:column}.admin-mini-btn{width:100%}.welcome-card{align-items:flex-start;flex-direction:column}.welcome-illustration{font-size:3.5rem}.recent-donations-card{padding:14px}.login-options{flex-direction:column}.modern-admin-table th,.modern-admin-table td{padding:12px 10px}}

/* === Ajustes finales de consistencia visual y usabilidad === */
.sidebar-brand{justify-content:center;text-align:center;gap:12px}.sidebar-brand img{margin:0 auto}.admin-sidebar .sidebar-brand span{font-size:1.15rem}.admin-page-card h1{font-size:clamp(2rem,5vw,3.2rem);letter-spacing:-.06em;margin:0}.admin-page-card{margin-top:28px}.admin-filterbar{display:grid;grid-template-columns:1fr;gap:12px;margin:18px 0 12px}.admin-count{color:var(--muted);font-weight:800}.in-card{width:100%;margin:12px 0}.compact-admin-table td{font-size:.96rem}.compact-admin-table td small,.date-cell small{display:block;color:#46536c;line-height:1.55}.token-text{word-break:break-word;display:block;max-width:180px}.date-cell{min-width:210px}.modern-actions .status-select{min-width:150px}.admin-status-card{display:grid;gap:8px;border-radius:22px;padding:18px 20px;margin-top:16px;border:1px solid var(--line);background:#f8faff}.admin-status-card b{font-size:1.25rem}.admin-status-card.recibido{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}.admin-status-card.pendiente{background:#fffbeb;border-color:#fde68a;color:#92400e}.admin-verify-panel{scroll-margin-top:90px}.upload-preview{margin-top:12px}.preview-box{display:flex;align-items:center;gap:14px;border:1px dashed #cbd5f5;background:#f8faff;border-radius:18px;padding:12px}.preview-box img{width:92px;height:72px;object-fit:cover;border-radius:14px;border:1px solid var(--line);box-shadow:0 8px 20px rgba(17,24,47,.08)}.preview-box strong{display:block;word-break:break-word}.preview-box small{display:block;color:var(--muted);font-weight:800;margin-top:4px}.pdf-preview{width:92px;height:72px;border-radius:14px;background:linear-gradient(135deg,#ef4444,#fb7185);color:#fff;display:grid;place-items:center;font-weight:900;letter-spacing:.06em}.public-logo-panel{text-align:center}.public-logo-panel img,.login-main-logo{margin-left:auto!important;margin-right:auto!important}.success-card img,.receipt-card img{margin-left:auto!important;margin-right:auto!important}
@media(min-width:760px){.admin-filterbar{grid-template-columns:1fr 220px auto}}
@media(max-width:980px){.modern-admin-table{min-width:900px}.dashboard-shell{display:block}.admin-sidebar{position:relative;width:100%;height:auto;border-right:0;border-bottom:1px solid var(--line)}.sidebar-nav{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.logout-link{position:relative;margin-top:16px}.admin-topbar{position:sticky;top:0;z-index:30}.admin-main{min-height:auto}}
