/* ═══════════════════════════════════════════════
   PARÓQUIA SJB — Admin CSS
   ═══════════════════════════════════════════════ */
:root {
  --gold:    #C4A45F;
  --dark:    #23140c;
  --brown:   #754D25;
  --cream:   #fcfbf9;
  --slate:   #64748b;
  --muted:   #94a3b8;
  --border:  #e2e8f0;
  --white:   #ffffff;
  --font-body:  'Inter', system-ui, sans-serif;
  --font-serif: 'Merriweather', Georgia, serif;
  --sidebar-w: 240px;
  --topbar-h:  60px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:#f8fafc;color:#1e293b}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── Layout ─────────────────────────────────── */
.admin-body{display:flex;min-height:100vh}

/* ── Sidebar ────────────────────────────────── */
.admin-sidebar{
  width:var(--sidebar-w);background:var(--dark);color:#fff;
  display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;
  transition:transform .3s;
}
.admin-sidebar__logo{
  display:flex;align-items:center;gap:.75rem;
  padding:1.5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.07);
}
.admin-sidebar__logo-img{height:2.5rem;filter:brightness(0) invert(1);object-fit:contain}
.admin-sidebar__logo-text{font-weight:900;font-size:1rem;color:#fff}
.admin-sidebar__label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--gold)}

.admin-nav{flex:1;padding:1rem 0;overflow-y:auto}
.admin-nav__item{
  display:flex;align-items:center;gap:.75rem;
  padding:.7rem 1.25rem;font-size:.8rem;font-weight:600;
  color:rgba(255,255,255,.6);transition:background .15s,color .15s;
  border-left:3px solid transparent;
}
.admin-nav__item:hover{background:rgba(255,255,255,.06);color:#fff}
.admin-nav__item--active{background:rgba(196,164,95,.12);color:var(--gold);border-left-color:var(--gold)}
.admin-nav__icon{font-size:1rem;width:1.5rem;text-align:center}

.admin-sidebar__footer{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:.5rem}
.admin-sidebar__site-link,.admin-sidebar__logout{
  font-size:.78rem;font-weight:600;padding:.5rem .75rem;border-radius:.5rem;
  display:flex;align-items:center;gap:.5rem;transition:background .15s;
}
.admin-sidebar__site-link{color:rgba(255,255,255,.5)} 
.admin-sidebar__site-link:hover{background:rgba(255,255,255,.07);color:#fff}
.admin-sidebar__logout{color:#fca5a5}
.admin-sidebar__logout:hover{background:rgba(252,165,165,.1)}

/* ── Main ───────────────────────────────────── */
.admin-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── Topbar ─────────────────────────────────── */
.admin-topbar{
  height:var(--topbar-h);background:#fff;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:1rem;padding:0 1.5rem;
  position:sticky;top:0;z-index:40;
}
.admin-topbar__menu{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer}
.admin-topbar__title{font-size:1rem;font-weight:800;flex:1}
.admin-topbar__user{font-size:.8rem;color:var(--slate)}

/* ── Content ────────────────────────────────── */
.admin-content{padding:1.75rem;flex:1}

/* ── Dashboard card ─────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{
  background:#fff;border-radius:1rem;border:1px solid var(--border);
  padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;
  transition:box-shadow .2s,transform .2s;
}
.stat-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.07);transform:translateY(-2px)}
.stat-card__icon{
  width:2.5rem;height:2.5rem;border-radius:.75rem;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.stat-card__val{font-size:1.75rem;font-weight:900;line-height:1}
.stat-card__label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}

/* ── Welcome banner ─────────────────────────── */
.welcome-banner{
  background:var(--dark);border-radius:1.25rem;padding:1.75rem 2rem;
  margin-bottom:1.75rem;display:flex;align-items:center;justify-content:space-between;
  background-image:radial-gradient(ellipse at top right, rgba(196,164,95,.18), transparent 55%);
}
.welcome-banner__title{font-size:1.5rem;font-weight:800;color:#fff}
.welcome-banner__date{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.welcome-banner__sub{font-size:.85rem;color:rgba(255,255,255,.4)}
.welcome-banner__link{
  display:flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.1);color:#fff;padding:.6rem 1.2rem;border-radius:.75rem;
  font-size:.78rem;font-weight:700;border:1px solid rgba(255,255,255,.1);transition:background .2s;
  white-space:nowrap;
}
.welcome-banner__link:hover{background:rgba(196,164,95,.2)}

/* ── Admin card ─────────────────────────────── */
.admin-card{
  background:#fff;border-radius:1rem;border:1px solid var(--border);
  padding:1.5rem;margin-bottom:1.5rem;
}
.admin-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.admin-card__title{font-size:.95rem;font-weight:800}

/* ── Tables ─────────────────────────────────── */
.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}
.admin-table th{text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:.75rem 1rem;border-bottom:2px solid var(--border)}
.admin-table td{padding:.9rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:0}
.admin-table tr:hover td{background:#f8fafc}

/* ── Forms ──────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-size:.78rem;font-weight:700;color:var(--dark)}
.form-input,.form-select,.form-textarea{
  padding:.65rem 1rem;border:1px solid var(--border);border-radius:.75rem;
  font-size:.88rem;outline:none;transition:border-color .2s;font-family:inherit;
  background:#fff;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold)}
.form-textarea{resize:vertical;min-height:120px}
.form-hint{font-size:.72rem;color:var(--muted)}
.form-check{display:flex;align-items:center;gap:.5rem;font-size:.88rem;cursor:pointer}
.form-check input{width:1rem;height:1rem;accent-color:var(--gold)}

/* ── Buttons (admin) ─────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.6rem 1.2rem;border-radius:.75rem;font-weight:700;
  font-size:.82rem;cursor:pointer;border:none;transition:.15s;
}
.btn-gold{background:var(--gold);color:var(--dark)}
.btn-dark{background:var(--dark);color:#fff}
.btn-red{background:#fee2e2;color:#dc2626}
.btn-gray{background:#f1f5f9;color:var(--slate)}
.btn:hover{filter:brightness(.93)}
.btn-sm{padding:.4rem .9rem;font-size:.78rem}

/* ── Status badges ───────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:.2rem .7rem;border-radius:2rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}
.badge-green{background:#dcfce7;color:#16a34a}
.badge-gray{background:#f1f5f9;color:var(--slate)}
.badge-amber{background:#fef3c7;color:#d97706}

/* ── Flash messages ──────────────────────────── */
.flash{padding:.9rem 1.25rem;border-radius:.75rem;margin-bottom:1.25rem;font-size:.88rem;font-weight:600}
.flash-success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}
.flash-error{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}

/* ── Image preview ───────────────────────────── */
.img-preview{max-width:200px;max-height:150px;object-fit:cover;border-radius:.75rem;border:2px solid var(--border);margin-top:.5rem}

/* ── Pagination ──────────────────────────────── */
.pagination{display:flex;gap:.4rem;margin-top:1.5rem;flex-wrap:wrap}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;border-radius:.5rem;font-size:.82rem;font-weight:600;border:1px solid var(--border);transition:.2s}
.pagination a:hover{border-color:var(--gold);color:var(--gold)}
.pagination .active{background:var(--gold);color:var(--dark);border-color:var(--gold)}

/* ── Shortcuts ────────────────────────────────── */
.shortcut-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}
.shortcut{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  padding:.75rem;border-radius:.75rem;border:1px solid var(--border);
  font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--slate);
  transition:.2s;text-align:center;
}
.shortcut:hover{border-color:var(--gold);color:var(--dark);background:#fffbf4}
.shortcut__icon{font-size:1.5rem}

/* ── Responsive ──────────────────────────────── */
@media(max-width:768px){
  .admin-sidebar{transform:translateX(-100%)}
  .admin-sidebar.open{transform:translateX(0)}
  .admin-main{margin-left:0}
  .admin-topbar__menu{display:block}
  .form-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .welcome-banner{flex-direction:column;gap:1rem}
}
