/* viv.css — VivManager */
:root {
  --bg:      #080f1e;
  --surface: #0c1628;
  --card:    #101e36;
  --border:  rgba(148,163,184,0.09);
  --borderH: rgba(56,189,248,0.35);
  --accent:  #38bdf8;
  --accent2: #818cf8;
  --text:    #e2e8f0;
  --muted:   #64748b;
  --faint:   #1e3a5f;
  --danger:  #f87171;
  --success: #34d399;
  --warn:    #fbbf24;
  --sw:      248px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;}
a{text-decoration:none;color:inherit;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--faint);border-radius:99px;}

/* ── SIDEBAR ── */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sw);background:rgba(12,22,40,0.98);border-right:1px solid var(--border);backdrop-filter:blur(20px);z-index:200;display:flex;flex-direction:column;transition:transform .3s ease;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:199;}
.sidebar-logo{display:flex;align-items:center;gap:10px;padding:22px 20px 16px;border-bottom:1px solid var(--border);}
.logo-text{font-size:17px;font-weight:900;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.logo-sub{font-size:10px;color:var(--muted);margin-top:-2px;}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border);background:rgba(56,189,248,0.04);}
.user-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;color:#fff;}
.user-name{font-size:13px;font-weight:700;color:var(--text);}
.user-sub{font-size:10px;color:var(--muted);}
.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto;}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 16px;margin:2px 10px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;color:var(--muted);border-left:3px solid transparent;}
.nav-item:hover{background:rgba(56,189,248,0.06);color:var(--text);}
.nav-item.active{background:rgba(56,189,248,0.12);color:var(--accent);border-left-color:var(--accent);}
.nav-item span{font-size:16px;}
.sidebar-footer{padding:14px 20px;border-top:1px solid var(--border);}
.btn-logout{display:block;width:100%;padding:9px;text-align:center;background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.25);border-radius:10px;color:var(--danger);font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .2s;}
.btn-logout:hover{background:rgba(239,68,68,0.2);}

/* ── TOPBAR ── */
.topbar{position:sticky;top:0;z-index:100;background:rgba(12,22,40,0.95);border-bottom:1px solid var(--border);backdrop-filter:blur(16px);display:flex;align-items:center;padding:0 24px;height:58px;gap:16px;margin-left:var(--sw);}
.topbar-menu{display:none;background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:4px 8px;border-radius:8px;}
.topbar-menu:hover{background:rgba(255,255,255,0.05);}
.topbar-title{font-weight:800;color:var(--text);font-size:15px;flex:1;}
.topbar-date{font-size:12px;color:var(--muted);}

/* ── MAIN ── */
.main{margin-left:var(--sw);padding:28px 30px;min-height:100vh;}
.page-title{font-size:22px;font-weight:900;color:var(--text);letter-spacing:-.5px;margin-bottom:22px;}

/* ── CARDS ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px 24px;}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px;}

/* ── STATS ── */
.stat-grid{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px;}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;flex:1 1 130px;border-left-width:3px;border-left-style:solid;}
.stat-num{font-size:28px;font-weight:900;}
.stat-label{font-size:10px;color:var(--muted);margin-top:4px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;}

/* ── TABLA ── */
.tbl-wrap{overflow-x:auto;}
table.viv-table{width:100%;border-collapse:collapse;font-size:13px;}
.viv-table th{padding:11px 13px;text-align:left;color:var(--muted);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border);white-space:nowrap;background:rgba(56,189,248,0.03);}
.viv-table td{padding:11px 13px;border-bottom:1px solid var(--border);vertical-align:middle;}
.viv-table tr:last-child td{border-bottom:none;}
.viv-table tr:hover td{background:rgba(56,189,248,0.03);}

/* ── BOTONES ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border:none;border-radius:10px;font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;transition:opacity .2s,transform .1s;text-decoration:none;}
.btn:hover{opacity:.88;}
.btn:active{transform:scale(.97);}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;}
.btn-danger{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:var(--danger);}
.btn-ghost{background:rgba(56,189,248,.1);border:1px solid var(--border);color:var(--accent);}
.btn-sm{padding:6px 13px;font-size:12px;}

/* ── FORMULARIOS ── */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;}
.form-control{width:100%;padding:10px 13px;background:rgba(8,15,30,0.7);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;outline:none;font-family:inherit;transition:border-color .2s;}
.form-control:focus{border-color:var(--accent);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:99px;font-size:11px;font-weight:700;}
.badge-dot{width:6px;height:6px;border-radius:50%;display:inline-block;}

/* ── ALERTAS ── */
.alert{padding:12px 18px;border-radius:12px;margin-bottom:18px;font-size:13px;}
.alert-danger{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:var(--danger);}
.alert-success{background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.25);color:var(--success);}
.alert-info{background:rgba(56,189,248,.08);border:1px solid rgba(56,189,248,.2);color:var(--accent);}

/* ── TARJETA UNIDAD ── */
.unit-card{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .25s,box-shadow .25s,border-color .25s;border-top-width:3px;border-top-style:solid;}
.unit-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(0,0,0,.5);border-color:var(--borderH);}
.unit-thumb{height:180px;overflow:hidden;background:var(--faint);position:relative;}
.unit-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.unit-card:hover .unit-thumb img{transform:scale(1.07);}
.unit-thumb-empty{height:100%;display:flex;align-items:center;justify-content:center;color:rgba(56,189,248,.18);font-size:52px;}
.unit-thumb-badge{position:absolute;top:10px;left:10px;}
.unit-thumb-count{position:absolute;bottom:9px;right:10px;background:rgba(0,0,0,.72);color:#fff;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:600;}
.unit-body{padding:14px 16px;}
.unit-name{font-weight:800;color:var(--text);font-size:15px;margin-bottom:2px;}
.unit-sub{font-size:11px;color:var(--muted);margin-bottom:10px;}
.unit-icons{display:flex;gap:14px;font-size:12px;color:var(--muted);margin-bottom:12px;flex-wrap:wrap;}
.unit-price-a{font-size:18px;font-weight:900;color:var(--accent);}
.unit-price-v{font-size:18px;font-weight:900;color:var(--success);}
.unit-mas{margin-top:10px;font-size:12px;font-weight:600;color:var(--muted);transition:color .2s;}
.unit-card:hover .unit-mas{color:var(--accent);}
.unit-deuda{margin-top:8px;padding:5px 10px;font-size:11px;font-weight:700;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:8px;color:var(--danger);}

/* ── FILTROS ── */
.filtros{display:flex;gap:10px;flex-wrap:wrap;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 18px;margin-bottom:18px;}
.filtros input,.filtros select{padding:9px 13px;background:rgba(8,15,30,.7);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;outline:none;font-family:inherit;transition:border-color .2s;}
.filtros input:focus,.filtros select:focus{border-color:var(--accent);}
.filtros-label{font-size:12px;color:var(--muted);font-weight:600;}
.filtros-count{font-size:12px;color:var(--muted);margin-bottom:14px;}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:500;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(10px);}
.modal-overlay.open{display:flex;}
.modal-box{background:var(--card);border:1px solid var(--borderH);border-radius:20px;width:100%;max-width:860px;max-height:92vh;overflow-y:auto;box-shadow:0 40px 80px rgba(0,0,0,.8);animation:modalIn .25s ease;}
.modal-sm{max-width:480px;}
.modal-hdr{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.modal-hdr-title{font-size:19px;font-weight:900;color:var(--text);}
.modal-hdr-sub{font-size:12px;color:var(--muted);margin-top:3px;}
.modal-close{flex-shrink:0;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:16px;line-height:1;font-family:inherit;}
.modal-body{padding:22px 24px;}
@keyframes modalIn{from{opacity:0;transform:scale(.96) translateY(8px);}to{opacity:1;transform:scale(1) translateY(0);}}

/* ── CARRUSEL ── */
.carousel-wrap{position:relative;border-radius:14px;overflow:hidden;background:#000;margin-bottom:10px;}
.carousel-wrap img{width:100%;max-height:400px;object-fit:cover;display:block;}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.65);border:none;color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center;}
.carousel-btn.prev{left:12px;}
.carousel-btn.next{right:12px;}
.carousel-counter{position:absolute;bottom:12px;right:14px;background:rgba(0,0,0,.65);color:#fff;padding:4px 12px;border-radius:99px;font-size:12px;}
.carousel-code{position:absolute;bottom:12px;left:14px;background:rgba(0,0,0,.65);color:var(--accent);padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;}
.carousel-thumbs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}
.carousel-thumbs img{width:80px;height:60px;object-fit:cover;border-radius:8px;cursor:pointer;border:2px solid transparent;opacity:.55;transition:all .2s;}
.carousel-thumbs img.active{border-color:var(--accent);opacity:1;}

/* ── DETALLES GRID ── */
.det-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;}
.det-item{background:#f7f5f2;border:1px solid #e0dbd4;border-radius:10px;padding:10px 13px;}
.det-lbl{font-size:11px;color:#374151;font-weight:800;text-transform:uppercase;letter-spacing:.5px;}
.det-val{font-size:13px;color:#111827;margin-top:3px;font-weight:700;}
.det-section{grid-column:1/-1;background:#e8f5ef;border:1px solid #b6d9c8;border-radius:10px;padding:10px 13px;}
.det-section-lbl{font-size:10px;color:#1a6b52;font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.det-section-row{display:flex;gap:8px;flex-wrap:wrap;font-size:13px;color:#111827;font-weight:600;align-items:center;}
.det-contact{grid-column:1/-1;background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;padding:10px 13px;}
.det-contact-lbl{font-size:10px;color:#92400e;font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.det-contact-row{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:#111827;font-weight:600;align-items:center;}

/* ── VISTA PÚBLICA ── */
.pub-topbar{background:rgba(12,22,40,0.97);border-bottom:1px solid var(--border);backdrop-filter:blur(16px);position:sticky;top:0;z-index:100;}
.pub-topbar-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:62px;}
.pub-logo{display:flex;align-items:center;gap:10px;}
.pub-logo-text{font-size:19px;font-weight:900;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.pub-logo-sub{font-size:10px;color:var(--muted);}
.pub-hero{max-width:1280px;margin:0 auto;padding:48px 24px 32px;text-align:center;background:linear-gradient(180deg,rgba(56,189,248,.05) 0%,transparent 100%);}
.pub-hero-eyebrow{font-size:12px;color:var(--accent);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;}
.pub-hero-h1{font-size:clamp(26px,5vw,46px);font-weight:900;letter-spacing:-1px;line-height:1.1;margin-bottom:12px;}
.pub-hero-h1 span{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.pub-hero-p{color:var(--muted);font-size:15px;max-width:480px;margin:0 auto 26px;line-height:1.7;}
.pub-stats{display:inline-flex;gap:6px;flex-wrap:wrap;justify-content:center;}
.pub-stat{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:99px;padding:5px 14px;font-size:12px;font-weight:700;}
.pub-content{max-width:1280px;margin:0 auto;padding:0 24px 60px;}
.pub-section-hdr{display:flex;align-items:center;gap:14px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.pub-section-ico{width:40px;height:40px;border-radius:10px;flex-shrink:0;background:rgba(56,189,248,.07);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:20px;}
.pub-section-title{font-weight:800;font-size:18px;color:var(--text);}
.pub-section-sub{font-size:12px;color:var(--muted);}

/* ── FOTOS ── */
.foto-thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;}
.foto-thumb{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s,border-color .2s;}
.foto-thumb:hover{transform:scale(1.03);border-color:var(--borderH);}
.foto-thumb img{width:100%;height:135px;object-fit:cover;display:block;}
.foto-thumb-info{padding:8px 10px;}
.foto-thumb-code{font-size:11px;font-weight:800;color:var(--accent);}
.foto-thumb-sub{font-size:10px;color:var(--muted);margin-top:2px;}

/* ── INFO BOX ── */
.info-box{background:rgba(56,189,248,.05);border:1px solid rgba(56,189,248,.15);border-radius:12px;padding:11px 16px;margin-bottom:18px;font-size:12px;color:var(--muted);line-height:1.7;}
.info-box b{color:var(--accent);}

/* ── LOGIN ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse at 30% 20%,rgba(56,189,248,.07) 0%,transparent 55%),radial-gradient(ellipse at 70% 80%,rgba(129,140,248,.05) 0%,transparent 55%),var(--bg);}
.login-card{background:var(--card);border:1px solid var(--borderH);border-radius:22px;width:100%;max-width:420px;padding:44px 38px;box-shadow:0 32px 64px rgba(0,0,0,.6);}
.login-logo{text-align:center;margin-bottom:32px;}
.login-icon{font-size:50px;margin-bottom:8px;}
.login-title{font-size:28px;font-weight:900;letter-spacing:-1px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.login-sub{color:var(--muted);font-size:13px;margin-top:4px;}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);}
  .sidebar-overlay.open{display:block;}
  .topbar{margin-left:0;}
  .topbar-menu{display:flex;}
  .main{margin-left:0;padding:20px 16px;}
  .form-row,.form-row-3{grid-template-columns:1fr;}
  .stat-card{flex:1 1 120px;}
}
