.navbar{position:sticky;top:0;z-index:100;background:var(--bg-card);padding:1rem 0;margin-bottom:2rem;border-radius:0;box-shadow:0 4px 8px var(--shadow-dark),0 -2px 4px var(--shadow-light)}.navbar-container{max-width:1800px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.navbar-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;font-weight:700;font-size:1.5rem;color:var(--text-primary);transition:var(--transition)}.navbar-brand:hover{transform:translateY(-2px)}.brand-icon{font-size:2rem}.brand-text{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-links{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center}.nav-link{padding:.75rem 1.5rem;border-radius:var(--border-radius-small);text-decoration:none;color:var(--text-secondary);font-weight:600;font-size:.9rem;transition:var(--transition);display:flex;align-items:center;gap:.5rem;white-space:nowrap}.nav-link:hover{color:var(--text-primary);background:#667eea0d;transform:translateY(-2px)}.nav-link.active{color:#fff;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));box-shadow:4px 4px 8px var(--shadow-dark),-4px -4px 8px var(--shadow-light)}.navbar-user{display:flex;align-items:center;gap:1rem}.user-name{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.btn-logout{padding:.5rem 1rem;border:none;border-radius:var(--border-radius-small);font-size:.875rem;font-weight:600;color:var(--text-primary);background:var(--bg-card);cursor:pointer;transition:var(--transition)}.btn-logout:hover{transform:translateY(-2px);color:var(--accent-primary)}@media(max-width:1024px){.navbar-links{gap:.25rem}.nav-link{padding:.6rem 1rem;font-size:.85rem}}@media(max-width:768px){.navbar-container{flex-direction:column;gap:1rem;padding:0 1rem}.navbar-links{width:100%;flex-wrap:wrap;justify-content:center;gap:.5rem}.nav-link{padding:.5rem .75rem;font-size:.8rem}.navbar-user{width:100%;justify-content:center}}@media(max-width:480px){.navbar-brand{font-size:1.25rem}.brand-icon{font-size:1.5rem}.nav-link{flex:1;justify-content:center;min-width:100px}}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-content{flex:1;padding-bottom:2rem}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary);padding:1rem;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(0,102,204,.06),transparent);top:-300px;right:-200px;border-radius:50%;pointer-events:none}.login-container:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(0,196,140,.05),transparent);bottom:-150px;left:-100px;border-radius:50%;pointer-events:none}.login-box{background:var(--bg-card);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);border:1px solid rgba(0,102,204,.08);padding:2.5rem;width:100%;max-width:440px;position:relative;z-index:1;animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:clamp(2rem,5vw,2.5rem);margin-bottom:.75rem;font-weight:700}.login-header p{color:var(--text-secondary);font-size:clamp(.875rem,2vw,.95rem)}.login-form{display:flex;flex-direction:column;gap:1.5rem;width:100%}.login-description{text-align:center;color:var(--text-secondary);line-height:1.6;margin:0;font-size:.95rem}.login-button{width:100%;padding:1rem;background:var(--bg-card);color:var(--accent-primary);border:1px solid rgba(0,102,204,.15);border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-soft);transition:var(--transition);margin-top:.5rem;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));opacity:0;transition:opacity .3s ease;border-radius:var(--border-radius-sm)}.login-button:hover:not(:disabled):before{opacity:.08}.login-button:hover:not(:disabled){box-shadow:var(--shadow-inset);border-color:#0066cc40;transform:translateY(1px)}.login-button:active:not(:disabled){box-shadow:var(--shadow-inset)}.login-button:disabled{opacity:.5;cursor:not-allowed}.divider{text-align:center;margin:1.5rem 0;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:calc(50% - 3rem);height:2px;background:linear-gradient(to right,transparent,var(--shadow-dark),transparent)}.divider:before{left:0}.divider:after{right:0}.divider span{background:var(--bg-card);padding:0 1rem;color:var(--text-secondary);font-size:.9rem;font-weight:500;position:relative;z-index:1}.sso-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem;background:var(--bg-card);color:var(--text-dark);border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none;box-shadow:6px 6px 12px var(--shadow-dark),-6px -6px 12px var(--shadow-light);transition:var(--transition)}.sso-button:hover{box-shadow:inset 3px 3px 6px var(--shadow-dark),inset -3px -3px 6px var(--shadow-light),0 0 20px #00a4ef26;transform:scale(.98)}.sso-button svg{width:21px;height:21px}.error-message{background:var(--bg-card);color:#d32f2f;padding:1rem;border-radius:var(--border-radius-sm);font-size:.9rem;box-shadow:inset 4px 4px 8px #d32f2f1a,4px 4px 12px var(--shadow-dark),-4px -4px 12px var(--shadow-light);border-left:4px solid #d32f2f}.error-message.blocked{color:#f57c00;border-left-color:#f57c00;box-shadow:inset 4px 4px 8px #f57c001a,4px 4px 12px var(--shadow-dark),-4px -4px 12px var(--shadow-light)}.block-info{margin-top:.5rem;font-weight:600;font-size:.95rem}.login-info{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid transparent;background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(90deg,transparent,var(--shadow-dark),transparent) border-box;text-align:center}.login-info p{margin:.5rem 0;color:var(--text-secondary);font-size:.9rem}.login-info strong{color:var(--text-dark);font-family:Courier New,monospace;background:var(--bg-primary);padding:.25rem .5rem;border-radius:6px;box-shadow:inset 2px 2px 4px var(--shadow-dark),inset -2px -2px 4px var(--shadow-light)}.login-info small{display:block;margin-top:.75rem;color:#f57c00;font-size:.85rem;font-weight:500}@media(max-width:640px){.login-box{padding:2rem 1.5rem}.login-header h1{font-size:2rem}.divider:before,.divider:after{width:calc(50% - 2.5rem)}}@media(max-width:400px){.login-container{padding:.75rem}.login-box{padding:1.5rem 1rem}}.cloud-scope-filter{display:flex;align-items:center;gap:.5rem;margin:.75rem 0 1rem;flex-wrap:wrap}.cloud-scope-filter .label{font-size:.9rem;color:var(--text-secondary);font-weight:600}.cloud-scope-filter button{border:1px solid var(--border-color, #d8dbe3);background:#fff;color:var(--text-secondary);border-radius:999px;padding:.35rem .75rem;cursor:pointer;font-size:.82rem}.cloud-scope-filter button.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-color:transparent}.dashboard{min-height:100vh;background:var(--bg-primary)}.loading-container{display:flex;align-items:center;justify-content:center;padding:3rem;font-size:1.1rem;color:var(--text-secondary)}.error-banner{background:var(--bg-card);color:#d32f2f;padding:1rem;border-radius:var(--border-radius-sm);margin:1rem 0;border-left:4px solid #d32f2f;box-shadow:var(--shadow-md)}.dashboard-header{background:var(--bg-card);color:var(--text-dark);padding:1.25rem 0;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,102,204,.08)}.header-content{max-width:1400px;margin:0 auto;padding:0 clamp(1rem,3vw,2rem);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.header-content h1{font-size:clamp(1.5rem,4vw,2rem);margin:0;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.user-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.user-badge{background:linear-gradient(135deg,#0066cc0d,#00c48c0d);padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;color:var(--accent-primary);border:1px solid rgba(0,102,204,.1);box-shadow:var(--shadow-sm)}.user-name{font-weight:500;color:var(--text-dark)}.logout-button{background:var(--bg-card);color:var(--text-dark);border:1px solid rgba(0,102,204,.1);padding:.625rem 1.25rem;border-radius:var(--border-radius-sm);cursor:pointer;font-weight:600;transition:var(--transition);box-shadow:var(--shadow-soft)}.logout-button:hover{box-shadow:var(--shadow-inset);transform:translateY(1px);background:var(--bg-primary)}.dashboard-main{max-width:1400px;margin:0 auto;padding:clamp(1.5rem,4vw,3rem) clamp(1rem,3vw,2rem)}.welcome-card{background:var(--bg-card);border-radius:var(--border-radius);padding:clamp(1.5rem,4vw,2.5rem);box-shadow:var(--shadow-soft);margin-bottom:2rem;animation:slideUp .5s ease-out;border:1px solid rgba(0,102,204,.06)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.action-buttons{display:flex;gap:1rem;margin:1.5rem 0;flex-wrap:wrap}.manage-users-button,.process-csv-button{margin:0;padding:.875rem 1.75rem;background:var(--bg-card);color:var(--accent-primary);border:1px solid rgba(0,102,204,.15);border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:.5rem;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.manage-users-button:before,.process-csv-button:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));opacity:0;transition:opacity .3s ease}.manage-users-button:hover:before,.process-csv-button:hover:before{opacity:.08}.manage-users-button:hover,.process-csv-button:hover{box-shadow:var(--shadow-inset);transform:translateY(1px)}.process-csv-button{color:#10b981}.welcome-card h2{color:var(--text-dark);margin-bottom:.75rem;font-size:clamp(1.5rem,3vw,1.8rem);font-weight:700}.welcome-card p{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.range-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:1rem 0 1.5rem}.range-controls label{font-weight:600;color:var(--text-dark)}.range-controls select,.range-controls input[type=date]{padding:.5rem .75rem;border-radius:var(--border-radius-sm);border:1px solid rgba(0,102,204,.2);background:var(--bg-card);color:var(--text-dark)}.range-sep{color:var(--text-secondary);font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.stat-card{background:var(--bg-card);padding:1.75rem;border-radius:var(--border-radius);display:flex;align-items:center;gap:1.25rem;transition:var(--transition);cursor:pointer;box-shadow:var(--shadow-soft);border:1px solid rgba(0,102,204,.06)}.stat-card.clickable{cursor:pointer}.stat-card:hover,.stat-card.clickable:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#0066cc1f}.stat-card:active,.stat-card.clickable:active{transform:translateY(-1px);box-shadow:var(--shadow-md)}.stat-icon{font-size:2.5rem;background:linear-gradient(135deg,#0066cc0d,#00c48c0d);width:70px;height:70px;min-width:70px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);border:1px solid rgba(0,102,204,.08)}.stat-content{flex:1;min-width:0}.stat-content h3{margin:0 0 .5rem;color:var(--text-dark);font-size:clamp(1rem,2vw,1.2rem);font-weight:600}.stat-content p{margin:0;color:var(--text-secondary);font-size:.9rem}.info-section{background:var(--bg-card);border-radius:var(--border-radius);padding:clamp(1.5rem,4vw,2.5rem);box-shadow:10px 10px 20px var(--shadow-dark),-10px -10px 20px var(--shadow-light);margin-top:2rem}.info-section h3{color:var(--text-dark);margin-bottom:1.5rem;font-size:clamp(1.25rem,2.5vw,1.4rem);font-weight:700}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--bg-primary);border-radius:var(--border-radius-sm);box-shadow:inset 3px 3px 6px var(--shadow-dark),inset -3px -3px 6px var(--shadow-light)}.info-label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.info-value{color:var(--text-dark);font-size:1.1rem;font-weight:600}.status-active{color:#10b981}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:2rem;margin:2rem 0}.chart-card{background:var(--bg-card);border-radius:var(--border-radius);padding:1.5rem;box-shadow:10px 10px 20px var(--shadow-dark),-10px -10px 20px var(--shadow-light);animation:slideUp .5s ease-out}.chart-card h3{color:var(--text-dark);margin-bottom:1.5rem;font-size:1.1rem;font-weight:600}.table-container{overflow-x:auto;margin-top:1rem}.data-table{width:100%;border-collapse:collapse;font-size:.95rem}.data-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-dark);border-bottom:2px solid var(--shadow-dark)}.data-table td{padding:.875rem 1rem;border-bottom:1px solid rgba(0,0,0,.05);color:var(--text-secondary)}.data-table tbody tr:hover{background:var(--bg-primary)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge-high{background:#ef44441a;color:#ef4444}.badge-medium{background:#f59e0b1a;color:#f59e0b}.badge-low{background:#10b9811a;color:#10b981}@media(max-width:1024px){.charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.header-content{flex-direction:column;align-items:flex-start}.user-info{width:100%;justify-content:space-between}.stats-grid,.info-grid,.charts-grid{grid-template-columns:1fr}}@media(max-width:480px){.stat-card{flex-direction:column;text-align:center}.action-buttons{flex-direction:column;width:100%}.manage-users-button,.process-csv-button{width:100%;justify-content:center}}.users-page{min-height:100vh;background:var(--bg-primary)}.users-header{background:var(--bg-card);color:var(--text-dark);padding:1.25rem 0;box-shadow:0 4px 12px var(--shadow-dark);position:sticky;top:0;z-index:100}.users-main{max-width:1400px;margin:0 auto;padding:clamp(1.5rem,4vw,3rem) clamp(1rem,3vw,2rem)}.create-user-card,.users-list-card{background:var(--bg-card);border-radius:var(--border-radius);padding:clamp(1.5rem,4vw,2.5rem);box-shadow:10px 10px 20px var(--shadow-dark),-10px -10px 20px var(--shadow-light);margin-bottom:2rem;animation:slideUp .5s ease-out}.create-user-card h2,.users-list-card h2{color:var(--text-dark);margin-bottom:1.5rem;font-size:clamp(1.25rem,2.5vw,1.5rem);font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card-description{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6;font-size:.95rem}.user-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.625rem}.form-group label{color:var(--text-dark);font-weight:600;font-size:.95rem}.form-group input,.form-group select{padding:1rem 1.25rem;border:none;background:var(--bg-primary);border-radius:var(--border-radius-sm);font-size:1rem;color:var(--text-dark);transition:var(--transition);box-shadow:inset 4px 4px 8px var(--shadow-dark),inset -4px -4px 8px var(--shadow-light)}.form-group input:focus,.form-group select:focus{outline:none;box-shadow:inset 6px 6px 12px var(--shadow-dark),inset -6px -6px 12px var(--shadow-light),0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{opacity:.5;cursor:not-allowed}.create-button{padding:1rem 1.75rem;background:var(--bg-card);color:var(--accent-primary);border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition);max-width:200px;box-shadow:6px 6px 12px var(--shadow-dark),-6px -6px 12px var(--shadow-light);position:relative;overflow:hidden}.create-button:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));opacity:0;transition:opacity .3s ease}.create-button:hover:not(:disabled):before{opacity:.1}.create-button:hover:not(:disabled){box-shadow:inset 3px 3px 6px var(--shadow-dark),inset -3px -3px 6px var(--shadow-light);transform:scale(.98)}.create-button:disabled{opacity:.5;cursor:not-allowed}.back-button{background:var(--bg-card);color:var(--text-dark);border:none;padding:.625rem 1.25rem;border-radius:var(--border-radius-sm);cursor:pointer;font-weight:600;transition:var(--transition);box-shadow:5px 5px 10px var(--shadow-dark),-5px -5px 10px var(--shadow-light)}.back-button:hover{box-shadow:inset 3px 3px 6px var(--shadow-dark),inset -3px -3px 6px var(--shadow-light);transform:scale(.98)}.error-message{background:var(--bg-card);color:#d32f2f;padding:1rem;border-radius:var(--border-radius-sm);font-size:.9rem;border-left:4px solid #d32f2f;box-shadow:inset 3px 3px 6px #d32f2f1a,6px 6px 12px var(--shadow-dark),-6px -6px 12px var(--shadow-light)}.success-message{background:var(--bg-card);color:#2e7d32;padding:1rem;border-radius:var(--border-radius-sm);font-size:.9rem;border-left:4px solid #2e7d32;box-shadow:inset 3px 3px 6px #2e7d321a,6px 6px 12px var(--shadow-dark),-6px -6px 12px var(--shadow-light)}.users-table{width:100%;border-collapse:collapse;margin-top:1.5rem}.users-table thead{background:var(--bg-primary)}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:2px solid var(--bg-primary)}.users-table th{font-weight:600;color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.users-table td{color:var(--text-dark);font-size:.95rem}.users-table tbody tr{transition:var(--transition)}.users-table tbody tr:hover{background:var(--bg-primary);transform:scale(1.01)}.role-badge{background:var(--bg-primary);color:var(--accent-primary);padding:.375rem .875rem;border-radius:16px;font-size:.85rem;font-weight:600;text-transform:uppercase;box-shadow:inset 2px 2px 4px var(--shadow-dark),inset -2px -2px 4px var(--shadow-light);display:inline-block}@media(max-width:768px){.form-row{grid-template-columns:1fr}.users-table{font-size:.85rem}.users-table th,.users-table td{padding:.75rem .5rem}.create-button{max-width:100%}}@media(max-width:480px){.users-table th,.users-table td{padding:.5rem .25rem;font-size:.8rem}.role-badge{font-size:.75rem;padding:.25rem .625rem}}.cost-dashboard{min-height:100vh;background:var(--bg-primary)}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.2rem;color:var(--text-secondary)}.page-header{margin-bottom:2rem}.page-header h1{color:var(--text-dark);font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;margin:0}.dashboard-main{max-width:1400px;margin:0 auto;padding:clamp(1.5rem,4vw,2.5rem) clamp(1rem,3vw,2rem)}.error-banner{background:var(--bg-card);color:#d32f2f;padding:1rem;border-radius:var(--border-radius-sm);margin-bottom:1.5rem;border-left:4px solid #d32f2f;box-shadow:var(--shadow-md)}.sync-section{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem;flex-wrap:wrap}.sync-button{padding:.875rem 1.75rem;background:var(--bg-card);color:var(--accent-primary);border:1px solid rgba(0,102,204,.15);border-radius:var(--border-radius-sm);font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-soft)}.sync-button:hover:not(:disabled){box-shadow:var(--shadow-inset);transform:translateY(1px)}.sync-button:disabled{opacity:.5;cursor:not-allowed}.period-badge{background:linear-gradient(135deg,#0066cc0d,#00c48c0d);padding:.625rem 1.25rem;border-radius:var(--border-radius-sm);font-weight:600;color:var(--accent-primary);border:1px solid rgba(0,102,204,.1);box-shadow:var(--shadow-sm)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:var(--bg-card);border-radius:var(--border-radius);padding:1.75rem;display:flex;align-items:center;gap:1.25rem;box-shadow:var(--shadow-soft);border:1px solid rgba(0,102,204,.06);transition:var(--transition)}.summary-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#0066cc1f}.summary-card.savings{background:linear-gradient(135deg,#00c48c14,#00a8b514);border:1px solid rgba(0,196,140,.2);box-shadow:var(--shadow-md)}.card-icon{font-size:2.5rem;min-width:60px;display:flex;align-items:center;justify-content:center}.card-content{flex:1;min-width:0}.card-content h3{margin:0 0 .5rem;font-size:.9rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.card-value{margin:0;font-size:clamp(1.5rem,3vw,1.8rem);font-weight:700;color:var(--text-dark)}.card-content small{color:var(--text-secondary);font-size:.85rem}.data-section{background:var(--bg-card);border-radius:var(--border-radius);padding:clamp(1.5rem,4vw,2.5rem);margin-bottom:2rem;box-shadow:10px 10px 20px var(--shadow-dark),-10px -10px 20px var(--shadow-light);animation:slideUp .5s ease-out}.data-section h2{margin:0 0 1.5rem;color:var(--text-dark);font-size:clamp(1.25rem,2.5vw,1.5rem);font-weight:700}.table-container{overflow-x:auto;border-radius:var(--border-radius-sm)}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-primary)}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:2px solid var(--bg-primary)}.data-table th{font-weight:600;color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.data-table td{color:var(--text-dark);font-size:.95rem}.data-table tbody tr{transition:var(--transition)}.data-table tbody tr:hover{background:var(--bg-primary);transform:scale(1.01)}.text-right{text-align:right!important}.text-center{text-align:center!important}.region-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}.region-card{background:var(--bg-card);color:var(--text-dark);padding:1.5rem;border-radius:var(--border-radius);text-align:center;box-shadow:8px 8px 16px var(--shadow-dark),-8px -8px 16px var(--shadow-light);transition:var(--transition);position:relative;overflow:hidden}.region-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))}.region-card:hover{transform:translateY(-5px);box-shadow:12px 12px 24px var(--shadow-dark),-12px -12px 24px var(--shadow-light)}.region-card h3{margin:0 0 .75rem;font-size:1.1rem;color:var(--text-dark);font-weight:600}.region-cost{font-size:1.5rem;font-weight:700;margin:.75rem 0;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.region-card small{color:var(--text-secondary);font-size:.9rem}@media(max-width:768px){.summary-cards,.region-grid{grid-template-columns:1fr}.data-table{font-size:.85rem}.data-table th,.data-table td{padding:.75rem .5rem}.summary-card{flex-direction:column;text-align:center}}@media(max-width:480px){.sync-section{flex-direction:column;align-items:stretch}.sync-button,.period-badge{width:100%;text-align:center}.data-table th,.data-table td{padding:.5rem .25rem;font-size:.8rem}}.cost-explorer{padding:2rem;max-width:1800px;margin:0 auto}.explorer-header{padding:2rem;margin-bottom:2rem;border-radius:var(--border-radius)}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header-top h1{margin:0;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-actions{display:flex;gap:1rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.summary-card{padding:1.5rem;border-radius:var(--border-radius-small);display:flex;flex-direction:column;gap:.5rem}.summary-card .label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.summary-card .value{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.explorer-filters{padding:2rem;margin-bottom:2rem;border-radius:var(--border-radius)}.explorer-filters h3{margin:0 0 1.5rem;color:var(--text-primary)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.filter-group input,.filter-group select{padding:.75rem;border-radius:var(--border-radius-small);border:none;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:var(--transition)}.filter-group input:disabled,.filter-group select:disabled{opacity:.5;cursor:not-allowed}.filter-group input:focus,.filter-group select:focus{outline:none;box-shadow:inset 3px 3px 6px var(--shadow-dark),inset -3px -3px 6px var(--shadow-light),0 0 0 2px var(--accent-primary)}.group-by-section{display:flex;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid rgba(102,126,234,.1)}.group-by-section label{font-weight:600;color:var(--text-secondary)}.group-by-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.group-by-buttons button{padding:.5rem 1.25rem;border:none;border-radius:var(--border-radius-small);font-size:.875rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:var(--transition);background:var(--bg-card)}.group-by-buttons button.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.explorer-results{min-height:400px}.results-table-container{padding:1.5rem;border-radius:var(--border-radius);overflow-x:auto}.results-table{width:100%;border-collapse:collapse}.results-table thead{position:sticky;top:0;background:var(--bg-card);z-index:10}.results-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--bg-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.results-table td{padding:1rem;border-bottom:1px solid var(--bg-primary);font-size:.875rem;color:var(--text-primary)}.results-table tbody tr{transition:var(--transition)}.results-table tbody tr:hover{background:#667eea0d}.results-table .resource-id{font-family:Courier New,monospace;font-size:.75rem;color:var(--text-secondary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.results-table .cost{font-weight:700;color:var(--accent-primary);text-align:right}.results-table .no-data{text-align:center;padding:3rem;color:var(--text-secondary)}.project-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;color:var(--accent-primary)}.unassigned{color:var(--text-secondary);font-style:italic;font-size:.75rem}.tags-cell{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.tag-badge{padding:.25rem .5rem;border-radius:8px;font-size:.7rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.tag-more{font-size:.7rem;color:var(--text-secondary);font-weight:600}.modal{background:var(--bg-card);padding:2rem;border-radius:var(--border-radius);max-width:600px;width:100%;max-height:80vh;overflow-y:auto}.modal h2{margin:0 0 1rem;color:var(--text-primary)}.modal p{margin:0 0 1.5rem;color:var(--text-secondary)}.project-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.project-option{padding:1.5rem;border-radius:var(--border-radius-small);border:none;cursor:pointer;text-align:left;transition:var(--transition);background:var(--bg-card)}.project-option:hover{transform:translateY(-2px)}.project-name{font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.project-meta{font-size:.875rem;color:var(--text-secondary)}.btn-primary:active{transform:translateY(0)}input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-primary)}@media(max-width:1024px){.filters-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media(max-width:768px){.cost-explorer{padding:1rem}.explorer-header{padding:1.5rem}.header-top{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{width:100%}.header-actions button{flex:1}.summary-cards{grid-template-columns:repeat(2,1fr)}.filters-grid{grid-template-columns:1fr}.group-by-section{flex-direction:column;align-items:flex-start}.results-table{font-size:.75rem}.results-table th,.results-table td{padding:.5rem}}@media(max-width:480px){.summary-cards{grid-template-columns:1fr}.summary-card .value{font-size:1.5rem}.group-by-buttons{width:100%}.group-by-buttons button{flex:1}}.projects-page{padding:2rem;max-width:1600px;margin:0 auto}.projects-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;margin-bottom:2rem;border-radius:var(--border-radius)}.projects-header h1{margin:0 0 .5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projects-header p{margin:0;color:var(--text-secondary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.project-card{padding:1.5rem;border-radius:var(--border-radius);transition:var(--transition)}.project-card:hover{transform:translateY(-4px);box-shadow:8px 8px 16px var(--shadow-dark),-8px -8px 16px var(--shadow-light)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--bg-primary)}.project-card-header h3{margin:0;color:var(--text-primary);font-size:1.25rem;flex:1}.project-actions{display:flex;gap:.5rem}.btn-icon{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:var(--transition);background:var(--bg-card)}.btn-icon:hover{transform:scale(1.1)}.btn-icon:active{transform:scale(.95)}.project-card-body{display:flex;flex-direction:column;gap:1.5rem}.project-meta{display:flex;flex-direction:column;gap:1rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-item .label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.meta-item .value{font-size:.875rem;color:var(--text-primary)}.project-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding-top:1rem;border-top:1px solid rgba(102,126,234,.1)}.stat{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.75rem;font-weight:600;color:var(--text-secondary)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-value.cost{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.no-projects{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1.5rem;text-align:center}.no-projects p{font-size:1.125rem;color:var(--text-secondary);margin:0}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.spinner{width:50px;height:50px;border:4px solid var(--bg-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal{background:var(--bg-card);padding:2rem;border-radius:var(--border-radius);max-width:500px;width:100%}.modal h2{margin:0 0 1.5rem;color:var(--text-primary)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.875rem;color:var(--text-secondary)}.form-group input{width:100%;padding:.75rem;border:none;border-radius:var(--border-radius-small);background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:var(--transition);box-sizing:border-box}.form-group input:focus{outline:none;box-shadow:inset 3px 3px 6px var(--shadow-dark),inset -3px -3px 6px var(--shadow-light),0 0 0 2px var(--accent-primary)}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius-small);font-weight:600;cursor:pointer;transition:var(--transition);font-size:.875rem}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:6px 6px 12px var(--shadow-dark),-6px -6px 12px var(--shadow-light)}.btn-primary:hover{transform:translateY(-2px);box-shadow:8px 8px 16px var(--shadow-dark),-8px -8px 16px var(--shadow-light)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);box-shadow:6px 6px 12px var(--shadow-dark),-6px -6px 12px var(--shadow-light)}.btn-secondary:hover{transform:translateY(-2px)}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:768px){.projects-page{padding:1rem}.projects-header{flex-direction:column;align-items:flex-start;gap:1rem}.projects-header button{width:100%}.projects-grid,.project-stats{grid-template-columns:1fr}}.csv-processor{max-width:1200px;margin:0 auto;padding:2rem}.processor-header{text-align:center;margin-bottom:3rem}.processor-header h1{color:#1a1a1a;margin-bottom:.5rem}.processor-header p{color:#666;font-size:1.1rem}.processor-controls{display:flex;justify-content:center;margin-bottom:2rem}.btn-primary,.btn-secondary,.btn-processing{padding:1rem 2rem;font-size:1.1rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-processing{background:#f0f0f0;color:#666;cursor:not-allowed}.progress-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a}.progress-group{margin-bottom:2rem}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.progress-header h3{margin:0;color:#333;font-size:1.1rem}.progress-label{color:#666;font-size:.95rem;font-weight:600}.progress-bar{width:100%;height:32px;background:#e9ecef;border-radius:16px;overflow:hidden;position:relative}.progress-fill{height:100%;transition:width .5s ease;position:relative;overflow:hidden}.progress-fill.download{background:linear-gradient(90deg,#3b82f6,#2563eb)}.progress-fill.processing{background:linear-gradient(90deg,#10b981,#059669)}.progress-fill:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.current-file{margin-top:.5rem;color:#666;font-size:.9rem;font-style:italic}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin:2rem 0}.stat-card{background:linear-gradient(135deg,#f5f7fa,#e4e8ec);padding:1.5rem;border-radius:12px;text-align:center;border:2px solid transparent;transition:all .3s ease}.stat-card:hover{border-color:#667eea;transform:translateY(-2px)}.stat-value{font-size:2.5rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-label{color:#666;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.logs-section{margin-top:2rem}.logs-section h3{margin-bottom:1rem;color:#333}.logs-container{background:#f8f9fa;border-radius:8px;padding:1rem;max-height:300px;overflow-y:auto;font-family:Monaco,Courier New,monospace;font-size:.85rem}.log-entry{padding:.5rem;margin-bottom:.5rem;border-left:3px solid #ddd;background:#fff;border-radius:4px}.log-entry.log-success{border-left-color:#10b981;background:#f0fdf4}.log-entry.log-error{border-left-color:#ef4444;background:#fef2f2}.log-time{color:#999;margin-right:.5rem;font-size:.8rem}.log-message{color:#333}.error-box{background:#fee;border:2px solid #f88;border-radius:8px;padding:1rem;margin-top:1rem;color:#c00}.success-box{background:#efe;border:2px solid #8f8;border-radius:8px;padding:1rem;margin-top:1rem;color:#060}.logs-container::-webkit-scrollbar{width:8px}.logs-container::-webkit-scrollbar-track{background:#e9ecef;border-radius:4px}.logs-container::-webkit-scrollbar-thumb{background:#adb5bd;border-radius:4px}.logs-container::-webkit-scrollbar-thumb:hover{background:#868e96}.resource-list-container{padding:2rem;max-width:1600px;margin:0 auto}.resource-list-header{margin-bottom:2rem}.resource-list-header h1{font-size:2rem;color:#1a1a1a;margin-bottom:.5rem}.subtitle{color:#666;font-size:1rem}.resource-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.search-box{width:100%}.search-input{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease}.search-input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.tag-filters{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-size:.85rem;font-weight:500;color:#666}.filter-select,.filter-input{padding:.6rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;transition:all .3s ease;min-width:200px}.filter-select:focus,.filter-input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.resource-stats{display:flex;gap:1rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid #e0e0e0}.stat-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.stat-badge.warning{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-badge.success{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-badge strong{font-weight:600}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;color:#c00}.error-icon{font-size:1.5rem}.loading-state{text-align:center;padding:4rem 2rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid #4a90e2;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow-x:auto;margin-bottom:1.5rem}.resource-table{width:100%;border-collapse:collapse;min-width:1200px}.resource-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.resource-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.resource-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease}.resource-table th.sortable:hover{background:#ffffff1a}.resource-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background .2s ease}.resource-table tbody tr:hover{background:#f8f9fa}.resource-table td{padding:1rem;font-size:.9rem}.resource-id{font-family:Monaco,Courier New,monospace;font-size:.85rem;color:#555;max-width:300px;overflow:hidden;text-overflow:ellipsis}.resource-name{font-weight:500;color:#1a1a1a}.resource-type-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.cost-cell{font-weight:600;color:#e74c3c;font-size:1rem}.center{text-align:center}.date-cell{color:#666;font-size:.85rem}.tags-count{background:#e3f2fd;color:#1976d2;padding:.25rem .5rem;border-radius:8px;font-size:.85rem}.no-tags{color:#999;font-style:italic;font-size:.85rem}.btn-details{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s ease}.btn-details:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.no-data{text-align:center;padding:3rem!important;color:#999;font-style:italic}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem}.btn-pagination{background:#fff;border:2px solid #667eea;color:#667eea;padding:.5rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease}.btn-pagination:hover:not(:disabled){background:#667eea;color:#fff;transform:translateY(-2px)}.btn-pagination:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.9rem;color:#666;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;max-width:800px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0}.modal-header h2{margin:0;font-size:1.5rem}.btn-close{background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;transition:transform .2s ease}.btn-close:hover{transform:scale(1.1)}.modal-body{padding:2rem}.detail-section{margin-bottom:2rem}.detail-section:last-child{margin-bottom:0}.detail-section h3{font-size:1.2rem;color:#667eea;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e0e0e0}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f0f0f0}.detail-row:last-child{border-bottom:none}.detail-row label{font-weight:600;color:#555;min-width:150px}.detail-value{flex:1;text-align:right;color:#1a1a1a}.detail-value.monospace{font-family:Monaco,Courier New,monospace;font-size:.9rem;word-break:break-all}.cost-highlight{font-size:1.5rem;font-weight:700;color:#e74c3c}.tags-list{display:flex;flex-direction:column;gap:.5rem}.tag-item{display:flex;gap:.5rem;padding:.5rem;background:#f8f9fa;border-radius:6px}.tag-key{font-weight:600;color:#667eea;min-width:150px}.tag-value{color:#1a1a1a;font-family:Monaco,Courier New,monospace;font-size:.9rem}.no-tags-message{color:#999;font-style:italic;text-align:center;padding:2rem}@media(max-width:768px){.resource-list-container{padding:1rem}.resource-controls{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.resource-stats{justify-content:center}.table-container{border-radius:8px}.modal-content{width:95%;max-height:95vh}.detail-row{flex-direction:column;align-items:flex-start;gap:.5rem}.detail-value{text-align:left}}.trenes-page{display:flex;flex-direction:column;gap:1rem}.trenes-filters{display:flex;flex-wrap:wrap;gap:.75rem;padding:1rem;align-items:end}.filter-group{display:flex;flex-direction:column;min-width:170px;gap:.35rem}.filter-group label{font-size:.85rem;color:#52606d}.filter-group select,.filter-group input{border:1px solid #d8e0eb;border-radius:10px;padding:.5rem .6rem}.btn-refresh{border:none;border-radius:12px;background:#3b82f6;color:#fff;padding:.6rem 1rem;cursor:pointer}.btn-refresh:disabled{opacity:.6;cursor:not-allowed}.period-chip{font-size:.92rem;color:#334155;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.7rem .9rem}.trenes-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:1200px){.trenes-grid{grid-template-columns:1fr 1fr}}.trenes-card{padding:1rem}.trenes-table{width:100%;border-collapse:collapse}.trenes-table th,.trenes-table td{border-bottom:1px solid #e2e8f0;padding:.55rem;font-size:.9rem}.item-name{max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-right{text-align:right}.up{color:#b91c1c;font-weight:600}.down{color:#047857;font-weight:600}.neumorph{background:var(--bg-card);box-shadow:8px 8px 16px var(--shadow-dark),-8px -8px 16px var(--shadow-light);border-radius:var(--border-radius);transition:var(--transition)}.neumorph-inset{background:var(--bg-card);box-shadow:inset 6px 6px 12px var(--shadow-dark),inset -6px -6px 12px var(--shadow-light);border-radius:var(--border-radius-sm);transition:var(--transition)}.neumorph-flat{background:var(--bg-card);box-shadow:4px 4px 8px var(--shadow-dark),-4px -4px 8px var(--shadow-light);border-radius:var(--border-radius-sm);transition:var(--transition)}.neumorph:hover{box-shadow:12px 12px 24px var(--shadow-dark),-12px -12px 24px var(--shadow-light)}.neumorph-pressed{box-shadow:inset 4px 4px 8px var(--shadow-dark),inset -4px -4px 8px var(--shadow-light)}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 1rem}@media(min-width:640px){.container{padding:0 1.5rem}}@media(min-width:1024px){.container{padding:0 2rem}}:root{--bg-primary: #f7f9fc;--bg-secondary: #ffffff;--bg-card: #ffffff;--text-primary: #2c3e50;--text-secondary: #6c7a89;--text-dark: #1a252f;--finops-blue: #0066CC;--finops-green: #00C48C;--focus-teal: #00A8B5;--accent-primary: #0066CC;--accent-secondary: #00C48C;--shadow-sm: 0 2px 4px rgba(0, 102, 204, .04);--shadow-md: 0 4px 8px rgba(0, 102, 204, .08);--shadow-lg: 0 8px 16px rgba(0, 102, 204, .12);--shadow-soft: 4px 4px 12px rgba(0, 102, 204, .06), -4px -4px 12px rgba(255, 255, 255, .9);--shadow-inset: inset 2px 2px 6px rgba(0, 102, 204, .06), inset -2px -2px 6px rgba(255, 255, 255, .8);--border-radius: 16px;--border-radius-sm: 8px;--transition: all .3s cubic-bezier(.4, 0, .2, 1);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden}#root{width:100%;min-height:100vh}
