/* ═══════════════════════════════════════════════════════════
   ELNENE_SANDO — CSS Principal
   Orbitron (títulos) + Inter (cuerpo) · Dark Neon
═══════════════════════════════════════════════════════════ */
:root {
  --bg:      #04060f;
  --panel:   #0a0d16;
  --panel2:  #0d1226;
  --line:    rgba(255,255,255,0.08);
  --txt:     #e8ecff;
  --muted:   #6a7299;
  --cyan:    #33c2ff;
  --green:   #22c98a;
  --gold:    #ffd166;
  --red:     #ff5d6c;
  --purple:  #9a6bff;
  --orange:  #ffb648;
}
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg);
  color:var(--txt);
  font-family:'Inter',system-ui,sans-serif;
  font-size:14px;
  min-height:100vh;
  line-height:1.6;
}
.circuit {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image: linear-gradient(rgba(51,194,255,.03) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(51,194,255,.03) 1px, transparent 1px);
  background-size:40px 40px;
}
/* Navbar público */
.navbar { position:sticky; top:0; z-index:100; background:rgba(4,6,15,.95); border-bottom:1px solid var(--line); backdrop-filter:blur(10px); }
.nav-inner { max-width:1200px; margin:0 auto; padding:0 20px; display:flex; align-items:center; justify-content:space-between; height:58px; }
.nav-logo-img img { height:34px; }
.nav-links { display:flex; align-items:center; gap:20px; }
.nav-links a { color:var(--muted); text-decoration:none; font-size:13.5px; font-weight:600; transition:.15s; }
.nav-links a:hover, .nav-links a.active { color:var(--txt); }
.btn-nav-reg { background:linear-gradient(135deg,var(--cyan),#1a8fd1); color:#04060f !important; padding:7px 18px; border-radius:9px; font-weight:800 !important; }
.nav-burger { display:none; background:none; border:none; font-size:20px; color:var(--muted); cursor:pointer; }
/* Contenido principal */
.main-content { position:relative; z-index:1; }
/* Footer */
.footer { border-top:1px solid var(--line); padding:20px; text-align:center; margin-top:40px; }
.footer-inner { max-width:800px; margin:0 auto; }
.footer-contacts a { color:var(--muted); text-decoration:none; font-size:13px; }
.footer-contacts a:hover { color:var(--cyan); }
/* WA FAB */
.wa-fab { position:fixed; bottom:22px; right:22px; z-index:999; background:linear-gradient(135deg,#25d366,#128c7e); width:50px; height:50px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; text-decoration:none; box-shadow:0 4px 16px rgba(37,211,102,.4); }
/* Alertas */
.alert { padding:11px 14px; border-radius:10px; margin-bottom:10px; font-size:13px; }
.alert-success { background:rgba(34,201,138,.1); border:1px solid rgba(34,201,138,.25); color:var(--green); }
.alert-error   { background:rgba(255,93,108,.1);  border:1px solid rgba(255,93,108,.25);  color:var(--red); }
.alert-warn    { background:rgba(255,182,72,.08); border:1px solid rgba(255,182,72,.2);   color:var(--orange); }
.alert-info    { background:rgba(51,194,255,.07); border:1px solid rgba(51,194,255,.2);   color:var(--cyan); }
/* Formularios */
.form-group { margin-bottom:14px; }
.form-group label { display:block; font-size:12.5px; font-weight:700; color:var(--muted); margin-bottom:5px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; background:rgba(255,255,255,.04); border:1px solid var(--line);
  border-radius:10px; padding:10px 14px; color:var(--txt); font-size:13.5px;
  font-family:'Inter',sans-serif; transition:.15s; outline:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:rgba(51,194,255,.4); background:rgba(51,194,255,.04); }
/* Botones */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:10px 20px; border-radius:10px; font-weight:700; font-size:13.5px; cursor:pointer; border:none; font-family:'Inter',sans-serif; text-decoration:none; transition:.15s; }
.btn-primary { background:linear-gradient(135deg,var(--cyan),#1a8fd1); color:#04060f; }
.btn-primary:hover { opacity:.9; }
.btn-success { background:linear-gradient(135deg,var(--green),#1ba870); color:#04060f; }
.btn-outline { background:rgba(255,255,255,.05); border:1px solid var(--line); color:var(--muted); }
.btn-outline:hover { border-color:rgba(51,194,255,.3); color:var(--txt); }
.btn-full { width:100%; }
.btn-lg { padding:12px 24px; font-size:14px; }
/* Admin buttons */
.btn-admin { display:inline-flex; align-items:center; gap:4px; background:rgba(51,194,255,.08); border:1px solid rgba(51,194,255,.2); border-radius:7px; padding:5px 12px; font-size:12px; color:var(--cyan); font-weight:700; cursor:pointer; text-decoration:none; font-family:'Inter',sans-serif; transition:.15s; }
.btn-admin:hover { background:rgba(51,194,255,.14); }
/* Modals */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.8); z-index:200; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(4px); }
.modal-overlay.open { display:flex; }
.modal { background:var(--panel2); border:1px solid rgba(120,150,255,.2); border-radius:18px; padding:24px; width:460px; max-width:95vw; max-height:90vh; overflow-y:auto; position:relative; box-shadow:0 30px 80px rgba(0,0,0,.7); }
.modal-title { font-family:'Orbitron',sans-serif; font-size:16px; font-weight:800; margin-bottom:6px; }
.modal-sub { font-size:12.5px; color:var(--muted); margin-bottom:16px; }
.modal-close { position:absolute; top:14px; right:16px; background:none; border:none; font-size:20px; cursor:pointer; color:var(--muted); }
/* Dash alert */
.dash-alert { display:flex; justify-content:space-between; align-items:center; background:rgba(255,93,108,.07); border:1px solid rgba(255,93,108,.2); border-radius:10px; padding:10px 14px; font-size:13px; color:var(--red); gap:10px; flex-wrap:wrap; }
/* Service detail */
.svc-detail-wrap { display:grid; grid-template-columns:160px 1fr; gap:18px; }
.svc-sidebar { background:var(--panel); border:1px solid var(--line); border-radius:12px; overflow:hidden; height:fit-content; position:sticky; top:70px; }
.svc-sidebar h4 { padding:7px 12px; font-size:9px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; border-bottom:1px solid var(--line); }
.svc-sidebar a { display:flex; align-items:center; gap:7px; padding:8px 12px 8px 14px; font-size:12px; color:var(--muted); text-decoration:none; transition:.15s; }
.svc-sidebar a:hover { color:var(--txt); background:rgba(255,255,255,.03); }
.svc-sidebar a.act { color:var(--cyan); background:rgba(51,194,255,.07); border-left:2px solid var(--cyan); padding-left:12px; }
.svc-sidebar-sep { height:1px; background:var(--line); }
.svc-main { display:flex; flex-direction:column; gap:12px; }
.svc-banner { background:linear-gradient(135deg,#1577d6,#0e4fa3); border-radius:14px; padding:20px; text-align:center; }
.svc-banner-icon { font-size:32px; margin-bottom:8px; }
.svc-banner-name { font-weight:800; font-size:16px; color:#fff; }
.svc-banner-ip   { font-size:12px; color:rgba(255,255,255,.7); font-family:monospace; margin-top:4px; }
.svc-info-card { background:var(--panel); border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.svc-info-row { display:flex; justify-content:space-between; padding:9px 14px; border-bottom:1px solid rgba(255,255,255,.04); font-size:12.5px; }
.svc-info-lbl { color:var(--muted); }
.svc-info-val { font-weight:600; }
.svc-status { display:inline-flex; align-items:center; gap:5px; font-size:11.5px; font-weight:700; padding:3px 10px; border-radius:999px; }
.ss-activo   { color:var(--green); background:rgba(34,201,138,.1); border:1px solid rgba(34,201,138,.25); }
.ss-venciendo{ color:var(--red);   background:rgba(255,93,108,.1);  border:1px solid rgba(255,93,108,.25); }
.ss-dot { width:7px; height:7px; border-radius:50%; display:inline-block; }
.ss-dot-g { background:var(--green); box-shadow:0 0 5px var(--green); }
.ss-dot-r { background:var(--red);   box-shadow:0 0 5px var(--red); }
/* SSH Modal específico */
.ssh-modal-row { display:grid; grid-template-columns:160px 1fr auto; align-items:center; padding:10px 16px; border-bottom:1px solid rgba(255,255,255,.05); gap:10px; }
.ssh-modal-lbl { font-size:11px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; }
.ssh-modal-val { font-size:13px; font-weight:600; font-family:monospace; }
.ssh-copy-btn, .ssh-eye-btn { background:rgba(255,255,255,.06); border:1px solid var(--line); border-radius:5px; padding:4px 8px; font-size:12px; cursor:pointer; color:var(--muted); }
.ssh-copy-btn:hover, .ssh-eye-btn:hover { background:rgba(255,255,255,.1); }
/* Tables */
.adm-table { width:100%; border-collapse:collapse; font-size:12.5px; }
.adm-table th { text-align:left; padding:8px 12px; color:var(--muted); font-weight:700; border-bottom:1px solid var(--line); }
.adm-table td { padding:9px 12px; border-bottom:1px solid rgba(255,255,255,.04); }
/* Status badges */
.status { display:inline-block; padding:2px 9px; border-radius:999px; font-size:11px; font-weight:700; }
.status-entregado { color:var(--green); background:rgba(34,201,138,.1); border:1px solid rgba(34,201,138,.25); }
.status-pagado, .status-en_proceso { color:var(--orange); background:rgba(255,182,72,.1); border:1px solid rgba(255,182,72,.25); }
.status-cancelado, .status-pendiente_pago { color:var(--muted); background:rgba(255,255,255,.04); border:1px solid var(--line); }
/* Code box */
.code-box { background:rgba(0,0,0,.4); border:1px solid rgba(51,194,255,.15); border-radius:10px; padding:12px 14px; font-family:monospace; font-size:12px; color:#7af0c0; white-space:pre-wrap; word-break:break-all; }
/* Mobile */
@media(max-width:768px){
  .nav-links{display:none;flex-direction:column;position:absolute;top:58px;left:0;right:0;background:rgba(4,6,15,.97);padding:16px;border-bottom:1px solid var(--line);}
  .nav-links.open{display:flex;}
  .nav-burger{display:block;}
  .svc-detail-wrap{grid-template-columns:1fr;}
  .svc-sidebar{position:static;}
}
