:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.homepage{max-width:1200px;margin:0 auto;padding:3rem 2rem}.homepage-header{margin-bottom:4rem}.header-content{display:flex;justify-content:space-between;align-items:center;text-align:center}.header-content>div:first-child{flex:1}.user-section{display:flex;align-items:center;gap:1rem}.username{color:#6b7280;font-size:.95rem}.settings-btn{padding:.5rem 1.5rem;background:linear-gradient(135deg,#6b7280 0%,#4b5563 100%);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.settings-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6b72804d}.logout-btn{padding:.5rem 1.5rem;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.logout-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.homepage-title{font-size:4rem;font-weight:800;margin:0;background:linear-gradient(135deg,#3b82f6 0%,#8b5cf6 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.homepage-subtitle{font-size:1.25rem;color:#6b7280;margin-top:.5rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.dashboard-card{background:white;border:2px solid #e5e7eb;border-radius:12px;padding:2rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-width:3px}.dashboard-icon{font-size:3rem;margin-bottom:1rem}.dashboard-title{font-size:1.5rem;font-weight:700;margin:.5rem 0;color:#1f2937}.dashboard-description{color:#6b7280;font-size:.95rem;line-height:1.5;margin:.5rem 0 1rem}.dashboard-arrow{font-size:1.5rem;font-weight:700;margin-top:1rem;transition:transform .3s ease}.dashboard-card:hover .dashboard-arrow{transform:translate(8px)}@media (max-width: 768px){.homepage{padding:2rem 1rem}.header-content{flex-direction:column;gap:1.5rem}.user-section{width:100%;justify-content:center;flex-wrap:wrap;gap:.5rem}.homepage-title{font-size:2.5rem}.dashboard-grid{grid-template-columns:1fr}}.bank-transactions-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;gap:1rem}.dashboard-header h1{margin:0;font-size:2rem;color:#333;flex:1}.header-actions{display:flex;gap:.5rem}.back-button,.refresh-button,.upload-button{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease}.back-button{background-color:#6c757d;color:#fff}.back-button:hover{background-color:#5a6268}.upload-button{background-color:#28a745;color:#fff}.upload-button:hover{background-color:#218838}.refresh-button{background-color:#007bff;color:#fff}.refresh-button:hover{background-color:#0056b3}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.visualizations-section{margin-bottom:2rem}.section-title{font-size:1.75rem;color:#333;margin-bottom:1.5rem;font-weight:600}.chart-container{background:white;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.chart-title{font-size:1.25rem;color:#495057;margin-bottom:1.5rem;font-weight:600;text-align:center}.averages-display{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:1rem}.average-card{padding:1.5rem;border-radius:12px;text-align:center;box-shadow:0 2px 4px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.average-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.average-card.income-avg{background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%);color:#fff}.average-card.spending-avg{background:linear-gradient(135deg,#ee0979 0%,#ff6a00 100%);color:#fff}.average-card.net-avg.positive{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.average-card.net-avg.negative{background:linear-gradient(135deg,#ff6b6b 0%,#c92a2a 100%);color:#fff}.avg-label{font-size:.9rem;font-weight:500;opacity:.9;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.avg-value{font-size:1.75rem;font-weight:700}.summary-card{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;color:#fff}.summary-card.credit{background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%)}.summary-card.debit{background:linear-gradient(135deg,#ee0979 0%,#ff6a00 100%)}.summary-card.positive{background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%)}.summary-card.negative{background:linear-gradient(135deg,#ee0979 0%,#ff6a00 100%)}.summary-card h3{margin:0 0 .5rem;font-size:.9rem;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.summary-card .summary-value{margin:0;font-size:2rem;font-weight:700}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #e0e0e0}.tab{padding:1rem 2rem;border:none;background:none;cursor:pointer;font-size:1rem;font-weight:500;color:#666;border-bottom:3px solid transparent;transition:all .3s ease;position:relative;bottom:-2px}.tab:hover{color:#667eea;background-color:#f8f9fa}.tab.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.controls{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.search-input{flex:1;min-width:300px;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#667eea}.sort-controls{display:flex;gap:.5rem;align-items:center}.sort-controls label{font-weight:500;color:#666}.sort-controls select{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:white;cursor:pointer}.sort-button{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;background:white;cursor:pointer;font-size:1.2rem;transition:all .3s ease}.sort-button:hover{background-color:#f8f9fa;border-color:#667eea}.transactions-table-container{background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;position:relative}.transactions-table{width:100%;border-collapse:collapse}.transactions-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:10}.transactions-table th{padding:1rem;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6;text-transform:uppercase;background-color:#f8f9fa;font-size:.85rem;letter-spacing:.5px}.transactions-table td{padding:1rem;border-bottom:1px solid #f0f0f0}.transactions-table tbody tr{transition:background-color .2s ease}.transactions-table tbody tr:hover{background-color:#f8f9fa}.amount-column{text-align:right;font-family:Monaco,Courier New,monospace;font-weight:500}.date-cell{white-space:nowrap;color:#666;font-weight:500}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-cell{font-family:Monaco,Courier New,monospace;color:#666;font-size:.9rem}.customer-cell{font-weight:500}.customer-badge{padding:.25rem .75rem;background-color:#e3f2fd;color:#1976d2;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.unknown-customer{color:#999;font-style:italic;font-size:.85rem}.debit-amount{color:#dc3545}.credit-amount{color:#28a745}.balance-amount{font-weight:600;color:#333}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-posted{background-color:#d4edda;color:#155724}.status-pending{background-color:#fff3cd;color:#856404}.status-cleared{background-color:#d1ecf1;color:#0c5460}.status-voided{background-color:#f8d7da;color:#721c24}.loading,.error{text-align:center;padding:3rem;font-size:1.2rem}.error{color:#dc3545}.no-data{text-align:center;padding:3rem;color:#999;font-style:italic}.table-footer{padding:1rem;text-align:center;color:#666;font-size:.9rem;background-color:#f8f9fa;border-top:1px solid #e0e0e0}@media (max-width: 1024px){.transactions-table{font-size:.9rem}.transactions-table th,.transactions-table td{padding:.75rem .5rem}.description-cell{max-width:200px}}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:stretch}.summary-cards{grid-template-columns:1fr}.controls{flex-direction:column;align-items:stretch}.search-input{min-width:100%}.transactions-table-container{overflow-x:auto}.transactions-table{min-width:800px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:white;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.close-button{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.close-button:hover{background-color:#f0f0f0;color:#333}.modal-body{padding:2rem}.help-text{color:#666;margin-bottom:1.5rem;line-height:1.6}.file-input-wrapper{margin-bottom:1rem}.file-input{display:none}.file-input-label{display:block;padding:1rem;background-color:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;text-align:center;cursor:pointer;transition:all .3s ease;color:#666;font-weight:500}.file-input-label:hover{border-color:#667eea;background-color:#f0f0ff;color:#667eea}.upload-status{padding:1rem;border-radius:8px;margin-top:1rem;text-align:center;font-weight:500}.upload-status.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.upload-status.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e0e0e0;background-color:#f8f9fa}.cancel-button,.submit-button{padding:.75rem 2rem;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease}.cancel-button{background-color:#e0e0e0;color:#666}.cancel-button:hover{background-color:#d0d0d0}.submit-button{background-color:#28a745;color:#fff}.submit-button:hover:not(:disabled){background-color:#218838}.submit-button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.drill-down-modal{max-width:900px;width:95%}.drill-down-modal .modal-body{padding:1.5rem;max-height:70vh;overflow-y:auto}.drill-down-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;padding:1rem;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-radius:8px}.drill-down-stat{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.85rem;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.5rem;font-weight:700;color:#333}.stat-value.spending-color{color:#dc3545}.stat-value.income-color{color:#28a745}.drill-down-transactions{margin-top:1rem}.transactions-subtitle{font-size:1.1rem;color:#495057;margin-bottom:1rem;font-weight:600;padding-bottom:.5rem;border-bottom:2px solid #e0e0e0}.drill-down-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e0e0e0}.drill-down-table{width:100%;border-collapse:collapse;font-size:.9rem}.drill-down-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:1}.drill-down-table th{padding:.75rem;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.drill-down-table td{padding:.75rem;border-bottom:1px solid #f0f0f0}.drill-down-table tbody tr{transition:background-color .2s ease}.drill-down-table tbody tr:hover{background-color:#f8f9fa}.drill-down-table tbody tr:last-child td{border-bottom:none}.close-modal-button{padding:.75rem 2rem;border:none;border-radius:8px;background-color:#667eea;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease}.close-modal-button:hover{background-color:#5568d3;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}@media (max-width: 768px){.drill-down-modal{width:98%;max-height:95vh}.drill-down-summary{grid-template-columns:1fr}.drill-down-table{font-size:.8rem}.drill-down-table th,.drill-down-table td{padding:.5rem}}.dashboard-container{padding:2rem;max-width:1400px;margin:0 auto;min-height:100vh}@media (max-width: 768px){.dashboard-container{padding:1rem}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}@media (max-width: 768px){.dashboard-header{flex-direction:column;text-align:center;align-items:center}.dashboard-header h1{order:-1;font-size:1.5rem}}.dashboard-header h1{flex:1;text-align:center;margin:0;font-size:2rem;color:#1f2937}.back-button,.refresh-button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:600;white-space:nowrap}@media (max-width: 768px){.back-button,.refresh-button{width:100%;padding:.6rem 1rem}}.back-button{background:#f3f4f6;color:#374151}.back-button:hover{background:#e5e7eb}.refresh-button{background:#3b82f6;color:#fff}.refresh-button:hover{background:#2563eb}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:white;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;text-align:center}.summary-card h3{margin:0 0 .5rem;font-size:.9rem;color:#6b7280;text-transform:uppercase;font-weight:600}.summary-value{margin:0;font-size:2.5rem;font-weight:700;color:#1f2937}.summary-card.status-active{border-color:#10b981}.summary-card.status-idle{border-color:#f59e0b}.data-table-container{background:white;border-radius:12px;border:2px solid #e5e7eb;overflow:hidden}.data-table{width:100%;border-collapse:collapse;min-width:600px}.data-table thead{background:#f9fafb}.data-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.data-table td{padding:1rem;border-bottom:1px solid #e5e7eb;color:#1f2937}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:600;text-transform:capitalize}.status-active{background:#d1fae5;color:#065f46}.status-idle{background:#fed7aa;color:#92400e}.status-completed{background:#dbeafe;color:#1e40af}.status-pending{background:#fef3c7;color:#92400e}.no-data{text-align:center;color:#6b7280;padding:3rem!important}.loading,.error{display:flex;justify-content:center;align-items:center;height:400px;font-size:1.25rem;color:#6b7280}.error{color:#dc2626}@media (max-width: 768px){.dashboard-container{padding:1rem}.dashboard-header{flex-direction:column}.dashboard-header h1{font-size:1.5rem}.summary-cards{grid-template-columns:1fr}.data-table-container{overflow-x:auto}}.viewer-section{margin-bottom:2rem}.viewer-grid{display:grid;grid-template-columns:1fr 2fr;gap:1.5rem}.upload-card,.preview-card,.table-card{background:white;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.upload-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.9rem;font-weight:500;color:#495057}.file-input-field,.text-input,.asset-selector,.stock-input{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;transition:border-color .3s ease}.file-input-field:focus,.text-input:focus,.asset-selector:focus,.stock-input:focus{outline:none;border-color:#667eea}.help-text{font-size:.85rem;color:#6c757d;margin-top:.25rem}.upload-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.upload-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.upload-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.preview-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.asset-selector{width:100%}.viewer-toolbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.toolbar-button{padding:.5rem 1rem;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.toolbar-button:hover{background-color:#e9ecef;border-color:#adb5bd}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#495057;cursor:pointer}.checkbox-label input[type=checkbox]{width:1.1rem;height:1.1rem;cursor:pointer}.stock-offsets-card{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-radius:8px;padding:1rem}.stock-title{font-size:.85rem;font-weight:600;color:#495057;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.stock-inputs{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.stock-input-group{display:flex;flex-direction:column;gap:.25rem}.stock-input-group label{font-size:.8rem;color:#6c757d;font-weight:500}.stock-input{padding:.5rem;font-size:.85rem}.dimensions-display{margin-top:.75rem;font-size:.85rem;color:#6c757d;padding-top:.75rem;border-top:1px solid #dee2e6}.viewer-container{height:400px;border-radius:8px;overflow:hidden}.header-stats{display:flex;gap:.5rem}.stat-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-radius:20px;font-size:.9rem;font-weight:500}.table-card{margin-top:2rem}.font-mono{font-family:Monaco,Courier New,monospace;font-weight:500}@media (max-width: 1024px){.viewer-grid{grid-template-columns:1fr}.viewer-container{height:350px}.preview-card{order:-1}}@media (max-width: 768px){.stock-inputs{grid-template-columns:repeat(2,1fr)}.viewer-toolbar{flex-direction:column;align-items:stretch;gap:.75rem}.toolbar-button{width:100%;justify-content:center;display:flex}.viewer-container{height:300px}.header-stats{flex-direction:row;flex-wrap:wrap;justify-content:center;width:100%}.stat-badge{flex:1;text-align:center;min-width:120px}.table-card .card-title{flex-direction:column;align-items:flex-start;gap:1rem}}@media (max-width: 480px){.stock-inputs{grid-template-columns:1fr}}.table-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.table-actions{display:flex;gap:.5rem;flex-wrap:wrap}@media (max-width: 768px){.table-header-row{flex-direction:column;align-items:stretch}.table-actions{flex-direction:column}.table-actions button{width:100%;justify-content:center}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:white;border-radius:16px;padding:2rem;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e9ecef}.modal-header h2{font-size:1.5rem;font-weight:600;color:#333;margin:0}.modal-close{background:none;border:none;font-size:2rem;color:#6c757d;cursor:pointer;line-height:1;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close:hover{background:#f8f9fa;color:#333}.modal-form{display:flex;flex-direction:column;gap:1.25rem}.info-banner{background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%);border-left:4px solid #2196f3;padding:1rem;border-radius:8px;margin-bottom:.5rem}.info-banner p{margin:0;color:#1565c0;font-size:.95rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-form .form-group{display:flex;flex-direction:column;gap:.5rem}.modal-form label{font-size:.9rem;font-weight:500;color:#495057}.modal-form .text-input,.modal-form textarea{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;transition:border-color .3s ease;font-family:inherit}.modal-form .text-input:focus,.modal-form textarea:focus{outline:none;border-color:#667eea}.modal-form textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}.cancel-button{padding:.75rem 1.5rem;background:#f8f9fa;color:#495057;border:1px solid #dee2e6;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.cancel-button:hover{background:#e9ecef;border-color:#adb5bd}@media (max-width: 768px){.modal-content{width:95%;padding:1.5rem;max-height:95vh}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.cancel-button,.upload-button{width:100%}}.header-controls{display:flex;align-items:center;gap:1rem}.auto-refresh-toggle{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#495057;cursor:pointer}.auto-refresh-toggle input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.machine-state-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 24px #667eea4d}.state-primary{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.machine-name{font-size:2rem;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.state-indicator{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;border-radius:30px;font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}.state-dot{width:14px;height:14px;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.state-meta{display:flex;gap:2rem;color:#ffffffe6}.meta-item{display:flex;gap:.5rem}.meta-label{font-weight:500;opacity:.8}.meta-value{font-weight:600;font-family:Monaco,monospace}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.dashboard-card{background:white;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.dashboard-card .card-title{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.card-program{grid-column:span 2}.program-info .info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f5f5f5}.program-info .info-row:last-child{border-bottom:none}.info-label{font-weight:500;color:#666;font-size:.9rem}.info-value{font-weight:600;color:#333;font-family:Monaco,monospace;font-size:1rem}.program-name{color:#667eea;font-size:1.1rem}.spindle-info{display:flex;gap:1.5rem}.spindle-main{flex:1;text-align:center;padding:1rem;background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);border-radius:12px}.spindle-rpm{font-size:2.5rem;font-weight:700;color:#fff;font-family:Monaco,monospace}.spindle-label{color:#ffffffe6;font-weight:600;margin-top:.5rem}.spindle-details{flex:1;display:flex;flex-direction:column;justify-content:center;gap:.5rem}.detail-row{display:flex;justify-content:space-between;padding:.5rem 0}.detail-label{font-weight:500;color:#666;font-size:.85rem}.detail-value{font-weight:600;color:#333;font-family:Monaco,monospace}.tool-info{text-align:center}.tool-main{padding:1.5rem;background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);border-radius:12px}.tool-number{font-size:3rem;font-weight:700;color:#fff;font-family:Monaco,monospace}.tool-label{color:#ffffffe6;font-weight:600;margin-top:.5rem}.feed-info{text-align:center}.feed-main{padding:1.5rem;background:linear-gradient(135deg,#fa709a 0%,#fee140 100%);border-radius:12px;margin-bottom:1rem}.feed-rate{font-size:2rem;font-weight:700;color:#fff;font-family:Monaco,monospace}.feed-label{color:#ffffffe6;font-weight:600;margin-top:.5rem}.card-axes{grid-column:span 2}.axes-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.axis-item{text-align:center;padding:1rem;border-radius:10px;border:2px solid #e0e0e0;transition:all .3s ease}.axis-item:hover{border-color:#667eea;background:#f8f9fe;transform:translateY(-2px)}.axis-label{font-size:1.2rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.axis-value{font-size:1.1rem;font-weight:600;color:#333;font-family:Monaco,monospace}.system-info .info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f5f5f5}.system-info .info-row:last-child{border-bottom:none}.tool-history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.tool-history-item{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:10px;padding:1rem;text-align:center;transition:all .3s ease}.tool-history-item:hover{transform:translateY(-4px);box-shadow:0 8px 20px #667eea66}.tool-hist-number{font-size:1.5rem;font-weight:700;color:#fff;font-family:Monaco,monospace;margin-bottom:.25rem}.tool-hist-time{font-size:.75rem;color:#fffc;font-weight:500}.tool-controls{display:flex;gap:1rem;align-items:center}.upload-button{cursor:pointer;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .3s ease;display:inline-block}.upload-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.upload-button:active{transform:translateY(0)}.upload-button[disabled]{opacity:.6;cursor:not-allowed}.toggle-tool-list-button{padding:.75rem 1.5rem;background:white;color:#667eea;border:2px solid #667eea;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease}.toggle-tool-list-button:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.upload-message{margin:1rem 0;padding:.75rem 1rem;border-radius:8px;font-weight:500;animation:slideIn .3s ease}.upload-message.success{background:#d4edda;color:#155724;border-left:4px solid #28a745}.upload-message.error{background:#f8d7da;color:#721c24;border-left:4px solid #dc3545}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tool-table{font-size:.9rem}.tool-table thead{background:#f8f9fa}.tool-table tbody tr:hover{background:#f0f7ff}.tool-name-cell{max-width:250px;font-weight:500;color:#333}.tool-type-badge{display:inline-block;padding:.25rem .75rem;background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.machine-selector-section{display:flex;align-items:center;gap:1rem;padding:1rem;background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem}.machine-selector-section label{font-weight:500;color:#495057}.machine-select{padding:.5rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;min-width:250px;transition:border-color .3s ease}.machine-select:focus{outline:none;border-color:#667eea}.machine-time{margin-left:auto;font-size:.85rem;color:#6c757d}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:white;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.summary-card.status-active{background:linear-gradient(135deg,#d4edda 0%,#c3e6cb 100%);border-left:4px solid #28a745}.summary-card.status-idle{background:linear-gradient(135deg,#fff3cd 0%,#ffeaa7 100%);border-left:4px solid #ffc107}.summary-card.status-stopped{background:linear-gradient(135deg,#f8d7da 0%,#f5c6cb 100%);border-left:4px solid #dc3545}.card-label{font-size:.9rem;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.card-value{font-size:2.5rem;font-weight:700;color:#333}.status-section{background:white;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e9ecef}.section-header h2{font-size:1.5rem;font-weight:600;color:#333;margin:0}.status-indicator{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;text-transform:uppercase}.status-indicator.status-active{background:#28a745;color:#fff}.status-indicator.status-ready{background:#ffc107;color:#333}.status-indicator.status-stopped{background:#dc3545;color:#fff}.status-indicator.status-idle{background:#6c757d;color:#fff}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.status-item{padding:1rem;background:#f8f9fa;border-radius:8px;border-left:3px solid #667eea}.status-label{font-size:.85rem;color:#6c757d;font-weight:500;margin-bottom:.5rem}.status-value{font-size:1.1rem;font-weight:600;color:#333;font-family:Monaco,Courier New,monospace}.table-card{background:white;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.card-title{font-size:1.25rem;font-weight:600;color:#333;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e9ecef}.selected-row{background:#e3f2fd!important;border-left:3px solid #2196f3}.view-button{padding:.4rem .8rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease}.view-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.font-bold{font-weight:600}.font-mono{font-family:Monaco,Courier New,monospace}.text-small{font-size:.85rem;color:#6c757d}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;text-transform:uppercase}.status-badge.status-active{background:#d4edda;color:#155724}.status-badge.status-ready{background:#fff3cd;color:#856404}.status-badge.status-stopped{background:#f8d7da;color:#721c24}.status-badge.status-idle{background:#d6d8db;color:#383d41}.status-badge.status-unknown{background:#e2e3e5;color:#6c757d}.observations-table{font-size:.9rem}.observations-table tbody tr:hover{background:#f8f9fa}.state-indicator.status-active{background:#28a745;color:#fff}.state-indicator.status-active .state-dot{background:white}.state-indicator.status-ready{background:#ffc107;color:#333}.state-indicator.status-ready .state-dot{background:#333}.state-indicator.status-stopped{background:#dc3545;color:#fff}.state-indicator.status-stopped .state-dot{background:white}.state-indicator.status-idle{background:#6c757d;color:#fff}.state-indicator.status-idle .state-dot{background:white}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}.card-program,.card-axes{grid-column:span 2}.axes-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1024px){.status-grid,.summary-cards{grid-template-columns:repeat(2,1fr)}.spindle-info{flex-direction:column}.machine-name{font-size:1.5rem}.state-indicator{font-size:.9rem;padding:.5rem 1rem}}@media (max-width: 768px){.machine-selector-section{flex-direction:column;align-items:stretch}.machine-select{width:100%}.machine-time{margin-left:0;text-align:center}.dashboard-grid{grid-template-columns:1fr}.card-program,.card-axes{grid-column:span 1}.axes-grid{grid-template-columns:repeat(2,1fr)}.status-grid,.summary-cards{grid-template-columns:1fr}.section-header{flex-direction:column;gap:1rem;align-items:flex-start}.header-controls{flex-direction:column;align-items:stretch;width:100%}.view-button{width:100%}.state-primary{flex-direction:column;gap:1rem;align-items:flex-start}.machine-state-header{padding:1.5rem}.tool-history-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.loading,.error{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.2rem;color:#6c757d}.error{color:#dc3545;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{animation:pulse 2s ease-in-out infinite}.analytics-dashboard{padding:20px;max-width:1600px;margin:0 auto;background:#f8f9fa;min-height:100vh}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:white;border-radius:8px;box-shadow:0 2px 4px #0000001a}.analytics-header h1{margin:0;color:#2d3748}.analytics-controls{display:flex;gap:10px}.analytics-controls select,.analytics-controls button{padding:8px 16px;border-radius:6px;border:1px solid #e2e8f0;background:white;cursor:pointer;font-size:14px}.analytics-controls button:hover{background:#f7fafc}.analytics-tabs{display:flex;gap:10px;margin-bottom:20px;padding:0 20px}.analytics-tabs button{padding:10px 20px;border:none;background:white;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.analytics-tabs button:hover{background:#edf2f7}.analytics-tabs button.active{background:#3b82f6;color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:white;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.stat-card.error{border-left:4px solid #ef4444}.stat-card.human{border-left:4px solid #10b981}.stat-card.bot{border-left:4px solid #3b82f6}.stat-value{font-size:32px;font-weight:700;color:#2d3748;margin-bottom:8px}.stat-label{color:#718096;font-size:14px}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:20px;margin-bottom:20px}.analytics-card{background:white;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.analytics-card h3{margin:0 0 20px;color:#2d3748;font-size:18px}.table-container{overflow-x:auto;max-height:500px;overflow-y:auto}.analytics-card table{width:100%;border-collapse:collapse}.analytics-card th{text-align:left;padding:12px;border-bottom:2px solid #e2e8f0;color:#4a5568;font-weight:600;font-size:12px;text-transform:uppercase;background:#f7fafc;position:sticky;top:0;z-index:1}.analytics-card th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.analytics-card th.sortable:hover{background:#edf2f7;color:#2d3748}.analytics-card td{padding:12px;border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:14px}.analytics-card tbody tr:hover{background:#f7fafc}.path-cell{font-family:monospace;font-size:12px;color:#4a5568;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ip-cell{font-family:monospace;font-size:13px;color:#2d3748}.status-2{color:#10b981;font-weight:600}.status-3{color:#3b82f6;font-weight:600}.status-4{color:#f59e0b;font-weight:600}.status-5{color:#ef4444;font-weight:600}.analytics-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:20px;color:#718096}.traffic-badge{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap}.traffic-badge.human{background:#d1fae5;color:#065f46}.traffic-badge.bot{background:#dbeafe;color:#1e40af}.traffic-badge.malicious{background:#fee2e2;color:#991b1b}.traffic-badge.unknown{background:#f3f4f6;color:#4b5563}.bot-category{font-size:10px;color:#6b7280;margin-top:2px}.suspicious-row{background:#fef2f2!important}.suspicious-row:hover{background:#fee2e2!important}.stat-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e2e8f0}.stat-row:last-child{border-bottom:none}.stat-row span{color:#4a5568}.stat-row strong{color:#2d3748}.timestamp-cell{font-family:monospace;font-size:12px;color:#4a5568;white-space:nowrap}.ua-cell{font-family:monospace;font-size:11px;color:#6b7280;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.success-row{background:#f0fdf4}.success-row:hover{background:#dcfce7!important}.failed-row{background:#fef2f2}.failed-row:hover{background:#fee2e2!important}.threat-row{background:#fef2f2;border-left:3px solid #ef4444}.threat-row:hover{background:#fee2e2!important}.threat-count{color:#dc2626;font-size:16px}.analytics-section{padding:0 20px}@media (max-width: 768px){.analytics-grid,.stats-grid{grid-template-columns:1fr}.analytics-header{flex-direction:column;gap:20px}}.success-text{color:#10b981;font-weight:600}.error-text{color:#ef4444;font-weight:600}.view-details-button{padding:4px 12px;background:#edf2f7;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.view-details-button:hover{background:#e2e8f0;transform:scale(1.05)}.analytics-modal{width:90%;max-width:1000px;max-height:85vh;display:flex;flex-direction:column}.analytics-modal .modal-body{overflow-y:auto;padding:20px}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:25px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.detail-item label{display:block;font-size:11px;color:#718096;text-transform:uppercase;margin-bottom:4px}.detail-item div{font-weight:600;color:#2d3748}.text-area-container{margin-bottom:20px}.text-area-container label{display:block;font-size:13px;font-weight:600;color:#4a5568;margin-bottom:8px}.log-text{background:#1a202c;color:#e2e8f0;padding:15px;border-radius:6px;font-family:Fira Code,Courier New,Courier,monospace;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-all;max-height:300px;overflow-y:auto;border:1px solid #2d3748}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px}.auth-card{background:white;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.auth-card h1{margin:0 0 10px;font-size:24px;color:#333;text-align:center}.auth-card h2{margin:0 0 30px;font-size:20px;color:#666;text-align:center;font-weight:400}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;color:#333;font-weight:500}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:5px;font-size:14px;box-sizing:border-box;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.auth-card button{width:100%;padding:12px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:5px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.auth-card button:hover:not(:disabled){transform:translateY(-2px)}.auth-card button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:5px;margin-bottom:20px;font-size:14px}.auth-link{text-align:center;margin-top:20px;color:#666;font-size:14px}.auth-link a{color:#667eea;text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.settings-container{max-width:1200px;margin:0 auto;padding:2rem}.settings-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.back-button{padding:.5rem 1rem;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.back-button:hover{background:#5a6268}.settings-header h1{margin:0;color:#333}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#666}.success-message{background:#d4edda;color:#155724;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #c3e6cb}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #f5c6cb}.settings-content{display:flex;flex-direction:column;gap:2rem}.settings-section{background:white;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.settings-section h2{margin-top:0;margin-bottom:1rem;color:#333;font-size:1.5rem}.settings-section h3{margin-top:1.5rem;margin-bottom:1rem;color:#555;font-size:1.2rem}.setting-description{color:#666;font-size:.9rem;margin-bottom:1rem}.setting-item{margin-bottom:1.5rem}.setting-item label{display:block;font-weight:600;margin-bottom:.5rem;color:#333}.api-key-input-group{display:flex;gap:.5rem;margin-bottom:.5rem}.api-key-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:.9rem}.toggle-visibility{padding:.75rem 1rem;background:#f8f9fa;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:1.2rem}.toggle-visibility:hover{background:#e9ecef}.clear-button{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.clear-button:hover{background:#c82333}.endpoints-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.endpoint-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:4px;border:1px solid #dee2e6}.endpoint-info{display:flex;flex-direction:column;gap:.25rem}.endpoint-info strong{color:#333}.endpoint-url{color:#666;font-size:.9rem;font-family:monospace}.endpoint-interval{color:#999;font-size:.85rem}.remove-button{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.remove-button:hover{background:#c82333}.add-endpoint-form{padding-top:1rem;border-top:1px solid #dee2e6}.form-row{display:grid;grid-template-columns:1fr 2fr 150px auto;gap:.75rem;align-items:center}.form-row input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.add-button{padding:.75rem 1.5rem;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;white-space:nowrap}.add-button:hover{background:#218838}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.checkbox-label span{color:#333}.settings-actions{display:flex;justify-content:flex-end;padding-top:1rem}.save-button{padding:1rem 2rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:600}.save-button:hover{background:#0056b3}.save-button:disabled{background:#6c757d;cursor:not-allowed}@media (max-width: 768px){.settings-container{padding:1rem}.form-row{grid-template-columns:1fr}.endpoint-item{flex-direction:column;align-items:flex-start;gap:1rem}}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;min-height:100vh;margin:0;padding:0}.logo,.card,.read-the-docs{display:none}.app-container{min-height:100vh;width:100%;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%)}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}
