body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.loading-container{display:flex;justify-content:center;align-items:center;height:100vh}.loading-spinner{border:4px solid #f3f3f3;border-top:4px solid #ed6823;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-header{background-color:#fff;padding:10px 15px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:100}.app-header img{max-width:200px;height:auto}.app-content{flex:1;overflow-y:auto;padding:15px 15px 80px}@media (min-width: 768px){.app-container{max-width:1200px;margin:0 auto}.app-header{padding:15px 30px}.app-header img{max-width:248px}.app-content{padding:30px 30px 80px}.nav-button{font-size:16px;padding:15px}}.form-control{width:100%;padding:12px;font-size:16px;border:1px solid #dedede;border-radius:4px;font-family:monospace;margin-bottom:15px}.btn{padding:10px 20px;font-size:14px;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;font-family:monospace}.btn-primary{background-color:#ed6823;color:#fff}.btn-primary:hover{background-color:#d45a1f}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-outline-secondary{background-color:transparent;color:#6c757d;border:1px solid #6c757d}.btn-outline-secondary:hover{background-color:#6c757d;color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed}.machines-table{width:100%;border-collapse:collapse;background-color:#fff;margin-top:15px;font-size:14px}.status-progress{color:#fff;text-shadow:1px 1px #000000;padding:2px 8px;display:inline-block;background-color:#33a532;border-radius:4px;font-size:.9em}input[type=checkbox]{width:20px;height:20px;cursor:pointer}select.inputBox{width:100%;padding:8px;font-size:.9em;border:1px solid #dedede;border-radius:4px;font-family:monospace}.spinner-border{display:inline-block;width:1rem;height:1rem;vertical-align:text-bottom;border:.15em solid currentColor;border-right-color:transparent;border-radius:50%;animation:spinner-border .75s linear infinite}.spinner-border-sm{width:.875rem;height:.875rem;border-width:.1em}@keyframes spinner-border{to{transform:rotate(360deg)}}.alert{padding:12px 20px;margin-bottom:20px;border-radius:4px}.empty-state{text-align:center;padding:40px 20px;color:#666}.app-version{font-size:11px;color:#8a8a8a;line-height:1.2;-webkit-user-select:none;user-select:none;white-space:nowrap}.app-header .app-version{position:absolute;right:12px;top:50%;transform:translateY(-50%)}.login-container .app-version--login{position:fixed;bottom:12px;left:0;right:0;text-align:center}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5;padding:20px}.login-box{background-color:#fff;padding:40px;border-radius:8px;box-shadow:0 2px 10px #0000001a;text-align:center;max-width:400px;width:100%}.login-logo{max-width:248px;height:auto;margin-bottom:20px}.login-box h2{color:#ed6823;margin-bottom:10px}.login-subtitle{color:#666;margin-bottom:30px}.login-button{width:100%;margin-bottom:10px;padding:12px;font-size:16px}@media (max-width: 768px){.login-box{padding:30px 20px}.login-logo{max-width:200px}}.app-container{display:flex;flex-direction:column;height:100vh;max-width:100%;overflow-x:hidden}.app-header{position:relative;background-color:#fff;padding:10px 15px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:100}.laundromat-selector-container{background-color:#fff;border-bottom:1px solid #dee2e6;flex-shrink:0;z-index:99}.status-circle{width:12px;height:12px;border-radius:50%;display:inline-block;flex-shrink:0}.status-circle.online{background-color:#28a745}.status-circle.offline{background-color:#6c757d}.header-logo{max-width:200px;height:auto}.app-content{flex:1;overflow-y:auto;padding:15px 15px 80px;background-color:#f5f5f5}@media (max-width: 768px){.app-content .calendar-view{margin-left:0;margin-right:0}}.app-nav{position:fixed;bottom:0;left:0;right:0;background-color:#fff;border-top:1px solid #dee2e6;display:flex;justify-content:space-around;padding:10px 0;box-shadow:0 -2px 4px #0000001a;z-index:100}.nav-button{flex:1;padding:10px;background:none;border:none;color:#666;font-size:14px;cursor:pointer;transition:color .2s;display:flex;flex-direction:column;align-items:center;gap:4px}.nav-button.active{color:#ed6823;font-weight:700}.nav-button:hover{color:#ed6823}.nav-button-icon{font-size:20px}@media (min-width: 768px){.app-container{max-width:1200px;margin:0 auto}.app-header{padding:15px 30px}.header-logo{max-width:248px}.app-content{padding:30px 30px 80px}.nav-button{font-size:16px;padding:15px}}.machines-view{max-width:100%}.machines-view h2{color:#ed6823;margin-bottom:20px}.loading-message{text-align:center;padding:20px;color:#666}.machines-table{width:100%;border-collapse:collapse;background-color:#fff;margin-top:15px;font-size:14px;box-shadow:0 1px 3px #0000001a}.machines-table th{background-color:#ed6823;color:#fcfcfc;font-weight:700;text-shadow:2px 2px #555555;padding:12px 8px;text-align:left}.machines-table td{padding:10px 8px;border-bottom:1px solid #dee2e6}.machines-table tr:hover{background-color:#f8f9fa}.status-indicator{display:inline-block;width:20px;height:20px;border-radius:50%}.status-indicator.red{background-color:#cc0605}.status-indicator.blue{background-color:#3333ce}.status-indicator.orange{background-color:#ed8128}.status-indicator.turquoise{background-color:#40e0d0}.status-indicator.green{background-color:#33a532}.status-indicator.grey{background-color:#ccc}.status-circle{display:inline-block;width:12px;height:12px;border-radius:50%;flex-shrink:0}.status-circle.online{background-color:#33a532}.status-circle.offline{background-color:#ccc}.status-progress{color:#fff;text-shadow:1px 1px #000000;padding:2px 8px;display:inline-block;background-color:#33a532;border-radius:4px;font-size:.9em;min-width:60px;text-align:center}.btn-outline-secondary-blue{background-color:transparent;color:#007bff;border:1px solid #007bff}.btn-outline-secondary-blue:hover{background-color:#007bff;color:#fff}@media (max-width: 768px){.machines-table{font-size:12px}.machines-table th,.machines-table td{padding:8px 4px}.status-indicator{width:16px;height:16px}}.services-view{max-width:100%}.services-view h2{color:#ed6823;margin-bottom:20px}.services-buttons{display:flex;flex-direction:column;gap:15px;margin-top:20px}.services-buttons .btn{width:100%;padding:12px;font-size:16px}.alert{padding:12px 20px;margin-top:15px;border-radius:4px}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.card-readers-list{margin-top:32px;max-width:640px}.card-readers-list h3{color:#ed6823;margin-bottom:8px;font-size:1.1rem}.card-readers-hint{font-size:.9rem;color:#666;margin-bottom:12px}.card-reader-rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.card-reader-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:#f8f8f8;border:1px solid #e0e0e0;border-radius:4px}.card-reader-row .btn{flex-shrink:0}@media (min-width: 768px){.services-buttons{max-width:500px}}.logs-view{max-width:100%}.logs-view h2{color:#ed6823;margin-bottom:20px}.calendar-view{max-width:100%;padding:20px 20px 100px;margin-bottom:0;background-color:transparent;position:relative}.calendar-view h2{color:#ed6823;margin-bottom:20px}.empty-state{text-align:center;padding:40px 20px;color:#666;margin-top:20px}.empty-state h3{margin-bottom:10px;color:#333}.empty-state p{font-size:16px}.calendar-container{background:#f5f5f5;border-radius:8px;padding:20px;margin-bottom:20px;position:relative;z-index:1}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;background:#fff;padding:10px;border-radius:4px}.calendar-header h3{margin:0;font-size:18px;color:#333}.calendar-nav-button{background:#fff;color:#ed6823;border:2px solid #ed6823;border-radius:4px;width:40px;height:40px;font-size:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.calendar-nav-button:hover{background:#ed6823;color:#fff}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.weekday-header{text-align:center;font-weight:700;font-size:12px;padding:10px 5px;color:#333}.calendar-day{aspect-ratio:1;border-radius:4px;padding:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:70px;transition:transform .2s,box-shadow .2s}.calendar-day:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.calendar-day.empty{background:transparent;cursor:default}.calendar-day.default{background:#d5e8d4;border:2px solid #82b366}.calendar-day.modified{background:#fff2cc;border:2px solid #d6b656}.calendar-day.closed{background:#f8cecc;border:2px solid #b85450;font-weight:700}.calendar-day.open24h{background:#d5e8d4;border:2px solid #82b366;font-weight:700}.day-number{font-size:14px;font-weight:700;margin-bottom:4px}.day-time{font-size:18px;text-align:center;white-space:pre-line;line-height:1.2;color:#333}.calendar-day.closed .day-time{font-size:20px;font-weight:700}.sync-button{width:100%;padding:12px;background:#dae8fc;border:2px solid #6c8ebf;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s;margin-bottom:20px}.sync-button:hover{background:#c5d9f0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-bottom-sheet{background:#fff;width:100%;max-width:600px;border-radius:16px 16px 0 0;padding:20px;max-height:80vh;overflow-y:auto;animation:slideUp .3s;box-shadow:0 -4px 20px #0003}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-bottom-sheet h3{margin:0 0 20px;color:#333;font-size:18px}.modal-content{display:flex;flex-direction:column;gap:20px}.time-inputs{display:grid;grid-template-columns:1fr 1fr;gap:15px}.time-input-group{display:flex;flex-direction:column;gap:8px}.time-input-group label{font-size:12px;font-weight:700;color:#333}.time-picker-group{display:flex;flex-direction:column;gap:8px}.time-picker-group label{font-size:12px;font-weight:700;color:#333}.time-picker-inputs{display:flex;align-items:center;gap:4px}.time-input{padding:12px;border:2px solid #82b366;border-radius:4px;background:#d5e8d4;font-size:18px;font-weight:700;text-align:center;min-width:70px;max-width:90px;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.time-input::-webkit-outer-spin-button,.time-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.time-input:focus{outline:none;border-color:#5a8a4a;box-shadow:0 0 0 3px #82b36633}.time-input:disabled{background:#e0e0e0;border-color:#ccc;cursor:not-allowed;opacity:.6}.time-separator{font-size:20px;font-weight:700;color:#333;padding:0 4px}.status-checkboxes{display:flex;flex-direction:column;gap:12px;margin-top:10px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.reason-input-group{display:flex;flex-direction:column;gap:8px}.reason-input-group label{font-size:12px;font-weight:700;color:#333}.reason-input-group select{padding:10px;border:2px solid #d6b656;border-radius:4px;background:#fff2cc;font-size:14px;cursor:pointer}.set-default-section{margin-top:10px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.btn-save{padding:10px 20px;background:#d5e8d4;border:2px solid #82b366;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;color:#333}.btn-save:hover{background:#c5d8c4}.btn-cancel{padding:10px 20px;background:#f8cecc;border:2px solid #b85450;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;color:#333}.btn-cancel:hover{background:#f0c0be}@media (max-width: 768px){.calendar-view{padding:0 0 100px;margin:0 8px}.calendar-view h2{font-size:16px;margin-bottom:8px;padding:0}.calendar-container{padding:4px;margin:0;border-radius:4px}.calendar-header{padding:4px;margin-bottom:6px}.calendar-header h3{font-size:12px}.calendar-nav-button{width:28px;height:28px;font-size:18px;padding:0}.calendar-grid{gap:1px}.weekday-header{font-size:9px;padding:2px 1px}.calendar-day{min-height:45px;padding:2px;border-width:1px}.day-number{font-size:12px;margin-bottom:1px}.day-time{font-size:10px;line-height:1.1}.calendar-day.closed .day-time{font-size:11px}.time-inputs{grid-template-columns:1fr}.time-input{font-size:20px;min-width:80px;max-width:100px;padding:14px}.time-separator{font-size:18px}.modal-bottom-sheet{max-height:90vh}}
