/* ============================================================
   AutoRegist v2 · Municipio de Arteaga
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700&family=Outfit:wght@300;400;500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#07080F; --s1:#0D0F1E; --s2:#141628;
  --gold:#C9A44C; --gold2:#E4CE82; --gdim:rgba(201,164,76,0.14); --gborder:rgba(201,164,76,0.28);
  --border:rgba(255,255,255,0.06); --border2:rgba(255,255,255,0.1);
  --text:#EEEAE2; --text2:#888070; --text3:#44423C;
  --red:#E05252; --green:#4CAF7A;
  --r:10px; --r2:16px; --tr:0.22s cubic-bezier(0.4,0,0.2,1);
}
html{scroll-behavior:smooth}
body{background:var(--bg);font-family:'Outfit',sans-serif;color:var(--text);min-height:100vh}
.vdb{min-height:100vh;display:flex;flex-direction:column}

/* ─── SITE HEADER (logo) ──────────────────────────────── */
.site-header{
  background:linear-gradient(135deg,#06080E 0%,#0B0F20 50%,#06080E 100%);
  border-bottom:1px solid var(--gborder);
  position:relative; flex-shrink:0;
}
.site-header__inner{
  max-width:1160px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 2rem; height:160px; gap:1.5rem;
}
.site-header--compact .site-header__inner{height:120px}

.site-header__logo{flex-shrink:0; display:flex; align-items:center}
.logo-img{max-height:120px; max-width:220px; width:auto; object-fit:contain; display:block}
.site-header--compact .logo-img{max-height:64px; max-width:140px}
.logo-fallback{
  width:100px; height:100px; border-radius:50%;
  background:var(--gdim); border:1.5px solid var(--gborder);
  display:flex; align-items:center; justify-content:center; font-size:42px;
}
.site-header--compact .logo-fallback{width:60px;height:60px;font-size:26px}

.site-header__center{flex:1; text-align:center}
.site-header__eyebrow{font-size:12px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:var(--gold);opacity:.85;margin-bottom:6px}
.site-header__name{
  font-family:'Barlow Condensed',sans-serif;
  font-size:46px; font-weight:700; letter-spacing:5px; text-transform:uppercase;
  color:var(--text); line-height:1;
}
.site-header__name--sm{font-size:22px; letter-spacing:3px}
.site-header__sub{font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--text2);margin-top:8px}

.site-header__right{flex-shrink:0; width:160px; display:flex; justify-content:flex-end}
.site-header__badge{
  border:1px solid var(--gborder); border-radius:8px;
  padding:.5rem .9rem; text-align:center;
  background:var(--gdim);
}
.shb-line{display:block;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text2)}
.shb-year{display:block;font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;color:var(--gold);line-height:1}
.site-header__credit{
  position:absolute; bottom:8px; right:1.5rem;
  font-size:10px; color:rgba(255,255,255,0.22); letter-spacing:1px;
}
/* Gold line bottom of header */
.site-header::after{
  content:''; display:block;
  height:2px; background:linear-gradient(to right, transparent, var(--gold), transparent);
  opacity:.5;
}

/* ─── NAVBAR ──────────────────────────────────────────── */
.nav{
  position:sticky; top:0; z-index:100; height:56px; padding:0 2rem;
  background:rgba(7,8,15,0.94); backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.nav-brand{
  font-family:'Barlow Condensed',sans-serif; font-size:20px; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  text-decoration:none; color:var(--text); display:flex; align-items:center; gap:8px; user-select:none;
}
.nav-brand em{color:var(--gold);font-style:normal}
.nav-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold);flex-shrink:0}
.nav-center{flex:1;display:flex;align-items:center;padding-left:.5rem}
.nav-crumb{font-size:13px;color:var(--text3)}
.nav-actions{display:flex;align-items:center;gap:8px}

/* ─── USER MENU ───────────────────────────────────────── */
.user-menu{position:relative}
.user-trigger{
  display:flex;align-items:center;gap:8px;
  background:transparent;border:1px solid var(--border);border-radius:var(--r);
  padding:5px 10px;cursor:pointer;transition:var(--tr);color:var(--text);
  font-family:'Outfit',sans-serif;font-size:13px;
}
.user-trigger:hover{border-color:var(--gborder);background:var(--gdim)}
.user-avt{
  width:26px;height:26px;border-radius:50%;background:var(--gold);
  color:#07080F;display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;flex-shrink:0;
}
.user-name{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role-badge{
  font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:2px 7px;border-radius:4px;
}
.role-admin{background:rgba(201,164,76,.2);color:var(--gold);border:1px solid var(--gborder)}
.role-op{background:rgba(255,255,255,.06);color:var(--text2);border:1px solid var(--border)}
.user-chevron{font-size:10px;color:var(--text3);transition:var(--tr)}
.user-menu.open .user-chevron{transform:rotate(180deg)}
.user-dropdown{
  position:absolute;right:0;top:calc(100% + 6px);
  background:var(--s1);border:1px solid var(--border2);border-radius:var(--r2);
  min-width:200px;box-shadow:0 16px 40px rgba(0,0,0,.6);
  display:none;z-index:200;overflow:hidden;
}
.user-menu.open .user-dropdown{display:block}
.user-dd-item{
  display:flex;align-items:center;gap:10px;
  padding:.65rem 1rem;font-size:13px;font-weight:500;
  color:var(--text2);text-decoration:none;transition:var(--tr);
}
.user-dd-item:hover{background:var(--gdim);color:var(--text)}
.user-dd-item--danger:hover{background:rgba(224,80,80,.08);color:var(--red)}
.user-dd-sep{height:1px;background:var(--border);margin:.25rem 0}

/* ─── BOTONES ─────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:8px 20px;border-radius:var(--r);
  font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;
  cursor:pointer;transition:var(--tr);border:none;white-space:nowrap;text-decoration:none;line-height:1;
}
.btn-sm{padding:6px 14px;font-size:13px}
.btn-xs{padding:4px 10px;font-size:12px}
.btn:disabled{opacity:.5;pointer-events:none}
.btn-gold{background:var(--gold);color:#07080F;font-weight:600}
.btn-gold:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(201,164,76,.35)}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text2)}
.btn-ghost:hover{border-color:var(--gborder);color:var(--text)}
.btn-danger{background:transparent;border:1px solid rgba(224,80,80,.3);color:var(--red)}
.btn-danger:hover{background:rgba(224,80,80,.09)}
.btn-outline{background:transparent;border:1px solid var(--gborder);color:var(--gold)}
.btn-outline:hover{background:var(--gdim)}

/* ─── PAGE ────────────────────────────────────────────── */
.page{max-width:1160px;margin:0 auto;padding:2.5rem 2rem;flex:1}
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}
.pt{font-family:'Barlow Condensed',sans-serif;font-size:32px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase}
.pt em{color:var(--gold);font-style:normal}
.ps{font-size:13px;color:var(--text2);margin-top:3px}

/* ─── ALERTAS ─────────────────────────────────────────── */
.alert-error{background:rgba(224,80,80,.08);border:1px solid rgba(224,80,80,.3);border-radius:var(--r);padding:1rem 1.25rem;color:var(--red);font-size:14px;margin-bottom:1.5rem}
.alert-success{background:rgba(76,175,122,.08);border:1px solid rgba(76,175,122,.3);border-radius:var(--r);padding:.75rem 1.25rem;color:var(--green);font-size:14px;margin-bottom:1.5rem}

/* ─── BUSCADOR ────────────────────────────────────────── */
.sbar{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);padding:1rem 1.25rem;margin-bottom:1.5rem;display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}
.sbar input,.sbar select{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;padding:9px 13px;outline:none;transition:var(--tr);-webkit-appearance:none;appearance:none}
.sbar input{flex:1;min-width:180px}
.sbar select{min-width:115px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%23888070' d='M5 7L0 2h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.sbar input:focus,.sbar select:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gdim)}
.sbar input::placeholder{color:var(--text3)}
.sfield{display:flex;flex-direction:column;gap:5px}
.sflex{flex:1;min-width:200px}
.sfield>label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3)}

/* ─── GRID ────────────────────────────────────────────── */
.vgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem}
.vcard{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:var(--tr);text-decoration:none;color:inherit;display:block}
.vcard:hover{border-color:var(--gborder);transform:translateY(-4px);box-shadow:0 20px 48px rgba(0,0,0,.55),0 0 0 1px var(--gborder)}
.vthumb{width:100%;height:175px;background:var(--s2);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:44px;overflow:hidden}
.vthumb img{width:100%;height:100%;object-fit:cover;display:block}
.vcbody{padding:1.1rem 1.25rem}
.vplate{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;background:var(--gdim);border:1px solid var(--gborder);color:var(--gold);border-radius:6px;padding:3px 10px;display:inline-block;margin-bottom:9px}
.vcname{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;line-height:1.05}
.vctype{font-size:13px;color:var(--text2);margin:3px 0 8px}
.vcmotivo{font-size:12px;color:var(--text3);line-height:1.5;margin-bottom:8px;font-style:italic;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.vcowner{display:flex;align-items:center;gap:9px;padding-top:11px;border-top:1px solid var(--border)}
.avt{width:32px;height:32px;border-radius:50%;background:var(--gdim);border:1px solid var(--gborder);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;color:var(--gold);flex-shrink:0}
.oname{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.odate{font-size:12px;color:var(--text3)}
.empty{text-align:center;padding:4rem 2rem;grid-column:1/-1}
.empty-icon{font-size:60px;margin-bottom:1.25rem;opacity:.25}
.empty-t{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text2);margin-bottom:6px}
.empty-s{font-size:14px;color:var(--text3);margin-bottom:1.5rem}

/* ─── FORM ────────────────────────────────────────────── */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fsec{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);padding:1.5rem;margin-bottom:1rem}
.fst{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;display:flex;align-items:center;gap:10px}
.fst::after{content:'';flex:1;height:1px;background:var(--gborder);opacity:.5}
.field{display:flex;flex-direction:column;gap:6px}
.field.span2{grid-column:1/-1}
label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text2)}
input,select,textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;padding:10px 14px;transition:var(--tr);outline:none;width:100%;-webkit-appearance:none;appearance:none}
input::placeholder,textarea::placeholder{color:var(--text3)}
input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gdim)}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888070' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}
select option{background:#0D0F1E}

/* ─── FOTO UPLOAD ─────────────────────────────────────── */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}
.pslot{aspect-ratio:4/3;border:1.5px dashed var(--gborder);border-radius:var(--r);background:var(--bg);cursor:pointer;position:relative;overflow:hidden;transition:var(--tr);display:flex;align-items:center;justify-content:center}
.pslot:hover{border-color:var(--gold);background:var(--gdim)}
.pslot-empty{display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--text3);pointer-events:none;transition:var(--tr)}
.pslot:hover .pslot-empty{color:var(--gold)}
.pslot-preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pov{position:absolute;inset:0;background:rgba(7,8,15,.72);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--tr);font-size:13px;font-weight:600;color:white}
.pslot:hover .pov{opacity:1}
.plabel{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;text-align:center;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;background:rgba(7,8,15,.78);color:var(--gold)}
.picon{font-size:22px}.ptxt{font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}

/* ─── DETALLE HÉROE ───────────────────────────────────── */
.dhero{width:100%;aspect-ratio:16/7;position:relative;border-radius:var(--r2);overflow:hidden;margin-bottom:1rem;background:var(--s2);display:flex;align-items:center;justify-content:center}
.dhero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.doverlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,8,15,.92) 0%,transparent 55%);pointer-events:none}
.dhinfo{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;z-index:1}
.dhero-title{font-family:'Barlow Condensed',sans-serif;font-size:44px;font-weight:700;text-transform:uppercase;letter-spacing:1px;line-height:1;color:white;text-shadow:0 3px 24px rgba(0,0,0,.9);margin-top:8px}
.dhero-sub{color:rgba(255,255,255,.6);font-size:16px;margin-top:5px}
.thumbrow{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
.thumb{width:72px;height:52px;border-radius:8px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:var(--tr);position:relative}
.thumb.act{border-color:var(--gold);box-shadow:0 0 12px rgba(201,164,76,.5)}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.7);font-size:9px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--gold);text-align:center;padding:2px 4px;opacity:0;transition:var(--tr)}
.thumb:hover .thumb-label{opacity:1}
.hero-zoom-btn{
  position:absolute;top:12px;right:12px;z-index:2;
  background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.2);border-radius:8px;
  color:white;font-size:18px;width:36px;height:36px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:var(--tr);backdrop-filter:blur(4px);
}
.hero-zoom-btn:hover{background:var(--gold);border-color:var(--gold);color:#07080F}

/* ─── STRIP DE FOTOS ──────────────────────────────────── */
.photos-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.2rem}
.photo-strip-item{
  aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--border);cursor:zoom-in;
  position:relative;transition:var(--tr);background:var(--s2);
}
.photo-strip-item:hover{border-color:var(--gborder);transform:scale(1.02)}
.photo-strip-item img{width:100%;height:100%;object-fit:cover;display:block}
.photo-strip-label{position:absolute;bottom:0;left:0;right:0;padding:4px 8px;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;background:rgba(7,8,15,.8);color:var(--gold)}
.photo-strip-zoom{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.6);color:white;font-size:14px;width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--tr)}
.photo-strip-item:hover .photo-strip-zoom{opacity:1}

/* ─── LIGHTBOX ────────────────────────────────────────── */
.lb-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.95);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
}
.lb-overlay.open{display:flex}
.lb-body{
  position:relative;max-width:92vw;max-height:90vh;
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
}
.lb-img{
  max-width:92vw;max-height:80vh;
  object-fit:contain;border-radius:var(--r);
  box-shadow:0 24px 64px rgba(0,0,0,.8);
  transition:opacity .2s;
}
.lb-caption{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
.lb-close{
  position:fixed;top:20px;right:24px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:white;font-size:24px;width:42px;height:42px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:var(--tr);z-index:1;
}
.lb-close:hover{background:var(--red);border-color:var(--red)}
.lb-prev,.lb-next{
  position:fixed;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:white;font-size:28px;width:48px;height:48px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:var(--tr);z-index:1;
}
.lb-prev:hover,.lb-next:hover{background:rgba(201,164,76,.3);border-color:var(--gold)}
.lb-prev{left:20px}
.lb-next{right:20px}

/* ─── DETALLE LAYOUT ──────────────────────────────────── */
.dlayout{display:grid;grid-template-columns:1fr 340px;gap:1.2rem}
.icard{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);padding:1.5rem}
.ist{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.irow{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.irow:last-child{border-bottom:none}
.ilabel{font-size:12px;color:var(--text2)}
.ivalue{font-size:14px;font-weight:500;text-align:right;max-width:62%;word-break:break-all}
.ivalue.gold-val{font-weight:700;letter-spacing:2px;color:var(--gold)}
.ivalue.mono-val{font-family:monospace;font-size:12px;letter-spacing:1px}
.badge{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:6px;background:var(--gdim);border:1px solid var(--gborder);color:var(--gold);display:inline-block}
.avt-lg{width:48px;height:48px;border-radius:50%;background:var(--gdim);border:1px solid var(--gborder);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--gold);flex-shrink:0}
.del-confirm{background:rgba(224,80,80,.07);border:1px solid rgba(224,80,80,.22);border-radius:var(--r);padding:1rem;text-align:center}

/* ─── TABLA DE USUARIOS ───────────────────────────────── */
.users-layout{display:grid;grid-template-columns:1fr 300px;gap:1.2rem;align-items:start}
.users-table{width:100%;border-collapse:collapse}
.users-table thead tr{border-bottom:1px solid var(--border)}
.users-table th{padding:.75rem 1rem;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);text-align:left}
.users-table td{padding:.75rem 1rem;font-size:14px;border-bottom:1px solid var(--border)}
.users-table tbody tr:last-child td{border-bottom:none}
.users-table tbody tr:hover td{background:rgba(255,255,255,.02)}
.user-row--inactive td{opacity:.45}
.user-row--inactive .oname,.user-row--inactive .ivalue{text-decoration:line-through}
.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
.status-on{background:var(--green);box-shadow:0 0 6px var(--green)}
.status-off{background:var(--text3)}

/* ─── LOGIN ───────────────────────────────────────────── */
.login-body{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}
.login-card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);padding:2.5rem;width:100%;max-width:400px;text-align:center}
.login-icon{width:52px;height:52px;border-radius:50%;background:var(--gdim);border:1px solid var(--gborder);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:24px}
.login-t{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}
.login-s{font-size:13px;color:var(--text2);margin-bottom:2rem}
.login-err{font-size:13px;color:var(--red);min-height:18px}
.login-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border);font-size:11px;color:var(--text3);letter-spacing:1px}
.login-card .field{text-align:left}
.pwd-wrap{position:relative}
.pwd-wrap input{padding-right:46px}
.pwd-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text2);font-size:16px;padding:4px;line-height:1;transition:var(--tr)}
.pwd-eye:hover{color:var(--gold)}
.shake{animation:shake .5s ease}
@keyframes shake{0%,100%{transform:translateX(0)}15%,45%,75%{transform:translateX(-6px)}30%,60%,90%{transform:translateX(6px)}}

/* ─── FOOTER ──────────────────────────────────────────── */
.site-footer{text-align:center;padding:2rem 1rem;border-top:1px solid var(--border);margin-top:auto;font-size:11px;color:var(--text3);letter-spacing:1px}

/* ─── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:1000px){.users-layout{grid-template-columns:1fr}}
@media(max-width:900px){.dlayout{grid-template-columns:1fr}.dhinfo{flex-direction:column;align-items:flex-start}}
@media(max-width:680px){
  .fgrid{grid-template-columns:1fr}.pgrid{grid-template-columns:repeat(2,1fr)}.photos-strip{grid-template-columns:repeat(2,1fr)}
  .page{padding:1.5rem 1rem}.nav{padding:0 1rem}.dhero{aspect-ratio:4/3}.sbar{flex-direction:column}
  .dhero-title{font-size:32px}.site-header__name{font-size:22px;letter-spacing:2px}
  .site-header__inner{height:110px}.logo-img{max-height:76px}
  .user-name{display:none}
}
