:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#000000de;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}img{max-width:100%;height:auto;display:block}html{scroll-behavior:smooth}*:focus-visible{outline:2px solid #0d7377;outline-offset:2px}.phone-auth-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background-color:#f5f5f5}.phone-auth-container{width:100%;max-width:400px;background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 12px #0000001a}.phone-auth-container h1{font-size:28px;font-weight:500;color:#333;margin:0 0 30px;text-align:center}.auth-step{display:flex;flex-direction:column;gap:20px}.auth-instructions{font-size:14px;color:#666;text-align:center;line-height:1.6;margin:0}.auth-instructions strong{color:#0d7377;display:block;margin-bottom:8px}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:14px;font-weight:500;color:#333}.phone-input,.code-input{width:100%;padding:14px 16px;font-size:16px;border:2px solid #ddd;border-radius:8px;box-sizing:border-box;transition:border-color .3s}.phone-input:focus,.code-input:focus{outline:none;border-color:#0d7377}.phone-input:disabled,.code-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.code-input{text-align:center;letter-spacing:.5em;font-size:24px;font-weight:500}.error-message{background-color:#fff5f5;color:#dc3545;padding:12px;border-radius:8px;font-size:14px;border:1px solid #ffdddd;text-align:center}.auth-button{background-color:#0d7377;color:#fff;border:none;padding:14px 24px;font-size:16px;font-weight:500;border-radius:8px;cursor:pointer;transition:background-color .3s}.auth-button:hover:not(:disabled){background-color:#0a5f62}.auth-button:disabled{background-color:#ccc;cursor:not-allowed}.back-button-auth{background:none;border:none;color:#0d7377;font-size:14px;cursor:pointer;padding:8px;transition:color .3s}.back-button-auth:hover:not(:disabled){color:#0a5f62;text-decoration:underline}.back-button-auth:disabled{color:#ccc;cursor:not-allowed}#recaptcha-container{margin-top:20px}@media (max-width: 480px){.phone-auth-container{padding:30px 20px}.phone-auth-container h1{font-size:24px}.code-input{font-size:20px}}.start-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background-color:#f5f5f5}.start-container{width:100%;max-width:600px;text-align:center}.start-title{font-size:32px;font-weight:400;color:#333;margin-bottom:80px;line-height:1.4}.start-instructions{font-size:18px;color:#666;margin-bottom:40px;line-height:1.6}.email-input{width:100%;max-width:500px;padding:16px 20px;font-size:16px;border:1px solid #ddd;border-radius:8px;margin-bottom:60px;box-sizing:border-box}.email-input:focus{outline:none;border-color:#0d7377}.button-container{display:flex;justify-content:flex-end;max-width:500px;margin:0 auto}.next-button{background-color:#0d7377;color:#fff;border:none;padding:14px 48px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:background-color .3s}.next-button:hover:not(:disabled){background-color:#0a5f62}.next-button:disabled{background-color:#ccc;cursor:not-allowed}@media (max-width: 768px){.start-title{font-size:24px;margin-bottom:60px}.start-instructions{font-size:16px;margin-bottom:30px}.email-input{font-size:16px;margin-bottom:40px}}.device-info-modal{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.device-info-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.device-info-modal .modal-header h2{margin:0;font-size:20px;color:#333}.device-info-modal .modal-close{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1}.device-info-modal .modal-close:hover{color:#333}.device-info-modal .modal-body{padding:20px}.device-info-header{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.device-info-item{display:flex;flex-direction:column;gap:5px}.device-info-item label{font-weight:600;color:#666;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.device-info-value{font-size:14px;color:#333;word-break:break-word}.device-info-value.status-badge{display:inline-block;font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px;width:fit-content}.device-info-value.status-badge.online{color:#28a745;background-color:#d4edda}.device-info-value.status-badge.offline{color:#dc3545;background-color:#f8d7da}.status-data-section h3{margin:0 0 15px;font-size:16px;color:#333}.status-data-grid{display:flex;flex-direction:column;gap:8px}.status-data-row{display:grid;grid-template-columns:40% 60%;gap:15px;padding:10px;background-color:#f8f9fa;border-radius:6px;align-items:start}.status-data-key{font-weight:600;color:#555;font-size:13px;word-break:break-word}.status-data-value{color:#333;font-size:13px;font-family:Courier New,monospace;word-break:break-all;white-space:pre-wrap}.no-data-message{text-align:center;padding:40px 20px;color:#999}.no-data-message p{margin:0;font-size:14px}.device-info-modal .modal-footer{padding:20px;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.update-info{margin:0;font-size:12px;color:#666;font-style:italic}.device-info-modal .modal-button{background-color:#007bff;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.device-info-modal .modal-button:hover{background-color:#0056b3}.device-info-modal .modal-button:active{background-color:#004494}@media (max-width: 600px){.device-info-modal{max-height:95vh}.device-info-modal .modal-header{padding:15px}.device-info-modal .modal-header h2{font-size:18px}.device-info-modal .modal-body{padding:15px}.device-info-header{grid-template-columns:1fr;gap:12px}.status-data-row{grid-template-columns:1fr;gap:8px}.device-info-modal .modal-footer{padding:15px;flex-direction:column;gap:10px}.update-info{order:2}.device-info-modal .modal-button{order:1;width:100%}}.mred-modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:0}.mred-modal-content{background:#fff;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.mred-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #ddd;background-color:#f8f9fa;flex-shrink:0}.mred-modal-header h2{margin:0;font-size:24px;font-weight:500;color:#333}.mred-modal-close{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;line-height:1;transition:color .2s}.mred-modal-close:hover{color:#333}.mred-modal-body{flex:1;overflow-y:auto;padding:24px;background-color:#fff}.mred-diagram{margin-bottom:40px;padding:20px;background-color:#f8f9fa;border-radius:12px;border:1px solid #ddd}.mred-diagram:last-child{margin-bottom:0}.mred-diagram-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #0d7377}.mred-diagram-header h3{margin:0;font-size:20px;font-weight:500;color:#0d7377}.mred-legend{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:12px;background-color:#fff;border-radius:8px;border:1px solid #e0e0e0}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#555}.legend-color{width:20px;height:20px;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.legend-color.online{background-color:#d4edda;border-color:#28a745}.legend-color.offline{background-color:#f8d7da;border-color:#dc3545}.zoom-controls{display:flex;align-items:center;gap:8px;margin-bottom:12px}.zoom-btn{width:36px;height:36px;border:1px solid #ddd;background-color:#fff;border-radius:6px;font-size:18px;font-weight:600;color:#333;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.zoom-btn:hover{background-color:#f0f0f0;border-color:#0d7377;color:#0d7377}.zoom-btn:active{background-color:#e0e0e0}.zoom-level{font-size:13px;color:#666;min-width:50px;text-align:center;font-weight:500}.zoom-hint{font-size:11px;color:#999;margin-left:auto;font-style:italic}.mermaid-viewport{background-color:#fff;border-radius:8px;border:1px solid #e0e0e0;overflow:hidden;position:relative;min-height:300px;max-height:500px;touch-action:none;-webkit-user-select:none;user-select:none}.mermaid-container{background-color:#fff;padding:20px;transform-origin:0 0;transition:none;min-width:100%;min-height:100%}.mermaid-container svg{display:block;margin:0 auto;max-width:none}.mermaid-container .node rect,.mermaid-container .node polygon{rx:8px;ry:8px}.mermaid-container .nodeLabel{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.mermaid-container .nodeLabel small{font-size:11px;color:#666}.mermaid-container .edgeLabel{background-color:#fff!important;padding:4px 8px!important;border-radius:4px;font-size:11px!important;font-weight:500}.mermaid-container .edgeLabel rect{fill:#fff!important;stroke:none!important}.mermaid-container .edgeLabel span,.mermaid-container .edgeLabel p{background-color:#fff!important;padding:2px 4px;display:inline-block}.mermaid-container .edgePath+.edgeLabel{overflow:visible!important}.mermaid-container .edgeLabel foreignObject{overflow:visible!important}.mermaid-container .edgeLabel foreignObject>div{display:flex!important;justify-content:center!important;align-items:center!important;background:#fff!important;padding:2px 6px!important;border-radius:4px!important;border:1px solid #ddd!important}.error-message{color:#dc3545;text-align:center;padding:20px;font-size:14px}.no-equipment-message{text-align:center;padding:60px 20px;color:#666;font-size:16px}.mred-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #ddd;background-color:#f8f9fa;flex-shrink:0}.mred-modal-button{background-color:#0d7377;color:#fff;border:none;padding:12px 32px;font-size:16px;font-weight:500;border-radius:8px;cursor:pointer;transition:background-color .2s}.mred-modal-button:hover{background-color:#0a5f62}.mred-modal-button.export-button{background-color:#2563eb}.mred-modal-button.export-button:hover{background-color:#1d4ed8}.view-mreds-button{background-color:#fff;color:#0d7377;border:2px solid #0d7377;padding:14px 36px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:all .3s}@media (max-width: 768px){.mred-modal-header{padding:12px 16px}.mred-modal-header h2{font-size:20px}.mred-modal-close{font-size:28px}.mred-modal-body{padding:16px}.mred-diagram{padding:16px;margin-bottom:24px}.mred-diagram-header h3{font-size:18px}.zoom-controls{gap:6px}.zoom-btn{width:32px;height:32px;font-size:16px}.zoom-level{font-size:12px;min-width:45px}.mred-legend{gap:12px;padding:10px}.legend-item{font-size:12px}.legend-color{width:16px;height:16px}.mermaid-viewport{min-height:250px;max-height:400px}.mermaid-container{padding:12px}.mred-modal-footer{padding:12px 16px;flex-wrap:wrap;gap:8px}.mred-modal-button{padding:10px 20px;font-size:14px;flex:1;min-width:120px}.view-mreds-button{padding:12px 24px;font-size:14px}}@media (min-width: 769px) and (max-width: 1024px){.mred-modal-content{width:95%;height:95%;border-radius:12px}}@media (min-width: 1025px){.mred-modal-content{width:90%;height:90%;max-width:1400px;border-radius:12px;box-shadow:0 8px 32px #0000004d}}.installed-equipment-screen{display:flex;flex-direction:column;height:calc(100vh - 60px);background-color:#fff;padding:20px 20px 0;box-sizing:border-box;overflow:hidden}.installed-header{text-align:center;margin-bottom:10px}.installed-header h1{font-size:28px;font-weight:400;color:#333;margin:0}.installed-content{flex:1;width:100%;overflow-y:auto;padding-bottom:20px}.empty-state{text-align:center;padding:60px 20px;color:#666;font-size:16px}.equipment-items{display:flex;flex-direction:column;gap:10px;width:100%}.mred-group{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50;border-radius:12px;padding:16px;margin-bottom:8px}.mred-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(76,175,80,.3)}.mred-group-info{display:flex;align-items:center;gap:12px}.mred-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#2e7d32;background-color:#4caf5033;padding:4px 8px;border-radius:4px}.mred-group-id{font-size:14px;font-weight:600;color:#1b5e20;font-family:monospace}.mred-group-count{font-size:12px;color:#388e3c}.mred-menu-container{position:relative}.mred-menu-button{background:#4caf5033;border:1px solid #4caf50;color:#2e7d32;font-size:20px;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s}.mred-menu-button:hover{background:#4caf504d}.mred-dropdown{right:0;top:100%;margin-top:4px;min-width:180px}.mred-group-cards{display:flex;flex-direction:column;gap:10px}.equipment-card{background-color:#fff;border:1px solid #666;border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:5px;position:relative}.equipment-card.paired{background:linear-gradient(135deg,#f1f8e9,#dcedc8);border-color:#8bc34a;box-shadow:0 2px 8px #8bc34a33}.mred-equipment-id-badge{position:absolute;top:8px;left:8px;font-size:10px;font-weight:600;font-family:monospace;color:#558b2f;background-color:#8bc34a4d;padding:2px 6px;border-radius:4px;z-index:1}.mred-equipment-id-badge.component{top:0;left:0}.equipment-card-header{display:flex;align-items:center;width:100%;padding:16px;gap:12px;background-color:#f8f9fa;position:relative;border-radius:10px 10px 0 0}.equipment-thumbnail{width:60px;height:60px;flex-shrink:0;border-radius:8px;overflow:hidden;background-color:#fff;border:1px solid #ddd;display:flex;align-items:center;justify-content:center}.equipment-thumbnail img{max-width:100%;max-height:100%;object-fit:contain}.equipment-title-section{flex:1}.equipment-title-section h3{font-size:18px;font-weight:500;color:#333;margin:0 0 4px}.equipment-id{font-size:12px;color:#666;margin:0}.equipment-name{color:#0d7377;font-weight:500}.equipment-status-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:4px}.last-updated{font-size:11px;color:#555;font-style:italic}.status-badge{display:inline-block;font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px;margin-top:4px}.status-badge.online{color:#28a745;background-color:#d4edda}.status-badge.offline{color:#dc3545;background-color:#f8d7da}.status-badge.paired{color:#0d7377;background-color:#d1f2f4}.equipment-menu-container{position:relative}.menu-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s}.menu-button:hover{color:#333}.dropdown-menu{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border:2px solid #333;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;z-index:2000;overflow:hidden}.dropdown-menu.dropdown-upward{top:auto;bottom:100%;margin-top:0;margin-bottom:4px;box-shadow:0 -4px 12px #00000026}.mred-dropdown.dropdown-upward{top:auto;bottom:100%;margin-top:0;margin-bottom:4px}.menu-item{width:100%;display:flex;align-items:center;gap:10px;padding:12px 16px;background:none;border:none;text-align:left;font-size:14px;color:#333;cursor:pointer;transition:background-color .2s}.menu-item:hover{background-color:#f5f5f5}.menu-item.delete{color:#dc3545;border-top:1px solid #eee}.menu-item.delete:hover{background-color:#fff5f5}.menu-icon{font-size:16px}.menu-backdrop{position:fixed;inset:0;z-index:999}.missing-requirements{padding:12px 16px;display:flex;flex-wrap:wrap;gap:8px}.requirement-button{padding:8px 16px;font-size:13px;font-weight:500;border:none;border-radius:20px;cursor:pointer;transition:all .3s}.requirement-button.missing{background-color:#ff6b6b;color:#fff}.requirement-button.missing:hover{background-color:#ee5a52;transform:translateY(-1px)}.components-section{padding:8px 0 16px;display:flex;flex-direction:column;gap:10px;width:100%;box-sizing:border-box}.nested-components{padding-left:20px;margin-top:10px;display:flex;flex-direction:column;gap:10px}.component-card{background-color:#fff;border:1px solid #ddd;border-radius:8px;padding:12px 6px 12px 12px;margin-left:20px;position:relative;width:calc(100% - 20px);box-sizing:border-box}.component-card.paired{background:linear-gradient(135deg,#f1f8e9,#dcedc8);border-color:#8bc34a}.component-card:before{content:"↳";position:absolute;left:-20px;top:12px;color:#999;font-size:16px}.component-header{display:flex;align-items:center;justify-content:space-between}.component-info h4{font-size:15px;font-weight:500;color:#555;margin:0 0 4px}.component-id{font-size:11px;color:#999;margin:0}.installed-footer{display:flex;justify-content:center;gap:15px;width:100%;flex-wrap:wrap;flex-shrink:0;padding:20px 0;background-color:#fff;border-top:1px solid #eee}.add-equipment-button,.pair-button,.exit-button,.view-mreds-button,.unpair-button{background-color:#fff;color:#333;border:2px solid #333;padding:14px 36px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:all .3s}.view-mreds-button{color:#0d7377;border-color:#0d7377}.view-mreds-button:hover{background-color:#0d7377;color:#fff}.add-equipment-button:hover{background-color:#f5f5f5}.pair-button{background-color:#0d7377;color:#fff;border-color:#0d7377}.pair-button:hover{background-color:#0a5f62}.exit-button{background-color:#dc3545;color:#fff;border-color:#dc3545}.completion-message{text-align:center;margin-top:20px;padding:20px}.completion-message p{font-size:16px;color:#666;margin:0}.modal-content{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:100%;box-shadow:0 8px 24px #0003}.modal-content h2{margin:0 0 16px;font-size:20px;font-weight:500;color:#333}.modal-content p{margin:0 0 12px;font-size:14px;color:#666;line-height:1.5}.warning-text{color:#dc3545;font-weight:500}.delete-confirmation-input{margin:20px 0}.delete-confirmation-input label{display:block;font-size:14px;color:#333;margin-bottom:8px;font-weight:500}.delete-confirmation-input input{width:100%;padding:12px;font-size:14px;border:2px solid #ddd;border-radius:8px;box-sizing:border-box}.delete-confirmation-input input:focus{outline:none;border-color:#0d7377}.modal-actions{display:flex;gap:12px;margin-top:20px}.cancel-button,.delete-button{flex:1;padding:12px 24px;font-size:14px;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.cancel-button{background-color:#f5f5f5;color:#333}.cancel-button:hover{background-color:#e8e8e8}.delete-button{background-color:#dc3545;color:#fff}.delete-button:hover:not(:disabled){background-color:#c82333}.delete-button:disabled{background-color:#ccc;cursor:not-allowed}.provisioning-status{margin-bottom:20px;padding:16px 20px;border-radius:8px;border:1px solid}.provisioning-status.pending,.provisioning-status.running{background-color:#e3f2fd;border-color:#2196f3;color:#1565c0}.provisioning-status.success{background-color:#e8f5e9;border-color:#4caf50;color:#2e7d32}.provisioning-success-details{display:flex;flex-direction:column;gap:4px}.provisioning-result-summary{font-size:13px;opacity:.85}.provisioning-status.failed{background-color:#ffebee;border-color:#f44336;color:#c62828}.provisioning-status-content{display:flex;align-items:center;gap:12px}.provisioning-spinner{width:20px;height:20px;border:3px solid #90caf9;border-top-color:#1565c0;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.provisioning-icon{font-size:20px;font-weight:700}.provisioning-dismiss{margin-left:auto;padding:6px 16px;font-size:13px;font-weight:500;background-color:transparent;border:1px solid currentColor;border-radius:4px;cursor:pointer;color:inherit;transition:background-color .2s}.provisioning-dismiss:hover{background-color:#0000000d}.pair-button:disabled{background-color:#a5d6d7;border-color:#a5d6d7;cursor:not-allowed}.unpair-button{background-color:#ff8c00;color:#fff;border-color:#ff8c00}.unpair-button:hover:not(:disabled){background-color:#e67e00;border-color:#e67e00}.unpair-button:disabled{background-color:#ffcc80;border-color:#ffcc80;cursor:not-allowed}.installer-info{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid #e0e0e0;font-size:12px;color:#666}.installer-label{font-weight:500}.installer-name{color:#2196f3;font-weight:600}.installed-date{margin-left:auto;font-style:italic}@media (max-width: 768px){.installed-equipment-screen{padding:15px}.installed-header h1{font-size:24px}.equipment-card-header{padding:12px}.equipment-thumbnail{width:50px;height:50px}.equipment-title-section h3{font-size:16px}.menu-item{padding:10px 14px;font-size:13px}.requirement-button{padding:6px 12px;font-size:12px}.component-card{margin-left:15px}.add-equipment-button,.pair-button,.exit-button,.view-mreds-button,.unpair-button{padding:12px 30px;font-size:14px}.modal-content{padding:20px}}.category-select-screen{display:flex;flex-direction:column;background-color:#fff;padding:20px}.category-header{position:relative;margin-bottom:40px}.hamburger-menu{position:absolute;left:0;top:0;background:none;border:none;cursor:pointer;padding:10px;display:flex;flex-direction:column;gap:5px}.hamburger-line{width:30px;height:3px;background-color:#333;border-radius:2px}.category-header h1{font-size:28px;font-weight:400;color:#333;text-align:center;margin:0;padding:0 50px}.category-list{flex:1;display:flex;flex-direction:column;gap:20px;max-width:700px;margin:0 auto;width:100%}.category-item{background-color:#fff;border:2px solid #333;border-radius:8px;padding:30px;font-size:24px;font-weight:400;color:#333;cursor:pointer;transition:all .3s;text-align:center}.category-item:hover{background-color:#f5f5f5;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.category-footer{display:flex;justify-content:space-between;margin-top:40px;max-width:700px;margin-left:auto;margin-right:auto;width:100%}.exit-button{background-color:#dc3545;color:#fff;border:none;padding:14px 48px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:background-color .3s}.exit-button:hover{background-color:#c82333}@media (max-width: 768px){.category-select-screen{padding:15px}.category-header h1{font-size:20px;padding:0 40px}.category-item{padding:20px;font-size:20px}.back-button,.exit-button{padding:12px 36px;font-size:14px}}.equipment-list-screen{display:flex;flex-direction:column;background-color:#fff;padding:20px}.equipment-header{text-align:center;margin-bottom:40px}.equipment-header h1{font-size:28px;font-weight:400;color:#333;margin:0 0 10px}.equipment-subtitle{font-size:16px;color:#666;margin:0}.equipment-list{flex:1;display:flex;flex-direction:column;gap:20px;max-width:800px;margin:0 auto;width:100%}.equipment-card{background-color:#fff;border:1px solid #666;border-radius:8px;padding:10px;display:flex;gap:5px;align-items:center}.equipment-image-container{flex-shrink:0;width:120px;height:120px;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:8px;background-color:#f5f5f5}.equipment-image{max-width:100%;max-height:100%;object-fit:contain}.equipment-info{flex:1}.equipment-info h3{font-size:20px;font-weight:500;color:#333;margin:0 0 8px}.equipment-info p{font-size:14px;color:#666;margin:0;line-height:1.5}.equipment-footer{display:flex;justify-content:space-between;margin-top:40px;max-width:800px;margin-left:auto;margin-right:auto;width:100%}.back-button{background-color:#0d7377;color:#fff;border:none;padding:14px 48px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:background-color .3s}.back-button:hover{background-color:#0a5f62}@media (max-width: 768px){.equipment-list-screen{padding:15px}.equipment-header h1{font-size:22px}.equipment-subtitle{font-size:14px}.equipment-card{flex-direction:column;text-align:center}.equipment-image-container{width:100px;height:100px}.equipment-info h3{font-size:18px}.equipment-info p{font-size:13px}.back-button{padding:12px 36px;font-size:14px}}.install-instructions-screen{display:flex;flex-direction:column;background-color:#fff;padding:20px}.install-header{text-align:center;margin-bottom:30px}.install-header h1{font-size:28px;font-weight:400;color:#333;margin:0}.install-content{flex:1;max-width:900px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:30px}.install-image-container{display:flex;justify-content:center;padding:20px;background-color:#f5f5f5;border-radius:8px}.install-image{max-width:100%;max-height:300px;object-fit:contain}.instructions-container{flex:1;display:flex;flex-direction:column;gap:20px}.instructions-text{font-size:16px;color:#666;text-align:center;line-height:1.6}.instructions-buttons{display:flex;flex-direction:column;align-items:center;gap:12px}.instructions-button{background-color:#0d7377;color:#fff;border:none;padding:14px 32px;font-size:14px;font-weight:500;border-radius:30px;cursor:pointer;transition:background-color .3s;min-width:280px}.instructions-button:hover{background-color:#0a5f62}.instructions-button.download-button{background-color:#2a6b6e}.instructions-button.download-button:hover{background-color:#1e5558}.iframe-container{flex:1;min-height:400px;border:1px solid #ddd;border-radius:8px;overflow:hidden}.instructions-iframe{width:100%;height:100%;border:none;min-height:400px}.install-footer{display:flex;justify-content:space-between;margin-top:40px;max-width:900px;margin-left:auto;margin-right:auto;width:100%}.back-button,.next-button{background-color:#0d7377;color:#fff;border:none;padding:14px 48px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:background-color .3s}.back-button:hover,.next-button:hover{background-color:#0a5f62}@media (max-width: 768px){.install-instructions-screen{padding:15px}.install-header h1{font-size:22px}.install-image{max-height:200px}.instructions-text{font-size:14px}.iframe-container,.instructions-iframe{min-height:300px}.back-button,.next-button{padding:12px 36px;font-size:14px}.instructions-button{min-width:240px;padding:12px 24px;font-size:13px}}.data-entry-screen{display:flex;flex-direction:column;background-color:#fff;padding:20px}.data-entry-header{text-align:center;margin-bottom:30px}.data-entry-header h1{font-size:24px;font-weight:400;color:#333;margin:0 0 10px}.field-progress{font-size:14px;color:#666;margin:0}.data-entry-content{flex:1;max-width:700px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:30px}.auto-discover-section{text-align:center;margin-bottom:10px;padding:20px;background-color:#e6f7f8;border-radius:12px;border:2px dashed #0d7377;width:100%}.auto-discover-button{background-color:#0d7377;color:#fff;border:none;padding:16px 32px;font-size:18px;font-weight:600;border-radius:30px;cursor:pointer;transition:all .3s;box-shadow:0 4px 8px #0d737733}.auto-discover-button:hover{background-color:#0a5f62;transform:translateY(-2px);box-shadow:0 6px 12px #0d73774d}.auto-discover-button:active{transform:translateY(0)}.auto-discover-hint{margin:12px 0 0;font-size:14px;color:#666;font-style:italic}.data-image-container{display:flex;justify-content:center;padding:20px;background-color:#f5f5f5;border-radius:8px}.data-image{max-width:100%;max-height:300px;object-fit:contain}.field-info{text-align:center}.field-info h2{font-size:20px;font-weight:500;color:#333;margin:0 0 10px}.field-info p{font-size:14px;color:#666;margin:0;line-height:1.6}.text-entry-container{display:flex;flex-direction:column;gap:10px}.data-input{width:100%;padding:16px 20px;font-size:16px;border:2px solid #ddd;border-radius:8px;box-sizing:border-box}.data-input:focus{outline:none;border-color:#0d7377}.char-count{font-size:12px;color:#999;text-align:right;margin:0}.scan-button{background-color:#fff;color:#0d7377;border:2px solid #0d7377;padding:14px 32px;font-size:16px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .3s}.scan-button:hover{background-color:#0d7377;color:#fff}.data-entry-footer{display:flex;justify-content:space-between;margin-top:40px;max-width:700px;margin-left:auto;margin-right:auto;width:100%}.scanning-mode{padding:0;background-color:#000}.scanner-container{position:relative;width:100%;height:100vh;display:flex;flex-direction:column}.scanner-video{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.scanner-frame{width:250px;height:250px;border:3px solid #0d7377;border-radius:8px;box-shadow:0 0 0 9999px #00000080}.scanner-overlay p{color:#fff;font-size:16px;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.8)}.cancel-scan-button{position:absolute;bottom:40px;left:50%;transform:translate(-50%);background-color:#ffffffe6;color:#333;border:none;padding:14px 48px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:background-color .3s}.cancel-scan-button:hover{background-color:#fff}@media (max-width: 768px){.data-entry-screen{padding:15px}.data-entry-header h1{font-size:20px}.field-info h2{font-size:18px}.data-image{max-height:200px}.back-button,.done-button{padding:12px 36px;font-size:14px}}.component-entry-screen{display:flex;flex-direction:column;min-height:100vh;background-color:#fff;padding:20px}.component-header{text-align:center}.component-header h1{font-size:24px;font-weight:400;color:#333;margin:0 0 10px}.component-subtitle{font-size:16px;color:#666;margin:0}.component-content{flex:1;max-width:900px;margin:0 auto;width:100%}.field-section{margin-bottom:40px}.field-title{font-size:20px;font-weight:500;color:#333;margin:0 0 10px;text-align:center}.field-description{font-size:14px;color:#666;margin:0 0 10px;text-align:center;line-height:1.6}.field-hint{font-size:13px;color:#0d7377;margin:0 0 20px;text-align:center;font-style:italic;font-weight:500}.options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.option-card{position:relative;background-color:#fff;border:2px solid #ddd;border-radius:8px;padding:20px;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;gap:15px;align-items:center;text-align:center}.option-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.option-card.selected{border-color:#0d7377;background-color:#e8f5f5}.option-image-container{width:100%;height:150px;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:8px;background-color:#f5f5f5}.option-image{max-width:100%;max-height:100%;object-fit:contain}.option-info h3{font-size:18px;font-weight:500;color:#333;margin:0 0 8px}.option-info p{font-size:14px;color:#666;margin:0;line-height:1.5}.selected-indicator{position:absolute;top:10px;right:10px;width:30px;height:30px;background-color:#0d7377;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.option-checkbox{position:absolute;top:10px;right:10px}.option-checkbox .checkbox{width:28px;height:28px;border:2px solid #ccc;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;background-color:#fff;transition:all .2s}.option-checkbox .checkbox.checked{background-color:#0d7377;border-color:#0d7377;color:#fff}.option-card:hover .option-checkbox .checkbox:not(.checked){border-color:#0d7377}.equipment-selection-list{display:flex;flex-direction:column;gap:12px}.equipment-selection-item{background-color:#fff;border:2px solid #ddd;border-radius:8px;padding:16px;cursor:pointer;transition:all .3s;position:relative;display:flex;align-items:center;justify-content:space-between}.equipment-selection-item:hover{border-color:#0d7377;background-color:#f8f9fa}.equipment-selection-item.selected{border-color:#0d7377;background-color:#e6f7f8;border-width:3px}.equipment-selection-info{flex:1}.equipment-selection-info h3{margin:0 0 4px;font-size:16px;color:#333}.equipment-selection-id{margin:0;font-size:12px;color:#666}.component-footer{display:flex;justify-content:space-between;margin-top:40px;max-width:900px;margin-left:auto;margin-right:auto;width:100%}.back-button,.done-button{background-color:#0d7377;color:#fff;border:none;padding:14px 48px;font-size:16px;font-weight:500;border-radius:30px;cursor:pointer;transition:background-color .3s}.back-button:hover,.done-button:hover:not(:disabled){background-color:#0a5f62}.done-button:disabled{background-color:#ccc;cursor:not-allowed}@media (max-width: 768px){.component-entry-screen{padding:15px}.component-header h1{font-size:20px}.component-subtitle{font-size:14px}.options-grid{grid-template-columns:1fr}.option-image-container{height:120px}.option-info h3{font-size:16px}.back-button,.done-button{padding:12px 36px;font-size:14px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:20px;color:#333}.modal-close{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:20px}.contact-section{margin-bottom:20px}.contact-section:last-child{margin-bottom:0}.contact-section label{display:block;font-weight:600;color:#666;font-size:14px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.contact-value{font-size:16px;color:#333;padding:10px 0}.contact-link{display:block;font-size:16px;color:#007bff;text-decoration:none;padding:10px 0;transition:color .2s;word-break:break-word}.contact-link:hover{color:#0056b3;text-decoration:underline}.address-link{white-space:pre-line;line-height:1.6}.modal-footer{padding:20px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end}.modal-button{background-color:#007bff;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.modal-button:hover{background-color:#0056b3}.modal-button:active{background-color:#004494}@media (max-width: 600px){.modal-overlay{padding:10px}.modal-content{max-height:95vh}.modal-header{padding:15px}.modal-header h2{font-size:18px}.modal-body{padding:15px}.contact-section{margin-bottom:15px}.modal-footer{padding:15px}}*{box-sizing:border-box}.app{min-height:100vh;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}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5}.loading-container{text-align:center}.spinner{border:4px solid #f3f3f3;border-top:4px solid #0d7377;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{font-size:16px;color:#666}.top-bar{position:sticky;top:0;z-index:100;background-color:#0d7377;color:#fff;padding:12px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.participant-info{flex:1}.participant-name{font-size:16px;font-weight:600}.contact-info-button{background-color:#fff;color:#0d7377;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s;min-height:36px}.contact-info-button:hover{background-color:#f0f0f0}.contact-info-button:active{background-color:#e0e0e0}@media (max-width: 480px){.top-bar{padding:10px 15px}.participant-name{font-size:14px}.contact-info-button{font-size:12px;padding:6px 12px}}@media (max-width: 480px){body{font-size:14px}h1{font-size:20px!important}h2{font-size:18px!important}h3{font-size:16px!important}}@media (min-width: 481px) and (max-width: 1024px){body{font-size:15px}}@media (min-width: 1025px){.app{max-width:1200px;margin:0 auto}}button{min-height:44px;min-width:44px}input,textarea,select{min-height:44px;font-size:16px}
