:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--bg-card: #1c2128;--bg-hover: #2d333b;--text-primary: #f0f6fc;--text-secondary: #c9d1d9;--text-muted: #8b949e;--accent-blue: #0ea5e9;--accent-primary: #0ea5e9;--accent-purple: #7c3aed;--accent-green: #22c55e;--accent-orange: #f59e0b;--accent-red: #ef4444;--accent-cyan: #38bdf8;--money-positive: #22c55e;--money-negative: #ef4444;--money-neutral: #f0f6fc;--border-color: #30363d;--border-light: #484f58;--gradient-primary: linear-gradient(135deg, #0ea5e9 0%, #38bdf8 100%);--gradient-success: linear-gradient(135deg, #22c55e 0%, #4ade80 100%);--gradient-warning: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(14, 165, 233, .3);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100}.sidebar-header{padding:24px;border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px}.logo-text{font-size:18px;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:0 12px;margin-bottom:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;margin-bottom:4px}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:#3b82f626;color:var(--accent-blue)}.nav-item.active:before{content:"";position:absolute;left:0;width:3px;height:24px;background:var(--accent-blue);border-radius:0 2px 2px 0}.nav-icon{width:20px;height:20px}.main-content{flex:1;margin-left:260px;min-height:100vh}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:16px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-title{font-size:24px;font-weight:700}.header-actions{display:flex;align-items:center;gap:16px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s ease}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px #3b82f680}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn-success{background:var(--gradient-success);color:#fff}.btn-icon{padding:10px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;transition:all .3s ease}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:16px;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:13px;color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;padding:24px 32px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card.blue:before{background:var(--accent-blue)}.stat-card.green:before{background:var(--accent-green)}.stat-card.purple:before{background:var(--accent-purple)}.stat-card.orange:before{background:var(--accent-orange)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:16px}.stat-icon.blue{background:#3b82f626;color:var(--accent-blue)}.stat-icon.green{background:#10b98126;color:var(--accent-green)}.stat-icon.purple{background:#8b5cf626;color:var(--accent-purple)}.stat-icon.orange{background:#f59e0b26;color:var(--accent-orange)}.stat-value{font-size:28px;font-weight:700;margin-bottom:4px}.stat-label{font-size:14px;color:var(--text-muted)}.stat-change{display:inline-flex;align-items:center;gap:4px;font-size:13px;padding:4px 8px;border-radius:20px;margin-top:12px}.stat-change.up{background:#10b98126;color:var(--accent-green)}.stat-change.down{background:#ef444426;color:var(--accent-red)}.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;padding:0 32px 32px}@media(max-width:1200px){.content-grid{grid-template-columns:1fr}}.chart-container{height:300px}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-color)}th{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-tertiary)}th:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}th:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}td{font-size:14px;color:var(--text-secondary)}tr:hover td{background:var(--bg-hover)}.provider-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:500}.provider-badge.aws{background:#ff990026;color:#f90}.provider-badge.gcp{background:#4285f426;color:#4285f4}.provider-badge.azure{background:#0078d426;color:#0078d4}.provider-badge.cloudflare{background:#f59e0b26;color:#f59e0b}.provider-badge.atlassian{background:#0052cc26;color:#0052cc}.upload-area{border:2px dashed var(--border-light);border-radius:var(--radius-xl);padding:48px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-tertiary)}.upload-area:hover{border-color:var(--accent-blue);background:#3b82f60d}.upload-area.dragover{border-color:var(--accent-blue);background:#3b82f61a;transform:scale(1.02)}.upload-icon{width:64px;height:64px;margin:0 auto 16px;color:var(--accent-blue)}.upload-title{font-size:18px;font-weight:600;margin-bottom:8px}.upload-subtitle{color:var(--text-muted);margin-bottom:16px}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{padding:24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:20px;font-weight:700}.modal-close{width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-tertiary);border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:500;margin-bottom:8px;color:var(--text-secondary)}.form-input,.form-select{width:100%;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);transition:all .2s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f633}.form-input::placeholder{color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.toast{position:fixed;bottom:24px;right:24px;padding:16px 24px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease;z-index:2000}.toast.success{border-left:4px solid var(--accent-green)}.toast.error{border-left:4px solid var(--accent-red)}.toast.warning{border-left:4px solid var(--accent-orange)}.empty-state{text-align:center;padding:48px}.empty-icon{width:80px;height:80px;margin:0 auto 24px;color:var(--text-muted);opacity:.5}.empty-title{font-size:18px;font-weight:600;margin-bottom:8px}.empty-text{color:var(--text-muted);margin-bottom:24px}.loading{display:flex;align-items:center;justify-content:center;padding:48px}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.money-value{font-family:var(--font-mono);font-weight:600;letter-spacing:-.02em}.money-positive{color:var(--money-positive)!important}.money-negative{color:var(--money-negative)!important}.money-lg{font-size:28px;font-weight:700}.highlight-amount{display:inline-flex;align-items:center;padding:4px 12px;background:linear-gradient(135deg,#0ea5e91a,#22c55e0d);border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-sm);font-family:var(--font-mono);font-weight:600}.highlight-warning{background:#f59e0b1a;border-color:#f59e0b4d;color:var(--accent-orange)}.highlight-danger{background:#ef44441a;border-color:#ef44444d;color:var(--accent-red)}.highlight-success{background:#22c55e1a;border-color:#22c55e4d;color:var(--accent-green)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.status-badge.active,.status-badge.paid{background:#22c55e26;color:var(--accent-green)}.status-badge.pending,.status-badge.expiring{background:#f59e0b26;color:var(--accent-orange)}.status-badge.overdue,.status-badge.expired{background:#ef444426;color:var(--accent-red)}table tbody tr:nth-child(2n) td{background:#21262d80}table td.amount,table th.amount{text-align:right;font-family:var(--font-mono)}.metric-card{position:relative;overflow:hidden}.metric-card:after{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle,rgba(14,165,233,.1) 0%,transparent 70%);pointer-events:none}.metric-card .metric-value{font-size:32px;font-weight:700;font-family:var(--font-mono);letter-spacing:-.02em;margin-bottom:4px}.metric-card .metric-label{font-size:13px;color:var(--text-muted);font-weight:500}.pulse-warning{animation:pulseWarning 2s ease-in-out infinite}@keyframes pulseWarning{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 8px #f59e0b00}}.data-grid .value{font-family:var(--font-mono);font-weight:600;text-align:right}@media(max-width:768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.stats-grid{grid-template-columns:1fr}}.tbm-dashboard{padding:24px 32px}.tbm-dashboard .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--text-muted)}.tbm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.tbm-title{display:flex;align-items:center;gap:16px}.tbm-title svg{color:var(--accent-purple)}.tbm-title h2{font-size:24px;font-weight:700;background:linear-gradient(135deg,#8b5cf6,#06b6d4);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:2px}.tbm-title p{font-size:13px;color:var(--text-muted)}.currency-toggle{display:flex;gap:4px;background:var(--bg-tertiary);padding:4px;border-radius:var(--radius-md)}.currency-toggle button{padding:8px 20px;border:none;background:transparent;color:var(--text-muted);font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s}.currency-toggle button.active{background:var(--gradient-primary);color:#fff}.currency-toggle button:hover:not(.active){color:var(--text-primary)}.tbm-layers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}@media(max-width:1200px){.tbm-layers-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.tbm-layers-grid{grid-template-columns:1fr}}.tbm-layer-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;display:flex;gap:16px}.tbm-layer-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.tbm-layer-card.active{border-color:var(--accent-purple);background:linear-gradient(135deg,#8b5cf61a,#06b6d40d)}.layer-active-indicator{position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-purple),var(--accent-cyan))}.layer-icon{width:48px;height:48px;border-radius:var(--radius-md);background:#8b5cf626;display:flex;align-items:center;justify-content:center;color:var(--accent-purple);flex-shrink:0}.layer-info h3{font-size:14px;font-weight:600;margin-bottom:4px}.layer-description{font-size:12px;color:var(--text-muted);margin-bottom:8px}.layer-total{font-size:18px;font-weight:700;color:var(--accent-cyan)}.tbm-visualization{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.viz-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.viz-header h3{font-size:18px;font-weight:600}.viz-total{font-size:14px;color:var(--text-muted);padding:6px 12px;background:var(--bg-tertiary);border-radius:20px}.viz-content{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}@media(max-width:1000px){.viz-content{grid-template-columns:1fr}}.viz-chart{min-height:350px}.viz-table{overflow-x:auto}.viz-table table{width:100%}.viz-table th,.viz-table td{padding:12px;font-size:13px}.viz-table .amount{font-weight:600;color:var(--accent-green);text-align:right}.viz-table .percent{text-align:right;color:var(--text-muted)}.viz-table .count{text-align:center;color:var(--text-muted)}.color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}.category-tag{display:inline-block;font-size:10px;padding:2px 8px;background:var(--bg-tertiary);border-radius:10px;margin-left:8px;color:var(--text-muted)}.tbm-tooltip{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px 16px;box-shadow:var(--shadow-lg)}.tbm-tooltip-name{font-weight:600;margin-bottom:4px}.tbm-tooltip-value{font-size:16px;font-weight:700;color:var(--accent-cyan)}.tbm-tooltip-count{font-size:12px;color:var(--text-muted);margin-top:4px}.tbm-tooltip-category{font-size:11px;color:var(--accent-purple);margin-top:4px}.tbm-model{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}.tbm-model h3{font-size:18px;font-weight:600;margin-bottom:24px;text-align:center}.tbm-model-diagram{display:flex;flex-direction:column;gap:12px;max-width:800px;margin:0 auto}.model-layer{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px;position:relative}.model-layer .layer-label{position:absolute;top:-10px;left:16px;font-size:10px;font-weight:600;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.model-layer .layer-title{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--accent-purple)}.model-layer .layer-items{display:flex;flex-wrap:wrap;gap:8px}.model-layer .layer-item{font-size:12px;padding:4px 12px;border-radius:20px;border:1px solid;background:#8b5cf61a;border-color:var(--accent-purple);color:var(--text-primary)}.model-layer .layer-item.consumer{background:#10b9811a;border-color:var(--accent-green)}.model-arrow{text-align:center;font-size:20px;color:var(--text-muted)}.model-layer.layer-1 .layer-title{color:#3b82f6}.model-layer.layer-2 .layer-title{color:#f97316}.model-layer.layer-3 .layer-title{color:#8b5cf6}.model-layer.layer-4 .layer-title{color:#10b981}.yody-page{padding:24px 32px}.yody-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--text-muted)}.yody-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.yody-title{display:flex;align-items:center;gap:16px}.yody-title svg{color:var(--accent-purple)}.yody-title h2{font-size:24px;font-weight:700;margin-bottom:2px}.yody-title p{font-size:13px;color:var(--text-muted)}.header-controls{display:flex;gap:16px;align-items:center}.yody-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--border-color);padding-bottom:16px}.tab-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;background:var(--bg-tertiary);color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:all .2s}.tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.tab-btn.active{background:var(--gradient-primary);color:#fff}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.section-header h3{font-size:18px;font-weight:600}.badge{font-size:12px;padding:4px 10px;background:var(--accent-purple);color:#fff;border-radius:12px}.line-items-table{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.table-header{display:grid;grid-template-columns:80px 1fr 70px 150px 120px 100px 200px;gap:8px;padding:12px 16px;background:var(--bg-tertiary);font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.line-item-group{border-bottom:1px solid var(--border-color)}.line-item-group:last-child{border-bottom:none}.group-header{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;background:var(--bg-secondary);transition:background .2s}.group-header:hover{background:var(--bg-hover)}.group-name{font-weight:600;flex:1}.group-count{font-size:12px;color:var(--text-muted);padding:2px 10px;background:var(--bg-tertiary);border-radius:10px}.group-items{background:var(--bg-primary)}.line-item-row{display:grid;grid-template-columns:80px 1fr 70px 150px 120px 100px 200px;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-color);font-size:13px;align-items:center}.line-item-row:last-child{border-bottom:none}.line-item-row:hover{background:var(--bg-hover)}.code-badge{display:inline-block;font-size:11px;font-weight:600;padding:4px 8px;border-radius:6px;font-family:var(--font-mono)}.code-badge.capex{background:#3b82f626;color:#3b82f6}.code-badge.opex{background:#10b98126;color:#10b981}.item-name{font-weight:500}.item-name-en{font-size:11px;color:var(--text-muted)}.type-badge{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600}.type-badge.capex{background:#3b82f626;color:#3b82f6}.type-badge.opex{background:#10b98126;color:#10b981}.col-tower,.col-pic,.col-center{font-size:12px;color:var(--text-secondary)}.tbm-badges{display:flex;flex-wrap:wrap;gap:4px}.tbm-badge{font-size:10px;padding:2px 6px;border-radius:4px;border:1px solid}.consumers-section{min-height:600px}.consumers-grid{display:grid;grid-template-columns:300px 1fr;gap:24px}@media(max-width:1000px){.consumers-grid{grid-template-columns:1fr}}.consumer-list{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px}.consumer-list h3{font-size:14px;margin-bottom:16px;color:var(--text-muted)}.consumer-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;margin-bottom:8px}.consumer-card:hover{background:var(--bg-hover)}.consumer-card.active{background:#8b5cf626;border:1px solid var(--accent-purple)}.consumer-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--accent-purple)}.consumer-info{flex:1}.consumer-name{font-weight:500;font-size:14px}.consumer-type{font-size:11px;color:var(--text-muted)}.consumer-detail{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}.detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-muted);gap:16px}.detail-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.detail-header h3{font-size:20px;margin-bottom:16px}.detail-stats{display:flex;gap:32px}.detail-stats .stat{display:flex;flex-direction:column}.detail-stats .stat-value{font-size:24px;font-weight:700;color:var(--accent-cyan)}.detail-stats .stat-label{font-size:12px;color:var(--text-muted)}.detail-section{margin-bottom:24px}.detail-section h4{font-size:14px;margin-bottom:12px;color:var(--text-muted)}.breakdown-list{display:flex;flex-direction:column;gap:8px}.breakdown-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.provider-dot{width:10px;height:10px;border-radius:50%}.breakdown-name{flex:1;font-weight:500}.breakdown-amount{font-weight:600;color:var(--accent-green)}.breakdown-count{font-size:12px;color:var(--text-muted)}.solution-badge{font-size:10px;padding:2px 8px;background:var(--accent-purple);color:#fff;border-radius:10px}.bills-table{max-height:300px;overflow-y:auto}.bills-table table{width:100%}.bills-table td.amount{font-weight:600;color:var(--accent-green);text-align:right}.period-report-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}.report-controls{display:flex;gap:16px;margin-bottom:24px}.control-group{display:flex;align-items:center;gap:8px}.control-group label{font-size:13px;color:var(--text-muted)}.control-group select{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px}.report-section{margin-bottom:32px}.report-section h3{font-size:16px;margin-bottom:16px}.period-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.period-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;text-align:center}.period-label{font-size:12px;color:var(--text-muted);margin-bottom:8px}.period-amount{font-size:16px;font-weight:700;color:var(--accent-cyan)}.period-count{font-size:11px;color:var(--text-muted);margin-top:4px}.report-table{width:100%;border-collapse:collapse}.report-table th,.report-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border-color);font-size:13px}.report-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-muted)}.report-table td.amount{font-weight:600;color:var(--accent-green);text-align:right}.type-tag{font-size:10px;padding:2px 8px;background:var(--bg-tertiary);border-radius:10px;color:var(--text-muted)}.app{display:flex;min-height:100vh}
