*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--azul: #1e3a5f;--azul-med: #2d5a8e;--azul-claro: #4a90d9;--verde: #27ae60;--rojo: #e74c3c;--naranja: #f39c12;--gris-bg: #f4f6f9;--gris-borde: #dde3ec;--texto: #2c3e50;--texto-suave:#7f8c8d;--blanco: #ffffff;--sidebar-w: 240px;--topbar-h: 56px;--bottomnav-h:60px}html{height:100%}body{font-family:Segoe UI,Arial,sans-serif;background:var(--gris-bg);color:var(--texto);font-size:14px;height:100%;-webkit-text-size-adjust:100%}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--azul);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:200;flex-shrink:0}.sidebar-logo{padding:20px 16px 12px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo h2{font-size:16px;font-weight:700;line-height:1.3}.sidebar-logo p{font-size:11px;opacity:.65;margin-top:2px}.sidebar nav,.sidebar .sidebar-nav{padding:12px 0;flex:1;overflow-y:auto;min-height:0}.sidebar-user{padding:12px 16px 16px;border-top:1px solid rgba(255,255,255,.12);flex-shrink:0}.sidebar-user-email{font-size:12px;color:#ffffffbf;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout{width:100%;padding:8px 10px;font-size:13px;border-radius:8px;border:1px solid rgba(255,255,255,.35);background:#ffffff1a;color:#fff;cursor:pointer;font-family:inherit}.btn-logout:hover{background:#ffffff2e}.drawer-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.15);margin-top:auto}.drawer .drawer-footer .sidebar-user-email{display:block;margin-bottom:8px;color:#ffffffd9;font-size:12px}.topbar-logout-desktop{display:block;padding:6px 12px;font-size:13px;border-radius:8px;border:1px solid var(--gris-borde);background:var(--blanco);color:var(--azul);cursor:pointer;font-family:inherit}.topbar-logout-desktop:hover{background:var(--gris-bg)}.nav-item{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;transition:background .15s;font-size:14px;color:#ffffffd1;text-decoration:none;min-height:48px}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:var(--azul-claro);color:#fff;font-weight:600}.drawer-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;animation:fadeIn .18s ease}.drawer{position:absolute;left:0;top:0;bottom:0;width:280px;background:var(--azul);color:#fff;display:flex;flex-direction:column;animation:slideInLeft .22s ease;overflow:hidden}.drawer>nav{flex:1;overflow-y:auto;min-height:0;padding:12px 0}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 16px;border-bottom:1px solid rgba(255,255,255,.15);font-size:16px;font-weight:700}.drawer-close{background:none;border:none;color:#fffc;font-size:20px;cursor:pointer;padding:4px 8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{background:var(--blanco);padding:0 20px;height:var(--topbar-h);border-bottom:1px solid var(--gris-borde);display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100}.topbar h1{font-size:17px;font-weight:700;color:var(--azul);flex:1}.topbar-date{font-size:12px;color:var(--texto-suave);white-space:nowrap}.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;min-width:44px;min-height:44px;flex-shrink:0}.hamburger span{display:block;width:22px;height:2px;background:var(--azul);border-radius:2px;transition:.2s}.page{padding:20px 24px 24px;flex:1}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--bottomnav-h);background:var(--blanco);border-top:1px solid var(--gris-borde);z-index:200;padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--texto-suave);text-decoration:none;background:none;border:none;cursor:pointer;padding:6px 2px;min-height:48px;transition:color .15s;font-family:inherit}.bottom-nav-item.active{color:var(--azul-claro)}.bottom-nav-item:hover{color:var(--azul)}.bottom-nav-icon{font-size:20px;line-height:1}.bottom-nav-label{font-size:10px;font-weight:600;letter-spacing:.3px}.card{background:var(--blanco);border:1px solid var(--gris-borde);border-radius:8px;padding:16px;margin-bottom:16px}.card-title{font-size:14px;font-weight:700;margin-bottom:14px;color:var(--azul)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:var(--blanco);border:1px solid var(--gris-borde);border-radius:8px;padding:14px;display:flex;flex-direction:column;gap:4px}.stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--texto-suave)}.stat-value{font-size:20px;font-weight:700;color:var(--azul)}.stat-card.verde .stat-value{color:var(--verde)}.stat-card.rojo .stat-value{color:var(--rojo)}.stat-card.naranja .stat-value{color:var(--naranja)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:13px;min-width:480px}th{background:var(--azul);color:#fff;padding:10px 12px;text-align:left;font-weight:600;white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid var(--gris-borde);vertical-align:middle}tr:hover td{background:#f0f4fa}tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge-verde{background:#d5f5e3;color:#1e8449}.badge-rojo{background:#fadbd8;color:#a93226}.badge-azul{background:#d6eaf8;color:#1a5276}.badge-naranja{background:#fef5e7;color:#b7770d}.badge-gris{background:#ecf0f1;color:#7f8c8d}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:6px;border:none;cursor:pointer;font-size:13px;font-weight:600;transition:opacity .15s;text-decoration:none;min-height:40px;white-space:nowrap}.btn:active{opacity:.75}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--azul);color:#fff}.btn-success{background:var(--verde);color:#fff}.btn-danger{background:var(--rojo);color:#fff}.btn-outline{background:transparent;color:var(--azul);border:1px solid var(--azul)}.btn-sm{padding:6px 10px;font-size:12px;min-height:34px}.form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:12px;font-weight:600;color:var(--texto-suave)}.form-control{padding:10px 12px;border:1px solid var(--gris-borde);border-radius:6px;font-size:16px;outline:none;transition:border-color .15s;background:var(--blanco);color:var(--texto);width:100%;min-height:44px}.form-control:focus{border-color:var(--azul-claro)}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}.toolbar .spacer{flex:1;min-width:8px}.toolbar-filters{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}.toolbar-filters .form-control{flex:1;min-width:130px}.toolbar-actions{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.toolbar-hint{font-size:13px;color:var(--texto-suave);flex:1}.upload-area{border:2px dashed var(--azul-claro);border-radius:8px;padding:28px 16px;text-align:center;color:var(--texto-suave);cursor:pointer;transition:background .15s}.upload-area:hover{background:#eaf3fb}.upload-area.dragging{background:#d6eaf8}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:500;padding:16px}.modal{background:var(--blanco);border-radius:12px;padding:20px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.modal-header h3{font-size:16px;font-weight:700;color:var(--azul)}.modal-close{background:none;border:none;cursor:pointer;font-size:22px;color:var(--texto-suave);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;flex-wrap:wrap}.alert{padding:12px 16px;border-radius:6px;margin-bottom:14px;font-size:13px}.alert-success{background:#d5f5e3;color:#1e8449;border:1px solid #a9dfbf}.alert-error{background:#fadbd8;color:#a93226;border:1px solid #f1948a}.alert-info{background:#d6eaf8;color:#1a5276;border:1px solid #aed6f1}.pagination{display:flex;gap:6px;align-items:center;justify-content:center;margin-top:16px;flex-wrap:wrap}.pagination button{padding:8px 14px;border:1px solid var(--gris-borde);background:var(--blanco);border-radius:4px;cursor:pointer;font-size:13px;min-height:40px}.pagination button.active{background:var(--azul);color:#fff;border-color:var(--azul)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.text-center{text-align:center}.text-right{text-align:right}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.empty-state{text-align:center;padding:40px 16px;color:var(--texto-suave)}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--gris-borde);border-top-color:var(--azul-claro);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.tag{display:inline-block;padding:2px 6px;background:#e8f0fb;color:var(--azul-med);border-radius:4px;font-size:11px;margin:1px}@media(max-width:900px){.grid-2{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr 1fr}}@media(max-width:768px){.sidebar,.topbar-logout-desktop{display:none}.hamburger,.bottom-nav{display:flex}.drawer-overlay{display:block}.main-content{margin-left:0;padding-bottom:calc(var(--bottomnav-h) + env(safe-area-inset-bottom,0px))}.topbar{padding:0 14px}.topbar h1{font-size:15px}.page{padding:14px 12px 16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-value{font-size:17px}.grid-2{grid-template-columns:1fr;gap:12px}.form-row{grid-template-columns:1fr}.table-wrap{border-radius:0}table{min-width:560px;font-size:12px}th,td{padding:8px 10px}.toolbar{gap:6px}.toolbar .spacer{display:none}.toolbar>.btn{flex:1;justify-content:center;min-width:0}.toolbar-filters{flex-direction:column;gap:6px}.toolbar-filters .form-control{width:100%;min-width:0}.toolbar-actions{gap:6px}.toolbar-hint{display:none}.toolbar-actions>.btn{flex:1;justify-content:center;min-width:0;font-size:12px;padding:10px 8px}.card{padding:14px 12px}.modal{position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:92vh;border-radius:16px 16px 0 0}.modal-overlay{align-items:flex-end;padding:0}.pagination span{font-size:12px}}@media(max-width:360px){.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-value{font-size:15px}.bottom-nav-label{font-size:9px}.btn{font-size:12px;padding:8px 10px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(160deg,var(--azul) 0%,#0f2844 100%)}.auth-card{width:100%;max-width:420px;background:var(--blanco);border-radius:14px;padding:28px 24px 22px;box-shadow:0 16px 48px #00000040}.auth-brand{text-align:center;margin-bottom:22px}.auth-brand-icon{font-size:36px;display:block;margin-bottom:6px}.auth-brand h1{font-size:20px;color:var(--azul);margin-bottom:4px}.auth-brand p{font-size:13px;color:var(--texto-suave)}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--texto-suave)}.auth-input{padding:10px 12px;border:1px solid var(--gris-borde);border-radius:8px;font-size:14px;font-family:inherit}.auth-input:focus{outline:none;border-color:var(--azul-claro);box-shadow:0 0 0 3px #4a90d933}.auth-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--texto);cursor:pointer}.auth-check input{width:16px;height:16px}.btn-auth{margin-top:4px;padding:12px;font-size:15px;font-weight:600;border:none;border-radius:8px;background:var(--azul);color:#fff;cursor:pointer;font-family:inherit}.btn-auth:hover:not(:disabled){background:var(--azul-med)}.btn-auth:disabled{opacity:.65;cursor:not-allowed}.auth-error{padding:10px 12px;border-radius:8px;font-size:13px;background:#fadbd8;color:#922b21;border:1px solid #f1948a}.auth-notice{padding:12px;border-radius:8px;font-size:13px;background:#fef9e7;color:#7d6608;border:1px solid #f9e79f;margin-bottom:16px;line-height:1.45}.auth-footer-text{text-align:center;margin-top:18px;font-size:13px;color:var(--texto-suave)}.auth-link{color:var(--azul-claro);font-weight:600;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-muted{text-align:center;color:var(--texto-suave);font-size:14px}.auth-center{text-align:center}
