.sidebar{width:240px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;transition:width .3s ease}.sidebar.collapsed{width:72px}.sidebar-header{padding:20px;border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;gap:12px;margin-bottom:4px}.logo-icon{color:var(--accent-blue);flex-shrink:0}.logo-text{font-size:18px;font-weight:700;color:var(--text-primary);white-space:nowrap}.logo-subtitle{font-size:12px;color:var(--text-secondary);margin-left:36px}.sidebar.collapsed .logo-text,.sidebar.collapsed .logo-subtitle{display:none}.sidebar-nav{flex:1;overflow-y:auto;padding:16px 0}.nav-section{margin-bottom:24px}.section-title{font-size:11px;font-weight:600;color:var(--text-muted);padding:8px 20px;letter-spacing:.5px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 20px;color:var(--text-secondary);text-decoration:none;transition:all .2s;position:relative;cursor:pointer}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:#3b82f61a;color:var(--accent-blue)}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-blue)}.nav-icon{flex-shrink:0}.nav-label{font-size:14px;font-weight:500;white-space:nowrap}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar.collapsed .nav-label{display:none}.collapse-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-top:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.collapse-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.collapse-button .rotated{transform:rotate(180deg)}.sidebar.collapsed .collapse-button span{display:none}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;height:64px;position:sticky;top:0;z-index:100}.header-left{flex:1;max-width:500px}.search-box{position:relative}.search-input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:8px 16px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--accent-blue)}.search-input::placeholder{color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:16px}.header-selector{display:flex;align-items:center;gap:8px}.selector-label{font-size:13px;color:var(--text-secondary);white-space:nowrap}.selector-dropdown{position:relative;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:6px 12px;min-width:200px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:border-color .2s}.selector-dropdown:hover{border-color:var(--accent-blue)}.selector-value{font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #0000004d;max-height:300px;overflow-y:auto;z-index:1000}.dropdown-item{padding:10px 16px;cursor:pointer;font-size:14px;color:var(--text-primary);transition:background .2s}.dropdown-item:hover{background:var(--bg-tertiary)}.dropdown-item.active{background:#3b82f61a;color:var(--accent-blue)}.dropdown-divider{height:1px;background:var(--border-color);margin:4px 0}.icon-button{position:relative;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.notification-badge{position:absolute;top:4px;right:4px;background:var(--accent-red);color:#fff;font-size:10px;font-weight:600;padding:2px 5px;border-radius:10px;min-width:16px;text-align:center}.user-menu{position:relative;display:flex;align-items:center;gap:12px;padding:4px 12px 4px 4px;border-radius:8px;cursor:pointer;transition:background .2s}.user-menu:hover{background:var(--bg-tertiary)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-purple);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.user-info{display:flex;flex-direction:column;align-items:flex-start}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.2}.user-email{font-size:12px;color:var(--text-secondary);line-height:1.2}.user-dropdown{right:0;left:auto;min-width:180px}.cost-dashboard{display:flex;flex-direction:column;gap:24px}.loading{text-align:center;padding:60px;color:var(--text-secondary);font-size:16px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.summary-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-label{font-size:13px;color:var(--text-secondary);font-weight:500}.card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center}.card-icon.blue{background:#3b82f61a;color:var(--accent-blue)}.card-icon.green{background:#10b9811a;color:var(--accent-green)}.card-icon.orange{background:#f59e0b1a;color:var(--accent-orange)}.card-icon.purple{background:#8b5cf61a;color:var(--accent-purple)}.card-value{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.card-change{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500}.card-change.positive{color:var(--accent-green)}.card-change.negative{color:var(--accent-red)}.card-meta{font-size:13px;color:var(--text-muted)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:20px}.chart-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px}.chart-header{margin-bottom:24px}.chart-header h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.chart-header p{font-size:13px;color:var(--text-secondary)}.pie-legend{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.legend-color{width:12px;height:12px;border-radius:2px}.legend-label{color:var(--text-secondary);flex:1}.legend-value{color:var(--text-primary);font-weight:600}.recommendations-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px}.section-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.savings-amount{color:var(--accent-green);font-weight:600}.view-all-button{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.view-all-button:hover{background:var(--bg-tertiary);border-color:var(--accent-blue);color:var(--accent-blue)}.recommendations-grid{display:flex;flex-direction:column;gap:12px}.recommendation-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:16px;transition:all .2s}.recommendation-card:hover{border-color:var(--accent-blue);transform:translate(4px)}.recommendation-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.recommendation-icon{width:40px;height:40px;border-radius:8px;background:#3b82f61a;color:var(--accent-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.recommendation-info{flex:1}.recommendation-info h4{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.recommendation-info p{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.recommendation-category{display:inline-block;background:var(--bg-secondary);color:var(--text-secondary);font-size:11px;font-weight:500;padding:4px 8px;border-radius:4px}.recommendation-footer{display:flex;justify-content:space-between;align-items:center;padding-left:52px}.savings{font-size:14px;font-weight:600;color:var(--accent-green)}.apply-button{background:var(--accent-blue);border:none;color:#fff;padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.apply-button:hover{background:#2563eb;transform:translateY(-1px)}.compliance-dashboard{display:flex;flex-direction:column;gap:24px}.score-card{grid-column:span 1}.score-container{display:flex;flex-direction:column;align-items:center;gap:16px}.score-circle{position:relative;width:120px;height:120px}.score-circle svg{transform:rotate(-90deg);width:100%;height:100%}.score-background{fill:none;stroke:var(--bg-tertiary);stroke-width:8}.score-progress{fill:none;stroke:var(--accent-green);stroke-width:8;stroke-linecap:round;stroke-dasharray:283;transition:stroke-dashoffset 1s ease}.score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px;font-weight:700;color:var(--text-primary)}.score-label{font-size:14px;font-weight:500;color:var(--text-secondary);text-align:center}.status-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.status-card .card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.status-card.passed .card-icon{background:#10b9811a;color:var(--accent-green)}.status-card.failed .card-icon{background:#ef44441a;color:var(--accent-red)}.status-card.warning .card-icon{background:#f59e0b1a;color:var(--accent-orange)}.status-card .card-value{font-size:36px;font-weight:700;color:var(--text-primary)}.status-card .card-label{font-size:13px;color:var(--text-secondary)}.checks-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px}.section-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.checks-table{display:flex;flex-direction:column}.table-header,.table-row{display:grid;grid-template-columns:140px 1fr 200px 140px;gap:16px;padding:12px 16px;align-items:center}.table-header{background:var(--bg-tertiary);border-radius:6px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.table-row{border-bottom:1px solid var(--border-color);font-size:14px;transition:background .2s}.table-row:hover{background:var(--bg-tertiary)}.table-row:last-child{border-bottom:none}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:capitalize}.status-badge.passed{background:#10b9811a;color:var(--accent-green)}.status-badge.failed{background:#ef44441a;color:var(--accent-red)}.status-badge.warning{background:#f59e0b1a;color:var(--accent-orange)}.col-name{color:var(--text-primary);font-weight:500}.col-resource code{background:var(--bg-tertiary);padding:4px 8px;border-radius:4px;font-size:12px;color:var(--accent-blue);font-family:Courier New,monospace}.col-time{color:var(--text-muted);font-size:13px}.resources-dashboard{display:flex;flex-direction:column;gap:24px}.resource-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.resource-summary-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:transform .2s,box-shadow .2s}.resource-summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.summary-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon.compute{background:#3b82f61a;color:var(--accent-blue)}.summary-icon.database{background:#ec48991a;color:var(--accent-pink)}.summary-icon.storage{background:#f59e0b1a;color:var(--accent-orange)}.summary-info{flex:1}.summary-label{font-size:13px;color:var(--text-secondary);margin-bottom:4px}.summary-value{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.summary-meta{font-size:12px;color:var(--text-muted)}.resources-table-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.section-subtitle{font-size:14px;color:var(--text-secondary)}.table-filters{display:flex;gap:8px}.filter-button{padding:8px 16px;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.filter-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.filter-button.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.resources-table{overflow-x:auto}.resources-table .table-header,.resources-table .table-row{display:grid;grid-template-columns:2fr 1.5fr 120px 150px 120px 120px 50px;gap:16px;padding:12px 16px;align-items:center}.resources-table .table-header{background:var(--bg-tertiary);border-radius:6px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.resources-table .table-row{border-bottom:1px solid var(--border-color);font-size:14px;transition:background .2s}.resources-table .table-row:hover{background:var(--bg-tertiary)}.resources-table .table-row:last-child{border-bottom:none}.col-name{display:flex;align-items:center;gap:8px;color:var(--text-primary);font-weight:500}.col-type{color:var(--text-secondary)}.col-region,.col-created{color:var(--text-muted);font-size:13px}.col-cost{color:var(--text-primary);font-weight:600}.action-button{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.action-button:hover{background:var(--bg-primary);color:var(--text-primary)}.dashboard-container{padding:24px;max-width:1600px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.dashboard-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.dashboard-subtitle{font-size:14px;color:var(--text-secondary)}.dashboard-updated{font-size:13px;color:var(--text-muted);background:var(--bg-tertiary);padding:8px 16px;border-radius:6px}.view-switcher{display:flex;gap:12px;margin-bottom:24px;padding:8px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.view-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;flex:1;justify-content:center}.view-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.view-button.active{background:var(--accent-blue);color:#fff}.dashboard-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f1724,#1a2332);padding:20px}.login-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000080}.login-header{text-align:center;margin-bottom:32px}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));border-radius:16px;color:#fff;margin-bottom:16px}.login-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.login-header p{font-size:14px;color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:20px}.error-message{background:#ef44441a;border:1px solid var(--accent-red);color:var(--accent-red);padding:12px 16px;border-radius:8px;font-size:14px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.input-wrapper{position:relative;display:flex;align-items:center;gap:12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;transition:border-color .2s}.input-wrapper:focus-within{border-color:var(--accent-blue)}.input-wrapper svg{color:var(--text-muted);flex-shrink:0}.input-wrapper input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14px}.input-wrapper input::placeholder{color:var(--text-muted)}.login-button{background:var(--accent-blue);border:none;color:#fff;padding:14px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.login-button:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color);text-align:center}.login-footer p{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.login-footer code{display:block;background:var(--bg-tertiary);padding:10px;border-radius:6px;font-size:12px;color:var(--accent-blue);font-family:Courier New,monospace}.app-layout{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.content-area{flex:1;overflow-y:auto;background:var(--bg-primary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary);gap:20px}.spinner{width:48px;height:48px;border:4px solid var(--bg-tertiary);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{color:var(--text-secondary);font-size:16px}.placeholder{padding:40px;text-align:center;color:var(--text-secondary);font-size:18px}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f1724;--bg-secondary: #1a2332;--bg-tertiary: #242d3d;--text-primary: #ffffff;--text-secondary: #9ca3af;--text-muted: #6b7280;--border-color: #2d3748;--accent-blue: #3b82f6;--accent-purple: #8b5cf6;--accent-green: #10b981;--accent-orange: #f59e0b;--accent-red: #ef4444;--accent-pink: #ec4899}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary)}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3d4859}.card{background:var(--bg-secondary);border-radius:8px;padding:20px;border:1px solid var(--border-color)}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.badge-running{background:#10b9811a;color:var(--accent-green)}.badge-high{background:#ef44441a;color:var(--accent-red)}.badge-medium{background:#f59e0b1a;color:var(--accent-orange)}.status-indicator{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:8px}.status-running{background:var(--accent-green)}.status-stopped{background:var(--text-muted)}
