@import"https://fonts.googleapis.com/css2?family=Doto:wght@100..900&family=Sour+Gummy:ital,wght@0,100..900;1,100..900&display=swap";.network-visualizer{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:1.5rem;margin:1rem auto 2rem;width:90%}.network-container{position:relative;height:500px;border:1px solid #E5E7EB;border-radius:8px;overflow:hidden;background:#f9fafb;margin-top:1rem}@media (max-width: 768px){.network-container{height:400px}}.network-graph{width:100%;height:100%}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.loading-spinner{width:40px;height:40px;border:4px solid #E5E7EB;border-top:4px solid #3B82F6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.legend{margin-top:1rem;padding:.75rem 1rem;background:#f9fafb;border-radius:6px;border:1px solid #E5E7EB}.legend-title{font-weight:600;color:#374151;margin-bottom:.5rem}.legend-items{display:flex;flex-wrap:wrap;gap:1rem}.legend-color{width:16px;height:16px;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.dataset-selector{position:relative;min-width:150px;max-width:100%;margin-top:1rem}.dataset-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;background-color:#fff;border:1px solid #E5E7EB;border-radius:8px;box-shadow:0 1px 2px #0000000d;cursor:pointer;transition:all .2s}.dataset-select:hover{border-color:#9ca3af}.dataset-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.select-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);pointer-events:none;color:#6b7280;font-size:1rem}@media (max-width: 480px){.dataset-selector{width:100%}.legend-items,.radio-group{flex-direction:column;gap:.5rem}}.graph-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.graph-title{font-size:1.5rem;color:#1e40af;margin:0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.graph-controls{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:space-between}.dataset-selector{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.selector-label{font-weight:600;color:#4b5563}.toggle-switch{position:relative;display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;flex-wrap:wrap}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:relative;display:inline-block;width:50px;height:24px;background-color:#d1d5db;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#1e40af}input:checked+.slider:before{transform:translate(26px)}.toggle-label{font-weight:500;color:#4b5563}.network-container{width:100%;height:500px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#f9fafb}.graph-loading{height:500px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#4b5563}.loading-spinner{width:50px;height:50px;border:5px solid #e5e7eb;border-top:5px solid #1e40af;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.graph-legend{display:flex;gap:1.5rem;margin-top:1rem;justify-content:center;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:20px;height:4px;border-radius:2px}.legend-color.normal{background:#51c454}.legend-color.leak{background:#ff6b6b}@media (max-width: 768px){.graph-title{font-size:1.25rem;flex-direction:column;align-items:flex-start}.network-container,.graph-loading{height:400px}}@media (max-width: 480px){.graph-title{font-size:1.1rem}.slider{width:40px;height:20px}.slider:before{width:14px;height:14px}.legend-color{width:16px}}.leak-detection{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:1.5rem;margin-bottom:2rem;width:90%;margin:20px auto}.section-title{font-size:1.5rem;color:#1f2937;margin:0;display:flex;align-items:center;gap:.5rem}.dataset-selector{display:flex;align-items:center;gap:.5rem}.selector-label{font-weight:500;color:#4b5563}.custom-select{position:relative;min-width:120px}.custom-select select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#fff;border:1px solid #E5E7EB;border-radius:6px;padding:.5rem 2rem .5rem 1rem;font-size:.9rem;cursor:pointer;transition:all .2s;width:100%}.custom-select select:hover{border-color:#9ca3af}.custom-select select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.select-arrow{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none;color:#6b7280}.analysis-container{display:flex;flex-direction:column;gap:1.5rem}.leak-table-container{background:#f9fafb;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.table-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#eff6ff;border-bottom:1px solid #E5E7EB}.table-header h3{margin:0;color:#1e40af;font-size:1.1rem}.pressure-threshold{font-weight:500;color:#4b5563}.pressure-threshold span{font-weight:600;color:#1e40af}.table-scroll-container{overflow-x:auto}.leak-table{width:100%;border-collapse:collapse;font-size:.9rem}.leak-table th{background:#f3f4f6;color:#374151;font-weight:600;text-align:left;padding:.75rem 1rem;white-space:nowrap}.leak-table td{padding:.75rem 1rem;border-bottom:1px solid #E5E7EB;white-space:nowrap}.leak-table tr:last-child td{border-bottom:none}.leak-table tr:hover{background:#f9fafb}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.normal{background:#d1fae5;color:#065f46}.status-badge.leak{background:#fee2e2;color:#b91c1c}.error-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fef2f2;border-radius:8px;color:#b91c1c;margin:1rem 0}.error-icon{font-size:1.5rem}.error-message{font-weight:500}@media (max-width: 768px){.section-header{flex-direction:column;align-items:flex-start}.analysis-container{flex-direction:column}}@media (max-width: 668px){.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.section-title{font-size:1.3rem;gap:.4rem}.dataset-selector{width:100%;justify-content:space-between;flex-wrap:wrap}.custom-select{width:100%}.table-header{flex-direction:column;align-items:flex-start;gap:.5rem}.table-header h3{font-size:1rem}.leak-table th,.leak-table td{padding:.6rem .8rem}.status-badge{font-size:.7rem;padding:.2rem .45rem}.error-card{flex-direction:column;align-items:flex-start}.error-icon{font-size:1.3rem}.error-message{font-size:.9rem}}@media (max-width: 480px){.leak-detection{padding:1rem}.section-title{font-size:1.1rem}.selector-label{font-size:.85rem}.custom-select select{padding:.45rem .8rem;font-size:.85rem}.table-header{padding:.8rem 1rem}.leak-table{font-size:.8rem}.leak-table th,.leak-table td{padding:.5rem .6rem}.status-badge{font-size:.65rem;padding:.15rem .4rem}.error-card{font-size:.85rem;padding:.8rem}}.header{background:linear-gradient(135deg,#1e3a8a,#1e40af);color:#fff;padding:1.5rem 0;box-shadow:0 4px 6px #0000001a;position:relative;overflow:hidden}.header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.header-title{font-size:2rem;font-weight:700;margin:0;background:linear-gradient(to right,#fff,#dbeafe);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 2px 4px rgba(0,0,0,.1);text-align:center;flex:1 1 100%}.water-animation{display:flex;gap:.5rem;justify-content:center;flex:1 1 100%}.water-drop{width:12px;height:12px;background:#ffffffb3;border-radius:50%;animation:drop-fall 2s infinite ease-in;transform:translateY(-20px);opacity:0}.water-drop.delay-1{animation-delay:.3s}.water-drop.delay-2{animation-delay:.6s}@keyframes drop-fall{0%{transform:translateY(-20px);opacity:0}20%{opacity:1}90%{opacity:1}to{transform:translateY(20px);opacity:0}}@media (max-width: 768px){.header-title{font-size:1.5rem;text-align:center}.header-content{flex-direction:column;padding:0 1rem}.water-animation{margin-top:.5rem}}@media (max-width: 480px){.header-title{font-size:1.3rem}.water-drop{width:10px;height:10px}}.pipe-optimization{padding:1.5rem;width:90%;margin:20px auto;background-color:#fff;border-radius:1rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.section-title{font-size:1.75rem;color:#1f2937;margin:0;display:flex;align-items:center;gap:.75rem}.title-icon{font-size:1.8rem}.dataset-selector{display:flex;align-items:center;gap:.75rem}.selector-label{font-weight:500;color:#4b5563;font-size:.95rem}.radio-group{display:flex;gap:.75rem;flex-wrap:wrap}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem .75rem;border-radius:6px;transition:all .2s;font-size:.9rem}.radio-label:hover{background:#f3f4f6}.radio-label.active{background:#e0e7ff;color:#1e40af}.radio-label input{position:absolute;opacity:0;cursor:pointer}.radio-custom{height:16px;width:16px;background-color:#fff;border:2px solid #D1D5DB;border-radius:50%;position:relative}.radio-label input:checked~.radio-custom{background-color:#1e40af;border-color:#1e40af}.radio-custom:after{content:"";position:absolute;display:none}.radio-label input:checked~.radio-custom:after{display:block}.radio-custom:after{top:2px;left:2px;width:8px;height:8px;border-radius:50%;background:#fff}.content-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.content-grid{grid-template-columns:1fr 1.5fr}}.card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;overflow:hidden}.card-header{padding:1rem 1.5rem;background:#eff6ff;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.card-title{font-size:1.25rem;color:#1e40af;margin:0;display:flex;align-items:center;gap:.5rem}.card-icon{font-size:1.5rem}.optimize-button{background:#1e40af;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s;font-size:.9rem}.optimize-button:hover{background:#1e3a8a}.optimize-button:disabled{background:#9ca3af;cursor:not-allowed}.button-icon{font-size:1rem}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.table-container{overflow-x:auto;padding:.5rem}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th{background:#f3f4f6;color:#374151;font-weight:600;text-align:left;padding:.75rem 1rem;white-space:nowrap;position:sticky;top:0}.data-table td{padding:.75rem 1rem;border-bottom:1px solid #E5E7EB}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background:#f9fafb}.zone-type{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.zone-type.agricultural{background:#d9f99d;color:#3f6212}.zone-type.industrial{background:#fde68a;color:#92400e}.zone-type.urban{background:#bfdbfe;color:#1e40af}.zone-type.source{background:#ddd6fe;color:#5b21b6}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge.resized{background:#d1fae5;color:#065f46}.status-badge.original{background:#e0e7ff;color:#3730a3}.empty-state{padding:2rem;text-align:center;color:#6b7280}.empty-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.5}@media (max-width: 768px){.section-header,.card-header{flex-direction:column;align-items:flex-start}.optimize-button{width:100%;justify-content:center}}body{margin:0;padding:0;background-color:#f2f2f2}.header-container{background:linear-gradient(135deg,#3c9fa8,#36f8ff);color:#000;text-align:center;padding:30px 0;margin:0;box-shadow:0 4px 8px #0000001a;font-family:Doto,Sour Gummy,Arial,sans-serif}.header-title{font-size:40px;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin:0}@media (max-width: 768px){.header-container{padding:20px 0}.header-title{font-size:33px}}
