.main-content{position:relative;z-index:1;padding:2rem;max-width:100%;margin:0 auto;width:100%}.login-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem}.login-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:3rem;width:100%;max-width:450px;box-shadow:0 20px 60px #0000004d}.login-card h2{color:#fff;font-size:2rem;margin-bottom:2rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{display:block;color:#fffc;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s}.form-group input:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.form-group input::placeholder{color:#fff6}.file-upload-widget{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;margin-top:0;height:100%;display:flex;flex-direction:column}.widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.widget-header h4{color:#fff;font-size:1.1rem;margin:0}.file-name-input{margin-bottom:1rem}.name-input{width:100%;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.9rem}.name-input:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.name-input::placeholder{color:#fff6}.files-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.files-list::-webkit-scrollbar{width:8px}.files-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.files-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}.files-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.files-list{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) rgba(255,255,255,.05)}.file-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.file-name{color:#fff;font-weight:500;margin-bottom:.25rem;word-break:break-word}.file-meta{color:#fff9;font-size:.85rem}.file-image-preview{width:80px;height:80px;border-radius:8px;overflow:hidden;margin-bottom:.5rem;background:#ffffff0d;display:flex;align-items:center;justify-content:center}.file-image-preview img{width:100%;height:100%;object-fit:cover}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#ffffff4d}.file-actions{display:flex;gap:.5rem;flex-shrink:0}.empty-files{text-align:center;padding:2rem;color:#ffffff80;font-size:.9rem}.button-small{padding:.5rem 1rem;font-size:.85rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;cursor:pointer;transition:all .3s;white-space:nowrap;text-decoration:none;display:inline-block}.button-small.button-primary{background:#60a5fa26;border-color:#60a5fa40;color:#93c5fd}.button-small.button-primary:hover:not(:disabled){background:#60a5fa40;border-color:#60a5fa59}.machine-modal-wrapper .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.machine-modal-wrapper .modal-content.machine-modal{max-width:100%;width:98vw;max-height:95vh;overflow-y:auto;overflow-x:hidden;background:#0f0f1ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;box-shadow:0 20px 60px #00000080}.machine-modal .form-group{margin-bottom:1.5rem}.machine-modal .form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.machine-modal .form-row-full{grid-column:1 / -1}@media (max-width: 768px){.machine-modal .form-row{grid-template-columns:1fr}}.machine-modal .form-group label{display:block;color:#fffc;margin-bottom:.5rem;font-weight:500}.machine-modal .form-group input,.machine-modal .form-group select{width:100%;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s}.machine-modal .form-group input:focus,.machine-modal .form-group select:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.machine-modal .form-group select option{background:#1a1a2e;color:#fff;padding:.5rem}.machine-modal .form-group input[type=date]{color-scheme:dark}.machine-modal .error-message{background:#a855f726;border:1px solid rgba(168,85,247,.25);color:#c4b5fd;padding:1rem;border-radius:12px;margin-bottom:1rem;text-align:center;font-size:.9rem}.machine-modal .form-group .file-upload-widget{height:100%;display:flex;flex-direction:column}.machine-modal::-webkit-scrollbar{width:12px}.machine-modal::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.machine-modal::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px;border:2px solid rgba(255,255,255,.05)}.machine-modal::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.machine-modal{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) rgba(255,255,255,.05)}.machines-list{width:100%;max-width:100%;box-sizing:border-box}.machines-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.machines-table-container{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow-x:auto;overflow-y:visible;width:100%;max-width:100%;box-sizing:border-box;display:block;padding:.5rem}.machines-table-container::-webkit-scrollbar{height:12px}.machines-table-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.machines-table-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px;border:2px solid rgba(255,255,255,.05)}.machines-table-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.machines-table-container{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) rgba(255,255,255,.05)}.machines-table{width:100%;border-collapse:collapse;table-layout:auto}.machines-table thead{background:#ffffff0d}.machines-table th{padding:.5rem .75rem;text-align:left;color:#fff;font-weight:600;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.1);white-space:nowrap}.machines-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.machines-table th.sortable:hover{background:#ffffff1a}.machines-table td{padding:.5rem .75rem;color:#fffc;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.05);word-wrap:break-word}.machines-table tbody tr:hover{background:#ffffff0d}.machines-table tbody tr.table-row-clickable{cursor:pointer;transition:background-color .2s}.machines-table tbody tr.table-row-clickable:hover{background-color:#ffffff1a}.client-machines-groups{display:flex;flex-direction:column;gap:2rem}.client-machines-section{display:flex;flex-direction:column;gap:1rem}.client-machines-count{color:#ffffffb3;font-size:.9rem;padding:.4rem .8rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px}.valve-modal-wrapper .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.valve-modal-wrapper .modal-content.valve-modal{max-width:100%;width:98vw;max-height:95vh;overflow-y:auto;overflow-x:hidden;background:#0f0f1ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;box-shadow:0 20px 60px #00000080}.valve-modal .form-group{margin-bottom:1.5rem}.valve-modal .form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.valve-modal .form-row-full{grid-column:1 / -1}@media (max-width: 768px){.valve-modal .form-row{grid-template-columns:1fr}}.valve-modal .form-group label{display:block;color:#fffc;margin-bottom:.5rem;font-weight:500}.valve-modal .form-group input,.valve-modal .form-group select{width:100%;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s}.valve-modal .form-group input:focus,.valve-modal .form-group select:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.valve-modal .form-group select option{background:#1a1a2e;color:#fff;padding:.5rem}.valve-modal .form-group input[type=date]{color-scheme:dark}.valve-modal .error-message{background:#a855f726;border:1px solid rgba(168,85,247,.25);color:#c4b5fd;padding:1rem;border-radius:12px;margin-bottom:1rem;text-align:center;font-size:.9rem}.valve-modal .form-group .file-upload-widget{height:100%;display:flex;flex-direction:column}.valve-modal::-webkit-scrollbar{width:12px}.valve-modal::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.valve-modal::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px;border:2px solid rgba(255,255,255,.05)}.valve-modal::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.valve-modal{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) rgba(255,255,255,.05)}.location-map-upload{margin-top:.5rem}.location-map-preview{display:flex;flex-direction:column;gap:1rem}.location-map-preview img{max-width:100%;max-height:400px;border-radius:8px;border:1px solid rgba(255,255,255,.1);object-fit:contain}.location-map-actions{display:flex;gap:.5rem}.location-map-upload-empty{display:flex;flex-direction:column;gap:.5rem}.location-map-hint{font-size:.85rem;color:#fff9;margin:0}.valves-list{width:100%;max-width:100%;box-sizing:border-box}.valves-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.table-search-input{padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.9rem;min-width:180px;transition:all .3s}.table-search-input:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.table-search-input::placeholder{color:#fff6}.valves-table-container{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow-x:auto;overflow-y:visible;width:100%;max-width:100%;box-sizing:border-box;display:block;padding:.5rem}.valves-table-container::-webkit-scrollbar{height:12px}.valves-table-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.valves-table-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px;border:2px solid rgba(255,255,255,.05)}.valves-table-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.valves-table-container{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) rgba(255,255,255,.05)}.valves-table{width:100%;border-collapse:collapse;table-layout:auto}.valves-table thead{background:#ffffff0d}.valves-table th{padding:.5rem .75rem;text-align:left;color:#fff;font-weight:600;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.1);white-space:nowrap}.valves-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.valves-table th.sortable:hover{background:#ffffff1a}.sort-indicator{color:#ffffff80;font-size:.9rem}.valves-table td{padding:.5rem .75rem;color:#fffc;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.05);word-wrap:break-word}.valves-table tbody tr:hover{background:#ffffff0d}.valves-table tbody tr.table-row-clickable{cursor:pointer;transition:background-color .2s}.valves-table tbody tr.table-row-clickable:hover{background-color:#ffffff1a}.machine-type-badge{padding:.2rem .5rem;border-radius:8px;font-size:.75rem;font-weight:600;white-space:nowrap;display:inline-block}.user-info{display:flex;flex-direction:column;gap:.15rem}.user-name{color:#ffffffe6;font-weight:500}.user-email{color:#fff9;font-size:.8rem}.hash-id{background:#ffffff1a;padding:.2rem .4rem;border-radius:4px;font-family:Courier New,monospace;font-size:.75rem;color:#fffc}.button-small{padding:.4rem .75rem;font-size:.8rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;cursor:pointer;transition:all .3s;white-space:nowrap}.button-small:hover:not(:disabled){background:#fff3}.button-small:disabled{opacity:.5;cursor:not-allowed}.button-small.button-danger:hover:not(:disabled){background:#a855f740;border-color:#a855f759}.table-pagination{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap;gap:.75rem}.pagination-info{display:flex;flex-direction:column;gap:.25rem;color:#ffffffb3;font-size:.85rem}.pagination-info strong{color:#fff}.pagination-controls{display:flex;gap:.4rem}.pagination-size{display:flex;align-items:center;gap:.4rem;color:#ffffffb3;font-size:.85rem}.page-size-select{padding:.4rem .5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.85rem;cursor:pointer}.page-size-select:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.error-message{background:#a855f726;border:1px solid rgba(168,85,247,.25);color:#c4b5fd;padding:1rem;border-radius:12px;margin-bottom:1rem;text-align:center}.client-select-container{display:flex;align-items:center;gap:.5rem}.client-select-label{color:#fffc;font-size:.9rem;white-space:nowrap}.client-select{padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.9rem;min-width:200px;max-width:300px;cursor:pointer;transition:all .3s}.client-select:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.client-select option{background:#1a1a2e;color:#fff;padding:.5rem}.client-valves-groups{display:flex;flex-direction:column;gap:2rem}.client-valves-section{display:flex;flex-direction:column;gap:1rem}.client-section-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;margin-bottom:.5rem}.client-section-title{margin:0;font-size:1.2rem;font-weight:600;color:#fff}.client-section-email{color:#fff9;font-weight:400;font-size:.95rem}.client-valves-count{color:#ffffffb3;font-size:.9rem;padding:.4rem .8rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px}.sequence-number{cursor:pointer;padding:.2rem .4rem;border-radius:4px;transition:background .2s;display:inline-block;min-width:2rem;text-align:center}.sequence-number:hover{background:#ffffff1a}.sequence-number-input{width:60px;padding:.2rem .4rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:4px;color:#fff;font-size:.9rem;text-align:center}.sequence-number-input:focus{outline:none;border-color:#ffffff80;background:#ffffff26}.inspection-date.date-critical{color:#ef4444;font-weight:600}.inspection-date.date-warning{color:#f59e0b;font-weight:500}.inspection-date.date-overdue{color:#dc2626;font-weight:700}.devices-container{width:100%}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.tabs-container{display:flex;gap:.5rem;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.25rem}.tab-button{padding:.75rem 1.5rem;background:transparent;border:none;border-radius:8px;color:#ffffffb3;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s}.tab-button:hover{color:#ffffffe6;background:#ffffff0d}.tab-button.active{background:#60a5fa33;color:#93c5fd;font-weight:600}.old-home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-title{color:#fff;font-size:1.5rem;margin:0;font-weight:600}.loading{text-align:center;color:#ffffffb3;padding:3rem;font-size:1.2rem}.empty-state{text-align:center;padding:4rem 2rem;color:#fff9}.empty-state-hint{margin-top:1rem;font-size:.9rem;color:#fff6}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.device-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;cursor:pointer;transition:all .3s}.device-card:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-5px);box-shadow:0 10px 40px #0000004d}.device-card h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}.device-card p{color:#fff9;font-size:.9rem}.users-management{width:100%}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.users-table-container{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;padding:.5rem}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:#ffffff0d}.users-table th{padding:.5rem .75rem;text-align:left;color:#fff;font-weight:600;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.1)}.users-table td{padding:.5rem .75rem;color:#fffc;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.05)}.users-table tbody tr:hover{background:#ffffff0d}.empty-table{text-align:center;color:#ffffff80;padding:3rem!important}.role-badge{padding:.2rem .5rem;border-radius:8px;font-size:.75rem;font-weight:600}.role-admin{background:#a855f726;color:#c4b5fd;border:1px solid rgba(168,85,247,.25)}.role-customer{background:#60a5fa26;color:#93c5fd;border:1px solid rgba(96,165,250,.25)}.status-active{color:#93c5fd}.status-inactive{color:#fff6}.device-limit{color:#fffc;font-weight:600}.actions{display:flex;gap:.4rem}.button-small{padding:.4rem .75rem;font-size:.8rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;cursor:pointer;transition:all .3s}.button-small:hover{background:#fff3}.button-small.button-danger{background:#a855f726;border-color:#a855f740;color:#c4b5fd}.button-small.button-danger:hover{background:#a855f740;border-color:#a855f759}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:2rem}.modal-content{background:#0f0f1ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.modal-header h3{color:#fff;font-size:1.5rem}.modal-close{background:none;border:none;color:#ffffffb3;font-size:2rem;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.modal-close:hover{background:#ffffff1a;color:#fff}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.modal-content .form-group{margin-bottom:1.5rem}.modal-content .form-group label{display:block;color:#fffc;margin-bottom:.5rem;font-weight:500}.modal-content .form-group input,.modal-content .form-group select{width:100%;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s}.modal-content .form-group input:focus,.modal-content .form-group select:focus{outline:none;background:#ffffff1a;border-color:#ffffff4d}.modal-content .form-group input[type=checkbox]{width:auto;margin-right:.5rem}.modal-content .form-group label input[type=checkbox]{display:inline;width:auto}.machine-public-view{min-height:100vh;background:#0f0f1e;color:#e0e0e0;padding:1rem;max-width:100%;overflow-x:hidden}.machine-header{text-align:center;margin-bottom:2rem;padding:2rem 1rem;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;gap:1rem}.machine-header h1{font-size:2rem;margin-bottom:0;color:#fff}.machine-content{max-width:1200px;margin:0 auto}.machine-info-section,.images-section,.files-section,.location-map-section{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;margin-bottom:2rem}.machine-info-section h2,.images-section h2,.files-section h2,.location-map-section h2{font-size:1.5rem;margin-bottom:1.5rem;color:#fff}@media (max-width: 768px){.machine-header h1{font-size:1.5rem}.info-grid{grid-template-columns:1fr}.images-gallery{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.file-item{flex-wrap:wrap}.download-button{width:100%;text-align:center}.image-modal-close{top:1rem;right:1rem}}@media (max-width: 480px){.machine-public-view{padding:.5rem}.machine-header{padding:1.5rem 1rem}.machine-info-section,.images-section,.files-section{padding:1rem}.images-gallery{grid-template-columns:repeat(2,1fr)}}.valve-public-view{min-height:100vh;background:#0f0f1e;color:#e0e0e0;padding:1rem;max-width:100%;overflow-x:hidden}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#ffffff80;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.error-container h2{color:#c4b5fd;margin-bottom:1rem}.valve-header{text-align:center;margin-bottom:2rem;padding:2rem 1rem;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;gap:1rem}.header-actions{display:flex;gap:1rem;align-items:center}.valve-header h1{font-size:2rem;margin-bottom:0;color:#fff}.machine-badge{display:flex;justify-content:center}.qr-generate-button{padding:.75rem 1.5rem;background:#60a5fa26;border:1px solid rgba(96,165,250,.25);color:#93c5fd;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s;margin-top:.5rem}.qr-generate-button:hover:not(:disabled){background:#60a5fa40;border-color:#60a5fa59;transform:translateY(-2px)}.qr-generate-button:disabled{opacity:.6;cursor:not-allowed}.machine-type-badge{padding:.5rem 1rem;border-radius:12px;font-size:.9rem;font-weight:600;display:inline-block}.machine-type-transportowe{background:#60a5fa26;color:#93c5fd;border:1px solid rgba(96,165,250,.25)}.machine-type-cisnieniowe{background:#a855f726;color:#c4b5fd;border:1px solid rgba(168,85,247,.25)}.valve-content{max-width:1200px;margin:0 auto}.valve-info-section,.images-section,.files-section,.location-map-section{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;margin-bottom:2rem}.valve-info-section h2,.images-section h2,.files-section h2,.location-map-section h2{font-size:1.5rem;margin-bottom:1.5rem;color:#fff}.location-map-container{display:flex;justify-content:center;align-items:center}.location-map-container img{max-width:100%;max-height:600px;border-radius:12px;border:1px solid rgba(255,255,255,.1);object-fit:contain}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.85rem;color:#fff9;font-weight:500}.info-value{font-size:1rem;color:#fff;font-weight:600}.images-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.gallery-item{aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);transition:transform .3s,box-shadow .3s}.gallery-item:hover{transform:scale(1.05);box-shadow:0 10px 30px #0000004d}.gallery-item img{width:100%;height:100%;object-fit:cover}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#ffffff4d}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.image-modal-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:12px}.image-modal-close{position:absolute;top:-2.5rem;right:0;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;width:40px;height:40px;border-radius:50%;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}.image-modal-close:hover{background:#ffffff4d}.files-list{display:flex;flex-direction:column;gap:1rem}.file-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;transition:all .3s}.file-item:hover{background:#ffffff1a;border-color:#fff3}.file-icon{font-size:2rem;flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-size:1rem;font-weight:600;color:#fff;margin-bottom:.25rem;word-break:break-word}.file-meta{font-size:.85rem;color:#fff9}.download-button{padding:.75rem 1.5rem;background:#60a5fa26;border:1px solid rgba(96,165,250,.25);color:#93c5fd;border-radius:12px;text-decoration:none;font-weight:600;transition:all .3s;white-space:nowrap;flex-shrink:0}.download-button:hover{background:#60a5fa40;border-color:#60a5fa59;transform:translateY(-2px)}@media (max-width: 768px){.valve-header h1{font-size:1.5rem}.info-grid{grid-template-columns:1fr}.images-gallery{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.file-item{flex-wrap:wrap}.download-button{width:100%;text-align:center}.image-modal-close{top:1rem;right:1rem}}@media (max-width: 480px){.valve-public-view{padding:.5rem}.valve-header{padding:1.5rem 1rem}.valve-info-section,.images-section,.files-section{padding:1rem}.images-gallery{grid-template-columns:repeat(2,1fr)}}.app{min-height:100vh;position:relative;overflow-x:hidden}.background-blobs{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;overflow:hidden}.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:float 20s infinite ease-in-out}.blob-1{width:500px;height:500px;background:linear-gradient(135deg,#667eea,#764ba2);top:-200px;left:-200px;animation-delay:0s}.blob-2{width:600px;height:600px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:-300px;right:-300px;animation-delay:5s}.blob-3{width:400px;height:400px;background:linear-gradient(135deg,#4facfe,#00f2fe);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(100px,-100px) scale(1.1)}66%{transform:translate(-100px,100px) scale(.9)}}.header{position:relative;z-index:1;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);padding:2.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.header-content{flex:1}.header-logo-section{display:flex;align-items:center;gap:1.5rem}.header-logo{height:80px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.title{font-size:2.8rem;font-weight:800;background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;letter-spacing:-.02em}.subtitle{font-size:1.1rem;color:#ffffffb3;font-weight:400}.button{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:#fff;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;cursor:pointer;border-radius:10px;transition:all .3s;display:inline-flex;align-items:center;gap:.4rem}.button:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 10px 30px #0000004d}.button-primary{background:#60a5fa26;border:1px solid rgba(96,165,250,.25);color:#93c5fd}.button-primary:hover{background:#60a5fa40;border-color:#60a5fa59;box-shadow:0 10px 30px #60a5fa26}.button-danger{background:#a855f726;border:1px solid rgba(168,85,247,.25);color:#c4b5fd}.button-danger:hover{background:#a855f740;border-color:#a855f759;box-shadow:0 10px 30px #a855f726}.logout-button{background:#a855f726;border:1px solid rgba(168,85,247,.25);color:#c4b5fd;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;cursor:pointer;border-radius:12px;transition:all .3s}.logout-button:hover{background:#a855f740;border-color:#a855f759;transform:translateY(-2px)}*{margin:0;padding:0;box-sizing:border-box}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px;border:2px solid rgba(255,255,255,.05)}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) rgba(255,255,255,.05)}body{font-family:Inter,Segoe UI,system-ui,sans-serif;background:#0f0f1e;color:#e0e0e0;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}
