*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f172a;--surface:#1e293b;--surface2:#263248;--border:#334155;--text:#f1f5f9;--text2:#94a3b8;--text3:#64748b;--accent:#3b82f6;--accent-dark:#1d4ed8;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b}[data-theme=light]{--bg:#f0f4f8;--surface:#fff;--surface2:#f1f5f9;--border:#e2e8f0;--text:#0f172a;--text2:#475569;--text3:#94a3b8;--accent:#2563eb;--accent-dark:#1d4ed8;--success:#16a34a;--danger:#dc2626;--warning:#d97706}html{transition:background-color .25s}[data-theme=light] .company-logo{filter:brightness(0)}html,body,#root{-webkit-font-smoothing:antialiased;background:var(--bg);height:100%;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;overflow-x:hidden}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin;display:inline-block}.app-layout{background:var(--bg);flex-direction:column;min-height:100dvh;display:flex}.app-main{flex:1;padding-bottom:76px;overflow:hidden auto}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);height:64px;padding:0 8px;padding-bottom:env(safe-area-inset-bottom);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:visible}.theme-toggle-btn{background:var(--surface);border:1px solid var(--border);width:38px;height:38px;color:var(--text2);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s,border-color .2s,color .2s;display:flex;position:absolute;top:-20px;right:12px;box-shadow:0 2px 10px #0003}.theme-toggle-btn:hover{color:var(--text)}.theme-toggle-btn svg{width:17px;height:17px}.nav-item{color:var(--text3);border-radius:12px;flex-direction:column;align-items:center;gap:3px;min-width:56px;padding:6px 12px;font-size:10px;font-weight:500;text-decoration:none;transition:color .2s,background .2s;display:flex}.nav-item svg{width:22px;height:22px}.nav-item.active,.nav-item.active svg{color:var(--accent)}.nav-item-center{background:var(--accent);border-radius:16px;padding:8px 14px;color:#fff!important}.nav-item-center svg{color:#fff!important}.page{width:100%;max-width:480px;margin:0 auto;padding:0 16px 24px;overflow-x:hidden}.page-header{align-items:center;gap:12px;padding:16px 0 12px;display:flex}.page-title{color:var(--text);flex:1;font-size:20px;font-weight:700}.back-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--text2);border-radius:10px;flex-shrink:0;align-items:center;padding:8px;transition:color .2s;display:flex}.back-btn:hover{color:var(--text)}.back-btn svg{width:18px;height:18px}.btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:6px;padding:11px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-danger{color:var(--danger);background:#ef444426;border:1px solid #ef44444d}.btn-success{color:var(--success);background:#22c55e26;border:1px solid #22c55e4d}.btn-sm{border-radius:10px;padding:7px 14px;font-size:13px}.btn-icon{border-radius:10px;padding:8px}.btn-full{width:100%}.form-group{flex-direction:column;gap:6px;min-width:0;display:flex}.form-label{color:var(--text2);font-size:13px;font-weight:600}.form-input,.form-select,.form-textarea{background:var(--surface);border:1.5px solid var(--border);color:var(--text);box-sizing:border-box;border-radius:12px;outline:none;width:100%;min-width:0;padding:11px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-select{appearance:none;cursor:pointer}.form-textarea{resize:vertical;min-height:80px}.form-input::placeholder,.form-textarea::placeholder{color:var(--text3)}.form-input[readonly]{color:var(--text3);cursor:default}.field-label-row{justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.dictation-btn{border:1px solid var(--border);background:var(--surface);min-height:32px;color:var(--text2);cursor:pointer;border-radius:10px;flex-shrink:0;align-items:center;gap:5px;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:700;transition:background .2s,border-color .2s,color .2s;display:inline-flex}.dictation-btn svg{width:14px;height:14px}.dictation-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.dictation-btn:disabled{opacity:.45;cursor:not-allowed}.dictation-btn-active{color:var(--danger);background:#ef444424;border-color:#ef444459}.dictation-hint{color:var(--text3);text-align:right;overflow-wrap:anywhere;font-size:11px;font-weight:600}input[type=time],input[type=date]{padding-left:6px;padding-right:6px;font-size:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px}.section-title{color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:13px;font-weight:700}.list-item{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:inherit;border-radius:14px;align-items:center;gap:12px;min-width:0;max-width:100%;padding:14px 16px;text-decoration:none;transition:border-color .2s,background .2s;display:flex;overflow:hidden}.list-item:hover{border-color:var(--accent);background:var(--surface2)}.list-item-icon{width:40px;height:40px;color:var(--accent);background:#3b82f61f;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.list-item-icon svg{width:20px;height:20px}.list-item-body{flex:1;min-width:0}.list-item-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600;overflow:hidden}.list-item-sub{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:13px;overflow:hidden}.list-item-arrow{color:var(--text3);flex-shrink:0}.list-item-arrow svg{width:16px;height:16px}.badge{border-radius:99px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-active{color:var(--success);background:#22c55e26}.badge-inactive{color:var(--text3);background:#94a3b826}.badge-admin{color:var(--accent);background:#3b82f626}.badge-inspector{color:var(--warning);background:#f59e0b26}.tags-container{flex-wrap:wrap;gap:8px;display:flex}.tag{border:1.5px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:99px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.tag:hover{border-color:var(--accent);color:var(--accent)}.tag.tag-selected{border-color:var(--accent);color:var(--accent);background:#3b82f626;font-weight:600}.tag-danger.tag-selected{border-color:var(--danger);color:var(--danger);background:#ef444426}.search-wrap{position:relative}.search-wrap svg{width:17px;height:17px;color:var(--text3);pointer-events:none;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.search-input{background:var(--surface);border:1.5px solid var(--border);color:var(--text);border-radius:12px;outline:none;width:100%;padding:11px 14px 11px 40px;font-family:inherit;font-size:15px;transition:border-color .2s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text3)}.stats-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:6px;min-width:0;padding:16px;display:flex;overflow:hidden}.stat-value{color:var(--text);font-size:26px;font-weight:800}.stat-label{color:var(--text2);overflow-wrap:anywhere;font-size:12px;font-weight:500}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;min-width:0;max-width:100%;padding:18px 16px;overflow:hidden}.vertical-bar-chart{align-items:flex-end;gap:6px;min-width:0;height:110px;padding:0 4px;display:flex}.vertical-bar-item{flex-direction:column;flex:1 1 0;align-items:center;gap:4px;min-width:0;display:flex}.vertical-bar-count{min-height:14px;color:var(--text3);font-size:10px}.vertical-bar-fill{background:linear-gradient(180deg, #60a5fa, var(--accent));border-radius:4px 4px 0 0;width:100%;transition:height .5s}.vertical-bar-baseline{background:var(--border);width:100%;height:1px}.vertical-bar-label{max-width:100%;color:var(--text3);text-transform:capitalize;text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.horizontal-bar-chart{flex-direction:column;gap:12px;min-width:0;display:flex}.horizontal-bar-item{min-width:0}.horizontal-bar-row{justify-content:space-between;align-items:center;gap:10px;min-width:0;margin-bottom:5px;display:flex}.horizontal-bar-label{min-width:0;color:var(--text2);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.horizontal-bar-count{color:var(--text3);flex-shrink:0;font-size:12px;font-weight:600}.horizontal-bar-track{background:var(--border);border-radius:3px;width:100%;height:6px;overflow:hidden}.actions-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;display:grid}.action-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:inherit;border-radius:16px;flex-direction:column;align-items:flex-start;gap:10px;min-width:0;padding:18px 14px;text-decoration:none;transition:border-color .2s,background .2s;display:flex;overflow:hidden}.action-card:hover{border-color:var(--accent);background:var(--surface2)}.action-icon{border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.action-icon svg{width:22px;height:22px}.action-card-title{color:var(--text);overflow-wrap:anywhere;font-size:14px;font-weight:600}.action-card-sub{color:var(--text2);overflow-wrap:anywhere;font-size:12px}.dynamic-row{background:var(--surface2);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:14px;display:flex}.dynamic-row-header{justify-content:space-between;align-items:center;display:flex}.row-num{color:var(--text3);font-size:12px;font-weight:700}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-state svg{width:48px;height:48px;color:var(--text3)}.empty-state-title{color:var(--text2);font-size:16px;font-weight:600}.empty-state-sub{color:var(--text3);font-size:14px}.msg{border-radius:12px;padding:12px 16px;font-size:14px;font-weight:500}.msg-error{color:var(--danger);background:#ef44441f;border:1px solid #ef444440}.msg-success{color:var(--success);background:#22c55e1f;border:1px solid #22c55e40}.photo-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.photo-thumb{aspect-ratio:1;background:var(--surface2);border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%}.photo-thumb-del{cursor:pointer;color:#fff;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;top:4px;right:4px}.photo-thumb-del svg{width:12px;height:12px}.photo-add{aspect-ratio:1;border:2px dashed var(--border);cursor:pointer;color:var(--text3);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:12px;transition:border-color .2s,color .2s;display:flex}.photo-add:hover{border-color:var(--accent);color:var(--accent)}.photo-add svg{width:22px;height:22px}.report-list{flex-direction:column;gap:10px;display:flex}.report-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:inherit;border-radius:14px;flex-direction:column;gap:8px;padding:14px 16px;text-decoration:none;transition:border-color .2s;display:flex}.report-card:hover{border-color:var(--accent)}.report-card-header{justify-content:space-between;align-items:center;display:flex}.report-card-title{color:var(--text);font-size:15px;font-weight:600}.report-card-date{color:var(--text3);font-size:13px}.report-card-meta{flex-wrap:wrap;gap:6px;display:flex}.report-meta-chip{color:var(--text2);background:var(--surface2);border-radius:6px;padding:3px 8px;font-size:12px}.filters-panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:12px;margin-bottom:16px;padding:16px;display:flex}.filters-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.detail-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px}.detail-row{border-bottom:1px solid var(--border);flex-direction:column;gap:2px;padding:10px 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-key{color:var(--text3);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.detail-val{color:var(--text);margin-top:2px;font-size:15px}*{box-sizing:border-box;margin:0;padding:0}.mobile-shell{background:#0f172a;justify-content:center;align-items:center;min-height:100dvh;padding:16px;display:flex}.login-screen{flex-direction:column;justify-content:center;align-items:center;gap:28px;width:100%;max-width:390px;min-height:100dvh;padding:40px 20px 32px;display:flex}.login-header{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.logo-circle{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border-radius:22px;justify-content:center;align-items:center;width:72px;height:72px;display:flex;box-shadow:0 8px 24px #3b82f666}.logo-circle svg{color:#fff;width:36px;height:36px}.app-title{color:#f1f5f9;letter-spacing:-.5px;font-size:24px;font-weight:700}.app-subtitle{color:#64748b;max-width:220px;font-size:13px;line-height:1.4}.login-card{background:#1e293b;border:1px solid #334155;border-radius:24px;width:100%;padding:28px 24px;box-shadow:0 20px 60px #0006}.login-mode-title{color:#f1f5f9;text-align:center;margin:0 0 24px;font-size:18px;font-weight:700}.login-form{flex-direction:column;gap:16px;display:flex}.field-group{flex-direction:column;gap:6px;display:flex}.field-label{color:#94a3b8;padding-left:2px;font-size:13px;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{pointer-events:none;align-items:center;display:flex;position:absolute;left:14px}.input-icon svg{color:#475569;width:18px;height:18px}.text-input{color:#f1f5f9;-webkit-appearance:none;background:#0f172a;border:1.5px solid #334155;border-radius:12px;outline:none;width:100%;padding:14px 44px;font-size:15px;transition:border-color .2s,box-shadow .2s}.text-input::placeholder{color:#334155}.text-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.eye-toggle{cursor:pointer;color:#475569;background:0 0;border:none;align-items:center;padding:0;transition:color .2s;display:flex;position:absolute;right:14px}.eye-toggle:hover{color:#94a3b8}.eye-toggle svg{width:18px;height:18px}.forgot-link{color:#3b82f6;cursor:pointer;text-align:right;background:0 0;border:none;align-self:flex-end;padding:0;font-size:13px;font-weight:500;transition:color .2s}.forgot-link:hover{color:#60a5fa}.alert{border-radius:10px;padding:12px 14px;font-size:13px;line-height:1.4}.alert-error{color:#fca5a5;background:#ef44441f;border:1px solid #ef44444d}.alert-success{color:#86efac;background:#22c55e1f;border:1px solid #22c55e4d}.btn-primary{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border:none;border-radius:14px;justify-content:center;align-items:center;width:100%;margin-top:4px;padding:15px;font-size:16px;font-weight:700;transition:opacity .2s,transform .1s;display:flex;box-shadow:0 4px 16px #3b82f666}.btn-primary:active{opacity:.9;transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}.footer-text{color:#334155;font-size:12px}@media (width<=430px){.mobile-shell{background:#0f172a;align-items:flex-start;padding:0}.login-screen{justify-content:center;min-height:100dvh;padding:60px 24px 32px}}[data-theme=light] .mobile-shell{background:var(--bg)}[data-theme=light] .login-card{background:var(--surface);border-color:var(--border)}[data-theme=light] .login-card-header{background:var(--surface2)}[data-theme=light] .app-title{color:var(--text)}[data-theme=light] .app-subtitle{color:var(--text3)}[data-theme=light] .login-mode-title{color:var(--text)}[data-theme=light] .field-label{color:var(--text2)}[data-theme=light] .input-icon svg{color:var(--text3)}[data-theme=light] .text-input{background:var(--surface2);border-color:var(--border);color:var(--text)}[data-theme=light] .text-input::placeholder{color:var(--text3)}[data-theme=light] .text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb26}[data-theme=light] .eye-toggle{color:var(--text2)}[data-theme=light] .eye-toggle:hover{color:var(--text)}[data-theme=light] .forgot-link{color:var(--accent)}[data-theme=light] .forgot-link:hover{color:var(--accent-dark)}[data-theme=light] .footer-text{color:var(--text3)}[data-theme=light] .alert-error{color:#991b1b}[data-theme=light] .alert-success{color:#166534}@media (width<=430px){[data-theme=light] .mobile-shell{background:var(--bg)}}@keyframes splash-fade-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes splash-fade-out{0%{opacity:1}to{opacity:0}}@keyframes logo-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.splash-screen{z-index:9999;background:var(--bg);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash-visible{pointer-events:all;animation:.4s forwards splash-fade-in}.splash-hidden{pointer-events:none;animation:.4s forwards splash-fade-out}.splash-content{flex-direction:column;align-items:center;gap:20px;display:flex}.splash-logo{object-fit:contain;width:200px;height:auto;animation:2s ease-in-out infinite logo-pulse}.splash-title{color:var(--text2);letter-spacing:.03em;font-size:1.15rem;font-weight:600}.splash-spinner{border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin;display:inline-block}@keyframes slide-up{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.offline-banner{z-index:500;white-space:nowrap;border-radius:100px;align-items:center;gap:8px;max-width:calc(100vw - 32px);padding:9px 16px;font-size:13px;font-weight:500;animation:.3s slide-up;display:flex;position:fixed;bottom:76px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000073}.ob-offline{color:#fef3c7;background:#292524;border:1px solid #57534e}[data-theme=light] .ob-offline{color:#92400e;background:#fef3c7;border:1px solid #fcd34d}.ob-online{background:var(--surface);color:var(--text);border:1px solid var(--border)}.ob-badge{background:var(--warning);color:#000;border-radius:100px;flex-shrink:0;padding:1px 8px;font-size:11px;font-weight:700}.ob-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}
