/* miPorteria — Design System v2 */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

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

:root{
  --brand:#1a56db;--brand-d:#1447b5;--brand-l:#e8f0fe;--brand-xl:#f0f4ff;
  --success:#0d9f6e;--success-bg:#ecfdf5;
  --danger:#e02424;--danger-bg:#fdf2f2;
  --warn:#c27803;--warn-bg:#fffbeb;
  --info:#1a56db;--info-bg:#eff6ff;
  --white:#fff;--gray-25:#fcfcfd;--gray-50:#f9fafb;--gray-100:#f3f4f6;
  --gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;
  --gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'SF Mono','Fira Code',monospace;
  --radius-sm:6px;--radius:8px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;
  --shadow-xs:0 1px 2px rgba(0,0,0,.05);
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow:0 4px 6px -1px rgba(0,0,0,.08),0 2px 4px -1px rgba(0,0,0,.04);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -2px rgba(0,0,0,.03);
  --sidebar-w:240px;--header-h:60px;--content-max:1180px;
  --accent:#1a56db;--accent-d:#1447b5;--accent-l:#e8f0fe;
}
body.tipo-conjunto{--accent:#0d9f6e;--accent-d:#057a55;--accent-l:#ecfdf5}

body{font-family:var(--font);font-size:14px;line-height:1.6;color:var(--gray-800);background:var(--gray-50);-webkit-font-smoothing:antialiased}

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

/* ── Sidebar ── */
.sidebar{width:var(--sidebar-w);background:var(--white);border-right:1px solid var(--gray-200);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:transform .25s ease}
.sidebar-brand{padding:1rem 1.25rem;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:.75rem;min-height:var(--header-h)}
.sidebar-logo{width:34px;height:34px;border-radius:var(--radius);object-fit:cover;flex-shrink:0}
.sidebar-logo-ph{width:34px;height:34px;border-radius:var(--radius);background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.sidebar-brand-name{font-weight:600;font-size:13px;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.sidebar-brand-tipo{font-size:11px;color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em}
.sidebar-nav{flex:1;padding:.75rem;overflow-y:auto}
.sidebar-section{margin-bottom:1.25rem}
.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-400);padding:0 .5rem .4rem;display:block}
.sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border-radius:var(--radius);color:var(--gray-600);text-decoration:none;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;margin-bottom:1px}
.sidebar-link:hover{background:var(--gray-100);color:var(--gray-900)}
.sidebar-link.active{background:var(--accent-l);color:var(--accent)}
.nav-icon{width:16px;height:16px;opacity:.5;flex-shrink:0}
.sidebar-link.active .nav-icon,.sidebar-link:hover .nav-icon{opacity:1}
.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:999px}
.sidebar-footer{padding:.75rem;border-top:1px solid var(--gray-100)}
.sidebar-user{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border-radius:var(--radius);text-decoration:none;transition:background .12s}
.sidebar-user:hover{background:var(--gray-100)}
.sidebar-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent-l);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.sidebar-user-name{font-size:12.5px;font-weight:600;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:11px;color:var(--gray-400)}

/* ── Topbar mobile ── */
.topbar{display:none;height:var(--header-h);background:var(--white);border-bottom:1px solid var(--gray-200);padding:0 1rem;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:40}
.topbar-brand{display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:14px;color:var(--gray-900)}
.btn-menu{background:none;border:none;cursor:pointer;padding:.4rem;border-radius:var(--radius);color:var(--gray-600)}
.btn-menu:hover{background:var(--gray-100)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:45}
.sidebar-overlay.open{display:block}

/* ── Main ── */
.main-wrap{margin-left:var(--sidebar-w);flex:1;min-width:0;display:flex;flex-direction:column}
.main-content{flex:1;padding:2rem;max-width:var(--content-max);width:100%;margin:0 auto}

/* ── Page header ── */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;gap:1rem;flex-wrap:wrap}
.page-header h1,.page-header h2{font-size:1.35rem;font-weight:700;color:var(--gray-900);line-height:1.2}
.page-header p{font-size:13px;color:var(--gray-500);margin-top:2px}
.page-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:12.5px;color:var(--gray-400);margin-bottom:.5rem}
.breadcrumb a{color:var(--gray-500);text-decoration:none}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb-sep{color:var(--gray-300)}

/* ── Alertas ── */
.alert{display:flex;align-items:flex-start;gap:.65rem;padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1.25rem;font-size:13.5px;line-height:1.5;border:1px solid transparent}
.alert-success{background:var(--success-bg);color:#065f46;border-color:#a7f3d0}
.alert-danger{background:var(--danger-bg);color:#9b1c1c;border-color:#fca5a5}
.alert-info{background:var(--info-bg);color:#1e40af;border-color:#bfdbfe}
.alert-warn{background:var(--warn-bg);color:#92400e;border-color:#fde68a}

/* ── Botones ── */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:13.5px;font-weight:500;cursor:pointer;text-decoration:none;border:1px solid transparent;line-height:1.4;transition:all .12s;white-space:nowrap;font-family:var(--font)}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent-d)}
.btn-primary:hover{background:var(--accent-d)}
.btn-secondary{background:var(--white);color:var(--gray-700);border-color:var(--gray-300);box-shadow:var(--shadow-xs)}
.btn-secondary:hover{background:var(--gray-50)}
.btn-danger{background:var(--danger);color:#fff;border-color:#c81e1e}
.btn-danger:hover{background:#c81e1e}
.btn-ghost{background:transparent;color:var(--gray-600);border-color:transparent}
.btn-ghost:hover{background:var(--gray-100);color:var(--gray-900)}
.btn-sm{padding:.3rem .65rem;font-size:12.5px;border-radius:var(--radius)}
.btn-lg{padding:.65rem 1.4rem;font-size:15px}
.btn-block{width:100%;justify-content:center;display:flex}
.btn-warn{background:var(--warn);color:#fff}
.btn-logout{background:transparent;color:var(--danger);border:1px solid var(--danger);padding:.35rem .75rem;font-size:12.5px;border-radius:var(--radius);cursor:pointer;font-family:var(--font);text-decoration:none;display:inline-block}

/* ── Cards ── */
.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.card-body{padding:1.5rem}
.card-header{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}
.card-header h3{font-size:14px;font-weight:600;color:var(--gray-800)}
.card-footer{padding:.75rem 1.5rem;border-top:1px solid var(--gray-100);background:var(--gray-25);border-radius:0 0 var(--radius-lg) var(--radius-lg)}

/* ── Stats ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem;margin-bottom:2rem}
.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.stat-card.stat-green::before{background:var(--success)}
.stat-card.stat-amber::before{background:var(--warn)}
.stat-card.stat-red::before{background:var(--danger)}
.stat-label{font-size:11.5px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem}
.stat-number{font-size:2.2rem;font-weight:700;color:var(--gray-900);line-height:1}
.stat-sub{font-size:12px;color:var(--gray-400);margin-top:.25rem}

/* ── Tablas ── */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}
.data-table{width:100%;border-collapse:collapse;background:var(--white);font-size:13.5px}
.data-table th{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);padding:.75rem 1rem;text-align:left;background:var(--gray-25);border-bottom:1px solid var(--gray-200);white-space:nowrap}
.data-table td{padding:.7rem 1rem;border-bottom:1px solid var(--gray-100);vertical-align:middle;color:var(--gray-700)}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr:hover td{background:var(--gray-25)}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap}
.badge-green{background:#dcfce7;color:#166534}
.badge-amber{background:#fef3c7;color:#92400e}
.badge-red{background:#fee2e2;color:#991b1b}
.badge-blue{background:#dbeafe;color:#1e40af}
.badge-purple{background:#ede9fe;color:#5b21b6}
.badge-gray{background:var(--gray-100);color:var(--gray-600)}

/* ── Formularios ── */
.form-section{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1.5rem;overflow:hidden}
.form-section-header{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100);background:var(--gray-25)}
.form-section-header h3{font-size:13.5px;font-weight:600;color:var(--gray-700)}
.form-section-header p{font-size:12.5px;color:var(--gray-400);margin-top:2px}
.form-section-body{padding:1.25rem 1.5rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grid-3{grid-template-columns:1fr 1fr 1fr}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:.3rem}
.form-hint{font-size:11.5px;color:var(--gray-400);margin-top:2px}
.form-actions{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--gray-100);background:var(--gray-25)}
label{font-size:12.5px;font-weight:500;color:var(--gray-700)}
label .req{color:var(--danger);margin-left:2px}
.emp-form{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:1.5rem}
.emp-form h4{margin:1.25rem 0 .75rem;color:var(--gray-500);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}

input[type="text"],input[type="email"],input[type="password"],input[type="tel"],
input[type="number"],input[type="date"],input[type="datetime-local"],input[type="week"],
select,textarea{
  width:100%;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);
  font-size:13.5px;font-family:var(--font);color:var(--gray-800);background:var(--white);
  transition:border-color .12s,box-shadow .12s;line-height:1.5
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(26,86,219,.12)}
input[type="file"]{padding:.4rem .75rem;font-size:12.5px;cursor:pointer}
textarea{resize:vertical;min-height:90px}

/* ── Imágenes ── */
.avatar{border-radius:50%;object-fit:cover;flex-shrink:0}
.avatar-sm{width:32px;height:32px}
.avatar-md{width:44px;height:44px}
.avatar-lg{width:80px;height:80px}
.avatar-placeholder{border-radius:50%;background:var(--accent-l);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.table-logo{height:28px;border-radius:var(--radius-sm)}
.thumb-sm{width:32px;height:32px;border-radius:50%;object-fit:cover}
.thumb-md{width:72px;height:72px;border-radius:var(--radius);object-fit:cover}

/* ── Search / Filter ── */
.search-bar{display:flex;gap:.5rem;margin-bottom:1rem}
.search-bar input{max-width:340px}
.filter-bar{display:flex;gap:.5rem;align-items:flex-end;margin-bottom:1rem;flex-wrap:wrap}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(2px)}
.modal-box{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;animation:modal-in .18s ease}
@keyframes modal-in{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-header{padding:1.25rem 1.5rem 1rem;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:15px;font-weight:700;color:var(--gray-900)}
.modal-body{padding:1.25rem 1.5rem}
.modal-footer{padding:.75rem 1.5rem;border-top:1px solid var(--gray-100);display:flex;gap:.75rem;justify-content:flex-end;background:var(--gray-25)}
.modal-actions{display:flex;gap:.75rem;margin-top:1.25rem}
.btn-modal-close{background:none;border:none;cursor:pointer;color:var(--gray-400);font-size:18px;line-height:1;padding:2px 4px;border-radius:4px}
.btn-modal-close:hover{color:var(--gray-700);background:var(--gray-100)}

/* ── Login ── */
.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--white)}
.login-panel-left{background:var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;color:#fff}
.login-panel-left h2{font-size:1.8rem;font-weight:700;margin-bottom:.5rem;text-align:center}
.login-panel-left p{font-size:14px;opacity:.8;text-align:center;max-width:280px;line-height:1.6}
.login-panel-logo{width:72px;margin-bottom:1.5rem;border-radius:var(--radius-md)}
.login-panel-right{display:flex;align-items:center;justify-content:center;padding:2rem}
.login-card{width:100%;max-width:380px}
.login-card h1{font-size:1.35rem;font-weight:700;color:var(--gray-900);margin-bottom:.35rem}
.login-card>p{font-size:13.5px;color:var(--gray-500);margin-bottom:1.75rem}
.login-card label{display:block;margin-bottom:.3rem}
.login-card input{margin-bottom:.75rem}
.login-brand-icon{width:48px;height:48px;background:var(--accent-l);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.login-logo{height:60px;display:block;margin:0 auto 1rem;border-radius:var(--radius)}
.login-brand{text-align:center;font-size:1.75rem;margin-bottom:.5rem}
.login-sub{text-align:center;color:var(--gray-500);font-size:13.5px;margin-bottom:1.5rem}

/* ── QR ── */
.qr-fullpage{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-50);padding:1rem}
.qr-emp-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:2rem 1.5rem;max-width:360px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}
.qr-emp-logo{height:44px;margin-bottom:.75rem}
.qr-emp-foto{width:88px;height:88px;border-radius:50%;object-fit:cover;border:3px solid var(--accent-l);display:block;margin:0 auto .75rem}
.qr-emp-nombre{font-size:1.15rem;font-weight:700;color:var(--gray-900)}
.qr-emp-cargo{font-size:.875rem;color:var(--gray-500);margin-top:.2rem}
.qr-big{display:flex;justify-content:center;margin:1rem 0 .5rem}
.qr-hint{font-size:.8rem;color:var(--gray-400);margin-bottom:1rem}
.btn-logout-small{font-size:.8rem;color:var(--danger);text-decoration:none;display:block;margin-top:1rem}
.redes-social{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem;margin-top:.75rem}
.red-btn{padding:.25rem .65rem;border-radius:999px;font-size:.75rem;text-decoration:none;font-weight:600;background:var(--gray-100);color:var(--gray-700)}
.red-whatsapp{background:#dcfce7;color:#166534}
.red-instagram{background:#fce7f3;color:#9d174d}
.red-linkedin{background:#dbeafe;color:#1e40af}

/* ── Scan ── */
.scan-result-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--gray-50)}
.scan-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:2rem 1.5rem;max-width:380px;width:95vw;text-align:center;box-shadow:var(--shadow-lg)}
.scan-card.scan-entrada{border-top:5px solid var(--success)}
.scan-card.scan-salida{border-top:5px solid var(--warn)}
.scan-tipo{font-size:1.3rem;font-weight:800;margin-bottom:.75rem;letter-spacing:.03em}
.scan-entrada .scan-tipo{color:var(--success)}
.scan-salida .scan-tipo{color:var(--warn)}
.scan-logo{height:36px;margin-bottom:.75rem}
.scan-foto{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:.75rem auto;display:block;border:3px solid var(--gray-100)}
.scan-hora{margin:.75rem 0}
.scan-hora strong{font-size:2.2rem;font-weight:800;display:block;color:var(--gray-900)}
.scan-hora span{color:var(--gray-400);font-size:.875rem}
.scan-redirect{font-size:.8rem;color:var(--gray-400);margin-top:1rem}
.emergencia-box{background:var(--warn-bg);border-radius:var(--radius);padding:.75rem;margin-top:.75rem;text-align:left;font-size:.85rem}
.emergencia-box summary{cursor:pointer;font-weight:600}

/* ── QR card admin ── */
.qr-page{display:flex;justify-content:center;padding:2rem 1rem}
.qr-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:2rem;width:380px;text-align:center;box-shadow:var(--shadow)}
.qr-container{display:flex;justify-content:center;margin:1rem 0}
.qr-code-text{font-size:.7rem;color:var(--gray-400);word-break:break-all;margin-bottom:.75rem;font-family:var(--font-mono)}
.emp-foto{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto .75rem;display:block}

/* ── Footer ── */
.site-footer{padding:1.25rem 2rem;border-top:1px solid var(--gray-100);font-size:12px;color:var(--gray-400);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}

/* ── Tipo selector ── */
.tipo-selector{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}
.tipo-card{border:2px solid var(--gray-200);border-radius:var(--radius-lg);padding:1.25rem 1rem;cursor:pointer;text-align:center;transition:all .15s;background:var(--white)}
.tipo-card:hover{border-color:var(--accent);background:var(--accent-l)}
.tipo-card.sel{border-color:var(--accent);background:var(--accent-l)}
.tipo-card-icon{font-size:1.75rem;margin-bottom:.4rem}
.tipo-card-label{font-size:13px;font-weight:600;color:var(--gray-700)}
.tipo-card.sel .tipo-card-label{color:var(--accent)}
.tipo-card-desc{font-size:11.5px;color:var(--gray-400);margin-top:2px}

/* ── Misc ── */
.nav-sep{color:var(--gray-200)}
.divider{border:none;border-top:1px solid var(--gray-200);margin:1.5rem 0}
.inline-form{display:flex;gap:.75rem;align-items:center;background:var(--white);padding:1rem 1.25rem;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1.25rem}
.info-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm);margin-bottom:1.25rem;line-height:2}
.ruta-url{font-family:var(--font-mono);font-size:.8rem;color:var(--accent)}
.check-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--gray-100);font-size:.9rem}

/* ── Responsive ── */
@media(max-width:900px){:root{--sidebar-w:200px}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}
  .topbar{display:flex}
  .main-wrap{margin-left:0}
  .main-content{padding:1.25rem 1rem}
  .form-grid,.form-grid-3{grid-template-columns:1fr}
  .stats-grid,.dashboard-grid{grid-template-columns:1fr 1fr}
  .login-page{grid-template-columns:1fr}
  .login-panel-left{display:none}
  .page-header{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .stats-grid,.dashboard-grid{grid-template-columns:1fr 1fr}
  .qr-emp-card{padding:1.5rem 1rem}
  .scan-hora strong{font-size:2rem}
}
