body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{background-color:#f5f7fa;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}header{background-color:#232f3e;box-shadow:0 2px 4px #0000001a;color:#fff;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1rem}.logo{color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none}.logo span{color:#f90}.nav-menu{display:flex;gap:1.5rem}.nav-item{color:#fff;font-weight:500;text-decoration:none;transition:color .3s}.nav-item:hover{color:#f90}main{padding:2rem 0}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.card{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;margin-bottom:2rem;padding:1.5rem}.card-title{border-bottom:2px solid #f90;color:#232f3e;font-size:1.5rem;margin-bottom:1rem;padding-bottom:.5rem}.card-highlight{background-color:#f0f7ff;border-left:4px solid #0073bb;border-radius:4px;margin-bottom:1.5rem;padding:1rem}.form-group{margin-bottom:1rem}.form-control{border:1px solid #ddd;padding:.75rem}.form-actions{margin-top:1.5rem}.btn{border:none;border-radius:4px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:background-color .3s,transform .1s}.btn:hover{transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.7}.btn-primary{background-color:#0073bb;color:#fff}.btn-primary:hover{background-color:#005d99}.btn-success{background-color:#1e8a3e;color:#fff}.btn-success:hover{background-color:#166d31}.btn-outline{background-color:initial;border:1px solid #0073bb;color:#0073bb}.btn-outline:hover{background-color:#f0f7ff}.permissions-list{margin-top:1.5rem}.permission-item{border-bottom:1px solid #eee}.permission-status{font-size:.875rem;margin-left:auto}.status-granted{background-color:#e6f4ea;color:#1e8a3e}.status-denied{background-color:#fce8e6;color:#d93025}.status-unchecked{background-color:#f1f3f4;color:#5f6368}.summary-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-bottom:1.5rem}.summary-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;padding:1.5rem;text-align:center}.summary-value{font-size:2rem;font-weight:700;margin:.5rem 0}.summary-label{color:#5f6368;font-size:.875rem}.resources-table td,.resources-table th{border-bottom:1px solid #eee;padding:.75rem;text-align:left}.resources-table th{background-color:#f5f7fa}.recommendation-card{background-color:#fff;border-left:4px solid #0073bb;box-shadow:0 2px 10px #0000000d}.recommendation-card.high-priority{border-left-color:#d93025}.recommendation-card.medium-priority{border-left-color:#f9ab00}.recommendation-card.low-priority{border-left-color:#1e8a3e}.recommendation-header{align-items:center}.recommendation-title{font-size:1.25rem;font-weight:600;margin:0}.recommendation-savings{background-color:#e6f4ea;color:#1e8a3e;padding:.25rem .75rem}.recommendation-details{color:#5f6368}.recommendation-resource{color:#5f6368;font-size:.875rem}.fade-in{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.error-message{background-color:#fce8e6;color:#d93025;margin-bottom:1rem}.loading-spinner{height:100px}.spinner{border:4px solid #0000001a;border-left-color:#0073bb;height:30px;width:30px}.permissions-button-container{margin-top:20px}.permissions-json-container{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:15px;padding:15px}.permissions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.permissions-json{background-color:#272822;border-radius:5px;color:#f8f8f2;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.5;overflow-x:auto;padding:15px}.permissions-footer{color:#6c757d;font-style:italic;margin-top:15px}.missing-permissions{background-color:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;margin-top:20px;padding:15px}.missing-permissions h4{color:#856404;margin-bottom:10px;margin-top:0}.missing-permissions ul{margin-bottom:15px}.missing-permissions code{background-color:#f8f9fa;border-radius:3px;font-family:Courier New,Courier,monospace;padding:2px 5px}.footer{background-color:#232f3e;color:#fff;margin-top:3rem;padding:1.5rem 0;text-align:center}.footer-content{margin:0 auto;max-width:1200px;padding:0 1rem}.footer-text{font-size:.9rem;margin:0}.footer-company{color:#f90;font-weight:700}.app-title{margin:2rem 0;text-align:center}.app-title h1{color:#232f3e;font-size:2.5rem;margin-bottom:.5rem}.app-title p{color:#5f6368;font-size:1.1rem}.header-actions{align-items:center;display:flex;gap:.5rem;height:40px}.export-btn,.import-btn{align-items:center;background-color:#f90;border:none;border-radius:4px;box-sizing:border-box;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;height:36px;justify-content:center;min-width:80px;padding:.5rem 1rem;text-decoration:none;transition:background-color .3s;vertical-align:middle}.export-btn:hover,.import-btn:hover{background-color:#e68900}.export-btn:disabled{background-color:#666;cursor:not-allowed}.dashboard-expanded{background:linear-gradient(135deg,#fff,#f8f9fa 50%,#e3f2fd);border:1px solid #e1e8ed;box-shadow:0 8px 32px #0000000f;color:#333}.dashboard-expanded .card-title{border-bottom:2px solid #2196f3;color:#1976d2;font-size:1.8rem;margin-bottom:1.5rem}.dashboard-expanded .summary-grid{margin-bottom:2rem}.dashboard-expanded .summary-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #2196f31a;box-shadow:0 4px 12px #1976d214}.dashboard-expanded h3{color:#1976d2;margin-bottom:1rem}.chart-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;padding:1.5rem}.chart-bars{align-items:flex-end;display:flex;gap:1rem;height:280px;justify-content:space-around;padding:0 5%}.chart-bar-container{align-items:center;display:flex;flex-direction:column;min-width:80px}.chart-bar{border-radius:5px 5px 0 0;box-shadow:0 4px 8px #0003;margin-bottom:10px;transition:transform .3s ease;width:60px}.chart-bar:hover{transform:scale(1.05)}.chart-label{color:#2c3e50;font-size:.8rem;font-weight:600;margin-bottom:5px;text-align:center;text-shadow:1px 1px 2px #fffc}.chart-value{color:#f90;font-size:.9rem;font-weight:700}.collapsible-section{margin-top:1.5rem}.collapsible-header{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#495057;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;justify-content:space-between;margin-bottom:0;padding:1rem 1.5rem;transition:all .3s ease;width:100%}.collapsible-header:hover{background:#e9ecef;box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.collapsible-header span:first-child{align-items:center;display:flex;gap:.5rem}.arrow{color:#6c757d;font-size:.8rem;transition:transform .3s ease}.arrow.expanded{transform:rotate(180deg)}.collapsible-content{animation:slideDown .3s ease-out;background:#fff;border:1px solid #dee2e6;border-radius:0 0 8px 8px;border-top:none;padding:1.5rem}@keyframes slideDown{0%{max-height:0;opacity:0;padding-bottom:0;padding-top:0}to{max-height:1000px;opacity:1;padding-bottom:1.5rem;padding-top:1.5rem}}.permissions-list{background:#f8f9fa;border-radius:8px;padding:1rem}.permission-item{align-items:center;background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;padding:.75rem}.permission-status{border-radius:20px;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.status-granted{background:#d4edda;color:#155724}.status-denied{background:#f8d7da;color:#721c24}.status-unchecked{background:#fff3cd;color:#856404}.recommendations-summary{background:linear-gradient(135deg,#28a745,#20c997);border-radius:8px;color:#fff;font-size:1.1rem;margin-bottom:1.5rem;padding:1rem 1.5rem;text-align:center}.recommendation-card{background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.recommendation-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.recommendation-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.recommendation-header h3{color:#495057;font-size:1.2rem;margin:0}.recommendation-savings{background:#28a745;border-radius:20px;color:#fff;font-size:.9rem;font-weight:600;padding:.5rem 1rem}.recommendation-details{color:#6c757d;line-height:1.6;margin-bottom:1rem}.recommendation-resource{border-top:1px solid #dee2e6;color:#495057;font-size:.9rem;padding-top:1rem}.resources-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:1rem;overflow:hidden;width:100%}.resources-table th{background:#495057;color:#fff;font-weight:600;padding:1rem;text-align:left}.resources-table td{border-bottom:1px solid #dee2e6;padding:.75rem 1rem}.resources-table tr:hover{background:#f8f9fa}.status-badge{border-radius:20px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.status-running{background:#d4edda;color:#155724}.status-stopped{background:#f8d7da;color:#721c24}.status-pending{background:#fff3cd;color:#856404}.loading-spinner{align-items:center;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;justify-content:center;margin:2rem 0;padding:3rem}.loading-spinner p{color:#6c757d;font-weight:500;margin-top:1rem}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#f90;height:50px;width:50px}@media (max-width:768px){.header-container{flex-direction:column;gap:1rem}.nav-menu{order:2}.header-actions{order:1}.summary-grid{grid-template-columns:1fr 1fr}.chart-bars{flex-wrap:wrap;gap:.5rem;height:auto}.chart-bar-container{min-width:60px}.recommendation-header{flex-direction:column;gap:1rem}}@media (max-width:480px){.summary-grid{grid-template-columns:1fr}.header-actions{flex-direction:column;width:100%}.export-btn,.import-btn{text-align:center;width:100%}}.checkbox-label{align-items:center;cursor:pointer;display:flex!important;font-weight:400!important;gap:.5rem;margin-bottom:1rem!important}.checkbox-label input[type=checkbox]{flex-shrink:0;margin:0!important;width:auto!important}.form-options{border-top:1px solid #dee2e6;margin-top:1.5rem;padding-top:1.5rem}.form-options .checkbox-label{color:#6c757d;font-size:.9rem}.security-notice{align-items:flex-start;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.security-icon{color:#28a745;flex-shrink:0;margin-top:.25rem}.security-icon svg{height:32px;width:32px}.security-content{flex:1 1}.security-content h3{color:#28a745;font-size:1.2rem;font-weight:600;margin:0 0 1rem}.security-content p{color:#495057;line-height:1.5;margin:0 0 .75rem}.security-content p:last-child{margin-bottom:0}.projection-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1rem}.projection-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #0000001a;color:#fff;padding:1.5rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.projection-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.projection-period{font-size:.9rem;font-weight:600;margin-bottom:.5rem;opacity:.9}.projection-value{font-size:2rem;font-weight:700;margin:.5rem 0;text-shadow:0 2px 4px #0000004d}.projection-label{font-size:.85rem;margin-top:.5rem;opacity:.8}.savings-badge{background:linear-gradient(135deg,#28a745,#20c997);border-radius:20px;box-shadow:0 2px 8px #28a7454d;color:#fff;font-size:.85rem;font-weight:600;padding:.3rem .8rem}@media (max-width:768px){.projection-grid{gap:1rem;grid-template-columns:1fr}.projection-value{font-size:1.5rem}}.line-chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;margin-bottom:1rem;padding:1rem}.legend-color{border-radius:2px;height:3px;width:16px}@media (max-width:768px){.line-chart-container svg{height:300px}.chart-legend{gap:1rem}.legend-item{font-size:.8rem}}.chart-container{border-radius:8px;box-shadow:0 2px 8px #0000000d;padding:1rem}.chart-container,.dashboard-expanded .chart-container{background:#fffffff2!important}.line-chart-container{background:#fffffff2;border:1px solid #2196f326;border-radius:12px;box-shadow:0 4px 16px #1976d21a;margin-top:2rem;padding:2rem}.line-chart-title{color:#1976d2;font-size:1.4rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.line-chart{height:300px;margin:2rem 0;position:relative}.line-chart-svg{height:100%;overflow:visible;width:100%}.line-historical{stroke:#1976d2;stroke-width:3;fill:none;stroke-dasharray:0;animation:drawLine 2s ease-in-out}.line-projection{stroke:#4caf50;stroke-width:3;fill:none;stroke-dasharray:8,4;animation:drawLine 2s ease-in-out .5s both}.line-optimized{stroke:#ff9800;stroke-width:3;fill:none;stroke-dasharray:4,4;animation:drawLine 2s ease-in-out 1s both}@keyframes drawLine{0%{stroke-dasharray:1000;stroke-dashoffset:1000}to{stroke-dasharray:1000;stroke-dashoffset:0}}.chart-point{fill:#1976d2;stroke:#fff;stroke-width:2;r:4;transition:r .3s ease}.chart-point:hover{r:6}.chart-point.projection{fill:#4caf50}.chart-point.optimized{fill:#ff9800}.chart-axis{stroke:#e0e0e0;stroke-width:1}.chart-axis-label{fill:#666;text-anchor:middle;font-size:12px}.chart-grid{stroke:#f5f5f5;stroke-width:1;stroke-dasharray:2,2}.chart-legend{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-top:1rem}.legend-item{align-items:center;color:#666;display:flex;font-size:.9rem;gap:.5rem}.legend-line{border-radius:2px;height:3px;width:20px}.legend-line.historical{background-color:#1976d2}.legend-line.projection{background-color:#4caf50;background-image:repeating-linear-gradient(90deg,#4caf50,#4caf50 8px,#0000 0,#0000 12px)}.legend-line.optimized{background-color:#ff9800;background-image:repeating-linear-gradient(90deg,#ff9800,#ff9800 4px,#0000 0,#0000 8px)}@media (max-width:768px){.line-chart-container{padding:1rem}.line-chart{height:250px}.chart-legend{gap:1rem}.legend-item{font-size:.8rem}}.modernization-suggestions,.modernization-summary{margin-bottom:2rem}.modernization-suggestions h3{color:#1976d2;font-size:1.2rem;margin-bottom:1rem}.suggestions-list{display:flex;flex-direction:column;gap:1rem}.suggestion-item{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:12px;padding:1.5rem;transition:all .3s ease}.suggestion-item:hover{border-color:#1976d2;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.suggestion-header{gap:1rem;justify-content:space-between;margin-bottom:1rem}.instance-info,.suggestion-header{align-items:center;display:flex;flex-wrap:wrap}.instance-info{gap:.5rem}.instance-name{color:#2c3e50;font-size:1.1rem;font-weight:700}.instance-type{background:#e3f2fd;border-radius:6px;color:#1976d2;font-size:.9rem;font-weight:500;padding:.25rem .5rem}.instance-region{color:#6c757d;font-size:.9rem}.suggestion-arrow{color:#28a745;font-size:1.5rem;font-weight:700}.recommendation-info{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.recommended-type{background:#e8f5e9;color:#2e7d32;font-size:.9rem;font-weight:500}.architecture-badge,.recommended-type{border-radius:6px;padding:.25rem .5rem}.architecture-badge{background:#ff9800;color:#fff;font-size:.8rem;font-weight:700}.suggestion-details{display:flex;flex-direction:column;gap:1rem}.cost-comparison{grid-gap:1rem;background:#fff;border:1px solid #e9ecef;border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:1rem}.cost-item{align-items:center;border-radius:6px;display:flex;justify-content:space-between;padding:.5rem}.cost-item.savings{background:#e8f5e9;border:1px solid #c8e6c9}.cost-label{color:#495057;font-weight:500}.cost-value{color:#2c3e50;font-weight:700}.cost-value.recommended{color:#2e7d32}.cost-item.savings .cost-value{color:#1b5e20}.suggestion-reason{border-left:4px solid #1976d2;font-size:.95rem;line-height:1.5}.more-suggestions,.suggestion-reason{background:#f8f9fa;border-radius:8px;padding:1rem}.more-suggestions{color:#6c757d;font-style:italic;text-align:center}.modernization-benefits{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border:1px solid #e1bee7;border-radius:12px;padding:2rem}.modernization-benefits h3{color:#1976d2;font-size:1.3rem;margin-bottom:1.5rem;text-align:center}.benefits-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.benefit-item{align-items:flex-start;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .3s ease}.benefit-item:hover{transform:translateY(-3px)}.benefit-icon{flex-shrink:0;font-size:2rem}.benefit-text strong{color:#1976d2;display:block;font-size:1.1rem;margin-bottom:.5rem}.benefit-text p{color:#6c757d;font-size:.95rem;line-height:1.4;margin:0}@media (max-width:768px){.suggestion-header{align-items:flex-start;flex-direction:column}.suggestion-arrow{align-self:center;transform:rotate(90deg)}.benefits-grid,.cost-comparison{grid-template-columns:1fr}.benefit-item{flex-direction:column;text-align:center}}.architecture-badge.graviton{background:linear-gradient(135deg,#ff6b35,#f7931e);border-radius:6px;color:#fff;font-size:.8rem;font-weight:700;padding:.25rem .5rem;text-shadow:0 1px 2px #0003}.service-indicator{background:#6c757d;border-radius:4px;color:#fff;font-size:.7rem;font-weight:700;margin-left:.5rem;padding:.2rem .4rem}.service-indicator.ec2{background:#007bff}.service-indicator.rds{background:#28a745}.modernization-benefits .benefit-item.rds-specific{border-left:4px solid #28a745}.modernization-benefits .benefit-item.graviton-specific{background:linear-gradient(135deg,#fff8f5,#ffeee6);border-left:4px solid #ff6b35}.btn-spaced{margin-left:1rem}.permissions-info-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-top:1.5rem;padding:1.5rem}.permissions-info-section h3{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 1rem}.permissions-info-section>p{color:#6c757d;line-height:1.5;margin:0 0 1.5rem}.permissions-info-section .permissions-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.permissions-info-section .permission-item{background:#fff;border:1px solid #e9ecef;border-radius:6px;box-shadow:0 1px 3px #0000000d;padding:1rem}.permissions-info-section .permission-name{background:#f8f9fa;border-radius:4px;color:#495057;display:inline-block;font-family:Courier New,monospace;font-size:.9rem;font-weight:600;margin-bottom:.5rem;padding:.25rem .5rem}.permissions-info-section .permission-description{color:#6c757d;font-size:.9rem;line-height:1.4}.permissions-note{background:#e7f3ff;border:1px solid #b3d9ff;border-radius:6px;margin-top:1rem;padding:1rem}.permissions-note p{color:#0056b3;font-size:.9rem;line-height:1.4;margin:0}.btn-info{background:linear-gradient(135deg,#17a2b8,#138496);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;margin-right:.75rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-info:hover{background:linear-gradient(135deg,#138496,#117a8b);box-shadow:0 4px 8px #17a2b84d;transform:translateY(-1px)}.btn-info:active{transform:translateY(0)}@media (max-width:768px){.permissions-info-section{margin-top:1rem;padding:1rem}.permissions-info-section .permission-item{padding:.75rem}.permissions-info-section .permission-name{font-size:.8rem}.permissions-info-section .permission-description{font-size:.85rem}}.share-btn{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;margin-left:.75rem;padding:.75rem 1.5rem;transition:all .3s ease}.share-btn:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1ea085);box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.share-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.share-result-card{background:linear-gradient(135deg,#e8f5e8,#f0f9f0);border:1px solid #28a745;margin-bottom:2rem}.share-result-card .card-title,.share-result-content p{color:#155724;margin-bottom:1rem}.share-url-container{display:flex;gap:.5rem;margin-bottom:1rem}.share-url-input{background:#fff;border:1px solid #28a745;border-radius:4px;color:#155724;flex:1 1;font-family:Courier New,monospace;font-size:.9rem;padding:.75rem}.copy-url-btn{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1rem;transition:background .3s ease}.copy-url-btn:hover{background:#218838}.share-actions{display:flex;justify-content:flex-end}.clear-share-btn{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background .3s ease}.clear-share-btn:hover{background:#5a6268}.shared-data-indicator{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border:1px solid #2196f3;margin-bottom:2rem}.shared-data-indicator .card-title{color:#1565c0;margin-bottom:1rem}.shared-data-indicator p{color:#1565c0;margin:0}.loading-shared-indicator{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #ffc107;margin-bottom:2rem}.loading-shared-indicator .card-title{color:#856404;margin-bottom:1rem}.loading-shared-indicator p{color:#856404;margin:0}@media (max-width:768px){.header-actions{flex-direction:column;gap:.5rem}.share-btn{margin-left:0;margin-top:.5rem}.share-url-container{flex-direction:column}.copy-url-btn{align-self:flex-start}}.share-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #007bff;margin-bottom:2rem;margin-top:2rem}.share-section .card-title{color:#0056b3;font-size:1.3rem;margin-bottom:1rem}.share-section-content p{color:#495057;line-height:1.6;margin-bottom:1.5rem}.share-action{margin:1.5rem 0;text-align:center}.share-report-btn{background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;box-shadow:0 4px 8px #007bff33;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.share-report-btn:hover:not(:disabled){background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 6px 12px #007bff4d;transform:translateY(-2px)}.share-report-btn:disabled{background:#6c757d;box-shadow:0 2px 4px #6c757d33;cursor:not-allowed;transform:none}.share-success{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;margin-top:1rem;padding:1.5rem}.share-success-text{color:#155724;font-size:1.1rem;font-weight:600}.share-success-text,.share-url-section{margin-bottom:1.5rem}.share-url-label{color:#155724;display:block;font-weight:600;margin-bottom:.5rem}.share-section .share-url-container{display:flex;gap:.75rem;margin-bottom:1rem}.share-section .share-url-input{background:#fff;border:2px solid #28a745;border-radius:6px;color:#155724;flex:1 1;font-family:Courier New,monospace;font-size:.9rem;font-weight:500;padding:.875rem}.copy-btn{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:6px;box-shadow:0 3px 6px #28a74533;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .3s ease;white-space:nowrap}.copy-btn:hover{background:linear-gradient(135deg,#218838,#1ea085);box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.share-info{background:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;margin-top:1rem;padding:1rem}.share-info p{color:#0d47a1;font-weight:600;margin-bottom:.75rem}.share-info ul{color:#1565c0;margin:0;padding-left:1.5rem}.share-info li{line-height:1.4;margin-bottom:.5rem}.share-error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;margin-top:1rem;padding:1.5rem;text-align:center}.share-error-text{color:#721c24;font-size:1.1rem;font-weight:600;margin-bottom:1rem}@media (max-width:768px){.share-section .share-url-container{flex-direction:column}.copy-btn{align-self:stretch;margin-top:.5rem}.share-report-btn{font-size:1rem;padding:.875rem 1.5rem}.share-info ul{padding-left:1.25rem}}.share-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;margin-top:10px;padding:10px}.share-warning p{color:#856404;font-size:14px;margin:0}.share-warning code{background:#f8f9fa;border-radius:3px;color:#495057;font-family:Courier New,monospace;padding:2px 6px}.copy-json-section{margin-top:15px;text-align:center}.copy-json-btn{background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:6px;box-shadow:0 2px 4px #007bff33;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s ease}.copy-json-btn:hover{background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.copy-json-btn:active{box-shadow:0 2px 4px #007bff33;transform:translateY(0)}.copy-json-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.shared-data-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:15px}.new-optimization-btn{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:6px;box-shadow:0 2px 4px #28a74533;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .3s ease;white-space:nowrap}.new-optimization-btn:hover{background:linear-gradient(135deg,#218838,#1e7e34);box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.new-optimization-btn:active{box-shadow:0 2px 4px #28a74533;transform:translateY(0)}@media (max-width:768px){.shared-data-header{align-items:flex-start;flex-direction:column}.new-optimization-btn{align-self:flex-end}}.form-group{margin-bottom:1.5rem}.form-control{background-clip:padding-box;background-color:#fff;border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);display:block;font-size:1rem;line-height:1.5;padding:.75rem 1rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}.form-control:focus{border-color:var(--primary-color);box-shadow:0 0 0 .2rem #007bff40;outline:0}.form-control::placeholder{color:var(--text-muted);opacity:.7}label{color:var(--primary-color);display:block;font-weight:500;margin-bottom:.5rem}.form-actions{margin-top:2rem}.error-message{background-color:#dc35451a;border-left:4px solid var(--danger-color);border-radius:4px;color:var(--danger-color);margin-top:1rem;padding:1rem}.loading-spinner{animation:spin 1s ease-in-out infinite;border:5px solid #007bff33;border-radius:50%;border-top:5px solid var(--primary-color);display:inline-block;height:50px;margin:1rem auto;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.permission-item{background-color:#f8f9fa;border-radius:4px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.5rem 1rem}.permissions-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:1.5rem}.permission-granted{background-color:#28a7451a;border-left:3px solid var(--success-color)}.permission-denied{background-color:#dc35451a;border-left:3px solid var(--danger-color)}.permission-name{font-family:monospace;font-size:.9rem}.permission-status{font-weight:700}.permissions-warning{background-color:#ffc1071a;border-left:4px solid var(--warning-color);border-radius:4px;margin-bottom:1.5rem;padding:1rem}.import-export-buttons{display:flex;flex-wrap:wrap;gap:.5rem}@media (max-width:768px){.permissions-grid{grid-template-columns:1fr}.import-export-buttons{flex-direction:column}.import-export-buttons button,.import-export-buttons label{margin-left:0!important;margin-top:.5rem}}
/*# sourceMappingURL=main.6a25086d.css.map*/