.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#00adee;padding:20px}.login-box{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px;text-align:center}.login-logo{width:280px;height:auto;margin-bottom:30px;border-radius:12px}.form-group{margin-bottom:20px;text-align:left}.form-group input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#00adee}.form-group input:disabled{background-color:#f5f5f5}.login-button{width:100%;padding:14px;background:#00adee;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #00adee66}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-error{background-color:#fee;color:#c00;padding:12px;border-radius:8px;margin-bottom:20px;font-size:.9rem}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{background:#fff;padding:0 30px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 10px #0000001a;height:60px;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:15px}.header-logo{height:36px;width:auto;object-fit:contain;border-radius:4px}.header-nav{display:flex;gap:5px}.nav-link{padding:8px 20px;text-decoration:none;color:#666;border-radius:6px;font-weight:500;transition:all .2s}.nav-link:hover{background:#f0f0f0;color:#333}.nav-link.active{background:#00adee;color:#fff}.admin-dropdown{position:relative;margin-left:15px;border-left:1px solid #e0e0e0;padding-left:5px}.admin-link{background:none;border:none;font-family:inherit;font-size:inherit;cursor:pointer}.admin-link.active{background:#ffd100;color:#333}.admin-dropdown-menu{position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;min-width:180px;z-index:200;padding:6px 0;margin-top:4px}.admin-dropdown-item{display:block;padding:10px 20px;text-decoration:none;color:#555;font-weight:500;transition:background .2s}.admin-dropdown-item:hover{background:#f5f5f5;color:#333}.admin-dropdown-item.active{background:#fff8d6;color:#333;font-weight:600}.header-right{display:flex;align-items:center;gap:20px}.user-name{color:#666}.logout-button{padding:8px 16px;background:#f0f0f0;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.logout-button:hover{background:#e0e0e0}.hamburger-btn{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:4px 8px;color:#333}.layout-main{flex:1;padding:30px;background:#f5f5f5}@media(max-width:768px){.layout-header{padding:0 15px}.header-logo{height:28px}.hamburger-btn{display:block}.header-nav{display:none;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:#fff;box-shadow:0 4px 12px #0000001a;padding:10px 0;z-index:99}.header-nav.nav-open{display:flex}.nav-link{width:100%;padding:12px 20px;border-radius:0;box-sizing:border-box}.admin-dropdown{margin-left:0;border-left:none;padding-left:0;width:100%}.admin-link{width:100%;text-align:left;padding:12px 20px;border-radius:0}.admin-dropdown-menu{position:static;box-shadow:none;border-radius:0;margin-top:0;padding:0;background:#f8f9fa}.admin-dropdown-item{padding-left:35px}.header-right{gap:10px}.header-right .user-name{display:none}.layout-main{padding:15px}}.schedule-grid-wrapper{overflow-x:auto;background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000014}.schedule-grid{border-collapse:collapse;width:100%;min-width:900px}.schedule-grid th,.schedule-grid td{border:1px solid #e0e0e0;text-align:center;padding:0}.schedule-grid th{background:#f8f9fa;font-size:.7rem;font-weight:600;color:#555;padding:8px 2px;position:sticky;top:0;z-index:1}.schedule-grid .cleaner-col{text-align:left;padding-left:12px;font-size:.85rem;min-width:130px;width:130px}.schedule-grid .time-col{min-width:32px;width:32px}.schedule-grid .cleaner-name{text-align:left;padding:6px 12px;font-size:.85rem;font-weight:500;color:#333;white-space:nowrap}.schedule-grid tbody tr:nth-child(odd) .cleaner-name,.schedule-grid tbody tr:nth-child(odd) .grid-cell:not([style*=background]){background:#fafafa}.schedule-grid tbody tr:nth-child(2n) .cleaner-name,.schedule-grid tbody tr:nth-child(2n) .grid-cell:not([style*=background]){background:#fff}.grid-cell{height:32px;min-width:32px;transition:opacity .1s}.grid-cell.clickable{cursor:pointer}.grid-cell.clickable:hover{opacity:.7;outline:2px solid #333;outline-offset:-2px}.grid-cell.active-cell{outline:2px solid #333;outline-offset:-2px}@media(max-width:768px){.schedule-grid th{font-size:.6rem;padding:6px 1px}.schedule-grid .cleaner-col{min-width:90px;width:90px;font-size:.75rem}.schedule-grid .cleaner-name{font-size:.75rem;padding:4px 8px}.grid-cell{height:28px;min-width:28px}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.page-header h1{color:#333;font-size:1.8rem}.header-actions,.refresh-section{display:flex;align-items:center;gap:15px}.last-updated{color:#999;font-size:.85rem}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:#00adee;color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 5px 20px #00adee66}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover{background:#e0e0e0}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-sm{padding:6px 12px;font-size:.85rem}.card,.table-container{background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000014;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:15px 20px;text-align:left}.data-table th{background:#f8f9fa;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.data-table .col-shrink{width:1%;white-space:nowrap}.data-table tr:hover{background:#f8f9fa}.data-table td{border-bottom:1px solid #e0e0e0;color:#555}.data-table tr:last-child td{border-bottom:none}.data-table.compact th,.data-table.compact td{padding:8px 12px;font-size:.9rem}.table-actions{display:flex;gap:8px}.form-container{background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000014;padding:30px;max-width:600px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#00adee}.form-group textarea{min-height:100px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-actions{display:flex;gap:15px;margin-top:30px}.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:#666}.loading:before{content:"";width:20px;height:20px;border:2px solid #ddd;border-top-color:#00adee;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:60px 20px;color:#666}.error-message{background:#fee;color:#c00;padding:15px 20px;border-radius:8px;margin-bottom:20px}.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:500}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-danger{background:#f8d7da;color:#721c24}.badge-info{background:#d1ecf1;color:#0c5460}.badge-secondary{background:#e9ecef;color:#6c757d}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f0f4ff!important}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:15px}.page-header h1{font-size:1.4rem}.header-actions,.refresh-section{flex-wrap:wrap;gap:10px}.table-container{overflow-x:auto}.data-table th,.data-table td{padding:10px 12px}.form-row{grid-template-columns:1fr}.form-container{padding:20px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#f5f5f5;min-height:100vh}#root{min-height:100vh}
