  @import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&family=Manrope:wght@600;700;800&display=swap');
  :root{--bg:#0f1219;--surface:#161c2a;--surface2:#1c2436;--border:#242d40;--accent:#2d6cdf;--accent2:#ff6b35;--text:#e8edf5;--text2:#64748b;--danger:#ef4444;--warn:#f59e0b;}
  body.light-mode{--bg:#f8fafc;--surface:#ffffff;--surface2:#f1f5f9;--border:#e2e8f0;--accent:#2d6cdf;--text:#0f172a;--text2:#64748b;--danger:#ef4444;--warn:#d97706;}
  body.light-mode #login-screen{background:#f8fafc;}
  body.light-mode .top-bar{background:var(--surface);}
  body.light-mode .cleaner-card{box-shadow:0 1px 3px rgba(0,0,0,.06);}
  body.light-mode .summary-box{box-shadow:0 1px 3px rgba(0,0,0,.06);}
  .logo-text-svg{fill:#dde6f0;}
  body.light-mode .logo-text-svg{fill:#0f172a;}
  .mgr-bcard-body{display:none;}
  .mgr-bcard-body.open{display:block;}
  .theme-toggle{background:none;border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:4px 8px;font-size:13px;cursor:pointer;line-height:1;}
  .theme-toggle:hover{border-color:var(--accent);color:var(--accent);}
  *{margin:0;padding:0;box-sizing:border-box;}
  body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;}
  #loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;}
  .spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;}
  @keyframes spin{to{transform:rotate(360deg);}}
  .loading-text{font-family:'DM Mono',monospace;font-size:13px;color:var(--text2);letter-spacing:2px;}
  #login-screen{min-height:100vh;display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:var(--bg);}
  .login-logo{font-size:13px;font-family:'DM Mono',monospace;color:var(--accent);letter-spacing:4px;text-transform:uppercase;margin-bottom:8px;}
  .login-title{font-size:32px;font-weight:800;text-align:center;line-height:1.1;margin-bottom:40px;}
  .login-title span{color:var(--accent);}
  .role-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:380px;margin-bottom:32px;}
  .role-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:24px 16px;cursor:pointer;transition:all .2s;text-align:center;}
  .role-btn:hover,.role-btn.active{border-color:var(--accent);background:#2d6cdf10;}
  .role-btn .icon{font-size:28px;margin-bottom:8px;}
  .role-btn .label{font-size:14px;font-weight:600;}
  .role-btn .sub{font-size:11px;color:var(--text2);margin-top:4px;font-family:'DM Mono',monospace;}
  .login-form{width:100%;max-width:380px;display:flex;flex-direction:column;gap:12px;}
  .login-form input,.login-form select{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:15px;outline:none;transition:border-color .2s;width:100%;}
  .login-form input:focus,.login-form select:focus{border-color:var(--accent);}
  .login-form select option{background:#222;}
  .btn-primary{background:var(--accent);color:#fff;border:none;border-radius:12px;padding:15px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;}
  .btn-primary:hover{background:#5b8ef5;transform:translateY(-1px);}
  .btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;}
  .error-msg{color:var(--danger);font-size:13px;text-align:center;font-family:'DM Mono',monospace;}
  .top-bar{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;}
  .top-bar-title{font-size:16px;font-weight:700;}
  .top-bar-sub{font-size:11px;color:var(--accent);font-family:'DM Mono',monospace;}
  .logout-btn{background:transparent;border:1px solid var(--border);color:var(--text2);border-radius:8px;padding:6px 12px;font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;}
  .logout-btn:hover{border-color:var(--danger);color:var(--danger);}
  /* TABS */
  .tab-bar{display:flex;background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;}
  .tab-btn{padding:14px 20px;font-size:13px;font-weight:700;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;font-family:'DM Sans',sans-serif;position:relative;background:none;border-top:none;border-left:none;border-right:none;}
  .tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);}
  .tab-badge{position:absolute;top:8px;right:4px;background:var(--danger);color:#fff;border-radius:50%;width:16px;height:16px;font-size:10px;display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;}
  .tab-panel{display:none;}
  .tab-panel.active{display:block;}
  #supervisor-panel{display:none;min-height:100vh;}
  .panel-content{padding:20px;max-width:640px;margin:0 auto;}
  .date-badge{font-family:'DM Mono',monospace;font-size:12px;color:var(--text2);background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 12px;display:inline-block;margin-bottom:20px;}
  .section-title{font-size:13px;font-weight:700;color:var(--text2);letter-spacing:2px;text-transform:uppercase;font-family:'DM Mono',monospace;margin-bottom:12px;}
  .announcement-box{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:14px;margin-bottom:20px;}
  .announcement-box textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;resize:none;min-height:60px;margin-top:8px;}
  .announcement-box textarea:focus{border-color:var(--accent);}
  .announcement-actions{display:flex;gap:8px;margin-top:8px;align-items:center;}
  .summary-box{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:14px;margin-bottom:20px;}
  .summary-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;}
  .summary-row:last-child{border-bottom:none;}
  .summary-name{font-weight:600;}
  .summary-pct{font-family:'DM Mono',monospace;font-size:12px;}
  .summary-pct.complete{color:var(--accent);}
  .summary-pct.partial{color:var(--accent2);}
  .summary-pct.empty{color:var(--danger);}
  .summary-time{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;min-width:72px;text-align:right;}
  .cleaner-card{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:16px;margin-bottom:12px;}
  .cleaner-card.inactive{border-color:var(--warn);}
  .cleaner-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;cursor:pointer;}
  .cleaner-name-row{display:flex;align-items:center;gap:10px;}
  .cleaner-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#0099cc);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;flex-shrink:0;}
  .cleaner-name{font-size:15px;font-weight:600;}
  .cleaner-meta{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;}
  .inactive-badge{font-size:10px;background:var(--warn);color:#fff;border-radius:4px;padding:2px 5px;font-family:'DM Mono',monospace;font-weight:700;margin-left:6px;vertical-align:middle;}
  .cleaner-call-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:4px;flex-shrink:0;}
  .progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:8px;}
  .progress-fill{height:100%;border-radius:2px;transition:width .5s;}
  .progress-fill.complete{background:var(--accent);}
  .progress-fill.partial{background:var(--accent2);}
  .progress-fill.empty{background:var(--danger);width:4px !important;}
  .tasks-list{display:none;}
  .tasks-list.open{display:block;}
  .cleaner-edit{background:var(--surface2);border-radius:10px;padding:12px;margin-bottom:10px;display:none;flex-direction:column;gap:8px;}
  .cleaner-edit.open{display:flex;}
  .cleaner-edit-row{display:flex;gap:8px;flex-wrap:wrap;}
  .cleaner-edit input,.cleaner-edit select{flex:1;min-width:100px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;}
  .cleaner-edit input:focus,.cleaner-edit select:focus{border-color:var(--accent);}
  .cleaner-edit select option{background:#222;}
  .cleaner-edit-actions{display:flex;gap:6px;flex-wrap:wrap;}
  .floor-group{margin-bottom:8px;border:1px solid var(--border);border-radius:10px;overflow:hidden;}
  .floor-header-sup{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:var(--surface2);cursor:pointer;}
  .floor-title-sup{font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px;}
  .floor-count{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;}
  .floor-pct-sup{font-size:11px;font-family:'DM Mono',monospace;color:var(--accent);}
  .floor-actions-sup{display:flex;align-items:center;gap:4px;}
  .floor-tasks-sup{display:none;padding:0 12px;}
  .floor-tasks-sup.open{display:block;}
  .area-note-display{font-size:12px;color:var(--accent2);padding:8px 0;font-style:italic;}
  .area-note-edit{display:none;padding:8px 0;}
  .area-note-edit.open{display:block;}
  .area-note-edit textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;resize:none;min-height:48px;}
  .task-item-sup{display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-top:1px solid var(--border);}
  .task-item-sup.priority-item{background:#ff475708;border-radius:6px;padding:6px 8px;margin:2px -4px;}
  .drag-handle{color:var(--text2);font-size:14px;cursor:grab;flex-shrink:0;padding-top:1px;user-select:none;}
  .task-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;margin-top:1px;}
  .task-dot.done{background:var(--accent);color:#fff;}
  .task-dot.pending{background:var(--border);}
  .task-dot.rejected{background:var(--danger);color:#fff;}
  .task-dot.pri{background:var(--danger);color:#fff;}
  .task-info-sup{flex:1;min-width:0;}
  .task-text-sup{font-size:13px;}
  .task-text-sup.done{text-decoration:line-through;color:var(--text2);}
  .task-text-sup.rejected{color:var(--danger);}
  .task-pri-label{font-size:10px;color:var(--danger);font-family:'DM Mono',monospace;font-weight:700;}
  .task-time-sup{font-size:10px;color:var(--text2);font-family:'DM Mono',monospace;margin-top:1px;}
  .task-note-sup{font-size:11px;color:var(--accent2);font-style:italic;margin-top:2px;}
  .task-actions-sup{display:flex;gap:4px;flex-shrink:0;align-items:flex-start;}
  .reject-btn{background:none;border:1px solid var(--danger);color:var(--danger);border-radius:5px;padding:2px 7px;font-size:11px;cursor:pointer;}
  .reject-btn:hover{background:var(--danger);color:#fff;}
  .pri-btn{background:none;border:1px solid var(--border);color:var(--text2);border-radius:5px;padding:2px 6px;font-size:11px;cursor:pointer;}
  .pri-btn.on{border-color:var(--danger);color:var(--danger);}
  .del-btn{background:none;border:none;color:var(--text2);cursor:pointer;font-size:15px;padding:0 2px;}
  .del-btn:hover{color:var(--danger);}
  .add-row{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);}
  .add-row input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;}
  .add-row input:focus{border-color:var(--accent);}
  .btn-sm{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 12px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;}
  .btn-sm:disabled{opacity:.5;cursor:not-allowed;}
  .btn-outline{background:none;border:1px solid var(--border);color:var(--text2);border-radius:8px;padding:6px 10px;font-size:11px;cursor:pointer;font-family:'DM Sans',sans-serif;}
  .btn-outline:hover{border-color:var(--warn);color:var(--warn);}
  .btn-danger-outline{background:none;border:1px solid var(--danger);color:var(--danger);border-radius:8px;padding:6px 10px;font-size:11px;cursor:pointer;font-family:'DM Sans',sans-serif;}
  .add-cleaner-box{background:var(--surface);border:1.5px dashed var(--border);border-radius:16px;padding:16px;margin-bottom:24px;}
  .add-cleaner-row{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;}
  .add-cleaner-row input,.add-cleaner-row select{flex:1;min-width:110px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;}
  .add-cleaner-row input:focus,.add-cleaner-row select:focus{border-color:var(--accent);}
  .add-cleaner-row select option{background:#222;}
  /* INCIDENTS */
  .incident-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;margin-bottom:10px;overflow:hidden;}
  .incident-card.resolved{border-color:var(--accent);}
  .incident-summary{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;}
  .incident-summary-left{display:flex;align-items:center;gap:10px;}
  .incident-summary-icon{font-size:20px;flex-shrink:0;}
  .incident-title{font-size:14px;font-weight:700;}
  .incident-meta{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;margin-top:2px;}
  .incident-status{font-size:10px;font-family:'DM Mono',monospace;padding:3px 8px;border-radius:4px;font-weight:700;flex-shrink:0;}
  .incident-status.open{background:#ff475720;color:var(--danger);}
  .incident-status.resolved{background:#2d6cdf20;color:var(--accent);}
  .incident-status.escalated{background:#ffffff10;color:var(--text2);}
  .incident-card.escalated{border-color:var(--border);}
  .incident-body{display:none;padding:0 16px 16px;border-top:1px solid var(--border);}
  .incident-body.open{display:block;}
  .incident-desc{font-size:13px;color:var(--text2);margin:10px 0;}
  .incident-photos{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;}
  .incident-thumb{width:80px;height:80px;object-fit:cover;border-radius:8px;cursor:pointer;transition:transform .2s;}
  .incident-thumb:hover{transform:scale(1.05);}
  .incident-section-label{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;margin-bottom:6px;text-transform:uppercase;letter-spacing:1px;}
  .resolve-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:7px 14px;font-size:12px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:8px;}
  .delete-incident-btn{background:none;border:1px solid var(--danger);color:var(--danger);border-radius:8px;padding:6px 12px;font-size:11px;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:8px;margin-left:8px;}
  /* LIGHTBOX */
  .lightbox{position:fixed;inset:0;background:#000d;display:none;align-items:center;justify-content:center;z-index:300;padding:20px;}
  .lightbox.open{display:flex;}
  .lightbox img{max-width:100%;max-height:90vh;border-radius:10px;object-fit:contain;}
  .lightbox-close{position:absolute;top:20px;right:20px;background:#fff2;color:#fff;border:none;border-radius:50%;width:36px;height:36px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
  /* PDF EXPORT BTN */
  .export-btn{background:var(--surface);border:1.5px solid var(--accent);color:var(--accent);border-radius:10px;padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;width:100%;margin-bottom:16px;}
  /* CLEANER VIEW */
  #cleaner-panel{display:none;min-height:100vh;}
  .announcement-bar{background:rgba(255,107,53,0.12);border-bottom:1px solid rgba(255,107,53,0.25);padding:12px 16px;display:none;}
  .announcement-bar.visible{display:block;}
  .announcement-label{font-size:10px;color:var(--text2);font-family:'DM Mono',monospace;margin-bottom:6px;text-transform:uppercase;letter-spacing:1px;}
  .announcement-text{font-size:15px;font-weight:700;color:#f0f0f0;background:rgba(255,107,53,0.12);border-radius:8px;padding:10px 12px;border-left:3px solid var(--accent2);}
  .cleaner-hero{background:linear-gradient(135deg,#2d6cdf15,#ff6b3510);border-bottom:1px solid var(--border);padding:24px 20px 20px;}
  .cleaner-hero-name{font-size:28px;font-weight:700;margin-bottom:4px;font-family:'Manrope',sans-serif;}
  .cleaner-hero-name span{color:var(--accent);}
  .cleaner-hero-date{font-size:12px;color:var(--text2);font-family:'DM Mono',monospace;}
  .big-progress{margin-top:16px;background:var(--surface);border-radius:12px;padding:14px 16px;}
  .big-progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
  .big-progress-label{font-size:13px;color:var(--text2);font-family:'DM Mono',monospace;}
  .big-progress-pct{font-size:20px;font-weight:800;color:var(--accent);}
  .big-progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;}
  .big-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#5b8ef5);border-radius:4px;transition:width .5s;}
  .cleaner-tasks{padding:20px;max-width:500px;margin:0 auto;}
  /* FLOOR CARDS CLEANER */
  .floor-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;margin-bottom:12px;overflow:hidden;transition:border-color .2s;position:relative;}
  .floor-card.complete{border-color:var(--accent);background:#2d6cdf08;}
  .floor-mini-bar{height:3px;background:var(--border);}
  .floor-mini-fill{height:100%;background:var(--accent);transition:width .4s;}
  .floor-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;}
  .floor-card-title{font-size:15px;font-weight:700;}
  .floor-card-sub{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;margin-top:2px;}
  .floor-card-pct{font-size:15px;font-weight:800;color:var(--accent);}
  .floor-subtasks{display:none;padding:0 12px 12px;}
  .floor-subtasks.open{display:block;}
  /* BADGE */
  .floor-badge{position:absolute;top:10px;right:10px;background:var(--danger);color:#fff;border-radius:50%;width:20px;height:20px;font-size:11px;display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-weight:700;z-index:2;}
  .area-note-cleaner{background:#ff6b3310;border-radius:8px;padding:10px 12px;margin-bottom:10px;font-size:13px;color:var(--accent2);font-style:italic;border-left:3px solid var(--accent2);}
  .task-card{background:var(--surface2);border:1.5px solid var(--border);border-radius:11px;padding:12px 14px;margin-bottom:8px;transition:border-color .2s;}
  .task-card.done{border-color:var(--accent);background:#2d6cdf08;}
  .task-card.rejected{border-color:var(--danger);background:#ff475710;}
  .task-card.priority{border-left:3px solid var(--danger);}
  .task-card.priority.done{border-left:3px solid var(--accent);}
  .task-top{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;}
  .task-checkbox{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;transition:all .2s;}
  .task-card.done .task-checkbox{background:var(--accent);border-color:var(--accent);color:#fff;}
  .task-card.rejected .task-checkbox{background:var(--danger);border-color:var(--danger);color:#fff;}
  .task-label{font-size:14px;font-weight:500;flex:1;}
  .task-card.done .task-label{text-decoration:line-through;color:var(--text2);}
  .task-priority-tag{font-size:10px;color:var(--danger);font-family:'DM Mono',monospace;font-weight:700;background:#ff475715;border-radius:4px;padding:1px 5px;flex-shrink:0;}
  .task-time-label{font-size:10px;color:var(--text2);font-family:'DM Mono',monospace;}
  .task-rejected-msg{font-size:11px;color:var(--danger);font-family:'DM Mono',monospace;margin-top:4px;}
  .task-note-display{font-size:12px;color:var(--accent2);font-style:italic;margin-top:4px;}
  .note-toggle-btn{background:none;border:none;color:var(--text2);font-size:11px;font-family:'DM Mono',monospace;cursor:pointer;margin-top:6px;padding:0;}
  .note-toggle-btn:hover{color:var(--accent);}
  .note-area{display:none;margin-top:8px;}
  .note-area.open{display:block;}
  .note-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;resize:none;min-height:56px;}
  .note-input:focus{border-color:var(--accent);}
  .note-save-btn{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:6px;}
  /* REPORT ISSUE CLEANER */
  .report-btn{display:flex;align-items:center;gap:12px;background:var(--surface);border:1.5px solid var(--warn);border-radius:14px;padding:14px 16px;margin-top:12px;cursor:pointer;width:100%;text-align:left;transition:all .2s;color:var(--text);}
  .report-btn:hover{background:#ffa50210;}
  .report-btn-icon{font-size:20px;}
  .report-btn-title{font-size:14px;font-weight:700;color:var(--warn);}
  .report-btn-sub{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;}
  .call-btn{display:flex;align-items:center;gap:12px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:16px;margin-top:12px;text-decoration:none;color:var(--text);transition:all .2s;}
  .call-btn:hover{border-color:var(--accent);}
  .call-btn-icon{font-size:22px;}
  .call-btn-title{font-size:14px;font-weight:700;}
  .call-btn-sub{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;}
  .all-done-banner{text-align:center;padding:24px;background:var(--surface);border:1.5px solid var(--accent);border-radius:16px;margin-top:8px;display:none;}
  .all-done-banner .emoji{font-size:36px;margin-bottom:8px;}
  .all-done-banner .msg{font-size:16px;font-weight:700;color:var(--accent);}
  .all-done-banner .sub{font-size:13px;color:var(--text2);margin-top:4px;font-family:'DM Mono',monospace;}
  /* MODALS */
  .modal-overlay{position:fixed;inset:0;background:#000b;display:none;align-items:center;justify-content:center;z-index:100;padding:20px;}
  .modal-overlay.open{display:flex;}
  .modal{background:var(--surface);border:1.5px solid var(--border);border-radius:18px;padding:24px;max-width:380px;width:100%;}
  .modal-title{font-size:17px;font-weight:800;margin-bottom:8px;}
  .modal-body{font-size:13px;color:var(--text2);margin-bottom:16px;line-height:1.5;}
  .modal-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;margin-bottom:12px;}
  .modal-input:focus{border-color:var(--accent);}
  .modal-textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;resize:none;min-height:80px;margin-bottom:12px;}
  .modal-textarea:focus{border-color:var(--accent);}
  .modal-select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;margin-bottom:12px;}
  .modal-select option{background:#222;}
  .modal-actions{display:flex;gap:10px;}
  .modal-photo-btn{width:100%;background:var(--surface2);border:1.5px dashed var(--border);border-radius:8px;padding:16px;text-align:center;cursor:pointer;color:var(--text2);font-size:13px;margin-bottom:12px;transition:border-color .2s;}
  .modal-photo-btn:hover{border-color:var(--accent);}
  .modal-photo-preview{width:100%;border-radius:8px;margin-bottom:12px;display:none;}
  .push-banner{position:fixed;top:0;left:0;right:0;padding:14px 20px;z-index:200;display:none;text-align:center;font-weight:700;font-size:14px;animation:slideDown .3s ease;}
  .push-banner.danger{background:var(--danger);color:#fff;}
  .push-banner.warn{background:var(--warn);color:#fff;}
  @keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}
  .sync-indicator{font-family:'DM Mono',monospace;font-size:11px;color:var(--text2);display:flex;align-items:center;gap:6px;}
  .sync-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite;}
  .sync-dot.offline{background:var(--danger);animation:none;}
  @keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
  .hidden{display:none !important;}
  .mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}
  @keyframes barWave{0%,100%{transform:scaleY(1);opacity:1}50%{transform:scaleY(0.4);opacity:0.5}}
  .curat-spinner rect:nth-child(1){animation:barWave 1.2s ease-in-out infinite 0s;}
  .curat-spinner rect:nth-child(2){animation:barWave 1.2s ease-in-out infinite 0.1s;}
  .curat-spinner rect:nth-child(3){animation:barWave 1.2s ease-in-out infinite 0.2s;}
  .curat-spinner rect:nth-child(4){animation:barWave 1.2s ease-in-out infinite 0.3s;}
  .curat-spinner rect:nth-child(5){animation:barWave 1.2s ease-in-out infinite 0.2s;}
  .curat-spinner rect:nth-child(6){animation:barWave 1.2s ease-in-out infinite 0.1s;}
  .curat-spinner{transform-origin:center;}
  .floor-group.drag-over{border-color:var(--accent);}
  .no-incidents{text-align:center;padding:40px 20px;color:var(--text2);font-family:'DM Mono',monospace;font-size:13px;}
  /* SUMMARIZE */
  .history-date-pill{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:8px 14px;font-family:'DM Mono',monospace;cursor:pointer;transition:all .15s;text-align:center;min-width:62px;flex-shrink:0;}
  .history-date-pill:hover{border-color:var(--accent);color:var(--text);}
  .history-date-pill.active{border-color:var(--accent);background:rgba(45,108,223,0.1);}
  #history-date-pills::-webkit-scrollbar{display:none;}
  .bin-row-3{display:grid;grid-template-columns:1fr 64px 64px 64px;gap:6px;padding:6px 0;border-bottom:1px solid var(--border);align-items:center;}
  .bin-row-3:last-child{border-bottom:none;}
  .bin-row-simple{display:flex;align-items:center;justify-content:space-between;padding:8px 4px;border-bottom:1px solid var(--border);}
  .bin-row-simple:last-child{border-bottom:none;}
  .bin-adj-btn{width:28px;height:28px;border-radius:7px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;}
  .bin-adj-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
  .bin-simple-count{width:36px;text-align:center;font-family:'DM Mono',monospace;font-size:14px;font-weight:700;color:var(--text);}
  .bin-co-pill{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:4px 10px;font-family:'DM Mono',monospace;font-size:11px;color:var(--accent);font-weight:700;display:inline-flex;align-items:center;gap:5px;}
  .bin-co-pill button{background:none;border:none;color:var(--text2);cursor:pointer;font-size:12px;line-height:1;padding:0;}
  .bin-co-pill button:hover{color:var(--danger);}
  .bin-multi-input{width:52px;background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:5px 6px;color:var(--text);font-family:'DM Mono',monospace;font-size:13px;font-weight:700;text-align:center;outline:none;transition:border-color .15s;}
  .bin-multi-input:focus{border-color:var(--accent);}
  .bin-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);}
  .bin-row:last-child{border-bottom:none;}
  .bin-label{flex:1;font-size:13px;font-weight:500;}
  .bin-input{width:64px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 6px;color:var(--text);font-family:'DM Mono',monospace;font-size:13px;font-weight:700;outline:none;text-align:center;}
  .bin-input:focus{border-color:var(--accent);}
  .bin-unit{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;min-width:28px;}
  .bin-del-btn{background:none;border:none;color:var(--text2);cursor:pointer;font-size:14px;padding:0 2px;}
  .bin-del-btn:hover{color:var(--danger);}
  .summarize-task-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px;}
  .summarize-task-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;}
  .summarize-task-title{font-size:14px;font-weight:700;}
  .summarize-task-cleaner{font-size:11px;color:var(--accent);font-family:'DM Mono',monospace;margin-top:2px;}
  .summarize-remove-btn{background:none;border:none;color:var(--text2);cursor:pointer;font-size:16px;padding:0;}
  .summarize-remove-btn:hover{color:var(--danger);}
  .summarize-note-edit{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;resize:none;min-height:44px;margin-bottom:8px;}
  .summarize-note-edit:focus{border-color:var(--accent);}
  .summarize-extra-info{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;resize:none;min-height:44px;margin-bottom:8px;}
  .summarize-extra-info:focus{border-color:var(--accent);}
  .summarize-photos{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px;}
  .summarize-photo-wrap{position:relative;display:inline-block;}
  .summarize-photo-del{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;}
  .sum-include-toggle{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;cursor:pointer;margin-bottom:8px;}
  /* SUMMARIZE button on task in supervisor view */
  .sum-btn{background:none;border:1px solid var(--accent);color:var(--accent);border-radius:5px;padding:2px 7px;font-size:11px;cursor:pointer;font-family:'DM Mono',monospace;}
  .sum-btn.added{background:var(--accent);color:#fff;}
  .sum-btn:hover{background:#2d6cdf20;}

/* ===================== DESKTOP LAYOUT ===================== */
@media (max-width: 767px) {
  #history-prev-btn, #history-next-btn { display: none !important; }
}

@media (min-width: 768px) {
  #login-screen { padding: 40px; }
  .role-grid { max-width: 500px; }
  .login-form { max-width: 500px; }
  .panel-content { max-width: 860px; padding: 32px 40px; }
  .cleaner-tasks { max-width: 860px; padding: 32px 40px; }
  .top-bar { padding: 16px 40px; }
  .tab-bar { padding: 0 40px; }
  #cleaners-list { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  #cleaners-list .cleaner-card { margin-bottom: 0; }
  .modal { max-width: 520px; }
  #mgr-buildings-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
  #history-date-pills { gap: 10px; }
  .history-date-pill { min-width: 80px; font-size: 13px; }
  .lightbox img { max-height: 85vh; max-width: 80vw; }
}

@media (min-width: 1200px) {
  .panel-content { max-width: 1100px; }
  .cleaner-tasks { max-width: 1100px; }
  #cleaners-list { grid-template-columns: repeat(3, 1fr); }
  #mgr-buildings-list { grid-template-columns: repeat(4, 1fr); }
}

/* ===================== LOGIN REDESIGN ===================== */
#login-screen::before{content:'';position:fixed;top:0;left:50%;transform:translateX(-50%);width:600px;height:500px;background:radial-gradient(ellipse at 50% 0%,rgba(45,108,223,0.1) 0%,transparent 70%);pointer-events:none;z-index:0;}
#login-screen > *{position:relative;z-index:1;}
.login-title{font-size:22px;font-weight:800;text-align:center;margin-bottom:6px;font-family:'Manrope',sans-serif;letter-spacing:-0.5px;}
.login-sub-label{font-family:'DM Mono',monospace;font-size:10px;color:var(--text2);letter-spacing:2px;text-transform:uppercase;text-align:center;margin-bottom:28px;}
.role-btn{position:relative;overflow:hidden;}
.role-btn::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),#4d8ef8);opacity:0;transition:opacity .2s;}
.role-btn:hover::before,.role-btn.active::before{opacity:1;}
.role-btn .icon{width:40px;height:40px;background:rgba(45,108,223,0.1);border:1px solid rgba(45,108,223,0.15);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;transition:all .2s;}
.role-btn.active .icon{background:rgba(45,108,223,0.2);border-color:rgba(45,108,223,0.4);}
.login-input-wrap{position:relative;margin-bottom:0;}
.login-input-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text2);pointer-events:none;}
.login-form input,.login-form select{padding-left:42px !important;}
.login-form input:focus,.login-form select:focus{border-color:var(--accent);background:rgba(45,108,223,0.03);}
