.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:15px;box-shadow:0 20px 40px #0003;max-height:90vh;max-width:900px;overflow:hidden;position:relative;width:100%}.modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #f0f3f7;border-radius:15px 15px 0 0;color:#fff;display:flex;justify-content:space-between;padding:25px 30px}.modal-header h2{-webkit-text-fill-color:#fff;background:none;-webkit-background-clip:unset;background-clip:initial;color:#fff!important;font-size:1.5rem;font-weight:600;margin:0;text-align:left}.modal-overlay .modal-content .close-btn{-webkit-tap-highlight-color:transparent;align-items:center!important;background:#ffffff1a!important;border:2px solid #ffffff4d!important;border-radius:50%!important;color:#fff!important;cursor:pointer;display:flex!important;font-size:1.5rem!important;font-weight:700!important;height:36px!important;justify-content:center!important;line-height:1!important;padding:0!important;touch-action:manipulation;transition:all .3s ease!important;width:36px!important}.modal-overlay .modal-content .close-btn:active,.modal-overlay .modal-content .close-btn:hover{background:#fff3!important;border-color:#ffffff80!important;transform:scale(1.05)!important}.construction-form{max-height:calc(90vh - 120px);overflow-y:auto;padding:30px}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;margin-bottom:20px;padding:12px 15px}.form-section{margin-bottom:30px}.form-section h3{align-items:center;border-bottom:2px solid #f0f3f7;color:#2c3e50;display:flex;font-size:1.2rem;gap:8px;margin:0 0 20px;padding-bottom:10px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.form-group{display:flex;flex-direction:column}.form-group label{color:#2c3e50;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:2px solid #ddd;border-radius:8px;font-family:inherit;font-size:16px;padding:12px 15px;transition:border-color .3s ease,box-shadow .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-group label:after{content:""}.form-group:has(input[required]) label:after,.form-group:has(select[required]) label:after,.form-group:has(textarea[required]) label:after{color:#e74c3c;content:" *";font-weight:700}.form-actions{border-top:2px solid #f0f3f7;display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px}.cancel-btn,.submit-btn{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 30px;transition:all .3s ease}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover{background:#5a6268;transform:translateY(-2px)}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d;color:#fff}.submit-btn:hover:not(:disabled){box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}@media (max-width:768px){.modal-overlay{padding:10px}.modal-content{max-height:95vh}.modal-header{padding:20px}.modal-header h2{-webkit-text-fill-color:#fff;background:none;-webkit-background-clip:unset;background-clip:initial;color:#fff!important;font-size:1.3rem;text-align:left}.modal-overlay .modal-content .close-btn{font-size:1.3rem!important;height:32px!important;min-height:44px!important;min-width:44px!important;width:32px!important}.construction-form{-webkit-overflow-scrolling:touch;max-height:calc(95vh - 100px);overflow-y:auto;padding:20px}.form-grid{gap:15px;grid-template-columns:1fr}.form-section h3{font-size:1.1rem}.form-group input,.form-group select,.form-group textarea{font-size:14px;padding:10px 12px}.form-actions{flex-direction:column;gap:10px}.cancel-btn,.submit-btn{font-size:14px;padding:12px;width:100%}}@media (max-width:480px){.modal-overlay{padding:5px}.construction-form,.modal-header{padding:15px}.form-section{margin-bottom:20px}.form-group{margin-bottom:15px}}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.modal-content::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.searchable-select{position:relative;width:100%}.searchable-select input{background:#fff;border:2px solid #e1e8ed;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 15px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.searchable-select input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.options-dropdown{background:#fff;border:2px solid #e1e8ed;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 12px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.option-item{border-bottom:1px solid #f0f3f7;cursor:pointer;padding:12px 15px;transition:background-color .2s ease}.option-item:hover{background-color:#f8fafc}.option-item:last-child{border-bottom:none}.well-name{color:#2c3e50;font-weight:600;margin-bottom:4px}.well-details{color:#6c757d;display:flex;font-size:12px;gap:15px}.well-details span{background:#f8f9fa;border-radius:4px;padding:2px 6px}.no-options{color:#6c757d;font-style:italic;padding:12px 15px;text-align:center}.modal-content::-webkit-scrollbar-thumb:hover{background:#555}.app-container{display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.main-content{flex:1 1;transition:margin-left .3s ease}.well-list{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1200px;padding:20px}h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#2c3e50;font-size:2.5rem;margin-bottom:30px;text-align:center}.statistics-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 16px #0000001a;color:#fff;margin-bottom:30px;padding:30px}.statistics-section h3{font-size:1.5em;font-weight:600;margin:0 0 20px;text-align:center}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.stat-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:20px;text-align:center}.stat-number{color:#fff;font-size:2.5em;margin-bottom:8px}.stat-label{font-size:.9em;opacity:.9}.stats-details{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.stat-category{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:20px}.stat-category h4{color:#fff;font-size:1.1em;font-weight:600;margin:0 0 15px}.stat-items{display:flex;flex-wrap:wrap;gap:8px}.stat-badge{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fff3;border:1px solid #ffffff4d;border-radius:20px;color:#fff;font-size:.85em;font-weight:500;padding:6px 12px}.loading{color:#666;font-size:18px;padding:50px;text-align:center}.error{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin:20px 0;padding:15px}.config-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;color:#856404;margin:20px 0;padding:20px}.config-warning h3{margin-top:0}.search-filters{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:15px;box-shadow:0 4px 6px #0000001a;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:25px;padding:20px}.search-box{flex:2 1;min-width:300px}.search-box input{border:2px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px 15px;transition:border-color .3s ease;width:100%}.search-box input:focus{border-color:#667eea;outline:none}.filter-box{flex:1 1;min-width:150px}.filter-box select{background:#fff;border:2px solid #ddd;border-radius:8px;font-size:16px;padding:12px 15px;transition:border-color .3s ease;width:100%}.filter-box select:focus{border-color:#667eea;outline:none}.clear-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;padding:12px 25px;transition:transform .2s ease,box-shadow .2s ease}.clear-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.results-header{align-items:center;display:flex;gap:15px;justify-content:space-between;margin-bottom:20px;padding:15px 0}.results-info{color:#666;font-size:16px}.results-info p{margin:0}.button-group{align-items:center;display:flex;gap:10px}.no-data{background:#f8f9fa;border-radius:10px;color:#666;margin:20px 0;padding:50px;text-align:center}.no-data p{font-size:16px;margin-bottom:10px}.no-data ul{display:inline-block;margin-top:20px;text-align:left}.no-data li{margin-bottom:5px}.wells-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:30px}.well-card{background:#fff;border:1px solid #e1e8ed;border-radius:15px;box-shadow:0 8px 25px #0000001a;padding:25px;transition:transform .3s ease,box-shadow .3s ease}.well-card:hover{box-shadow:0 15px 35px #00000026;transform:translateY(-5px)}.well-header{border-bottom:2px solid #f0f3f7;justify-content:space-between;margin-bottom:20px;min-height:40px;padding-bottom:15px}.well-header,.well-header h3{align-items:center;display:flex}.well-header h3{color:#2c3e50;font-size:1.4rem;line-height:1.2;margin:0}.header-buttons{align-items:center;display:flex;gap:10px}.expand-btn,.nav-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea33;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;height:auto;justify-content:center;line-height:1;padding:8px 16px;transition:all .3s ease}.nav-btn{background:linear-gradient(135deg,#28a745,#20c997);box-shadow:0 2px 8px #28a74533}.nav-btn:hover{box-shadow:0 4px 15px #28a74566;transform:translateY(-2px)}.expand-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.well-info{margin-bottom:20px}.basic-info{margin-bottom:15px}.info-row{align-items:center;border-bottom:1px solid #f0f3f7;display:flex;justify-content:space-between;padding:8px 0}.info-row:last-child{border-bottom:none}.info-label{color:#2c3e50;flex:1 1;font-weight:600;min-width:150px}.info-value{color:#555;flex:2 1;text-align:right}.expanded-info{border-top:2px solid #f0f3f7;margin-top:20px;padding-top:20px}.info-section{margin-bottom:25px}.info-section h4{align-items:center;color:#2c3e50;display:flex;font-size:1.1rem;gap:8px;margin:0 0 15px}.info-section p{color:#6c757d;font-size:14px;line-height:1.6;margin:6px 0}.info-section p strong{color:#495057;display:inline-block;font-weight:600;min-width:80px}.well-actions{display:flex;gap:10px;justify-content:flex-end}.delete-btn,.edit-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s ease}.edit-btn{background:linear-gradient(135deg,#00b894,#00a085);color:#fff}.edit-btn:hover{box-shadow:0 4px 12px #00b89466;transform:translateY(-2px)}.delete-btn{background:linear-gradient(135deg,#e17055,#d63031);color:#fff}.delete-btn:hover{box-shadow:0 4px 12px #e1705566;transform:translateY(-2px)}.construction-btn{background:linear-gradient(135deg,#74b9ff,#0984e3);border:none;border-radius:8px;box-shadow:0 2px 8px #74b9ff33;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.construction-btn:hover{box-shadow:0 4px 15px #74b9ff66;transform:translateY(-2px)}.add-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea33;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.add-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.login-btn{background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;box-shadow:0 2px 8px #007bff33;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.login-btn:hover{box-shadow:0 4px 15px #007bff66;transform:translateY(-2px)}.logout-btn{background:linear-gradient(135deg,#dc3545,#c82333);border:none;border-radius:8px;box-shadow:0 2px 8px #dc354533;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.logout-btn:hover{box-shadow:0 4px 15px #dc354566;transform:translateY(-2px)}.disabled{background:linear-gradient(135deg,#6c757d,#5a6268)!important;cursor:not-allowed!important;opacity:.7}.disabled,.disabled:hover{box-shadow:0 2px 8px #6c757d33!important}.disabled:hover{transform:none!important}.floating-nav{bottom:20px;position:fixed;right:20px;z-index:1000}.floating-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 20px #0000004d;color:#fff;cursor:pointer;display:flex;font-size:24px;height:60px;justify-content:center;transition:all .3s ease;width:60px}.hamburger-menu{display:flex;flex-direction:column;gap:4px;height:16px;width:20px}.hamburger-menu span{background-color:#fff;border-radius:1px;display:block;height:2px;transition:all .3s ease;width:100%}.floating-btn:hover .hamburger-menu span{transform:scaleX(.8)}.floating-btn:hover{box-shadow:0 6px 25px #0006;transform:translateY(-2px)}.floating-menu{animation:fadeInUp .3s ease;background:#fff;border-radius:12px;bottom:70px;box-shadow:0 8px 32px #0003;min-width:160px;padding:8px;position:absolute;right:0}.menu-item{background:#0000;border:none;border-radius:8px;color:#2c3e50;cursor:pointer;display:block;font-size:14px;padding:12px 16px;text-align:left;transition:background-color .2s ease;width:100%}.menu-item:hover{background-color:#f8f9fa}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.well-list{padding:15px}.search-filters{flex-direction:column;gap:10px;padding:15px}.search-box{min-width:0;min-width:auto;width:100%}.search-box input{box-sizing:border-box;min-width:0;width:100%}.filter-box{min-width:0;min-width:auto;width:100%}.filter-box select{box-sizing:border-box;width:100%}.results-header{align-items:flex-start;flex-direction:column;gap:15px;padding:10px 0}.results-info{text-align:left}.button-group{flex-direction:column;gap:10px;width:100%}.add-btn,.construction-btn{justify-content:center;width:100%}.wells-grid{gap:20px;grid-template-columns:1fr}.well-card{padding:20px}.well-header{align-items:center;flex-direction:row;gap:10px;justify-content:space-between}.header-buttons{gap:8px}.expand-btn,.nav-btn{align-self:center;font-size:13px;padding:6px 12px}.info-row{align-items:flex-start;flex-direction:column;gap:5px}.info-value{text-align:left}.well-actions{justify-content:center}}@media (max-width:480px){.search-filters,.well-list{padding:10px}.filter-box select,.search-box input{font-size:14px;padding:10px 12px}.clear-btn{font-size:14px;padding:10px 15px}.results-header{padding:5px 0}.results-info{font-size:14px}.add-btn,.construction-btn{font-size:14px;padding:10px 15px}.well-card{padding:15px}.well-header h3{font-size:1.2rem}.header-buttons{gap:6px}.expand-btn,.nav-btn{font-size:12px;padding:6px 10px}.info-section h4{font-size:1rem}}.user-management-modal .modal-content{border-radius:20px;box-shadow:0 20px 40px #0003;overflow:hidden}.user-management-modal .modal-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px 20px 0 0;padding:25px 30px;position:relative}.user-management-modal .construction-form{background:#fff;border-radius:0 0 20px 20px;overflow:hidden}.user-management-modal .close-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:#ffffff1a;border:2px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;font-weight:700;height:36px;justify-content:center;line-height:1;touch-action:manipulation;transition:all .3s ease;width:36px}.user-management-modal .close-btn:active,.user-management-modal .close-btn:hover{background:#fff3;border-color:#ffffff80;transform:scale(1.05)}@media (max-width:768px){.user-management-modal .modal-overlay{align-items:flex-start;padding:20px 5px 5px}.user-management-modal .modal-content{border-radius:16px;margin:0;max-height:calc(100vh - 40px);width:calc(100% - 10px)}.user-management-modal .modal-header{border-radius:16px 16px 0 0;padding:20px;position:sticky;top:0;z-index:10}.user-management-modal .modal-header h2{font-size:1.2rem}.user-management-modal .close-btn{font-size:1.3rem;height:32px;min-height:44px;min-width:44px;width:32px}.user-management-modal .construction-form{-webkit-overflow-scrolling:touch;border-radius:0 0 16px 16px;height:calc(100% - 80px);overflow-y:auto;padding:20px}}@media (max-width:480px){.user-management-modal .modal-overlay{align-items:stretch;padding:10px 0 0}.user-management-modal .modal-content{border-radius:12px 12px 0 0;margin:0;max-height:calc(100vh - 10px);width:100%}.user-management-modal .modal-header{border-radius:12px 12px 0 0;padding:16px 20px}.user-management-modal .modal-header h2{font-size:1.1rem}.user-management-modal .construction-form{border-radius:0;padding:16px}}.user-management-modal .user-list-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:20px;overflow:hidden;width:100%}.user-management-modal .user-list-table td,.user-management-modal .user-list-table th{border-bottom:1px solid #f0f0f0;padding:12px;text-align:left}.user-management-modal .user-list-table th{background:#f8f9fa;color:#495057;font-weight:600}@media (max-width:768px){.user-management-modal .user-list-table{font-size:14px}.user-management-modal .user-list-table td,.user-management-modal .user-list-table th{padding:8px 6px}}.user-management-modal .modal-content::-webkit-scrollbar{width:6px}.user-management-modal .modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.user-management-modal .modal-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.user-management-modal .modal-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.fab-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;bottom:80px;box-shadow:0 4px 20px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:24px;height:56px;justify-content:center;position:fixed;right:20px;transition:all .3s ease;width:56px;z-index:1000}.fab-button:hover{box-shadow:0 6px 25px #667eea99;transform:scale(1.1)}.fab-button:active{transform:scale(.95)}.mobile-overlay{animation:fadeIn .3s ease;background:#00000080;top:0;z-index:1001}.mobile-menu,.mobile-overlay{bottom:0;left:0;position:fixed;right:0}.mobile-menu{animation:slideUp .3s ease;background:#fff;border-radius:20px 20px 0 0;max-height:70vh;overflow-y:auto}.mobile-menu-header{align-items:center;background:#fff;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:20px;position:sticky;top:0;z-index:1}.mobile-menu-header h3{color:#2c3e50;font-size:1.2em;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;padding:5px;width:40px}.close-btn:hover{background:#f5f5f5}.mobile-menu-items{padding:10px 0 20px}.mobile-nav-item{align-items:center;background:none;border:none;cursor:pointer;display:flex;padding:15px 20px;text-align:left;transition:background-color .2s ease;width:100%}.mobile-nav-item:hover{background:#f8f9fa}.mobile-nav-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.mobile-nav-item .nav-icon{font-size:24px;margin-right:15px;min-width:40px;text-align:center}.nav-content{flex:1 1}.nav-label{display:block;font-size:16px;font-weight:600;margin-bottom:2px}.nav-description{display:block;font-size:14px;opacity:.7}.desktop-sidebar{background:#fff;border-right:1px solid #eee;box-shadow:2px 0 10px #0000001a;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:280px;z-index:100}.sidebar-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #eee;color:#fff;padding:30px 20px 20px}.sidebar-header h3{font-size:1.3em;font-weight:600;margin:0}.sidebar-nav{padding:20px 0}.sidebar-nav-item{align-items:center;background:none;border:none;border-left:4px solid #0000;cursor:pointer;display:flex;padding:15px 20px;text-align:left;transition:all .2s ease;width:100%}.sidebar-nav-item:hover{background:#f8f9fa;border-left-color:#667eea}.sidebar-nav-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-left-color:#667eea;color:#667eea}.sidebar-nav-item .nav-icon{font-size:22px;margin-right:15px;min-width:40px;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.desktop-sidebar{display:none}}@media (min-width:769px){.fab-button,.mobile-overlay{display:none}.main-content.with-navigation{margin-left:280px}}@media (prefers-color-scheme:dark){.desktop-sidebar,.mobile-menu{background:#1a1a1a;border-color:#333;color:#fff}.mobile-menu-header,.sidebar-header{border-color:#333}.mobile-nav-item:hover,.sidebar-nav-item:hover{background:#2a2a2a}.close-btn:hover{background:#333}}.data-analysis,.pvc-pipes-page{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.loading-container{align-items:center;color:#6c757d;display:flex;flex-direction:column;justify-content:center;min-height:300px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.stats-overview{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:40px}.stat-card{align-items:center;background:#fff;box-shadow:0 4px 16px #0000001a;display:flex;padding:24px;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.stat-card.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-card.secondary{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#8b4513}.stat-card.tertiary{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#2c3e50}.stat-card.quaternary{background:linear-gradient(135deg,#fbc2eb,#a6c1ee);color:#2c3e50}.stat-icon{font-size:32px;margin-right:16px;opacity:.9}.stat-content h3{font-size:2rem;font-weight:700;margin:0 0 4px}.stat-content p{font-size:.9rem;margin:0;opacity:.8}.charts-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:40px}.chart-card{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;padding:24px;transition:transform .2s ease}.chart-card:hover{transform:translateY(-2px)}.chart-card.full-width{grid-column:1/-1}.chart-card h3{border-bottom:2px solid #f8f9fa;color:#2c3e50;font-size:1.3rem;margin:0 0 20px;padding-bottom:12px}.chart-content{space-y:12px}.bar-item{align-items:center;display:flex;margin-bottom:12px}.bar-label{color:#495057;font-size:.9rem;font-weight:500;min-width:120px}.bar-container{background:#f8f9fa;border-radius:12px;flex:1 1;height:24px;margin:0 12px;overflow:hidden;position:relative}.bar-fill{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;height:100%;min-width:2px;transition:width .8s ease}.bar-fill.secondary{background:linear-gradient(135deg,#ffecd2,#fcb69f)}.bar-fill.tertiary{background:linear-gradient(135deg,#a8edea,#fed6e3)}.bar-value{color:#495057;font-size:.8rem;font-weight:700;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.depth-analysis{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.depth-stat{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid #667eea33;border-radius:8px;padding:20px;text-align:center}.depth-label{color:#6c757d;display:block;font-size:.9rem;margin-bottom:8px}.depth-value{color:#667eea;display:block;font-size:1.5rem;font-weight:700}.refresh-section{margin-top:40px;text-align:center}.refresh-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:all .2s ease}.refresh-btn:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.refresh-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.data-analysis{padding:15px}.page-header h2{font-size:2rem}.stats-overview{gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{flex-direction:column;padding:20px;text-align:center}.stat-icon{margin-bottom:8px;margin-right:0}.charts-container{gap:20px;grid-template-columns:1fr}.chart-card{padding:20px}.bar-label{font-size:.8rem;min-width:80px}.depth-analysis{gap:15px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.depth-stat{padding:15px}.depth-value{font-size:1.2rem}}@media (max-width:480px){.data-analysis{padding:10px}.stats-overview{grid-template-columns:1fr 1fr}.stat-card{padding:15px}.stat-content h3{font-size:1.5rem}.bar-item{align-items:stretch;flex-direction:column}.bar-label{margin-bottom:8px;min-width:auto;text-align:center}.bar-container{margin:0}}.search-controls{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:25px}.search-input-container{flex:1 1;min-width:250px}.search-input{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:16px;height:50px;padding:15px 18px;transition:border-color .2s ease;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.sort-container{min-width:180px}.sort-select{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:16px;padding:12px 16px;transition:border-color .2s ease;width:100%}.sort-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.results-info{color:#6c757d;font-weight:500;margin-bottom:20px;padding:10px 0}.pipes-grid-mobile{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px}.pipe-card{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.pipe-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.pipe-card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;text-align:center}.pipe-card-header h3{font-size:1.8rem;font-weight:700;margin:0 0 5px}.pipe-card-header .pipe-code{font-size:1.3rem;opacity:.9}.pipe-card-content{padding:20px}.pipe-spec{align-items:center;border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;padding:8px 0}.pipe-spec:last-child{border-bottom:none}.pipe-spec.price{color:#28a745;font-weight:600}.spec-label{color:#6c757d;font-weight:500}.spec-value{color:#2c3e50;font-weight:600}.pipes-table-container{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-bottom:30px;overflow-x:auto}.pipes-table{border-collapse:collapse;font-size:.9rem;width:100%}.pipes-table th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;padding:15px 12px;text-align:left;white-space:nowrap}.pipes-table td{border-bottom:1px solid #dee2e6;padding:12px;white-space:nowrap}.pipes-table tr:hover{background:#f8f9fa}.pipes-table tr:last-child td{border-bottom:none}.pipes-table .pipe-inch{color:#667eea;font-weight:600}.pipes-table .pipe-code{color:#764ba2;font-weight:600}@media (max-width:768px){.pvc-pipes-page{padding:10px}.search-controls{flex-direction:column;margin-bottom:20px}.search-input-container{min-width:auto;width:100%}.search-input{border-radius:6px;font-size:16px;height:48px;padding:12px 16px}.results-info{font-size:14px;margin-bottom:15px}.pipes-grid-mobile{gap:15px;grid-template-columns:1fr}.pipe-card-content,.pipe-card-header{padding:15px}}@media (max-width:480px){.pvc-pipes-page{padding:8px}.page-header h2{font-size:1.8rem}.page-header p{font-size:1rem}.search-input{padding:8px 10px}.results-info,.search-input{font-size:13px}.pipe-card-content,.pipe-card-header{padding:12px}.pipe-spec{padding:6px 0}}@media (prefers-color-scheme:dark){.data-analysis,.pvc-pipes-page{background:#1a1a1a;color:#fff}.pipe-card,.pipes-table-container{background:#2a2a2a;border:1px solid #333}.search-input,.sort-select{background:#2a2a2a;border-color:#444;color:#fff}.page-header h2{color:#fff}.page-header p,.results-info,.spec-label{color:#ccc}.spec-value{color:#fff}.pipe-spec,.pipes-table td{border-color:#333}.pipes-table tr:hover{background:#333}.chart-card,.stat-card{background:#2a2a2a;border:1px solid #333}.chart-card h3{color:#fff}.bar-container{background:#333}.depth-stat{background:#667eea33;border-color:#667eea4d}}.motor-section{border-bottom:1px solid #e9ecef;margin-bottom:16px;padding-bottom:12px}.motor-section:last-child{border-bottom:none;margin-bottom:0}.section-title{background-color:#f8f9fa;border-left:3px solid #667eea;border-radius:4px;color:#495057;font-size:18px;font-weight:600;margin-bottom:10px;padding:8px 12px}.motor-section .pipe-spec{margin:8px 0}.motor-section .spec-label{color:#6c757d;font-size:17px}.motor-section .spec-value{color:#2c3e50;font-size:17px;font-weight:500}.highlight-current{color:#dc3545!important;font-weight:700}.highlight-current .spec-label,.highlight-current .spec-value{color:#dc3545!important;font-weight:700!important}.settings{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:800px;padding:20px}.page-header{margin-bottom:40px;text-align:center}.page-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#2c3e50;font-size:2.5rem;margin-bottom:10px}.page-header p{color:#6c757d;font-size:1.1rem;margin:0}.settings-content{space-y:30px}.settings-section{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-bottom:25px;padding:25px;transition:transform .2s ease}.settings-section:hover{transform:translateY(-2px)}.settings-section h3{align-items:center;border-bottom:2px solid #f8f9fa;color:#2c3e50;display:flex;font-size:1.3rem;gap:8px;margin:0 0 20px;padding-bottom:12px}.setting-item{align-items:center;display:flex;gap:15px;justify-content:space-between;margin-bottom:20px}.setting-item:last-child{margin-bottom:0}.setting-item label{align-items:center;color:#495057;display:flex;flex:1 1;font-weight:500;gap:8px}.setting-item input[type=number],.setting-item select{border:2px solid #e9ecef;border-radius:6px;font-size:14px;min-width:150px;padding:8px 12px;transition:border-color .2s ease}.setting-item input[type=number]:focus,.setting-item select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.setting-item input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.system-info{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid #667eea33;border-radius:8px;padding:20px}.info-item{align-items:center;border-bottom:1px solid #667eea1a;display:flex;justify-content:space-between;padding:8px 0}.info-item:last-child{border-bottom:none}.info-item .label{color:#6c757d;font-weight:500}.info-item .value{color:#2c3e50;font-weight:600}.settings-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-top:40px}.action-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;min-width:140px;padding:12px 24px;transition:all .2s ease}.action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.secondary{background:#6c757d;color:#fff}.action-btn:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.action-btn:active{transform:translateY(0)}@media (max-width:768px){.settings{padding:15px}.page-header h2{font-size:2rem}.settings-section{margin-bottom:20px;padding:20px}.setting-item{align-items:flex-start;flex-direction:column;gap:10px}.setting-item label{width:100%}.setting-item input[type=number],.setting-item select{min-width:auto;width:100%}.info-item{align-items:flex-start;flex-direction:column;gap:4px}.settings-actions{align-items:center;flex-direction:column}.action-btn{max-width:300px;width:100%}}@media (max-width:480px){.settings{padding:10px}.settings-section{padding:15px}.page-header h2{font-size:1.8rem}.settings-section h3{font-size:1.1rem}}.tab-navigation{border-bottom:2px solid #f8f9fa;display:flex;gap:10px;margin-bottom:30px;padding-bottom:10px}.tab-btn{background:#f8f9fa;border:none;border-radius:8px 8px 0 0;color:#6c757d;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.tab-btn:hover:not(.active){background:#e9ecef;color:#495057}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:20px}.stat-card{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid #667eea33;border-radius:12px;padding:20px;text-align:center;transition:transform .2s ease}.stat-card:hover{transform:translateY(-5px)}.stat-icon{font-size:2rem;margin-bottom:10px}.stat-number{color:#667eea;font-size:2.5rem;font-weight:700;margin-bottom:5px}.stat-label{color:#6c757d;font-size:.9rem;font-weight:500}.tools-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px}.tool-btn{background:#fff;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;padding:20px;text-align:center;transition:all .2s ease}.tool-btn:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.tool-icon{font-size:2rem;margin-bottom:10px}.tool-title{color:#2c3e50;font-size:1.1rem;font-weight:600;margin-bottom:8px}.tool-desc{color:#6c757d;font-size:.9rem;line-height:1.4}@media (prefers-color-scheme:dark){.settings{background:#1a1a1a;color:#fff}.settings-section,.system-info{background:#2a2a2a;border-color:#333}.page-header h2{color:#fff}.page-header p{color:#ccc}.settings-section h3{border-color:#333;color:#fff}.setting-item label{color:#ccc}.setting-item input[type=number],.setting-item select{background:#333;border-color:#444;color:#fff}.info-item .label{color:#ccc}.info-item .value{color:#fff}.info-item{border-color:#333}.tab-btn{background:#333;color:#ccc}.tab-btn:hover:not(.active){background:#444;color:#fff}.stat-card{background:#667eea33;border-color:#667eea4d}.stat-label{color:#ccc}.tool-btn{background:#2a2a2a;border-color:#444}.tool-btn:hover{border-color:#667eea}.tool-title{color:#fff}.tool-desc{color:#ccc}}.wiring-diagram-container{padding:12px}.diagram-header{justify-content:space-between}.controls,.diagram-header{align-items:center;display:flex;gap:12px}.progress-info{align-items:center;display:flex;gap:8px}.progress-bar{background:#eee;border-radius:8px;height:8px;overflow:hidden;width:180px}.progress-fill{background:#f66;height:100%}.reset-btn{background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;padding:6px 10px}.diagram-wrapper{border:1px solid #f3f3f3;border-radius:10px;overflow:hidden}.wiring-svg{background:#fff;height:auto;width:100%}.diagram-title{fill:#b30000;font-size:32px;font-weight:800}.bus{stroke:#111;stroke-width:4}.wire{stroke:#666;stroke-width:4;cursor:pointer}.wire.connected{stroke:#d62424}.wire.disconnected{stroke:#666}.terminal-label{fill:#111;font-size:16px;font-weight:600}.switch-label{fill:#111;font-size:30px}.terminal-dot{fill:#fff;stroke:#111;stroke-width:2}.contact-blade,.motor{stroke:#111;stroke-width:3}.motor{fill:#fff}.motor-label{fill:#2a8a2a;font-size:20px;font-weight:700}.contact-label{fill:#111;font-size:14px}.aux-pill{stroke:#111;stroke-width:3}.diagram-selector{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;margin:15px 0;padding:15px}.diagram-selector h4{color:#2c3e50;font-size:16px;font-weight:600;margin:0 0 15px}.diagram-dropdown-wrapper{margin-bottom:15px;position:relative}.diagram-dropdown{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fff;border:2px solid #e9ecef;border-radius:8px;color:#2c3e50;cursor:pointer;font-size:16px;font-weight:500;padding:12px 40px 12px 16px;transition:all .2s ease;width:100%}.diagram-dropdown:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.diagram-dropdown:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33;outline:none}.dropdown-icon{color:#6c757d;font-size:12px;pointer-events:none;position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:all .2s ease}.diagram-dropdown:focus+.dropdown-icon{color:#667eea;transform:translateY(-50%) rotate(180deg)}.diagram-description{background:#fff;border-left:4px solid #667eea;border-radius:6px;color:#6c757d;font-size:14px;font-style:italic;margin:0;padding:10px}.coil-label{fill:#dc3545;font-size:12px;font-weight:600}.instructions{background:#f8f9fa;border-radius:10px;margin-top:15px;padding:15px}.instructions h4{color:#2c3e50;font-size:16px;margin:0 0 12px}.instructions ul{margin:0;padding-left:20px}.instructions li{color:#495057;font-size:14px;margin-bottom:8px}.completion-message{animation:celebration .6s ease-in-out;background:linear-gradient(135deg,#d4edda,#c3e6cb);border:2px solid #28a745;border-radius:8px;color:#155724;font-weight:700;margin-top:15px;padding:12px 16px;text-align:center}@keyframes celebration{0%{opacity:0;transform:scale(.9)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.diagram-dropdown{font-size:15px;padding:10px 35px 10px 14px}.dropdown-icon{font-size:11px;right:14px}}@media (max-width:480px){.diagram-dropdown{font-size:14px;padding:8px 30px 8px 12px}.dropdown-icon{font-size:10px;right:12px}}@media (prefers-color-scheme:dark){.diagram-selector,.instructions{background:#2c3e50;border-color:#34495e}.diagram-selector h4,.instructions h4{color:#ecf0f1}.diagram-dropdown{background:#34495e;border-color:#4a6741;color:#ecf0f1}.diagram-dropdown:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea33}.diagram-dropdown:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea4d}.dropdown-icon{color:#bdc3c7}.diagram-dropdown:focus+.dropdown-icon{color:#667eea}.diagram-description{background:#34495e;color:#bdc3c7}.instructions li{color:#bdc3c7}}.App{background-color:#f5f5f5;min-height:100vh}.App-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:20px;text-align:center}.App-header h1{font-size:2.5rem;font-weight:300;margin:0 0 10px}.App-header p{font-size:1.1rem;margin:0;opacity:.9}main{padding:20px 0}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}@media (max-width:768px){.App-header h1{font-size:2rem}.App-header p{font-size:1rem}}
/*# sourceMappingURL=main.0a2d91f0.css.map*/