:root{--bg-primary: #ffffff;--bg-secondary: #f1f5f9;--bg-accent: #e2e8f0;--accent-primary: #002777;--accent-secondary: #8b0c3f;--accent-primary-soft: #e4f4fb;--accent-primary-border: rgba(0, 39, 119, .32);--accent-secondary-soft: #ffffff;--accent-secondary-border: rgba(139, 12, 63, .4);--accent-gray: #a3a6a9;--accent-gray-light: #d8d9d7;--accent-surface: #f2f2f2;--accent-border: #d8d9d7;--accent-warning: #ffdb34;--accent-warning-soft: #fff4ca;--accent-warning-border: #ffe366;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--card-bg: #ffffff;--card-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--font-family: "Poppins", sans-serif;--transition: all .2s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:18px}body{background-color:var(--bg-secondary);color:var(--text-primary);font-family:var(--font-family);-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{display:flex;min-height:100vh;height:100vh;align-items:stretch;overflow:hidden}.sidebar{background:#fff;border-right:1px solid var(--border-color);width:360px;flex-shrink:0;height:100vh;display:flex;flex-direction:column}.dashboard-container{display:flex;width:100%;height:100vh;background-color:var(--bg-secondary);align-items:stretch;overflow:hidden}.content-side{flex:1;padding:0;display:flex;flex-direction:column;height:100vh;overflow:hidden;min-width:0}.top-user-header{height:60px;background:#fff;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:flex-end;padding:0 2rem;position:sticky;top:0;z-index:50}.user-profile-trigger{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:9999px;cursor:pointer;transition:background .2s}.user-profile-trigger:hover{background:var(--bg-secondary)}.user-avatar{width:35px;height:35px;border-radius:50%;background:var(--accent-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.profile-dropdown{position:absolute;top:55px;right:2rem;width:220px;background:#fff;border:1px solid var(--border-color);border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a;padding:.5rem;display:flex;flex-direction:column;z-index:100}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--text-primary);text-decoration:none;font-size:.85rem;border-radius:.5rem;transition:background .2s;border:none;background:none;width:100%;cursor:pointer;text-align:left}.dropdown-item:hover{background:var(--bg-secondary)}.dropdown-divider{height:1px;background:var(--border-color);margin:.5rem 0}.inner-content{padding:clamp(.75rem,1.6vw,1.5rem) clamp(.75rem,2vw,2.5rem);position:relative;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.header{margin-bottom:1.5rem;border-bottom:2px solid var(--bg-accent);padding-bottom:1rem}.header h1{font-size:2.225rem;color:var(--accent-primary);font-weight:700;text-transform:none}.header p{color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.kpi-grid{display:flex;flex-direction:column;gap:1rem;width:240px;flex-shrink:0}.main-content-layout{display:flex;gap:2rem;min-height:0;align-items:stretch}.filters-sidebar{width:180px;display:flex;flex-direction:column;gap:clamp(.65rem,1.4vh,1.5rem)}.filter-group{display:flex;flex-direction:column;gap:.5rem}@media (max-width: 1180px){.route-entry-button{grid-template-columns:minmax(80px,110px) minmax(240px,1fr) auto!important}.route-entry-button>span:nth-of-type(3){grid-column:2 / -1;align-items:flex-start!important;text-align:left!important}}@media (max-width: 760px){.route-entry-button{grid-template-columns:1fr!important;align-items:flex-start!important}.route-entry-button>span{width:100%;align-items:flex-start!important;text-align:left!important}}.filter-label{font-size:.75rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.login-container{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:var(--accent-primary) url(https://cloudfront-us-east-1.images.arcpublishing.com/elespectador/OOVDOTJPXJFMNDBUQL3PDMDFYE.jpg);background-size:cover;background-position:center;background-blend-mode:multiply;font-family:Poppins,sans-serif}.login-card{width:100%;max-width:400px;padding:3rem;background:#fff;border-radius:1.5rem;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;text-align:center}.login-input{width:100%;padding:.8rem 1rem;margin-bottom:1.25rem;border:1px solid #e2e8f0;border-radius:.75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.login-input:focus{outline:none;border-color:var(--accent-primary)}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.login-button{width:100%;padding:1rem;background:var(--accent-primary);color:#fff;border:none;border-radius:.75rem;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .1s,background .2s}.login-button:hover{background:#1e40af;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.login-page-shell{height:auto;min-height:100dvh;align-items:stretch;justify-content:stretch;background:#f4f7fb;background-image:none;background-blend-mode:normal;overflow:hidden}.login-split{width:100%;min-height:100dvh;display:grid;grid-template-columns:minmax(0,1.42fr) minmax(520px,.72fr);background:#f2f6fa}.login-hero-panel{position:relative;min-height:100dvh;background-size:cover;background-position:center;display:flex;align-items:center;padding:clamp(2.5rem,4vw,5rem) clamp(2.5rem,4vw,5rem) clamp(2.5rem,4vw,5rem) clamp(4rem,6vw,7rem);overflow:hidden}.login-hero-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#ffffff05,#fff3 64%,#f2f6faf5);pointer-events:none}.login-hero-panel:after{display:none}.login-hero-copy{display:none}.login-hero-copy h1{margin:0;color:#fff;font-size:clamp(3.25rem,5vw,5.85rem);line-height:1.04;font-weight:850;max-width:860px;letter-spacing:0;text-shadow:0 4px 22px rgba(0,0,0,.28);text-wrap:balance}.login-hero-copy p{margin:1.45rem 0 0;color:#fffffff0;font-size:clamp(1.08rem,1.4vw,1.28rem);line-height:1.55;max-width:620px;font-weight:700;text-shadow:0 2px 14px rgba(0,0,0,.28)}.login-form-panel{min-height:100dvh;height:auto;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:clamp(1.25rem,3.5dvh,2.75rem) clamp(3rem,5vw,5rem) clamp(2.25rem,5dvh,4rem);overflow:hidden;background:#f2f6fa}.login-form-card{width:min(100%,620px);position:relative;transform:translateY(clamp(-3rem,-4dvh,-1.2rem));padding:0;background:transparent;border:none;border-radius:0;box-shadow:none;overflow:visible}.login-form-card:before{display:none}.login-brand{text-align:center;margin-bottom:clamp(2.5rem,8dvh,5.2rem);padding-bottom:0;border-bottom:none}.login-brand img{width:clamp(170px,12vw,230px);height:auto;margin-bottom:clamp(.85rem,2dvh,1.35rem)}.login-brand p{margin:0 auto;color:#1f5bb8;font-size:clamp(1.35rem,2.8dvh,1.85rem);line-height:1.35;font-weight:500;max-width:520px}.login-heading{text-align:center;margin-bottom:clamp(2rem,5dvh,3.2rem)}.login-heading h2{margin:0;color:#030712;font-size:clamp(1.65rem,3.2dvh,2rem);line-height:1.2;font-weight:700}.login-heading p{margin:clamp(.45rem,1.2dvh,.8rem) auto 0;color:#5f6f84;font-size:clamp(.88rem,1.65dvh,1rem);font-weight:400;max-width:390px}.login-form{display:flex;flex-direction:column;gap:clamp(1.05rem,2dvh,1.35rem)}.login-field{display:flex;flex-direction:column;gap:.45rem;color:#000;font-size:clamp(.92rem,1.7dvh,1.05rem);font-weight:400}.login-input-wrap{height:clamp(48px,5.8dvh,54px);display:flex;align-items:center;gap:.95rem;padding:0 1.15rem;background:#fff;border:1px solid #c7d1dd;border-radius:5px;color:#64748b;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease}.login-input-wrap:focus-within{border-color:#2f61b7;box-shadow:0 0 0 2px #2f61b71f;background:#fff;color:#004497}.login-input-wrap input{width:100%;height:100%;border:none;outline:none;background:transparent;color:#0f172a;font:inherit;font-size:clamp(.92rem,1.7dvh,1.02rem);min-width:0}.login-input-wrap select{width:100%;height:100%;border:none;outline:none;background:transparent;color:#0f172a;font:inherit;font-size:clamp(.92rem,1.7dvh,1.02rem);min-width:0;cursor:pointer}.login-input-wrap input::placeholder{color:#7b8797}.login-password-toggle{width:34px;height:34px;border:none;border-radius:6px;background:transparent;color:#64748b;display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:background .18s ease,color .18s ease}.login-password-toggle:hover,.login-password-toggle:focus-visible{outline:none;background:#f1f5f9;color:#004497}.login-primary-button{width:100%;min-height:clamp(50px,5.8dvh,56px);margin-top:clamp(2rem,5dvh,3rem);border:none;border-radius:9px;background:linear-gradient(135deg,#004497,#2f61b7);color:#fff;font-size:clamp(.96rem,1.8dvh,1.08rem);font-weight:700;cursor:pointer;box-shadow:none;transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.login-primary-button:hover{background:linear-gradient(135deg,#003a84,#2554a7);transform:translateY(-1px);box-shadow:0 10px 22px #0044972e}.login-primary-button:focus-visible{outline:none;box-shadow:0 0 0 4px #00a9e033,0 14px 28px #00449747}.login-primary-button:active{transform:translateY(0)}.login-alert{border-radius:8px;padding:.85rem 1rem;margin-bottom:1rem;font-size:.86rem;font-weight:700;line-height:1.45}.login-alert-error{background:#fff5f5;border:1px solid #fecaca;color:#b91c1c}.login-alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.login-register-row{margin-top:clamp(1.05rem,2dvh,1.35rem);display:flex;justify-content:center;gap:.35rem;flex-wrap:wrap;color:#64748b;font-size:clamp(.78rem,1.45dvh,.88rem);font-weight:400}.login-register-row a{color:#004497;font-weight:400;text-decoration:none}.login-register-row a:hover{text-decoration:underline}.login-footnote{margin-top:clamp(2rem,4dvh,3rem);display:flex;justify-content:center;align-items:center;gap:.45rem;color:#52647a;font-size:clamp(.76rem,1.4dvh,.84rem);font-weight:700}.login-footnote svg{color:#64748b}.register-form-panel{padding-block:clamp(1rem,3dvh,2.6rem)}.register-form-card{width:min(100%,760px);padding-block:clamp(1.35rem,2.8dvh,2.55rem)}.register-brand{margin-bottom:clamp(1rem,2dvh,1.55rem);padding-bottom:clamp(.85rem,1.8dvh,1.25rem)}.register-brand img{width:clamp(118px,7.2vw,152px);margin-bottom:clamp(.45rem,1.3dvh,.85rem)}.register-heading{margin-bottom:clamp(.95rem,2dvh,1.45rem)}.register-heading h2{font-size:clamp(1.35rem,2.8dvh,1.62rem)}.register-heading p{font-size:clamp(.84rem,1.55dvh,.95rem)}.register-form{gap:1rem}.register-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(.7rem,1.4dvh,1rem) 1.15rem}.register-wide-field,.register-info-note,.register-back-button{grid-column:1 / -1}.register-info-note{display:flex;align-items:center;gap:.75rem;padding:.95rem 1.1rem;border:1px solid #cbd8e7;border-radius:10px;background:#f8fbff;color:#173d6b}.register-info-note svg{flex-shrink:0;color:#004497}.register-info-note p{margin:0;font-size:.85rem;line-height:1.45;font-weight:650}.register-back-button{display:inline-flex;justify-content:center;align-items:center;gap:.45rem;width:fit-content;margin:.2rem auto 0;border:none;background:transparent;color:#004497;cursor:pointer;font:inherit;font-size:.9rem;font-weight:800}.register-back-button:hover,.register-back-button:focus-visible{outline:none;text-decoration:underline}.register-primary-button{margin-top:clamp(.75rem,1.5dvh,.95rem)}@media (max-height: 840px) and (min-width: 981px){.login-form-panel{justify-content:flex-start;padding:1rem clamp(1.35rem,2.4vw,2.25rem)}.login-form-card{width:min(100%,590px);margin:auto 0;padding:1.55rem clamp(2.25rem,3.2vw,3.15rem);border-radius:14px}.login-brand{margin-bottom:1.05rem;padding-bottom:.9rem}.login-brand img{width:128px;margin-bottom:.5rem}.login-brand p{font-size:.88rem;line-height:1.25}.login-heading{margin-bottom:1.05rem}.login-heading h2{font-size:1.5rem}.login-heading p{margin-top:.35rem;font-size:.86rem}.login-form{gap:.75rem}.login-field{gap:.3rem;font-size:.84rem}.login-input-wrap{height:48px;border-radius:7px}.login-input-wrap input,.login-input-wrap select{font-size:.92rem}.login-primary-button{min-height:50px;margin-top:.85rem;font-size:.96rem}.login-register-row{margin-top:.85rem;font-size:.78rem}.login-footnote{margin-top:.85rem;padding-bottom:.1rem;font-size:.76rem}.register-form-card{width:min(100%,700px);padding-block:1.35rem}.register-grid{gap:.7rem .9rem}.register-info-note{padding:.7rem .9rem}.register-info-note p{font-size:.78rem}}@media (max-height: 700px) and (min-width: 981px){.login-form-panel{padding:.7rem clamp(1rem,2vw,1.6rem)}.login-form-card{width:min(100%,560px);padding:1.05rem clamp(1.6rem,2.6vw,2.4rem)}.login-brand{margin-bottom:.65rem;padding-bottom:.65rem}.login-brand img{width:104px;margin-bottom:.35rem}.login-brand p{font-size:.78rem;line-height:1.18}.login-heading{margin-bottom:.7rem}.login-heading h2{font-size:1.28rem}.login-heading p{font-size:.78rem;line-height:1.3}.login-form{gap:.55rem}.login-field{gap:.22rem;font-size:.76rem}.login-input-wrap{height:42px;padding:0 .85rem}.login-input-wrap input,.login-input-wrap select{font-size:.84rem}.login-primary-button{min-height:44px;margin-top:.6rem;font-size:.88rem}.login-register-row,.login-footnote{margin-top:.55rem;font-size:.72rem}.register-form-card{width:min(100%,680px);padding-block:.95rem}.register-brand img{width:96px}.register-grid{gap:.5rem .75rem}.register-info-note{padding:.55rem .7rem}}@media (max-width: 1100px){.login-split{grid-template-columns:1fr}.login-hero-panel{display:none}.login-form-panel{min-height:100dvh;padding:clamp(2rem,6dvh,4rem) clamp(1.5rem,8vw,6rem) clamp(1.5rem,4dvh,2.5rem)}.login-brand{margin-bottom:clamp(2.25rem,7dvh,4.5rem)}.login-form-card{width:min(100%,640px)}.login-footnote{margin-top:clamp(2rem,5dvh,3.2rem)}.register-form-card{width:min(100%,680px)}}@media (max-width: 640px){.login-hero-panel{min-height:28vh}.login-hero-copy p{display:none}.login-form-card{width:100%}.register-grid{grid-template-columns:1fr}}.loader-container{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background:#fff;z-index:10000}.spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.filter-box{background:#fff;border:1px solid var(--border-color);padding:.5rem;border-radius:.25rem;font-size:.8rem;color:var(--text-secondary)}.charts-grid{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.full-width{grid-column:span 2}.dashboard-card{background:var(--card-bg);border-radius:.5rem;padding:1.5rem;box-shadow:var(--card-shadow);border:1px solid var(--border-color)}.card-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:1.25rem;text-align:center}.compact-card .card-title{margin-bottom:.3rem;font-size:.88rem}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:.85rem;color:var(--text-secondary);padding:.75rem;border-bottom:1px solid var(--border-color)}td{padding:.75rem;font-size:.9rem;border-bottom:1px solid var(--bg-secondary)}.content-grid{flex:1;display:flex;flex-direction:column;gap:1.5rem;width:100%}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;color:var(--text-secondary);text-decoration:none;font-weight:400;border-left:4px solid transparent;transition:var(--transition)}.nav-item:hover{background:var(--bg-secondary);color:var(--accent-primary)}.nav-item.active{background:var(--accent-primary-soft);color:var(--accent-primary);border-left-color:var(--accent-primary);font-weight:500}body.dark-theme{--bg-primary: #0f172a;--bg-secondary: #020617;--bg-accent: #1e293b;--text-primary: #f8fafc;--text-secondary: #94a3b8;--card-bg: #0f172a;--border-color: #334155;--accent-primary: #0370f8}body.dark-theme .nav-item.active{background:#1e293b}body.dark-theme th{color:#f8fafc}@media (max-width: 1200px){.charts-grid{grid-template-columns:1fr}.full-width{grid-column:span 1}}@media (max-width: 992px){.main-content-layout{flex-direction:column!important}.filters-sidebar,.kpi-grid{width:100%;flex-direction:row;flex-wrap:wrap}.inner-content{padding:1.5rem}}@media (max-width: 768px){.inner-content{padding:1rem}.header h1{font-size:1.75rem}.top-user-header{padding:0 1rem}.profile-dropdown{right:1rem}}.inner-content.tm-dashboard-scaled{--tm-dashboard-scale: .75;transform:scale(var(--tm-dashboard-scale));transform-origin:top left;width:calc(100% / var(--tm-dashboard-scale));min-height:calc((100vh - 80px) / var(--tm-dashboard-scale))!important}.inner-content.tm-dashboard-scaled .filters-sidebar{width:300px!important}.inner-content.tm-dashboard-scaled .kpi-grid{gap:1.15rem!important}.inner-content.tm-dashboard-scaled .filter-group{gap:.7rem}.inner-content.tm-dashboard-scaled .filters-sidebar select{min-height:46px!important;font-size:1.15rem!important;font-weight:700!important}.inner-content.tm-dashboard-scaled .filters-sidebar span,.inner-content.tm-dashboard-scaled table{font-size:1.08rem!important}.inner-content.tm-dashboard-scaled th,.inner-content.tm-dashboard-scaled td{font-size:inherit!important}@media (max-width: 1366px),(max-height: 820px){.inner-content.tm-dashboard-scaled{--tm-dashboard-scale: .5}.inner-content.tm-dashboard-scaled .filters-sidebar select{min-height:56px!important;font-size:1.65rem!important}.inner-content.tm-dashboard-scaled .filters-sidebar span{font-size:1.55rem!important}.inner-content.tm-dashboard-scaled table{font-size:1.45rem!important}}
