*{box-sizing:border-box;margin:0;padding:0}body{background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}header{align-items:center;background:linear-gradient(135deg,#1a73e8,#0d47a1);color:#fff;display:flex;justify-content:space-between;padding:1rem 2rem}header h1{font-size:1.5rem}#user-info{align-items:center;display:flex;gap:1rem}#user-email{border-radius:4px;font-size:.9rem;opacity:.9;padding:.3rem .6rem;transition:background-color .2s,opacity .2s}#user-email:hover{background:hsla(0,0%,100%,.15);opacity:1}#logout-btn{background:transparent;border:1px solid hsla(0,0%,100%,.5);border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;padding:.4rem .8rem;transition:background-color .2s,border-color .2s}#logout-btn:hover{background:hsla(0,0%,100%,.1);border-color:#fff}.header-link{border-radius:4px;color:#fff;font-size:.85rem;padding:.4rem .8rem;text-decoration:none;transition:background-color .2s}.header-link:hover{background:hsla(0,0%,100%,.1)}main{margin:0 auto;max-width:1600px;padding:2rem}#summary{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2rem}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:1.5rem}.card h3{color:#666;font-size:.875rem;margin-bottom:.5rem}.card .value{font-size:1.75rem;font-weight:700}.card .monthly{color:#888;font-size:.9rem;margin-top:.25rem}.card .detail{color:#888;font-size:.85rem;margin-top:.25rem}.savings{color:#34a853}.potential{color:#fbbc04}.error{background:#fce8e6;border-radius:4px;color:#ea4335;padding:1rem}.empty{color:#666;padding:2rem;text-align:center}.chart-section{margin-bottom:2rem}.chart-section h3{color:#333;margin-bottom:1rem}.chart-section canvas{max-height:300px}table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);overflow:visible;width:100%}td,th{border-bottom:1px solid #eee;font-size:.9rem;padding:.75rem;text-align:left}th{background:#f8f9fa;font-weight:600}tr:hover{background:#f1f3f4}button{background:#666;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background .2s}button:hover{background:#555}button.primary{background:#1a73e8}button.primary:hover{background:#1557b0}button.success{background:#34a853}button.success:hover{background:#2d9048}button.danger{background:#ea4335}button.danger:hover{background:#d33426}.controls-bar{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);justify-content:space-between;margin-bottom:1.5rem;padding:1rem}.controls-bar,.filter-group{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.filter-group label{align-items:center;color:#666;display:flex;font-size:.9rem;gap:.5rem}.filter-group input,.filter-group select{border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem}.action-group{display:flex;gap:.5rem}.toggle-label{display:inline-block;height:26px;position:relative;width:50px}.toggle-label input{height:0;opacity:0;width:0}.slider{background-color:#ccc;border-radius:26px;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.3s}.slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:20px;left:3px;width:20px}input:checked+.slider{background-color:#34a853}input:checked+.slider:before{transform:translateX(24px)}.modal{align-items:center;background:rgba(0,0,0,.5);display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal.hidden{display:none}.modal-content{background:#fff;border-radius:8px;max-height:90vh;max-width:90%;overflow-y:auto;padding:2rem;width:500px}.modal-wide{max-width:95vw;width:800px}.modal-content h2{color:#333;margin-bottom:1.5rem}.modal-content label{color:#333;display:block;margin-bottom:1rem}.modal-content input[type=email],.modal-content input[type=number],.modal-content input[type=text],.modal-content select,.modal-content textarea{border:1px solid #ddd;border-radius:4px;font-size:.9rem;margin-top:.25rem;padding:.5rem;width:100%}.modal-content textarea{min-height:80px;resize:vertical}.modal-buttons{border-top:1px solid #eee;display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}.form-section{border-bottom:1px solid #eee;margin-bottom:1.5rem;padding-bottom:1rem}.form-section:last-of-type{border-bottom:none}.form-section h3{color:#1a73e8;font-size:1rem;margin-bottom:1rem}.form-row{display:flex;gap:1rem}.form-row label{flex:1}.ramp-options{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:.5rem}.ramp-option{border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;padding:1rem;transition:all .2s}.ramp-option:hover{border-color:#1a73e8}.ramp-option input[type=radio]{display:none}.ramp-option:has(input:checked){background:#e8f0fe;border-color:#1a73e8}.ramp-label{color:#333;font-weight:600;margin-bottom:.25rem}.ramp-desc{color:#666;font-size:.8rem}#custom-ramp-config{background:#f8f9fa;border-radius:8px;margin-top:1rem;padding:1rem}.tabs{background:#fff;border-bottom:2px solid #e0e0e0;display:flex;margin:0 auto;max-width:1600px;padding:0 2rem}.tab-btn{background:none;border:none;border-bottom:3px solid transparent;border-radius:0;color:#666;cursor:pointer;font-size:1rem;padding:1rem 1.5rem}.tab-btn:hover{background:#f5f5f5;color:#1a73e8}.tab-btn.active{border-bottom-color:#1a73e8;color:#1a73e8;font-weight:600}.tab-content{display:none}.tab-content.active{display:block}.date-range-picker{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem}.date-range-picker label{align-items:center;color:#666;display:flex;font-size:.9rem;gap:.5rem}.date-range-picker input[type=date],.date-range-picker select{border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem}#history-summary,#recommendations-summary{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem}#plans-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}#plans-header h2{margin:0}.plan-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);margin-bottom:1rem;overflow:hidden}.plan-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1rem 1.5rem}.plan-header h3{color:#333;margin:0}.plan-status{align-items:center;display:flex;gap:.5rem}.status-badge{border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.status-badge.active{background:#e6f4ea;color:#137333}.status-badge.paused{background:#fff3e0;color:#e65100}.status-badge.disabled{background:#f5f5f5;color:#666}.plan-body{padding:1.5rem}.plan-details{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1rem}.plan-detail{display:flex;flex-direction:column}.plan-detail-label{color:#666;font-size:.8rem;margin-bottom:.25rem}.plan-detail-value{color:#333;font-weight:600}.plan-actions{border-top:1px solid #eee;display:flex;gap:.5rem;padding-top:1rem}#upcoming-purchases{margin-top:2rem}#upcoming-purchases h2{margin-bottom:1rem}.upcoming-card{background:#fff;border-left:4px solid #1a73e8;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);justify-content:space-between;margin-bottom:.75rem;padding:1rem 1.5rem}.upcoming-card,.upcoming-info{align-items:center;display:flex}.upcoming-info{gap:2rem}.upcoming-date{min-width:80px;text-align:center}.upcoming-date .day{color:#1a73e8;font-size:1.5rem;font-weight:700}.upcoming-date .month{color:#666;font-size:.8rem}.upcoming-details h4{color:#333;margin:0 0 .25rem}.upcoming-details p{color:#666;font-size:.9rem;margin:0}.upcoming-savings{text-align:right}.upcoming-savings .amount{color:#34a853;font-size:1.25rem;font-weight:700}.upcoming-savings .label{color:#666;font-size:.8rem}#settings-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:2rem}#settings-section h2{color:#333;margin-bottom:.5rem}.settings-description{color:#666;margin-bottom:1.5rem}.settings-form{display:block}.settings-form.hidden{display:none}.settings-category{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.settings-category legend{color:#1a73e8;font-size:1.1rem;font-weight:600;padding:0 .5rem}.setting-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:1rem 0}.setting-row:last-child{border-bottom:none}.setting-info{align-items:center;display:flex;flex:1;gap:.5rem}.setting-info label{color:#333;font-weight:500;margin:0}.setting-input{align-items:center;display:flex;gap:1rem}.setting-input input[type=email],.setting-input input[type=number],.setting-input input[type=text],.setting-input select{border:1px solid #ddd;border-radius:4px;font-size:.9rem;min-width:200px;padding:.5rem}.setting-input input[type=number]{min-width:100px}.credential-status{background:#f5f5f5;border-radius:4px;color:#666;font-size:.9rem;padding:.25rem .75rem}.credential-status.configured{background:#e6f4ea;color:#137333}.settings-buttons{border-top:1px solid #e0e0e0;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem}.setting-row.sub-setting{border-left:2px solid #e0e0e0;margin-left:2rem;padding-left:1rem}.settings-help{color:#666;font-size:.85rem;font-style:italic;margin-bottom:1rem}.subsection-title{border-bottom:1px solid #e0e0e0;color:#333;font-size:.95rem;font-weight:600;margin:1.5rem 0 1rem;padding-bottom:.5rem}.provider-settings{background:#fafafa}.provider-settings.hidden{display:none}.provider-settings legend{align-items:center;display:flex;gap:.5rem}.service-defaults-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.service-default-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1rem}.service-default-card h5{color:#333;font-size:.9rem;font-weight:600;margin:0 0 .75rem}.service-default-card label{align-items:center;color:#666;display:flex;font-size:.85rem;gap:.5rem;margin-bottom:.5rem}.service-default-card label:last-child{margin-bottom:0}.service-default-card select{border:1px solid #ddd;border-radius:4px;flex:1;font-size:.85rem;padding:.35rem}.info-icon{color:#666;cursor:help;display:inline-block;font-size:.85rem;position:relative}.info-icon:hover{color:#1a73e8}.info-icon .tooltip-text{background-color:#333;border-radius:6px;bottom:125%;box-shadow:0 2px 8px rgba(0,0,0,.2);color:#fff;font-size:.8rem;font-weight:400;left:50%;line-height:1.4;opacity:0;padding:.75rem;position:absolute;text-align:left;transform:translateX(-50%);transition:opacity .2s,visibility .2s;visibility:hidden;white-space:normal;width:250px;z-index:1000}.info-icon .tooltip-text:after{border:6px solid transparent;border-top-color:#333;content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}.info-icon:hover .tooltip-text{opacity:1;visibility:visible}.help-text{color:#666;font-size:.875rem;margin-bottom:.75rem}.loading{color:#666;padding:2rem;text-align:center}.loading.hidden{display:none}.error-message{background:#fce8e6;border:1px solid #ea4335;border-radius:4px;color:#c5221f;margin-top:1rem;padding:1rem}.error-message.hidden{display:none}.provider-badge{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .5rem;text-transform:uppercase}.provider-badge.aws{background:#f90;color:#232f3e}.provider-badge.azure{background:#0078d4;color:#fff}.provider-badge.gcp{background:#4285f4;color:#fff}.service-badge{background:#e8f0fe;border-radius:4px;color:#1a73e8;display:inline-block;font-size:.75rem;padding:.2rem .5rem}.checkbox-col{text-align:center;width:40px}.checkbox-col input[type=checkbox]{cursor:pointer;height:18px;width:18px}tr.selected{background:#e8f0fe!important}tr.high-savings{border-left:3px solid #34a853}tr.medium-savings{border-left:3px solid #fbbc04}.modal-overlay{align-items:center;background:rgba(0,0,0,.5);display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-hint{background:#f8f9fa;border-radius:4px;font-size:.9rem;margin-bottom:1.5rem;padding:1rem}.modal-hint a{color:#1a73e8;font-weight:500;text-decoration:none}.modal-hint a:hover{text-decoration:underline}@media (max-width:768px){header{gap:1rem}.controls-bar,header{flex-direction:column}.filter-group{width:100%}table{display:block;overflow-x:auto}.modal-content{width:95%}.tabs{overflow-x:auto;padding:0 1rem}.tab-btn{font-size:.9rem;padding:.75rem 1rem;white-space:nowrap}.form-row{flex-direction:column}.ramp-options{grid-template-columns:1fr}.upcoming-card{gap:1rem}.upcoming-card,.upcoming-info{align-items:flex-start;flex-direction:column}.upcoming-info{gap:.5rem}.plan-details{grid-template-columns:1fr 1fr}}#planned-purchases-header{border-top:1px solid #e0e0e0;margin-top:2rem;padding-top:2rem}#planned-purchases-header h2{margin-bottom:.5rem}#planned-purchases-header .help-text{color:#666;font-size:.9rem;margin-bottom:1rem}.planned-purchases-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);overflow:hidden;width:100%}.planned-purchases-table td,.planned-purchases-table th{border-bottom:1px solid #e0e0e0;padding:.75rem 1rem;text-align:left}.planned-purchases-table th{background:#f8f9fa;color:#555;font-size:.85rem;font-weight:600}.planned-purchases-table tbody tr:hover{background:#f8f9fa}.planned-purchase-row .plan-name{display:block;font-weight:500}.planned-purchase-row .step-info{color:#888;font-size:.8rem}.planned-purchase-row .actions{white-space:nowrap}.btn-small{background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:.85rem;margin-right:.25rem;padding:.25rem .5rem}.btn-small:hover{background:#e8e8e8;border-color:#bbb}.btn-small.primary{background:#1a73e8;border-color:#1a73e8;color:#fff}.btn-small.primary:hover{background:#1557b0;border-color:#1557b0}.btn-small.success{background:#34a853;border-color:#34a853;color:#fff}.btn-small.success:hover{background:#2d9048;border-color:#2d9048}.btn-small.warning{background:#fbbc04;border-color:#fbbc04;color:#333}.btn-small.warning:hover{background:#f9a825;border-color:#f9a825}.btn-small.danger{background:#fce8e6;border-color:#ea4335;color:#c5221f}.btn-small.danger:hover{background:#ea4335;color:#fff}.status-pending{color:#fbbc04}.status-paused{color:#9e9e9e}.status-running{color:#1a73e8}.status-completed{color:#34a853}.status-failed{color:#ea4335}.planned-purchases-table .status-badge{border-radius:4px;font-size:.8rem;font-weight:500;padding:.25rem .5rem;text-transform:capitalize}.planned-purchases-table .status-badge.status-pending{background:#fef3cd;color:#856404}.planned-purchases-table .status-badge.status-paused{background:#e9ecef;color:#495057}.planned-purchases-table .status-badge.status-running{background:#cce5ff;color:#004085}.planned-purchases-table .status-badge.status-completed{background:#d4edda;color:#155724}.planned-purchases-table .status-badge.status-failed{background:#f8d7da;color:#721c24}@media (max-width:1200px){.planned-purchases-table{display:block;overflow-x:auto}}footer{background:#f8f9fa;border-top:1px solid #e0e0e0;margin-top:2rem;padding:1.5rem 2rem;text-align:center}footer a{color:#1a73e8;font-size:.9rem;text-decoration:none}footer a:hover{text-decoration:underline}.modal-description{color:#666;font-size:.9rem;margin-bottom:1rem}.cli-alternative{border-top:1px solid #e0e0e0;margin-top:1.5rem;padding-top:1rem}.cli-alternative p{color:#666;font-size:.85rem;margin-bottom:.5rem}.cli-command{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;display:flex;gap:.5rem;padding:.5rem .75rem}.cli-command code{background:none;color:#333;flex:1;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem;padding:0}.copy-btn{background:none;border:none;border-radius:4px;cursor:pointer;padding:.25rem;transition:background .2s}.copy-btn:hover{background:#e0e0e0}.copy-btn .copy-icon{font-size:1rem}.copy-btn.copied{color:#4caf50}.btn-small{font-size:.8rem;margin-left:.5rem;padding:.25rem .75rem}.prereq-section{background:#f0f7ff;border:1px solid #b3d4fc;border-radius:6px;margin-bottom:1.5rem;padding:1rem}.prereq-section h4{color:#1a73e8;font-size:.95rem;margin:0 0 .5rem}.prereq-description{color:#555;font-size:.85rem;margin-bottom:.75rem}.prereq-section .cli-command{margin-bottom:.5rem}.prereq-section .cli-command code{font-size:.8rem;word-break:break-all}.prereq-hint{color:#666;font-size:.8rem;font-style:italic;margin-bottom:0;margin-top:.75rem}.modal-content h4{color:#333;font-size:.95rem;margin:0 0 .75rem}
/*# sourceMappingURL=app.12684709.css.map*/