*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#f5f5f5;color:#333;line-height:1.5}.header{background:#1a1a2e;color:#fff;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.header h1{font-size:20px;font-weight:600;white-space:nowrap}.header-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.header-controls select{padding:6px 10px;border-radius:4px;border:1px solid #555;background:#2a2a4a;color:#fff;font-size:14px;cursor:pointer}.btn{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:hover:not(:disabled){opacity:.85}.btn-fetch{background:#4caf50;color:#fff}.btn-export{background:#2196f3;color:#fff}.main-content{max-width:1200px;margin:0 auto;padding:20px 24px}.tab-toggle{display:flex;gap:0;margin-bottom:20px}.tab{padding:10px 24px;border:1px solid #ddd;background:#fff;font-size:14px;font-weight:500;cursor:pointer;color:#666;transition:all .15s}.tab:first-child{border-radius:4px 0 0 4px}.tab:last-child{border-radius:0 4px 4px 0;border-left:none}.tab.active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}.error-banner{background:#ffebee;color:#c62828;padding:10px 16px;border-radius:4px;margin-bottom:16px;font-size:14px;border:1px solid #ef9a9a}.loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px 0;color:#888;font-size:16px}.spinner{width:28px;height:28px;border:3px solid #ddd;border-top-color:#1a1a2e;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.view-container{display:flex;flex-direction:column;gap:16px}.section{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.section-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fafafa;border-left:4px solid #999;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.section-header:hover{background:#f0f0f0}.section-header-lob{border-left-color:#1a1a2e}.collapse-icon{font-size:16px;font-weight:700;width:18px;text-align:center;color:#666}.section-title{font-size:16px;font-weight:600}.section-count{font-size:13px;color:#888}.section-subtotal{margin-left:auto;font-size:15px;font-weight:600;color:#333}.empty-section{padding:20px 16px;text-align:center;color:#999;font-size:14px}.cost-table{width:100%;border-collapse:collapse;font-size:14px}.cost-table thead th{text-align:left;padding:10px 12px;background:#f8f8f8;border-bottom:2px solid #e0e0e0;font-weight:600;font-size:13px;color:#555;text-transform:uppercase;letter-spacing:.3px}.cost-table tbody tr:nth-child(2n){background:#fafafa}.cost-table tbody tr:hover{background:#f0f4ff}.cost-table td{padding:8px 12px;border-bottom:1px solid #eee;vertical-align:middle}.cost-cell{text-align:right!important;font-variant-numeric:tabular-nums;white-space:nowrap}.subtotal-row{background:#f0f0f0!important}.subtotal-row td{padding:10px 12px;font-weight:600;border-top:2px solid #ddd}.subtotal-label{text-align:right}.notes-input{width:100%;padding:4px 8px;border:1px solid #ddd;border-radius:3px;font-size:13px;font-family:inherit;background:#fff;transition:border-color .15s}.notes-input:focus{outline:none;border-color:#1a1a2e}.notes-input::placeholder{color:#bbb}.lob-select{padding:4px 8px;border:1px solid #ddd;border-radius:3px;font-size:13px;font-family:inherit;background:#fff;cursor:pointer;min-width:120px}.lob-select:focus{outline:none;border-color:#1a1a2e}.grand-total{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:#1a1a2e;color:#fff;border-radius:6px;font-size:16px;font-weight:600}.grand-total-amount{font-size:18px}.notes-cell{min-width:200px}.notes-inline{display:flex;align-items:center;gap:6px}.notes-history-btn{flex-shrink:0;width:22px;height:22px;border-radius:50%;border:none;background:#1a1a2e;color:#fff;font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.notes-history-btn:hover{background:#2196f3}.notes-history-row td{padding:0!important;border-bottom:2px solid #1a1a2e}.notes-history-panel{background:#f8f9fc;padding:12px 16px;border-top:1px solid #e0e0e0}.notes-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px}.notes-history-close{background:none;border:none;cursor:pointer;font-size:16px;color:#999;padding:2px 6px}.notes-history-close:hover{color:#333}.notes-history-loading,.notes-history-empty{color:#999;font-size:13px;padding:8px 0}.notes-history-list{list-style:none;padding:0;margin:0;max-height:200px;overflow-y:auto}.notes-history-list li{display:flex;gap:12px;padding:6px 0;border-bottom:1px solid #eee;font-size:13px}.notes-history-list li:last-child{border-bottom:none}.note-date{flex-shrink:0;color:#888;font-size:12px;min-width:140px}.note-text{color:#333}.login-container{display:flex;align-items:center;justify-content:center;min-height:80vh;padding:20px}.login-form{background:#fff;border-radius:8px;box-shadow:0 2px 12px #0000001a;padding:40px 36px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:24px}.login-header h2{font-size:22px;font-weight:600;color:#1a1a2e;margin-bottom:6px}.login-header p{font-size:14px;color:#888}.login-error{background:#ffebee;color:#c62828;padding:10px 14px;border-radius:4px;margin-bottom:16px;font-size:14px;border:1px solid #ef9a9a}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:6px}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .15s}.form-group input:focus{outline:none;border-color:#1a1a2e}.form-group input::placeholder{color:#bbb}.btn-login{width:100%;padding:12px;background:#1a1a2e;color:#fff;border:none;border-radius:4px;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .2s;margin-top:8px}.btn-login:hover:not(:disabled){opacity:.85}.btn-login:disabled{opacity:.5;cursor:not-allowed}.btn-logout{background:transparent;color:#ccc;border:1px solid #555;font-size:13px;padding:6px 14px}.btn-logout:hover{background:#ffffff1a;color:#fff}.backend-banner{padding:10px 20px;font-size:14px;text-align:center}.backend-checking{background:#e3f2fd;color:#1565c0}.backend-error{background:#ffebee;color:#c62828}.top-resource-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px;margin-bottom:24px}.top-resource-card h2{font-size:18px;margin-bottom:16px;color:#1a1a2e}.resource-highlight{display:flex;gap:24px;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;color:#fff;margin-bottom:16px}.resource-info{flex:1}.resource-name{font-size:18px;font-weight:600;margin-bottom:4px}.resource-group{font-size:13px;opacity:.9;margin-bottom:8px}.resource-meta{display:flex;gap:8px;font-size:12px;opacity:.85}.provider-badge{background:#fff3;padding:2px 6px;border-radius:3px;font-weight:500}.subscription{display:flex;align-items:center}.resource-cost{text-align:right}.cost-amount{font-size:24px;font-weight:700;margin-bottom:4px}.cost-percentage{font-size:13px;opacity:.9}.resource-details{background:#fafafa;padding:12px 16px;border-radius:4px;font-size:13px}.detail-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #eee}.detail-row:last-child{border-bottom:none}.detail-label{color:#666;font-weight:500}.detail-value{color:#333;font-weight:600}.line-item-expanded{background:#fff;border-radius:4px}.line-item-expanded table{width:100%}.service-column{display:flex;flex-direction:column;gap:4px}.service-name{font-weight:500}.resource-group-badge{font-size:11px;background:#e3f2fd;color:#1565c0;padding:2px 6px;border-radius:3px;display:inline-block;width:fit-content}.resource-groups-summary{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px;margin-bottom:20px}.resource-groups-summary h2{font-size:18px;margin-bottom:12px;color:#1a1a2e}.summary-stat{display:flex;justify-content:space-between;align-items:center;font-size:15px}.stat-label{color:#666;font-weight:500}.stat-value{font-size:20px;font-weight:700;color:#1a1a2e}.resource-groups-container{display:flex;flex-direction:column;gap:12px}.resource-group-card{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.resource-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#f8f9fa;border-left:4px solid #667eea;transition:background .15s}.resource-group-header:hover{background:#f0f1f3}.group-info{flex:1}.group-name{font-size:15px;font-weight:600;margin:0 0 4px;color:#1a1a2e}.item-count{font-size:12px;color:#888}.group-cost{text-align:right;min-width:140px}.expand-icon{color:#666;font-size:12px;flex-shrink:0;width:16px;text-align:center}.group-items{padding:0;border-top:1px solid #eee}.group-items .cost-table{margin:0}.group-items .cost-table tbody tr:first-child{border-top:1px solid #eee}
