.dash-root{display:flex;flex-direction:column;height:100vh;overflow:hidden}.dash-topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;background:linear-gradient(135deg,#1e293b,#334155,#dc2626);color:#fff;padding:11px 18px;flex-shrink:0}.dash-title{font-size:15px;font-weight:800;letter-spacing:.3px}.dash-topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dash-date{padding:5px 9px;border:1px solid rgba(255,255,255,.3);border-radius:7px;background:#ffffff1a;color:#fff;font-size:12px;outline:none}.dash-date::-webkit-calendar-picker-indicator{filter:invert(1)}.dash-date:focus{border-color:#ffffffb3}.dash-summary{display:flex;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}.sum-item{flex:1;padding:8px 14px;display:flex;flex-direction:column;gap:1px;border-right:1px solid #f1f5f9;min-width:0}.sum-item:last-child{border-right:none}.sum-label{font-size:10px;font-weight:700;text-transform:uppercase;color:#9ca3af;letter-spacing:.04em}.sum-val{font-size:16px;font-weight:900;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sum-val.blue{color:#2563eb}.sum-val.green{color:#16a34a}.sum-val.orange{color:#d97706}.dash-body{display:flex;flex:1;overflow:hidden}.dash-sidebar{width:190px;flex-shrink:0;background:#f8fafc;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;overflow:hidden}.dash-filter-section{padding:8px 10px;border-bottom:1px solid #f1f5f9}.dash-filter-label{display:block;font-size:10px;font-weight:800;text-transform:uppercase;color:#9ca3af;letter-spacing:.04em;margin-bottom:4px}.dash-filter-input{width:100%;padding:5px 8px;border:1px solid #e5e7eb;border-radius:6px;font-size:12px;background:#fff;outline:none;color:#111827}.dash-filter-input:focus{border-color:#dc2626}.dash-patente-list{flex:1;overflow-y:auto;padding:2px}.dash-patente-item{display:flex;justify-content:space-between;align-items:center;padding:4px 6px;cursor:pointer;border-radius:5px;transition:background .1s}.dash-patente-item:hover{background:#e2e8f0}.dpi-patente{font-size:11px;font-weight:700;color:#1e293b}.dpi-cargas{font-size:10px;color:#6b7280;background:#e2e8f0;padding:1px 5px;border-radius:999px}.dash-main{flex:1;overflow-y:auto;padding:12px;background:#f1f5f9}.dash-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:10px;color:#6b7280}.vcards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.vcard{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px;cursor:pointer;transition:box-shadow .15s,border-color .15s,transform .1s}.vcard:hover{box-shadow:0 4px 16px #0000001a;border-color:#cbd5e1;transform:translateY(-1px)}.vcard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.vcard-patente{font-size:17px;font-weight:900;color:#0f172a;letter-spacing:.5px}.vcard-est{font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px}.est-green{background:#dcfce7;color:#15803d}.est-orange{background:#fff7ed;color:#c2410c}.est-red{background:#fee2e2;color:#991b1b}.est-darkred{background:#7f1d1d;color:#fca5a5}.est-gray{background:#f1f5f9;color:#475569}.vcard-model{font-size:12px;font-weight:600;color:#334155}.vcard-tipo{font-size:11px;color:#9ca3af}.vcard-ciudad{font-size:11px;color:#64748b;margin-top:2px}.vcard-metrics{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}.vmet{display:flex;flex-direction:column;gap:1px}.vmet-label{font-size:9px;font-weight:700;text-transform:uppercase;color:#9ca3af;letter-spacing:.04em}.vmet-val{font-size:13px;font-weight:800;color:#0f172a}.vcard-desv{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11px}.rend-badge{display:inline-block;padding:2px 7px;border-radius:6px;font-size:12px;font-weight:700}.rend-green{background:#dcfce7;color:#15803d}.rend-orange{background:#fff7ed;color:#c2410c}.rend-red{background:#fee2e2;color:#991b1b}.rend-gray{background:#f1f5f9;color:#475569}.vcard-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.vtag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px}.vtag-blue{background:#eff6ff;color:#1d4ed8}.vtag-gray{background:#f1f5f9;color:#475569}.vcard-rend-bar{margin-top:8px}.rend-bar-track{height:5px;background:#f1f5f9;border-radius:999px;overflow:hidden}.rend-bar-fill{height:100%;border-radius:999px;transition:width .3s}.rend-bar-fill.rend-green{background:#16a34a}.rend-bar-fill.rend-orange{background:#f97316}.rend-bar-fill.rend-red{background:#dc2626}.rend-bar-fill.rend-gray{background:#cbd5e1}.rend-bar-label{font-size:10px;color:#9ca3af;margin-top:2px;display:block}.vcard-fecha{font-size:10px;color:#9ca3af;margin-top:6px}.vdetail-root{flex:1;overflow-y:auto;background:#f8fafc}.vdetail-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;background:#fff;border-bottom:1px solid #e5e7eb;padding:14px 20px}.vdetail-header-left{display:flex;align-items:flex-start;gap:4px}.vdetail-patente{font-size:24px;font-weight:900;color:#0f172a;display:flex;align-items:center;gap:8px}.vdetail-subinfo{font-size:12px;color:#64748b;margin-top:2px}.vdetail-ciudad{display:inline-block;margin-top:6px;background:#0d9488;color:#fff;padding:3px 12px;border-radius:999px;font-size:12px;font-weight:700}.vdetail-rend-box{background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:10px 16px;min-width:180px}.vdetail-rend-row{display:flex;justify-content:space-between;gap:16px;font-size:12px;padding:3px 0}.vdetail-rend-row span{color:#6b7280}.vdetail-rend-row strong{font-weight:800}.vdetail-rend-row strong.rend-green{color:#16a34a}.vdetail-rend-row strong.rend-orange{color:#d97706}.vdetail-rend-row strong.rend-red{color:#dc2626}.vdetail-kpi{display:flex;flex-wrap:wrap;gap:0;background:#fff;border-bottom:1px solid #e5e7eb}.vdetail-kpi-item{flex:1;min-width:130px;padding:12px 18px;border-right:1px solid #f1f5f9;display:flex;flex-direction:column;gap:3px}.vdetail-kpi-item:last-child{border-right:none}.vdetail-kpi-val{font-size:20px;font-weight:900;color:#0f172a}.vdetail-kpi-val.blue{color:#2563eb}.vdetail-kpi-val.green{color:#16a34a}.vdetail-kpi-val.orange{color:#d97706}.vdetail-kpi-label{font-size:10px;font-weight:700;text-transform:uppercase;color:#9ca3af;letter-spacing:.04em}.vdetail-chart-wrap{background:#fff;margin:12px 16px;border:1px solid #e5e7eb;border-radius:12px;padding:12px;max-height:200px}.vdetail-chart-wrap canvas{max-height:160px}.vdetail-chart-title{font-size:13px;font-weight:700;color:#334155;margin-bottom:12px}.vdetail-table-section{margin:0 16px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.vdetail-table-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.vdetail-table-title{font-size:13px;font-weight:700;color:#334155}.vdetail-table th{font-size:10px;white-space:nowrap;background:#f8fafc;position:sticky;top:0}.vdetail-table td{font-size:12px;white-space:nowrap}.tr-even td{background:#fafafa}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#f8fafc;color:#111827;font-size:14px}.app-layout{display:flex;min-height:100vh}.sidebar{width:56px;flex-shrink:0;background:linear-gradient(180deg,#1e293b,#334155);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow:visible}.sidebar-logo{padding:14px 0 10px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:center}.sidebar-logo h1{margin:0;color:#fff;font-size:22px;line-height:1}.sidebar-logo p{display:none}.sidebar-nav{padding:8px 0;flex:1;display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;justify-content:center;padding:13px 0;color:#94a3b8;text-decoration:none;font-size:16px;transition:background .15s,color .15s;cursor:pointer;border:none;background:none;width:100%;position:relative}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#dc262640;color:#fca5a5}.nav-item i{width:20px;text-align:center}.nav-item:after{content:attr(data-label);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#1e293b;color:#fff;font-size:12px;font-weight:700;white-space:nowrap;padding:5px 10px;border-radius:7px;pointer-events:none;opacity:0;transition:opacity .15s;z-index:999;box-shadow:0 2px 8px #0000004d}.nav-item:hover:after{opacity:1}.main-content{margin-left:56px;flex:1;min-height:100vh;display:flex;flex-direction:column}.page-header{background:linear-gradient(135deg,#1e293b,#334155 35%,#dc2626);color:#fff;padding:18px 24px}.page-header h2{margin:0;font-size:20px;font-weight:800}.page-header p{margin:4px 0 0;color:#cbd5e1;font-size:13px}.page-body{padding:20px 24px;flex:1}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:18px;margin-bottom:16px;box-shadow:0 2px 10px #0000000f}.card h3{margin:0 0 14px;font-size:15px;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;box-shadow:0 2px 8px #0000000d}.stat-card .label{font-size:11px;color:#6b7280;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.stat-card .value{font-size:22px;font-weight:800;color:#0f172a;margin-top:4px}.stat-card .sub{font-size:11px;color:#9ca3af;margin-top:2px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border-radius:10px;font-weight:700;font-size:13px;cursor:pointer;border:none;transition:opacity .15s}.btn:hover{opacity:.85}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#dc2626;color:#fff}.btn-secondary{background:#f1f5f9;color:#334155}.btn-outline{background:#fff;color:#111827;border:1px solid #e5e7eb}.btn-success{background:#16a34a;color:#fff}.btn-sm{padding:6px 10px;font-size:12px}.form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;margin-bottom:14px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.form-group input,.form-group select{padding:9px 12px;border:1px solid #e5e7eb;border-radius:10px;font-size:13px;outline:none;background:#fff;color:#111827}.form-group input:focus,.form-group select:focus{border-color:#dc2626}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:10px 12px;border-bottom:1px solid #f1f5f9;text-align:left;vertical-align:middle}th{color:#6b7280;font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;background:#f8fafc}tr:hover td{background:#f8fafc}.pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}.pill-green{background:#dcfce7;color:#15803d}.pill-orange{background:#fff7ed;color:#9a3412}.pill-red{background:#fee2e2;color:#991b1b}.pill-gray{background:#f1f5f9;color:#475569}.pill-blue{background:#eff6ff;color:#1d4ed8}.upload-zone{border:2px dashed #e5e7eb;border-radius:14px;padding:40px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.drag-over{border-color:#dc2626;background:#fff5f5}.upload-zone i{font-size:36px;color:#dc2626;margin-bottom:10px}.upload-zone p{margin:6px 0;color:#64748b}.alert{border-radius:10px;padding:12px 16px;margin-bottom:14px;font-weight:600;font-size:13px}.alert-info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.alert-success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.alert-warning{background:#fff7ed;color:#9a3412;border:1px solid #fdba74}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.spinner{width:24px;height:24px;border:3px solid #e5e7eb;border-top-color:#dc2626;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;justify-content:center;align-items:center;padding:40px;gap:12px;color:#64748b}.text-muted{color:#6b7280}.text-right{text-align:right}.fw-bold{font-weight:700}.mb-0{margin-bottom:0}.gap-2{gap:8px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.mobile-topbar{display:none;position:fixed;top:0;left:0;right:0;z-index:200;height:52px;background:linear-gradient(135deg,#1e293b,#334155 60%,#dc2626);color:#fff;align-items:center;justify-content:space-between;padding:0 16px;box-shadow:0 2px 8px #0000004d}.mobile-topbar-title{font-size:15px;font-weight:800;letter-spacing:.3px}.mobile-menu-btn{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:6px}.mobile-drawer-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#00000073}.mobile-drawer{width:240px;height:100%;background:linear-gradient(180deg,#1e293b,#334155);display:flex;flex-direction:column}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;height:60px;background:#1e293b;border-top:1px solid rgba(255,255,255,.1);justify-content:space-around;align-items:stretch;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:3px;color:#94a3b8;text-decoration:none;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:6px 2px;transition:color .15s}.mobile-nav-item i{font-size:17px}.mobile-nav-item.active{color:#fca5a5}.mobile-nav-item:hover{color:#fff}@media (max-width: 768px){.sidebar{display:none}.mobile-topbar{display:flex}.mobile-drawer-overlay{display:block}.mobile-bottom-nav{display:flex}.main-content{margin-left:0!important;padding-left:0!important;padding-top:52px;padding-bottom:60px}.page-header{padding:14px 16px}.page-header h2{font-size:16px}.page-body{padding:12px 14px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.form-row{flex-direction:column}.vcards-grid{grid-template-columns:1fr!important}.dash-sidebar{display:none}.dash-body{flex-direction:column}.dash-main{padding:8px}.vdetail-kpi-item{min-width:100px}.vdetail-chart-wrap{margin:8px;padding:10px}.vdetail-table-section{margin:0 8px 16px}.dash-summary{flex-wrap:wrap}.sum-item{min-width:45%}}
