body{-webkit-font-smoothing:antialiased;margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif}#root{min-height:100vh}.toast-container{z-index:1100;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.toast{border-radius:8px;max-width:90vw;padding:.75rem 1.25rem;font-size:.9rem;animation:.3s toastIn;box-shadow:0 4px 12px #0006}.toast-error{background:var(--error);color:#fff}.toast-success{background:var(--success);color:#fff}.toast-info{background:var(--surface);color:var(--text);border:1px solid #38444d}@keyframes toastIn{0%{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.toast-leaving{animation:.28s forwards toastOut}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(.35rem)}}.upload-progress-panel{z-index:1050;filter:drop-shadow(8px 0 24px #00000073);pointer-events:none;width:min(18.5rem,85vw);animation:.45s cubic-bezier(.22,1,.36,1) forwards uploadPanelIn;position:fixed;top:50%;left:0;transform:translateY(-50%)translate(0)}.upload-progress-panel--exit{animation:.4s cubic-bezier(.55,.06,.68,.19) forwards uploadPanelOut}.upload-progress-panel__inner{background:linear-gradient(135deg,#1e2834f7 0%,#121820fa 100%);border:1px solid #ffffff14;border-left:none;border-radius:0 14px 14px 0;margin-left:0;padding:1.15rem 1.15rem 1.15rem 1.35rem;position:relative;overflow:hidden}.upload-progress-panel__accent{background:linear-gradient(180deg, var(--accent,#1d9bf0) 0%, #7c3aed 100%);border-radius:0 2px 2px 0;width:4px;position:absolute;top:0;bottom:0;left:0}.upload-progress-panel__eyebrow{letter-spacing:.06em;text-transform:uppercase;color:#ffffff73;margin:0 0 .35rem;font-size:.68rem;font-weight:600}.upload-progress-panel__title{color:var(--text,#e7e9ea);margin:0 0 .5rem;font-size:1rem;font-weight:700;line-height:1.25}.upload-progress-panel__file{color:#ffffff8c;white-space:nowrap;text-overflow:ellipsis;margin:0 0 .85rem;font-size:.78rem;overflow:hidden}.upload-progress-track{background:#ffffff14;border-radius:999px;height:6px;overflow:hidden}.upload-progress-fill{background:linear-gradient(90deg, var(--accent,#1d9bf0), #a78bfa);border-radius:999px;height:100%;transition:width .15s ease-out}.upload-progress-panel__percent{color:#ffffffbf;margin:.55rem 0 0;font-size:.85rem;font-weight:600}@keyframes uploadPanelIn{0%{opacity:0;transform:translateY(-50%)translate(-110%)}to{opacity:1;transform:translateY(-50%)translate(0)}}@keyframes uploadPanelOut{0%{opacity:1;transform:translateY(-50%)translate(0)}to{opacity:0;transform:translateY(-50%)translate(-110%)}}:root{--bg:#070b14;--surface:#111827d1;--surface-hover:#233046e6;--text:#f8fafc;--text-muted:#a6b3c5;--accent:#39d0ff;--accent-hover:#19b7eb;--success:#00ba7c;--warning:#ff7a00;--error:#f4212e;--radius:12px}*{box-sizing:border-box}body{background:radial-gradient(circle at top left, #39d0ff2e, transparent 32rem), radial-gradient(circle at top right, #7c3aed2e, transparent 28rem), 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}.glass-card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(145deg,#ffffff1f,#ffffff0b);border:1px solid #ffffff24;border-radius:24px;box-shadow:0 24px 80px #00000052}.glass-card--soft{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.glass-card--strong{-webkit-backdrop-filter:blur(26px);backdrop-filter:blur(26px)}.brand{color:var(--text);letter-spacing:-.04em;font-weight:800;text-decoration:none}.eyebrow{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin:0 0 .75rem;font-size:.78rem;font-weight:800}.btn-primary,.btn-secondary,.stack-form button,.plan-card button{border-radius:999px;justify-content:center;align-items:center;min-height:44px;padding:.75rem 1rem;font-weight:700;text-decoration:none;transition:transform .2s,border-color .2s,background .2s;display:inline-flex}.btn-primary,.stack-form button,.plan-card button{background:linear-gradient(135deg, var(--accent), #7c3aed);color:#fff;border:0}.btn-secondary{color:var(--text);background:#ffffff14;border:1px solid #ffffff26}.btn-primary:hover,.btn-secondary:hover,.stack-form button:hover,.plan-card button:hover{transform:translateY(-1px)}.public-site{min-height:100vh}.public-nav{z-index:20;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#070b14b8;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:1rem;padding:1rem clamp(1rem,4vw,4rem);display:flex;position:sticky;top:0}.public-nav nav{flex-wrap:wrap;align-items:center;gap:.85rem;display:flex}.public-nav a{color:var(--text-muted);text-decoration:none}.public-nav .nav-cta{color:var(--text);border:1px solid #ffffff2e;border-radius:999px;padding:.55rem .8rem}.public-main{width:min(1120px,100% - 2rem);margin:0 auto}.hero-section{place-items:center;min-height:68vh;padding:5rem 0 3rem;display:grid}.hero-card{text-align:center;padding:clamp(2rem,6vw,5rem)}.hero-card h1{letter-spacing:-.07em;margin:0;font-size:clamp(2.4rem,8vw,5.5rem);line-height:.95}.hero-card p{max-width:720px;color:var(--text-muted);margin:1.25rem auto 0;font-size:clamp(1rem,2vw,1.25rem)}.hero-actions,.plans-grid,.feature-grid,.admin-grid,.admin-columns{gap:1rem;display:grid}.hero-actions{grid-template-columns:repeat(2,minmax(0,auto));justify-content:center;margin-top:2rem}.feature-grid,.plans-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));margin:2rem 0}.feature-card,.plan-card,.admin-list{padding:1.5rem}.feature-card p,.plan-card p,.public-footer p{color:var(--text-muted)}.plans-section,.public-footer{padding:3rem 0}.section-heading{max-width:620px}.section-heading h2{margin:0;font-size:clamp(1.8rem,4vw,3rem)}.plan-card.highlighted{border-color:#39d0ff80}.plan-card strong,.admin-grid strong{margin:.5rem 0;font-size:2rem;display:block}.auth-page{place-items:center;min-height:100vh;padding:1rem;display:grid}.auth-card{width:min(520px,100%);padding:2rem}.auth-brand{margin-bottom:1rem;display:inline-block}.stack-form{gap:.85rem;display:grid}.stack-form input,.stack-form select,.stack-form textarea{width:100%;color:var(--text);background:#070b14c7;border:1px solid #ffffff1f;border-radius:14px;padding:.75rem .9rem}.admin-page,.cms-admin-page,.billing-page{width:min(1120px,100%)}.admin-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.admin-grid .glass-card{padding:1.25rem}.admin-columns{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:1rem}.admin-list p{color:var(--text-muted)}.list-button{width:100%;color:var(--text);text-align:left;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:12px;margin:.25rem 0;padding:.75rem}.success-text{color:var(--success)}.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:row;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.task-header .task-header-text{flex-direction:column;flex:1;gap:.35rem;min-width:0;display:flex}.task-header .btn-complete-inline{flex-shrink:0}.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-btn-row{margin-top:.5rem}.btn-add-observation-inline{background:var(--surface-hover);color:var(--text-muted);cursor:pointer;white-space:nowrap;border:1px dashed #38444d;border-radius:8px;padding:.5rem 1rem;font-size:.9rem}.btn-add-observation-inline:hover{border-color:var(--accent);color:var(--accent)}.btn-observation-collapse{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #38444d;border-radius:8px;flex-shrink:0;padding:.5rem .65rem}.btn-observation-collapse:hover{color:var(--error);border-color:var(--error)}.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,.photo-video-btn{white-space:nowrap;min-width:auto;padding:.5rem .75rem!important}.photo-video-btn{border-color:#a78bfa73!important}.photo-clear-btn{font-size:.8rem;padding:.35rem .6rem!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)}.media-preview{color:var(--text-muted);flex-wrap:wrap;gap:.35rem;margin-top:.5rem;font-size:.8rem;display:flex}.media-preview-item{background:var(--surface-hover);border-radius:6px;align-items:center;gap:.25rem;padding:.2rem .4rem;display:inline-flex}.media-remove{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 .2rem;font-size:1.1rem;line-height:1}.media-remove:hover{color:var(--error)}.btn-complete-wrap{flex:1;justify-content:flex-end;min-width:0;display:flex}.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}@media (width<=480px){.task-header{flex-wrap:wrap;gap:.5rem}.task-buttons-row{flex-direction:column;align-items:stretch}.photo-upload .photo-buttons{flex-wrap:wrap}.photo-gallery-btn{white-space:normal}}.task-done{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.task-done span{color:var(--success);font-size:.9rem}.proof-img,.proof-media{object-fit:cover;border-radius:8px;max-width:120px;max-height:120px}.proof-media{max-width:200px;max-height:150px}.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 table th:nth-child(3),.table-wrap table td:nth-child(3){min-width:140px}.table-wrap table th:nth-child(5),.table-wrap table td:nth-child(5){min-width:150px}.table-wrap table th:nth-child(6),.table-wrap table td:nth-child(6){min-width:120px}.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}.btn-view-media,.btn-view-observation{color:var(--accent);cursor:pointer;background:0 0;border:1px solid #38444d;border-radius:6px;padding:.35rem .65rem;font-size:.85rem}.btn-view-media:hover,.btn-view-observation:hover{border-color:var(--accent);background:#1d9bf01a}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border-radius:var(--radius);flex-direction:column;max-width:90vw;max-height:90vh;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid #38444d;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-header h3{margin:0;font-size:1.1rem}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{padding:1.25rem;overflow-y:auto}.modal-body.media-gallery{flex-wrap:wrap;gap:1rem;display:flex}.modal-media-item{object-fit:cover;border-radius:8px;max-width:280px;max-height:280px}.modal-media-item[src]{display:block}.modal-body .observation-text{white-space:pre-wrap;color:var(--text);margin:0}.modal-body .form-row{margin-bottom:1rem}.modal-body .form-row:last-of-type{margin-bottom:1.25rem}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.modal-actions button:not(.btn-primary){border-radius:var(--radius);color:var(--text);cursor:pointer;background:0 0;border:1px solid #38444d;padding:.5rem 1rem;font-size:.9rem}.modal-actions button:not(.btn-primary):hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.modal-actions .btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem}.modal-actions .btn-primary:hover:not(:disabled){opacity:.9}.modal-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.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);border-radius:var(--radius);color:var(--text);cursor:pointer;border:1px solid #38444d;padding:.5rem 1rem;font-size:.9rem}.settings-tabs button:hover:not(.active){background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.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;border-radius:var(--radius);cursor:pointer;border:none;padding:.5rem 1rem;font-size:.9rem}.inline-form button:hover,.shift-form button:hover,.user-form button:hover{filter:brightness(1.1)}.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}.settings-list li>div{gap:.5rem;display:flex}.settings-list button{color:var(--text);cursor:pointer;background:0 0;border:1px solid #38444d;border-radius:8px;padding:.35rem .75rem;font-size:.85rem}.settings-list button:hover{border-color:var(--accent);color:var(--accent);background:#1d9bf01a}.settings-list .btn-danger{color:var(--error);border-color:var(--error)}.settings-list .btn-danger:hover{color:var(--error);border-color:var(--error);background:#f4212e1a}.settings-list .btn-success{color:var(--success,#22c55e);border-color:var(--success,#22c55e)}.settings-list .btn-success:hover{color:var(--success,#22c55e);border-color:var(--success,#22c55e);background:#00ba7c1a}.btn-sm{padding:.35rem .75rem;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}}
