body{-webkit-font-smoothing:antialiased;margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif}#root{min-height:100vh}:root{--bg:#0f1419;--surface:#1a2332;--surface-hover:#243044;--text:#e7e9ea;--text-muted:#8b98a5;--accent:#1d9bf0;--accent-hover:#1a8cd8;--success:#00ba7c;--warning:#ff7a00;--error:#f4212e;--radius:12px}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);min-height:100vh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.loading-screen,.loading{min-height:50vh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--surface);border-radius:var(--radius);width:100%;max-width:360px;padding:2.5rem;box-shadow:0 8px 32px #0006}.login-card h1{margin:0 0 .25rem;font-size:1.75rem}.login-card .subtitle{color:var(--text-muted);margin:0 0 1.5rem;font-size:.9rem}.login-card form{flex-direction:column;gap:1rem;display:flex}.login-card input{background:var(--bg);color:var(--text);border:1px solid #38444d;border-radius:8px;padding:.75rem 1rem;font-size:1rem}.login-card input::placeholder{color:var(--text-muted)}.login-card input:focus{border-color:var(--accent);outline:none}.login-card .error{color:var(--error);margin:0;font-size:.875rem}.login-card button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:background .2s}.login-card button:hover:not(:disabled){background:var(--accent-hover)}.login-card button:disabled{opacity:.6;cursor:not-allowed}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-layout nav{background:var(--surface);border-bottom:1px solid #38444d;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.app-layout nav a{color:var(--text);font-weight:500;text-decoration:none}.app-layout nav a:hover{color:var(--accent)}.app-layout .nav-user{color:var(--text-muted);font-size:.9rem}.app-layout .btn-logout{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #38444d;border-radius:8px;margin-left:auto;padding:.5rem 1rem;font-size:.9rem}.app-layout .btn-logout:hover{background:var(--surface-hover);color:var(--text)}.app-layout main{flex:1;width:100%;max-width:640px;margin:0 auto;padding:1.5rem}.checklist-page header,.dashboard-page header{margin-bottom:1.5rem}.checklist-page h1,.dashboard-page h1{margin:0 0 .25rem;font-size:1.5rem}.checklist-page header p,.dashboard-page header p{color:var(--text-muted);margin:0;font-size:.95rem}.task-list{margin:0;padding:0;list-style:none}.task-list li{background:var(--surface);border-radius:var(--radius);border:1px solid #0000;margin-bottom:.75rem;padding:1.25rem;transition:border-color .2s}.task-list li.done{border-color:#00ba7c4d}.task-header{flex-direction:column;gap:.35rem;margin-bottom:.75rem;display:flex}.task-name{font-weight:600}.task-meta{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.badge-meta{color:var(--text-muted);background:var(--surface-hover);border-radius:6px;padding:.2rem .5rem;font-size:.75rem}.user-context{font-size:.9rem;color:var(--accent)!important;margin-top:.25rem!important}.offline-badge{font-size:.85rem;color:var(--warning)!important;margin-top:.25rem!important}.badge{color:var(--warning);background:#ff7a0026;border-radius:6px;padding:.2rem .5rem;font-size:.75rem}.observation-row{gap:.5rem;margin-bottom:.5rem;display:flex}.observation-row input,.observation-row textarea.observation-input{flex:1;min-width:0}.stt-dictate-btn{background:var(--surface-hover);color:var(--text);cursor:pointer;border:1px solid #38444d;border-radius:8px;padding:.6rem .75rem;font-size:1rem}.stt-dictate-btn:hover{border-color:var(--accent);color:var(--accent)}.task-actions input[type=text]{background:var(--bg);width:100%;color:var(--text);border:1px solid #38444d;border-radius:8px;padding:.6rem .75rem;font-size:.95rem}.task-buttons-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.photo-upload{margin:0}.photo-buttons{align-items:center;gap:.35rem;display:flex}.photo-gallery-btn{min-width:2.5rem;padding:.5rem!important}.photo-upload button{background:var(--surface-hover);color:var(--text-muted);cursor:pointer;border:1px dashed #38444d;border-radius:8px;padding:.5rem 1rem;font-size:.9rem}.photo-upload button:hover{color:var(--text);border-color:var(--accent)}.btn-complete{background:var(--success);color:#fff;cursor:pointer;border:none;border-radius:8px;margin:0;padding:.6rem 1.25rem;font-weight:600}.btn-complete:hover:not(:disabled){filter:brightness(1.1)}.btn-complete:disabled{opacity:.7;cursor:not-allowed}.task-done{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.task-done span{color:var(--success);font-size:.9rem}.proof-img{object-fit:cover;border-radius:8px;max-width:80px;max-height:80px}.btn-undo{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #38444d;border-radius:6px;padding:.35rem .75rem;font-size:.85rem}.btn-undo:hover:not(:disabled){color:var(--error);border-color:var(--error)}.filters{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.filters label{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.85rem;display:flex}.filters input,.filters select{background:var(--surface);color:var(--text);border:1px solid #38444d;border-radius:8px;padding:.5rem .75rem}.stats-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.stats{gap:1rem;display:flex}.export-buttons{gap:.5rem;display:flex}.export-buttons button{background:var(--surface);color:var(--text);cursor:pointer;border:1px solid #38444d;border-radius:8px;padding:.5rem 1rem;font-size:.9rem}.export-buttons button:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.stat-card{background:var(--surface);border-radius:var(--radius);text-align:center;flex:1;padding:1rem 1.25rem}.stat-card .stat-value{color:var(--success);font-size:1.75rem;font-weight:700;display:block}.stat-card.warning .stat-value{color:var(--warning)}.stat-card .stat-label{color:var(--text-muted);font-size:.85rem}.table-wrap{background:var(--surface);border-radius:var(--radius);overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid #38444d;padding:.75rem 1rem}th{color:var(--text-muted);font-size:.85rem;font-weight:600}tr:last-child td{border-bottom:none}.status{border-radius:6px;padding:.2rem .5rem;font-size:.85rem}.status-completed{color:var(--success);background:#00ba7c33}.status-pending{color:var(--warning);background:#ff7a0033}.task-manage-page,.settings-page{max-width:720px}.task-form,.settings-section{background:var(--surface);border-radius:var(--radius);margin-bottom:1.5rem;padding:1.5rem}.task-form h2,.settings-section h2{margin:0 0 1rem;font-size:1.1rem}.form-row{margin-bottom:1rem}.form-row-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-row-check{flex-wrap:wrap;gap:1.5rem;display:flex}.form-row label,.form-row-check label{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.9rem;display:flex}.form-row input,.form-row select,.form-row textarea{background:var(--bg);color:var(--text);border:1px solid #38444d;border-radius:8px;padding:.5rem .75rem}.checkbox{align-items:center;flex-direction:row!important}.form-actions{gap:.5rem;margin-top:1rem;display:flex}.form-actions button{cursor:pointer;border-radius:8px;padding:.5rem 1rem;font-weight:500}.form-actions button[type=submit]{background:var(--accent);color:#fff;border:none}.form-actions button[type=button]{color:var(--text-muted);background:0 0;border:1px solid #38444d}.task-list-manage h2{margin:0 0 1rem;font-size:1.1rem}.task-list-manage ul{margin:0;padding:0;list-style:none}.task-list-manage li{background:var(--surface);border-radius:var(--radius);border:1px solid #0000;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:1rem;display:flex}.task-list-manage li.inactive{opacity:.6}.task-list-manage .task-info{flex-direction:column;gap:.25rem;display:flex}.task-list-manage .task-meta{color:var(--text-muted);font-size:.85rem}.task-list-manage .task-actions{gap:.5rem;display:flex}.task-list-manage .task-actions button{cursor:pointer;background:var(--surface-hover);color:var(--text);border:1px solid #38444d;border-radius:6px;padding:.35rem .75rem;font-size:.9rem}.task-list-manage .btn-danger{color:var(--error);border-color:var(--error)}.settings-tabs{gap:.5rem;margin-bottom:1.5rem;display:flex}.settings-tabs button{background:var(--surface);color:var(--text);cursor:pointer;border:1px solid #38444d;border-radius:8px;padding:.5rem 1rem}.settings-tabs button.active{background:var(--accent);border-color:var(--accent);color:#fff}.inline-form,.shift-form,.user-form{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.inline-form input,.shift-form input,.shift-form select,.user-form input,.user-form select{background:var(--bg);color:var(--text);border:1px solid #38444d;border-radius:8px;padding:.5rem .75rem}.inline-form button,.shift-form button,.user-form button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem}.settings-list{margin:0;padding:0;list-style:none}.settings-list li{background:var(--surface);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem 1rem;display:flex}.settings-list li.inactive{opacity:.7}.btn-sm{padding:.25rem .5rem;font-size:.85rem}.btn-danger{color:var(--error);border-color:var(--error)}.btn-success{color:var(--success,#22c55e);border-color:var(--success,#22c55e)}.ranking-section{background:var(--surface);border-radius:var(--radius);margin-bottom:1.5rem;padding:1rem 1.25rem}.ranking-section h2{margin:0 0 .75rem;font-size:1rem}.ranking-list{margin:0;padding:0;list-style:none}.ranking-list li{border-bottom:1px solid #38444d;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.ranking-list li:last-child{border-bottom:none}.ranking-list .rank{color:var(--accent);min-width:2rem;font-weight:700}.ranking-list .name{flex:1}.ranking-list .pct{color:var(--success);font-weight:600}.pending-section{border:1px solid var(--warning);border-radius:var(--radius);background:#ff7a0026;margin-bottom:1.5rem;padding:1rem 1.25rem}.pending-section h2{color:var(--warning);margin:0 0 .25rem;font-size:1rem}.pending-date{color:var(--text-muted);font-size:.9rem;margin:0 0 .75rem!important}.pending-list{margin:0;padding:0;list-style:none}.pending-list li{border-bottom:1px solid #ff7a004d;flex-direction:column;gap:.15rem;padding:.5rem 0;display:flex}.pending-list li:last-child{border-bottom:none}.pending-list li span{color:var(--text-muted);font-size:.85rem}.a11y-float{bottom:calc(1rem + env(safe-area-inset-bottom,0px));right:calc(1rem + env(safe-area-inset-right,0px));z-index:1000;position:fixed}.pwa-toast{bottom:calc(1rem + env(safe-area-inset-bottom,0px));z-index:1100;background:var(--surface);border-radius:var(--radius);border:1px solid #38444d;padding:.75rem 1rem;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0006}.pwa-toast-message{align-items:center;gap:1rem;display:flex}.pwa-toast-actions{gap:.5rem;display:flex}.pwa-toast-actions button{background:var(--surface-hover);color:var(--text);cursor:pointer;border:1px solid #38444d;border-radius:6px;padding:.35rem .75rem;font-size:.9rem}.pwa-toast-actions button:first-of-type{background:var(--accent);border-color:var(--accent);color:#fff}.voice-assistant{bottom:calc(1rem + env(safe-area-inset-bottom,0px));left:calc(1rem + env(safe-area-inset-left,0px));z-index:1000;position:fixed}.voice-assistant-fab{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;width:56px;height:56px;font-size:1.5rem;transition:transform .2s;box-shadow:0 4px 16px #0000004d}.voice-assistant-fab:hover{transform:scale(1.05)}.voice-assistant-panel{background:var(--surface);border-radius:var(--radius);border:1px solid #38444d;flex-direction:column;width:320px;max-width:calc(100vw - 2rem);max-height:400px;display:flex;position:absolute;bottom:70px;left:0;overflow:hidden;box-shadow:0 8px 32px #0006}.voice-assistant-panel h3{border-bottom:1px solid #38444d;margin:0;padding:1rem;font-size:1rem}.voice-assistant-messages{flex-direction:column;flex:1;gap:.5rem;min-height:120px;padding:.75rem;display:flex;overflow-y:auto}.voice-assistant-hint{color:var(--text-muted);margin:0;font-size:.9rem}.voice-assistant-msg{border-radius:8px;align-items:flex-start;gap:.5rem;padding:.5rem .75rem;font-size:.9rem;display:flex}.voice-assistant-msg-user{background:#1d9bf026;align-self:flex-end}.voice-assistant-msg-assistant{background:var(--surface-hover);align-self:flex-start}.voice-assistant-msg span{flex:1}.voice-assistant-btn-listen{cursor:pointer;opacity:.8;background:0 0;border:none;padding:.2rem .4rem;font-size:.9rem}.voice-assistant-btn-listen:hover{opacity:1}.voice-assistant-input{border-top:1px solid #38444d;gap:.5rem;padding:.75rem;display:flex}.voice-assistant-input input{background:var(--bg);color:var(--text);border:1px solid #38444d;border-radius:8px;flex:1;padding:.5rem .75rem;font-size:.9rem}.voice-assistant-mic{background:var(--surface-hover);color:var(--text);cursor:pointer;border:1px solid #38444d;border-radius:8px;padding:.5rem .75rem}.voice-assistant-mic.listening{border-color:var(--error);background:#f5222e33}.voice-assistant-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem;font-weight:600}.voice-assistant-send:disabled{opacity:.6;cursor:not-allowed}.a11y-toggle{background:var(--surface);border-radius:var(--radius);border:1px solid #38444d;gap:.35rem;padding:.35rem;display:flex;box-shadow:0 4px 16px #0000004d}.a11y-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #38444d;border-radius:8px;align-items:center;gap:.35rem;padding:.5rem .75rem;font-size:.9rem;transition:all .2s;display:flex}.a11y-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--accent)}.a11y-btn.active{border-color:var(--accent);color:var(--accent);background:#1d9bf033}.a11y-btn-label{font-size:.85rem}@media (width<=480px){.a11y-btn-label{display:none}}.speakable{align-items:center;gap:.35rem;display:inline-flex}.speakable-btn{cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.9rem}.speakable-btn:hover{opacity:1;background:var(--surface-hover)}html.a11y-simplified{font-size:1.2em}html.a11y-simplified body{color:#f0f2f5}html.a11y-simplified .text-muted,html.a11y-simplified .task-meta,html.a11y-simplified .stat-label{color:#b8c5d0}html.a11y-simplified .task-list li,html.a11y-simplified .settings-list li,html.a11y-simplified .task-list-manage li{padding:1.25rem}html.a11y-simplified .btn-complete,html.a11y-simplified .btn-undo{min-height:48px;font-size:1.05rem}@media (width<=768px){.app-layout nav{flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem}.app-layout nav a{font-size:.9rem}.app-layout .nav-user{font-size:.85rem}.app-layout .btn-logout{margin-left:auto}.app-layout main{max-width:100%;padding:1rem}.checklist-page h1,.dashboard-page h1,.task-manage-page h1,.settings-page h1{font-size:1.25rem}.filters{flex-direction:column;gap:.75rem}.filters label,.filters input,.filters select{width:100%}.stats-row{flex-direction:column;align-items:stretch}.stats{flex-direction:column}.export-buttons{flex-wrap:wrap}.export-buttons button{flex:1;min-width:120px}.table-wrap{-webkit-overflow-scrolling:touch;border-radius:0;margin:0 -1rem}th,td{padding:.5rem .75rem;font-size:.9rem}.task-manage-page,.settings-page{max-width:100%}.task-form,.settings-section{padding:1rem}.form-row-2{grid-template-columns:1fr}.form-row-check{flex-direction:column;gap:.75rem}.task-list-manage li{flex-direction:column;align-items:stretch;gap:.75rem}.task-list-manage .task-actions{justify-content:flex-start}.settings-tabs{flex-wrap:wrap}.settings-tabs button{flex:1;min-width:90px}.shift-form{flex-direction:column}.shift-form input{width:100%}.user-form{flex-direction:column}.user-form input,.user-form select{width:100%}.settings-list li{flex-direction:column;align-items:stretch;gap:.5rem}.settings-list li>div{flex-wrap:wrap;gap:.5rem;display:flex}.task-list li{padding:1rem}.task-done{flex-direction:column;align-items:flex-start}.login-card{padding:1.5rem}}@media (width<=480px){.app-layout nav{padding:.5rem .75rem}.app-layout main{padding:.75rem}th,td{padding:.4rem .5rem;font-size:.85rem}.stat-card .stat-value{font-size:1.5rem}.task-list-manage .task-meta{font-size:.8rem}.btn-complete,.settings-tabs button,.shift-form button,.user-form button{min-height:44px}}
