:root{--color-primary:#008ce3;--color-primary-hover:#0074c2;--color-accent:#fff700;--color-white:#fff;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--color-success:#22c55e;--color-danger:#ef4444;--color-warning:#f59e0b;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--badge-success-bg:#dcfce7;--badge-success-text:#166534;--badge-danger-bg:#fee2e2;--badge-danger-text:#991b1b;--badge-warning-bg:#fef3c7;--badge-warning-text:#92400e;--badge-info-bg:#dbeafe;--badge-info-text:#1e40af;--banner-warn-bg:#fef9c3;--banner-warn-text:#78350f;--banner-info-bg:#dbeafe;--banner-info-text:#1e3a8a;--dlg-bg:#fff;--nav-shadow:0 -2px 10px #0000000f;--header-badge-border:#fff;--input-focus-shadow:#008ce326}[data-theme=dark]{--color-primary:#3b9fe8;--color-primary-hover:#5bb3f0;--color-accent:#fff700;--color-white:#1a1a2e;--color-gray-50:#0f0f1a;--color-gray-100:#1a1a2e;--color-gray-200:#2a2a3e;--color-gray-300:#3a3a50;--color-gray-400:#6b7280;--color-gray-500:#9ca3af;--color-gray-600:#b0b8c4;--color-gray-700:#d1d5db;--color-gray-800:#e5e7eb;--color-gray-900:#f3f4f6;--color-success:#4ade80;--color-danger:#f87171;--color-warning:#fbbf24;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--badge-success-bg:#14532d;--badge-success-text:#86efac;--badge-danger-bg:#7f1d1d;--badge-danger-text:#fca5a5;--badge-warning-bg:#78350f;--badge-warning-text:#fde68a;--badge-info-bg:#1e3a5f;--badge-info-text:#93c5fd;--banner-warn-bg:#422006;--banner-warn-text:#fde68a;--banner-info-bg:#1e3a5f;--banner-info-text:#93c5fd;--dlg-bg:#1a1a2e;--nav-shadow:0 -2px 10px #0000004d;--header-badge-border:#1a1a2e;--input-focus-shadow:#3b9fe840}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;font-size:16px}body{background-color:var(--color-gray-50);color:var(--color-gray-800);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:1rem}ul,ol{list-style:none}img{max-width:100%;display:block}.container{width:100%;max-width:480px;margin:0 auto;padding:0 16px}.btn{border-radius:var(--radius-sm);touch-action:manipulation;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:active{transform:scale(.97)}.btn-secondary{background:var(--color-gray-200);color:var(--color-gray-700)}.btn-secondary:hover{background:var(--color-gray-300)}.btn-accent{background:var(--color-accent);color:var(--color-gray-900)}.btn-danger{background:var(--color-danger);color:var(--color-white)}.btn-full{width:100%}.btn-lg{padding:14px 28px;font-size:1.05rem}.card{background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200);padding:16px}.badge{border-radius:999px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background:var(--badge-success-bg);color:var(--badge-success-text)}.badge-danger{background:var(--badge-danger-bg);color:var(--badge-danger-text)}.badge-warning{background:var(--badge-warning-bg);color:var(--badge-warning-text)}.badge-info{background:var(--badge-info-bg);color:var(--badge-info-text)}.form-group{margin-bottom:16px}.form-label{color:var(--color-gray-600);margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.form-input{border:1.5px solid var(--color-gray-300);border-radius:var(--radius-sm);background:var(--color-white);width:100%;color:var(--color-gray-800);padding:12px 14px;font-size:1rem;transition:border-color .2s}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--input-focus-shadow);outline:none}.page{flex:1;padding-bottom:80px}.page-header{padding:20px 0 12px}.page-title{color:var(--color-gray-900);font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--color-gray-500);margin-top:4px;font-size:.9rem}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}.pull-refresh-indicator{color:var(--color-primary);background:#e0f2fe;justify-content:center;align-items:center;gap:8px;padding:12px 0;font-size:.82rem;font-weight:600;animation:.3s pullRefreshSlide;display:flex}@keyframes pullRefreshSlide{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@supports (padding-bottom:env(safe-area-inset-bottom)){body{padding-bottom:env(safe-area-inset-bottom)}}.dlg-overlay{z-index:9999;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0000008c;justify-content:center;align-items:center;padding:24px;animation:.15s dlg-fade-in;display:flex;position:fixed;inset:0}@keyframes dlg-fade-in{0%{opacity:0}to{opacity:1}}.dlg-box{background:var(--dlg-bg);text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:340px;padding:28px 24px 22px;animation:.2s cubic-bezier(.16,1,.3,1) dlg-pop-in;display:flex;box-shadow:0 20px 60px #00000040}@keyframes dlg-pop-in{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.dlg-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.dlg-icon--error,.dlg-icon--danger{background:var(--badge-danger-bg);color:var(--color-danger)}.dlg-icon--info{background:var(--badge-info-bg);color:var(--color-primary,#008ce3)}.dlg-icon--warning{background:var(--badge-warning-bg);color:#d97706}.dlg-message{color:var(--color-gray-700,#374151);margin:0;font-size:.95rem;font-weight:500;line-height:1.5}.dlg-actions{gap:10px;width:100%;margin-top:4px;display:flex}.dlg-btn{cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;padding:11px 18px;font-family:inherit;font-size:.88rem;font-weight:600;transition:opacity .15s,transform .1s;display:flex}.dlg-btn:active{transform:scale(.97)}.dlg-btn--ok{background:var(--color-primary,#008ce3);color:#fff;flex:none;width:100%}.dlg-btn--ok:hover{opacity:.88}.dlg-btn--cancel{background:var(--color-gray-100,#f3f4f6);color:var(--color-gray-700,#374151)}.dlg-btn--cancel:hover{background:var(--color-gray-200,#e5e7eb)}.dlg-btn--confirm{background:var(--color-danger);color:#fff}.dlg-btn--confirm:hover{opacity:.88}.header{background:var(--color-white);border-bottom:1px solid var(--color-gray-200);z-index:100;box-shadow:var(--shadow-sm);padding-top:env(safe-area-inset-top);transition:background .25s,border-color .25s,box-shadow .25s;position:sticky;top:0}.header--transparent{box-shadow:none!important;background:0 0!important;border-bottom-color:#0000!important}.header-inner{justify-content:space-between;align-items:center;max-width:480px;margin:0 auto;padding:10px 16px;display:flex;position:relative}.header-brand{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:0;display:flex}.header-logo{background:var(--color-primary);border-radius:var(--radius-sm);width:38px;height:38px;color:var(--color-white);flex-shrink:0;justify-content:center;align-items:center;display:flex}.header-title h1{color:var(--color-gray-900);font-size:1.1rem;font-weight:700;line-height:1.2}.header-role{color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;font-size:.68rem;font-weight:600}.header-right{align-items:center;gap:8px;display:flex;position:absolute;right:16px}.header-icon-btn{background:var(--color-gray-100);width:38px;height:38px;color:var(--color-gray-500);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:relative}.header-icon-btn:hover{background:var(--badge-info-bg);color:var(--color-primary)}.header-badge{background:var(--color-danger);color:#fff;border:2px solid var(--header-badge-border);border-radius:99px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.6rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-2px;right:-2px}.header-avatar{border:2.5px solid var(--color-primary);background:var(--color-primary);color:#fff;cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.78rem;font-weight:700;transition:opacity .15s;display:flex}.header-avatar:hover{opacity:.85}.header-logout:hover{background:var(--color-danger);color:var(--color-white)}.header--transparent .header-title h1{color:#fff}.header--transparent .header-role{color:#ffffffbf}.header--transparent .header-logo{background:#fff3;border:1px solid #ffffff4d}.header--transparent .header-icon-btn{color:#fff;background:#ffffff2e}.header--transparent .header-icon-btn:hover{background:#ffffff4d}.header--transparent .header-avatar{background:#fff3;border-color:#ffffff80}.header--transparent .header-badge{border-color:#0000}.bottom-nav{background:var(--color-white);border-top:1px solid var(--color-gray-200);z-index:100;box-shadow:var(--nav-shadow);padding-bottom:env(safe-area-inset-bottom,0);position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{justify-content:space-around;max-width:480px;margin:0 auto;padding:6px 8px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--color-gray-400);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;font-size:.68rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.nav-item.active{color:var(--color-primary)}.nav-item:active{transform:scale(.92)}.nav-item--more{cursor:pointer;background:0 0;border:none;font-family:inherit}.nav-notif-wrap{display:inline-flex;position:relative}.nav-notif-badge{color:#fff;border:1.5px solid var(--color-white);background:#ef4444;border-radius:99px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.6rem;font-weight:800;line-height:1;animation:.2s both badgePop;display:flex;position:absolute;top:-5px;right:-7px}@keyframes badgePop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.more-backdrop{z-index:98;-webkit-backdrop-filter:blur(2px);background:#0000004d;animation:.2s both backdropIn;position:fixed;inset:0}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.more-drawer{z-index:99;background:var(--color-white);border-radius:20px 20px 0 0;padding:8px 20px 100px;animation:.28s cubic-bezier(.16,1,.3,1) both drawerUp;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #0000001f}@keyframes drawerUp{0%{opacity:.6;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.more-drawer-handle{background:var(--color-gray-300);border-radius:99px;width:36px;height:4px;margin:0 auto 20px}.more-drawer-grid{grid-template-columns:repeat(3,1fr);gap:12px;max-width:320px;margin:0 auto;display:grid}.more-item{color:var(--color-gray-700);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:8px;font-size:.75rem;font-weight:600;text-decoration:none;transition:transform .15s;display:flex}.more-item:active{transform:scale(.92)}.more-item.active .more-item-icon{background:var(--color-primary);color:#fff}.more-item.active{color:var(--color-primary)}.more-item-icon{background:var(--color-gray-100);width:56px;height:56px;color:var(--color-gray-600);border-radius:16px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}[data-theme=dark] .bottom-nav{box-shadow:var(--nav-shadow)}[data-theme=dark] .more-drawer{background:var(--color-white);box-shadow:0 -4px 24px #0006}[data-theme=dark] .more-item-icon{color:#e2e8f0;background:#ffffff1a}[data-theme=dark] .more-item{color:#cbd5e1}[data-theme=dark] .more-item.active .more-item-icon{background:var(--color-primary);color:#fff}[data-theme=dark] .more-item.active{color:var(--color-primary)}.login-page{background:linear-gradient(135deg, var(--color-gray-100) 0%, var(--color-gray-50) 100%);justify-content:center;align-items:center;min-height:100dvh;padding:24px 16px;display:flex}.login-container{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:32px}.login-logo{background:var(--color-primary);border-radius:var(--radius-md);width:64px;height:64px;color:var(--color-white);justify-content:center;align-items:center;margin:0 auto 16px;display:flex;box-shadow:0 4px 16px #008ce34d}.login-title{color:var(--color-gray-900);font-size:1.8rem;font-weight:800}.login-subtitle{color:var(--color-gray-500);margin-top:4px;font-size:.95rem}.login-form{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);padding:24px}.login-error{background:var(--badge-danger-bg);color:var(--badge-danger-text);border-radius:var(--radius-sm);text-align:center;margin-bottom:16px;padding:10px 14px;font-size:.85rem;font-weight:500}.password-wrapper{position:relative}.password-wrapper .form-input{padding-right:44px}.password-toggle{color:var(--color-gray-400);background:0 0;padding:4px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.login-demo{text-align:center;margin-top:24px}.demo-title{color:var(--color-gray-400);margin-bottom:8px;font-size:.8rem}.demo-accounts{flex-direction:column;gap:6px;display:flex}.demo-account{color:var(--color-gray-500);font-size:.8rem}.demo-role{margin-right:4px;font-weight:600}.demo-account code{background:var(--color-gray-100);border-radius:4px;padding:2px 6px;font-size:.78rem}.site-icon{border-radius:var(--radius-md);background:var(--si-bg);color:var(--si-color);flex-shrink:0;justify-content:center;align-items:center;transition:transform .15s;display:flex;position:relative}.site-icon:hover{transform:scale(1.05)}[data-theme=dark] .site-icon{background:color-mix(in srgb, var(--si-color) 25%, #0d0d1a);color:color-mix(in srgb, var(--si-color) 90%, #fff)}.dash-page{padding-bottom:90px}.dash-loading{color:var(--color-gray-500);flex-direction:column;justify-content:center;align-items:center;gap:14px;padding-top:80px;font-size:.9rem;display:flex}.dash-hero{color:#fff;background:linear-gradient(135deg,#0077c8 0%,#008ce3 55%,#33a8f5 100%);padding:24px 20px 22px}.dash-hero--worker{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 55%,#0f3460 100%)}.dash-hero-top{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.dash-greeting{color:#ffffffb3;margin:0 0 2px;font-size:.88rem;font-weight:500}.dash-name{color:#fff;letter-spacing:-.3px;margin:0 0 4px;font-size:1.55rem;font-weight:800;line-height:1.1}.dash-date{color:#fff9;text-transform:capitalize;margin:0;font-size:.78rem}.dash-hero-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;background:#ffffff26;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.dash-hero-badge--yellow{color:#1a1a1a;background:#fff700}.dash-hero-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.dash-refresh-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s,transform .2s;display:flex}.dash-refresh-btn:hover{background:#ffffff40}.dash-refresh-btn:active{transform:scale(.92)}.dash-refresh-btn:disabled{cursor:default}.dash-refresh-btn--spinning svg{animation:.8s linear infinite spin360}@keyframes spin360{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dash-att-bar{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff1f;border-radius:14px;align-items:center;gap:12px;padding:12px 16px;display:flex}.dash-att-bar-info{flex-direction:column;flex-shrink:0;min-width:0;display:flex}.dash-att-bar-label{color:#ffffffa6;text-transform:uppercase;letter-spacing:.5px;font-size:.7rem;font-weight:700}.dash-att-bar-value{color:#fff;font-size:1rem;font-weight:800;line-height:1.2}.dash-att-progress-track{background:#fff3;border-radius:99px;flex:1;height:6px;overflow:hidden}.dash-att-progress-fill{background:#fff700;border-radius:99px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.dash-att-pct{color:#fff700;text-align:right;flex-shrink:0;min-width:36px;font-size:.85rem;font-weight:800}.dash-stats{gap:10px;padding:16px 0 4px;display:flex}.dash-stat{background:#fff;border:1px solid #0000000a;border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 10px 12px;display:flex;box-shadow:0 2px 10px #0000000f}.dash-stat-icon{border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.dash-stat-icon--blue{color:#008ce3;background:#eff8ff}.dash-stat-icon--yellow{color:#b8860b;background:#fffbcc}.dash-stat-icon--green{color:#16a34a;background:#f0fdf4}.dash-stat-num{color:var(--color-gray-900);font-size:1.6rem;font-weight:800;line-height:1}.dash-stat-lbl{color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.4px;text-align:center;font-size:.68rem;font-weight:600}.dash-section{margin-top:24px}.dash-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.dash-section-title{color:var(--color-gray-800);font-size:1.05rem;font-weight:800}.dash-see-all{color:var(--color-primary);align-items:center;gap:4px;font-size:.8rem;font-weight:700;text-decoration:none;display:flex}.dash-see-all:hover{text-decoration:underline}.dash-actions{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.dash-action{text-align:center;color:#fff;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:14px 8px 12px;font-size:.75rem;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s;display:flex}.dash-action:active{transform:scale(.96)}.dash-action-icon{background:#fff3;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.dash-action--blue{background:linear-gradient(135deg,#008ce3,#06a)}.dash-action--purple{background:linear-gradient(135deg,#7c3aed,#5b21b6)}.dash-action--teal{background:linear-gradient(135deg,#0d9488,#0f766e)}.dash-sites-list{flex-direction:column;gap:10px;display:flex}.dash-site-card{background:#fff;border:1px solid #0000000a;border-radius:16px;align-items:center;gap:14px;padding:14px 12px 14px 14px;text-decoration:none;transition:transform .15s,box-shadow .15s;display:flex;position:relative;box-shadow:0 2px 10px #0000000f}.dash-site-card:hover{transform:translateY(-1px);box-shadow:0 4px 18px #00000017}.dash-site-card--checked{border-left:3px solid #22c55e}.dash-site-icon{flex-shrink:0}.dash-site-body{flex:1;min-width:0}.dash-site-row{justify-content:space-between;align-items:center;gap:6px;margin-bottom:3px;display:flex}.dash-site-name{color:var(--color-gray-900);white-space:nowrap;text-overflow:ellipsis;font-size:.93rem;font-weight:700;overflow:hidden}.dash-site-pct{color:var(--color-primary);flex-shrink:0;font-size:.8rem;font-weight:800}.dash-site-address{color:var(--color-gray-400);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:4px;margin-bottom:8px;font-size:.75rem;display:flex;overflow:hidden}.dash-site-bar-track{background:#f1f5f9;border-radius:99px;height:4px;margin-bottom:7px;overflow:hidden}.dash-site-bar-fill{background:linear-gradient(90deg,#008ce3,#33a8f5);border-radius:99px;height:100%;transition:width .5s}.dash-site-footer{justify-content:space-between;align-items:center;gap:6px;display:flex}.dash-site-type{color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.4px;font-size:.68rem;font-weight:700}.dash-site-att{color:var(--color-gray-500);align-items:center;gap:4px;font-size:.72rem;font-weight:600;display:flex}.dash-site-arrow{color:var(--color-gray-300);flex-shrink:0}.dash-workers-row{flex-wrap:wrap;gap:10px;display:flex}.dash-worker-chip{flex-direction:column;align-items:center;gap:5px;text-decoration:none;display:flex}.dash-worker-avatar{color:#fff;letter-spacing:-.5px;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:.82rem;font-weight:800;display:flex;box-shadow:0 2px 8px #0000002e}.dash-worker-more{font-size:.75rem;background:var(--color-gray-200)!important;color:var(--color-gray-600)!important}.dash-worker-name{color:var(--color-gray-500);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:50px;font-size:.7rem;font-weight:600;overflow:hidden}.dash-worker-summary{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff1a;border-radius:14px;align-items:center;padding:14px 16px;display:flex}.dash-worker-summary-stat{flex-direction:column;flex:1;align-items:center;gap:3px;display:flex}.dash-worker-summary-num{color:#fff;font-size:1.5rem;font-weight:800;line-height:1}.dash-worker-summary-lbl{color:#fff9;text-transform:uppercase;letter-spacing:.4px;text-align:center;font-size:.67rem;font-weight:700}.dash-worker-summary-divider{background:#fff3;width:1px;height:34px;margin:0 4px}.dash-worker-summary-status{color:#fff;font-size:.82rem;font-weight:800}.status--ok{color:#4ade80}.status--pending{color:#fbbf24}.dash-badge{white-space:nowrap;border-radius:99px;flex-shrink:0;align-items:center;padding:3px 9px;font-size:.72rem;font-weight:700;display:inline-flex}.dash-badge--green{color:#15803d;background:#dcfce7}.dash-badge--orange{color:#c2410c;background:#fff7ed}.dash-empty{text-align:center;color:var(--color-gray-400);flex-direction:column;align-items:center;gap:8px;padding:44px 20px 32px;display:flex}.dash-empty p{margin:0;font-size:.9rem}@keyframes spin{to{transform:rotate(360deg)}}.spinner{color:var(--color-primary);animation:.8s linear infinite spin}.greeting{color:var(--color-gray-900);font-size:1.3rem;font-weight:700}.today-date{color:var(--color-gray-500);margin-top:2px;font-size:.85rem}.section{margin-top:24px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--color-gray-800);font-size:1.1rem;font-weight:700}.section-link{color:var(--color-primary);align-items:center;gap:2px;font-size:.82rem;font-weight:600;display:flex}.sites-list{flex-direction:column;gap:12px;display:flex}.site-card-v2{align-items:center;gap:14px;padding:14px;transition:transform .15s,box-shadow .15s;display:flex;position:relative}.site-card-v2:active{transform:scale(.98)}.site-card-v2-left{flex-shrink:0}.site-card-v2-right{flex:1;min-width:0}.site-card-v2-header{justify-content:space-between;align-items:flex-start;gap:6px;margin-bottom:4px;display:flex}.site-card-v2-name{color:var(--color-gray-900);text-overflow:ellipsis;white-space:nowrap;font-size:.92rem;font-weight:700;line-height:1.3;overflow:hidden}.site-card-v2-address{color:var(--color-gray-500);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:4px;margin-bottom:6px;font-size:.75rem;display:flex;overflow:hidden}.site-card-v2-meta{align-items:center;gap:10px;display:flex}.site-card-v2-type-label{color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.3px;font-size:.7rem;font-weight:600}.site-card-v2-arrow{color:var(--color-gray-300);flex-shrink:0}.attendance-chip{color:var(--color-gray-500);align-items:center;gap:4px;font-size:.75rem;font-weight:500;display:flex}.attendance-chip svg{color:var(--color-success)}.empty-state{text-align:center;color:var(--color-gray-400);padding:40px 20px}.empty-state p{margin-top:12px;font-size:.9rem}.text-success{color:var(--color-success)}.text-gray{color:var(--color-gray-300)}[data-theme=dark] .dash-hero{background:linear-gradient(135deg,#0a2040 0%,#0f2f50 55%,#1a3a5a 100%)}[data-theme=dark] .dash-hero--worker{background:linear-gradient(135deg,#0f0f1a 0%,#0f1a2e 55%,#0a2040 100%)}[data-theme=dark] .dash-stat-card,[data-theme=dark] .dash-stat{background:var(--color-white)}[data-theme=dark] .dash-stat-icon--blue{background:var(--badge-info-bg);color:var(--color-primary)}[data-theme=dark] .dash-stat-icon--yellow{color:#fbbf24;background:#422006}[data-theme=dark] .dash-stat-icon--green{color:#4ade80;background:#0f2b1a}[data-theme=dark] .dash-site-card{background:var(--color-white)}[data-theme=dark] .dash-site-progress-bar{background:var(--color-gray-200)}[data-theme=dark] .dash-badge--green{background:var(--badge-success-bg);color:var(--badge-success-text)}[data-theme=dark] .dash-badge--orange{color:#fbbf24;background:#422006}[data-theme=dark] .site-card-v2{background:var(--color-white)}.flota-page{background:var(--color-gray-50,#f8fafc);min-height:100vh;padding-bottom:100px}.flota-hero{color:#fff;background:linear-gradient(135deg,#1e3a8a 0%,#1d4ed8 45%,#3b82f6 100%);padding:22px 20px 20px;position:relative;overflow:hidden}.flota-hero:after{content:"";pointer-events:none;background:#ffffff0f;border-radius:50%;width:180px;height:180px;position:absolute;top:-30px;right:-30px}.flota-hero-top{justify-content:space-between;align-items:flex-start;margin-bottom:18px;display:flex}.flota-hero-title{color:#fff;letter-spacing:-.4px;margin:0 0 3px;font-size:1.5rem;font-weight:800;line-height:1.1}.flota-hero-sub{color:#ffffffb3;margin:0;font-size:.82rem}.flota-hero-badge{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff26;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.flota-stats-strip{gap:10px;display:flex}.flota-stat{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff24;border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 12px;display:flex}.flota-stat-num{color:#fff;font-size:1.5rem;font-weight:800;line-height:1}.flota-stat-lbl{color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px;font-size:.64rem;font-weight:700}.flota-toolbar{padding:14px 16px 0}.flota-add-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 22px;font-size:.92rem;font-weight:700;transition:all .18s;display:flex;box-shadow:0 4px 14px #2563eb52}.flota-add-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.flota-add-btn:active{transform:translateY(0)}.flota-list{flex-direction:column;gap:10px;padding:14px 16px 0;display:flex}.flota-loading{color:#d97706;justify-content:center;align-items:center;padding:60px;display:flex}.flota-empty{text-align:center;flex-direction:column;align-items:center;padding:60px 24px;display:flex}.flota-empty-icon{opacity:.4;width:80px;height:80px;margin-bottom:20px}.flota-empty-title{color:var(--color-gray-700);margin:0 0 6px;font-size:1rem;font-weight:700}.flota-empty-sub{color:var(--color-gray-400);margin:0;font-size:.82rem}.flota-card{border:1px solid var(--color-gray-200,#e5e7eb);background:#fff;border-radius:18px;transition:box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 2px 10px #0000000d}.flota-card:hover{box-shadow:0 6px 22px #00000017}.flota-card-accent{background:var(--vc-color,#d97706);border-radius:18px 0 0 18px;width:5px;height:100%;position:absolute;top:0;left:0}.flota-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:13px;padding:14px 14px 0 20px;display:flex}.flota-card-icon{background:var(--vc-bg,#fef3c7);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;padding:6px;display:flex;overflow:hidden}[data-theme=dark] .flota-card-icon{background:color-mix(in srgb, var(--vc-color,#d97706) 25%, #0d0d1a)}.flota-card-icon svg{width:100%;height:100%}.flota-card-body{flex:1;min-width:0}.flota-card-toprow{justify-content:space-between;align-items:center;gap:8px;display:flex}.flota-card-name{color:var(--color-gray-900);white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:800;overflow:hidden}.flota-card-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.flota-icon-btn{cursor:pointer;background:0 0;border:none;border-radius:9px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.flota-icon-btn--edit{color:var(--color-gray-400)}.flota-icon-btn--edit:hover{color:#2563eb;background:#dbeafe}.flota-icon-btn--del{color:var(--color-gray-400)}.flota-icon-btn--del:hover{color:#ef4444;background:#fef2f2}.flota-chevron{color:var(--color-gray-400);align-items:center;display:flex}.flota-badge-row{flex-wrap:wrap;gap:5px;margin-top:5px;display:flex}.flota-badge{border-radius:20px;align-items:center;gap:3px;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.flota-badge--type{background:var(--vc-bg,#fef3c7);color:var(--vc-color,#b45309)}.flota-badge--active{color:#15803d;background:#dcfce7}.flota-badge--inactive{color:#6b7280;background:#f3f4f6}.flota-badge--maint{color:#dc2626;background:#fee2e2}.flota-badge--sites{color:#1d4ed8;background:#dbeafe}.flota-badge--status-btn{cursor:pointer;border:none;border-radius:20px;align-items:center;gap:4px;padding:2px 9px;font-family:inherit;font-size:.68rem;font-weight:700;transition:opacity .15s,transform .1s;display:inline-flex}.flota-badge--status-btn:hover{opacity:.82;transform:scale(1.04)}.flota-badge--status-btn:disabled{opacity:.6;cursor:default;transform:none}.flota-card-meta{color:var(--color-gray-500);flex-wrap:wrap;gap:0 8px;margin-top:4px;padding-bottom:12px;font-size:.74rem;display:flex}.flota-card-plate{color:var(--color-gray-700);background:var(--color-gray-100);letter-spacing:.8px;border-radius:5px;padding:0 6px;font-size:.71rem;font-weight:700}.flota-docs-row{flex-direction:column;gap:6px;padding:0 14px 14px 20px;display:flex}.flota-doc-pill{border-radius:11px;align-items:center;gap:8px;padding:7px 10px;font-size:.76rem;font-weight:600;display:flex}.flota-doc-pill--ok{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.flota-doc-pill--warn{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.flota-doc-pill--expired{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.flota-doc-pill--empty{background:var(--color-gray-50,#f9fafb);border:1px dashed var(--color-gray-300,#d1d5db);color:var(--color-gray-400,#9ca3af)}.flota-doc-label{text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;min-width:54px;font-size:.67rem;font-weight:800}.flota-doc-dates{flex:1}.flota-doc-badge{border-radius:8px;flex-shrink:0;padding:2px 8px;font-size:.68rem;font-weight:800}.flota-doc-pill--ok .flota-doc-badge{color:#166534;background:#bbf7d0}.flota-doc-pill--warn .flota-doc-badge{color:#92400e;background:#fde68a}.flota-doc-pill--expired .flota-doc-badge{color:#dc2626;background:#fecaca}.flota-card-expanded{border-top:1px solid var(--color-gray-100,#f3f4f6);flex-direction:column;gap:10px;padding:12px 14px 14px 20px;display:flex}.flota-notes-row{color:var(--color-gray-600);align-items:flex-start;gap:7px;font-size:.82rem;display:flex}.flota-notes-row svg{color:var(--color-gray-400);flex-shrink:0;margin-top:2px}.flota-sites-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-gray-400);margin-bottom:5px;font-size:.67rem;font-weight:800}.flota-sites-chips{flex-wrap:wrap;gap:6px;display:flex}.flota-site-chip{color:#1d4ed8;background:#dbeafe;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.74rem;font-weight:600;display:inline-flex}.flota-no-sites{color:var(--color-gray-400);font-size:.78rem;font-style:italic}.flota-modal{width:100%;max-width:560px;max-height:93vh;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 80px);background:#fff;border-radius:24px 24px 0 0;flex-direction:column;display:flex;position:fixed;bottom:0;left:50%;overflow:hidden auto;transform:translate(-50%);box-shadow:0 -8px 40px #00000029}.flota-modal-handle{background:var(--color-gray-300,#d1d5db);border-radius:99px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.flota-modal-head{border-bottom:1px solid var(--color-gray-100,#f3f4f6);flex-shrink:0;align-items:center;gap:14px;padding:14px 18px 13px;display:flex}.flota-modal-head-icon{border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;padding:7px;display:flex}.flota-modal-head-icon svg{width:100%;height:100%}.flota-modal-head-text{flex:1}.flota-modal-head-text h2{color:var(--color-gray-900);margin:0;font-size:1.05rem;font-weight:800}.flota-modal-head-text p{color:var(--color-gray-500);margin:2px 0 0;font-size:.78rem}.flota-modal-close{background:var(--color-gray-100,#f3f4f6);width:34px;height:34px;color:var(--color-gray-500);cursor:pointer;border:none;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.flota-modal-close:hover{background:var(--color-gray-200,#e5e7eb)}.flota-form-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;align-items:center;gap:7px;margin:10px 18px 0;padding:10px 14px;font-size:.82rem;font-weight:600;display:flex}.flota-modal-body{flex-direction:column;gap:16px;padding:16px 18px 8px;display:flex}.flota-form-section{text-transform:uppercase;letter-spacing:.6px;color:var(--color-gray-400);border-bottom:1px solid var(--color-gray-100,#f3f4f6);margin-top:2px;padding-bottom:4px;font-size:.7rem;font-weight:800;display:block}.flota-type-grid{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.flota-type-tile{border:2px solid var(--color-gray-200,#e5e7eb);background:var(--color-gray-50,#f9fafb);cursor:pointer;color:var(--color-gray-600);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:9px 3px 7px;font-family:inherit;font-size:.6rem;font-weight:600;line-height:1.2;transition:all .15s;display:flex}.flota-type-tile:hover{border-color:var(--color-gray-300);background:#fff}.flota-type-tile--active{border-color:var(--tt-color,#d97706);background:var(--tt-bg,#fef3c7);color:var(--tt-color,#d97706)}.flota-type-tile-icon{width:36px;height:36px}.flota-type-tile-icon svg{width:100%;height:100%}.flota-fg{flex-direction:column;flex:1;gap:7px;min-width:0;display:flex}.flota-fg-row{gap:12px;display:flex}.flota-fl{color:var(--color-gray-600);font-size:.76rem;font-weight:700}.flota-fi{border:1.5px solid var(--color-gray-200,#e5e7eb);width:100%;min-width:0;color:var(--color-gray-900);box-sizing:border-box;background:#fff;border-radius:10px;outline:none;max-width:100%;padding:10px 12px;font-family:inherit;font-size:.88rem;transition:border-color .15s,box-shadow .15s}.flota-fi:focus{border-color:#d97706;box-shadow:0 0 0 3px #d977061f}.flota-fi-plate{letter-spacing:1px;text-transform:uppercase;font-weight:700}.flota-fi-ta{resize:vertical;min-height:58px}.flota-submit-btn{background:linear-gradient(135deg, var(--sb-color,#2563eb), color-mix(in srgb, var(--sb-color,#2563eb) 68%, #000));color:#fff;cursor:pointer;border:none;border-radius:13px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:13px;font-family:inherit;font-size:.95rem;font-weight:700;transition:all .18s;display:flex}.flota-submit-btn:hover:not(:disabled){filter:brightness(1.07);transform:translateY(-1px)}.flota-submit-btn:disabled{opacity:.65;cursor:not-allowed}.flota-del-overlay{z-index:1000;-webkit-backdrop-filter:blur(3px);background:#0000008c;justify-content:center;align-items:center;padding:24px;animation:.15s dlg-fade-in;display:flex;position:fixed;inset:0}.flota-del-modal{text-align:center;background:#fff;border-radius:22px;flex-direction:column;align-items:center;gap:10px;width:90%;max-width:340px;padding:28px 24px 24px;display:flex;box-shadow:0 8px 36px #00000024}.flota-del-icon{color:#ef4444;background:#fef2f2;border-radius:15px;justify-content:center;align-items:center;width:54px;height:54px;margin-bottom:4px;display:flex}.flota-del-title{color:var(--color-gray-900);margin:0;font-size:1rem;font-weight:800}.flota-del-text{color:var(--color-gray-500);margin:0;font-size:.84rem;line-height:1.55}.flota-del-actions{gap:10px;width:100%;margin-top:6px;display:flex}.flota-del-actions .btn{flex:1;justify-content:center}[data-theme=dark] .flota-page{background:var(--color-gray-50)}[data-theme=dark] .flota-card{background:var(--color-white);border-color:var(--color-gray-200)}[data-theme=dark] .flota-modal{background:var(--color-white)}[data-theme=dark] .flota-fi{color:#e5e7eb;background:#ffffff0f;border-color:#ffffff24}[data-theme=dark] .flota-fi:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b2e}[data-theme=dark] .flota-fi::placeholder{color:#ffffff4d}[data-theme=dark] .flota-fi-plate{color:#fde68a;letter-spacing:1.5px}[data-theme=dark] .flota-modal-body .flota-fg:nth-child(odd) .flota-fi{background:#ffffff14}[data-theme=dark] .flota-fl{color:#9ca3af}[data-theme=dark] .flota-form-section{color:#6b7280;border-bottom-color:#ffffff14}[data-theme=dark] .flota-modal-head{border-bottom-color:#ffffff14}[data-theme=dark] .flota-modal-close{color:#9ca3af;background:#ffffff14}[data-theme=dark] .flota-modal-close:hover{background:#ffffff24}[data-theme=dark] .flota-type-tile{background:var(--color-gray-100);border-color:var(--color-gray-200)}[data-theme=dark] .flota-badge--inactive{background:var(--color-gray-200);color:var(--color-gray-500)}[data-theme=dark] .flota-badge--active{background:var(--badge-success-bg);color:var(--badge-success-text)}[data-theme=dark] .flota-badge--maint{background:var(--badge-danger-bg);color:var(--badge-danger-text)}[data-theme=dark] .flota-del-modal{background:#1e2035}[data-theme=dark] .flota-del-title{color:#f1f5f9}[data-theme=dark] .flota-del-text{color:#94a3b8}[data-theme=dark] .flota-del-icon{color:#f87171;background:#3b1818}[data-theme=dark] .flota-badge--sites{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .flota-doc-pill--empty{background:var(--color-gray-100);border-color:var(--color-gray-300)}[data-theme=dark] .flota-loading{color:#60a5fa}[data-theme=dark] .flota-badge--type{background:color-mix(in srgb, var(--vc-color,#3b82f6) 18%, #0d0d1a);color:color-mix(in srgb, var(--vc-color,#3b82f6) 85%, #fff)}[data-theme=dark] .flota-doc-pill--ok{color:#4ade80;background:#052e16;border-color:#166534}[data-theme=dark] .flota-doc-pill--ok .flota-doc-badge{color:#86efac;background:#14532d}[data-theme=dark] .flota-doc-pill--warn{color:#fbbf24;background:#1c1100;border-color:#854d0e}[data-theme=dark] .flota-doc-pill--warn .flota-doc-badge{color:#fde68a;background:#451a03}[data-theme=dark] .flota-doc-pill--expired{color:#f87171;background:#1f0a0a;border-color:#991b1b}[data-theme=dark] .flota-doc-pill--expired .flota-doc-badge{color:#fca5a5;background:#450a0a}[data-theme=dark] .flota-type-tile--active{background:color-mix(in srgb, var(--tt-color,#2563eb) 20%, #0d0d1a);border-color:var(--tt-color,#2563eb);color:color-mix(in srgb, var(--tt-color,#2563eb) 80%, #fff)}[data-theme=dark] .flota-site-chip{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .flota-card-plate{background:var(--color-gray-200);color:var(--color-gray-600)}.doc-grid{flex-direction:column;gap:18px;display:flex}.doc-block{flex-direction:column;gap:6px;display:flex}.doc-block-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-gray-500);font-size:.72rem;font-weight:800}.doc-block-row{gap:10px;display:flex}.doc-field{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.doc-field-label{color:var(--color-gray-600);font-size:.72rem;font-weight:600}.doc-field-input{box-sizing:border-box;border:1.5px solid var(--color-gray-200,#e5e7eb);width:100%;min-width:0;color:var(--color-gray-900);appearance:none;background:#fff;border-radius:9px;outline:none;padding:8px 10px;font-family:inherit;font-size:.82rem}.doc-field-input:focus{border-color:#d97706;box-shadow:0 0 0 3px #d977061f}[data-theme=dark] .doc-block-label,[data-theme=dark] .doc-field-label{color:var(--color-gray-400)}[data-theme=dark] .doc-field-input{color:#e5e7eb;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#ffffff12;border-color:#ffffff26}[data-theme=dark] .doc-field-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b2e}.sp-hero{background:linear-gradient(135deg,#0077c8 0%,#008ce3 50%,#33a8f5 100%);margin-bottom:18px;padding:28px 0 22px}.sp-hero-inner{padding:0 16px}.sp-hero-top{justify-content:space-between;align-items:flex-start;margin-bottom:18px;display:flex}.sp-hero-title{color:#fff;letter-spacing:-.3px;margin:0;font-size:1.6rem;font-weight:800}.sp-hero-sub{color:#ffffffb8;margin:3px 0 0;font-size:.84rem}.sp-hero-add{color:#1a1a1a;cursor:pointer;white-space:nowrap;background:#fff700;border:none;border-radius:24px;flex-shrink:0;align-items:center;gap:7px;padding:10px 20px;font-size:.88rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 14px #0000002e}.sp-hero-add:hover{transform:translateY(-1px);box-shadow:0 6px 18px #00000038}.sp-hero-add:active{transform:translateY(0)}.sp-hero-stats{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff24;border-radius:16px;align-items:center;gap:0;padding:14px 16px;display:flex}.sp-hero-stat{flex:1;align-items:center;gap:10px;display:flex}.sp-hero-stat>div{flex-direction:column;display:flex}.sp-hero-stat-div{background:#ffffff40;flex-shrink:0;width:1px;height:32px;margin:0 8px}.sp-hero-stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sp-hero-stat-icon--blue{color:#fff;background:#ffffff40}.sp-hero-stat-icon--green{color:#bbf7d0;background:#22c55e4d}.sp-hero-stat-icon--yellow{color:#1a1a1a;background:#fff700}.sp-hero-stat-val{color:#fff;font-size:1.3rem;font-weight:800;line-height:1}.sp-hero-stat-lbl{color:#ffffffa6;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:.68rem;font-weight:600}.sp-search-wrap{margin-bottom:12px;position:relative}.sp-search-icon{color:var(--color-gray-400);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.sp-search{border:1.5px solid var(--color-gray-200);background:var(--color-white);width:100%;color:var(--color-gray-800);box-sizing:border-box;border-radius:12px;outline:none;padding:11px 14px 11px 40px;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.sp-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #008ce31a}.sp-filters{-webkit-overflow-scrolling:touch;gap:8px;margin-bottom:16px;padding-bottom:2px;display:flex;overflow-x:auto}.sp-filter-btn{background:var(--color-gray-100);color:var(--color-gray-600);white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:600;transition:all .2s;display:flex}.sp-filter-active{background:var(--color-primary);color:#fff}.sp-filter-count{background:#00000014;border-radius:99px;padding:1px 7px;font-size:.72rem;font-weight:700;line-height:1.4}.sp-filter-active .sp-filter-count{color:#fff;background:#ffffff40}.sp-loading{color:var(--color-gray-400);flex-direction:column;align-items:center;gap:10px;padding:56px 0;font-size:.85rem;display:flex}.sp-empty{text-align:center;flex-direction:column;align-items:center;padding:48px 16px;display:flex}.sp-empty-icon{background:var(--color-gray-100);width:72px;height:72px;color:var(--color-gray-400);border-radius:20px;justify-content:center;align-items:center;margin-bottom:16px;display:flex}.sp-empty-title{color:var(--color-gray-700);margin:0 0 4px;font-size:1rem;font-weight:700}.sp-empty-sub{color:var(--color-gray-400);margin:0;font-size:.84rem}.sp-list{flex-direction:column;gap:12px;display:flex}.sp-completed-section{margin-top:8px}.sp-completed-toggle{cursor:pointer;width:100%;color:var(--color-text-secondary);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:7px;padding:10px 4px;font-size:.85rem;font-weight:600;transition:color .15s,background .15s;display:flex}.sp-completed-toggle:hover{color:var(--color-text);background:var(--color-gray-100)}.sp-completed-toggle svg{flex-shrink:0}.sp-list--completed{opacity:.82;margin-top:6px}[data-theme=dark] .sp-completed-toggle:hover{background:#ffffff0f}.sp-card{background:var(--color-white);cursor:pointer;border-radius:16px;transition:box-shadow .2s,transform .15s;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000000f,0 0 0 1px #00000008}.sp-card:hover{transform:translateY(-1px);box-shadow:0 6px 24px #0000001a}.sp-card:active{transform:scale(.985)}.sp-card-accent{border-radius:4px 0 0 4px;width:4px;height:100%;position:absolute;top:0;left:0}.sp-card-content{padding:14px 14px 12px 18px}.sp-card-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.sp-card-icon{background:var(--sp-tc-bg);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}[data-theme=dark] .sp-card-icon{background:color-mix(in srgb, var(--sp-tc-color) 25%, #0d0d1a)}.sp-card-icon .site-icon{box-shadow:none;background:0 0!important;width:44px!important;height:44px!important}.sp-card-title-area{flex:1;min-width:0}.sp-card-name{color:var(--color-gray-900);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:0 0 4px;font-size:.95rem;font-weight:700;line-height:1.2;display:-webkit-box;overflow:hidden}.sp-card-badges{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.sp-card-type-tag{text-transform:uppercase;letter-spacing:.3px;background:var(--sp-tc-bg);color:var(--sp-tc-color);border-radius:6px;padding:2px 8px;font-size:.7rem;font-weight:700}[data-theme=dark] .sp-card-type-tag{background:color-mix(in srgb, var(--sp-tc-color) 25%, #0d0d1a);color:color-mix(in srgb, var(--sp-tc-color) 90%, #fff)}.sp-card-status{border-radius:6px;padding:2px 8px;font-size:.68rem;font-weight:700}.sp-card-status--active{color:#1e40af;background:#dbeafe}.sp-card-status--done{color:#166534;background:#dcfce7}.sp-card-chevron{color:var(--color-gray-300);flex-shrink:0}.sp-card-address{color:var(--color-gray-500);align-items:center;gap:5px;margin-bottom:6px;padding-left:2px;font-size:.8rem;display:flex}.sp-card-address svg{color:var(--color-gray-400);flex-shrink:0}.sp-card-people{align-items:center;gap:12px;margin-bottom:8px;padding-left:2px;display:flex}.sp-card-manager{color:#7c3aed;align-items:center;gap:4px;font-size:.76rem;font-weight:600;display:flex}.sp-card-manager svg{flex-shrink:0}.sp-card-workers{color:var(--color-gray-500);align-items:center;gap:4px;font-size:.76rem;display:flex}.sp-card-workers svg{flex-shrink:0}.sp-card-attendance{color:#22c55e;align-items:center;gap:4px;margin-left:auto;font-size:.76rem;font-weight:600;display:flex}.sp-card-attendance svg{flex-shrink:0}.sp-card-progress{align-items:center;gap:10px;display:flex}.sp-progress-track{background:var(--color-gray-100);border-radius:99px;flex:1;height:6px;overflow:hidden}.sp-progress-fill{border-radius:99px;height:100%;transition:width .5s}.sp-progress-pct{text-align:right;min-width:32px;font-size:.78rem;font-weight:800}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.sp-modal{background:var(--color-white);width:100%;max-width:520px;max-height:92dvh;padding:12px 20px calc(env(safe-area-inset-bottom,0px) + 80px);border-radius:24px 24px 0 0;animation:.35s cubic-bezier(.16,1,.3,1) spSlideUp;overflow-y:auto}@keyframes spSlideUp{0%{opacity:.8;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.sp-modal-handle{background:var(--color-gray-300);border-radius:99px;width:36px;height:4px;margin:0 auto 16px}.sp-modal-header{align-items:center;gap:12px;margin-bottom:22px;display:flex}.sp-modal-hicon{width:44px;height:44px;color:var(--color-primary);background:#dbeafe;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sp-modal-title{color:var(--color-gray-900);margin:0;font-size:1.15rem;font-weight:800}.sp-modal-sub{color:var(--color-gray-400);margin:1px 0 0;font-size:.78rem}.sp-modal-close{background:var(--color-gray-100);width:34px;height:34px;color:var(--color-gray-500);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;transition:background .15s;display:flex}.sp-modal-close:hover{background:var(--color-gray-200)}.sp-modal-body{flex-direction:column;display:flex}.sp-fg{margin-bottom:16px}.sp-fg-row{gap:12px;display:flex}.sp-fg-half{flex:1}.sp-fl{color:var(--color-gray-600);align-items:center;gap:5px;margin-bottom:6px;font-size:.82rem;font-weight:600;display:flex}.sp-fl-icon{flex-shrink:0}.sp-fl-icon--purple{color:#7c3aed}.sp-fl-icon--blue{color:var(--color-primary)}.sp-fi{border:1.5px solid var(--color-gray-200);background:var(--color-gray-50);width:100%;color:var(--color-gray-800);box-sizing:border-box;border-radius:10px;outline:none;padding:11px 14px;font-size:.92rem;transition:border-color .2s,box-shadow .2s}.sp-fi:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #008ce31a}.sp-fi-ta{resize:vertical;min-height:60px}.sp-form-error{color:#dc2626;background:#fee2e2;border-radius:10px;align-items:center;gap:6px;margin-bottom:16px;padding:10px 14px;font-size:.84rem;font-weight:600;display:flex}.sp-section-divider{border-top:1px solid var(--color-gray-200);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;margin-bottom:4px;padding:14px 0 10px;font-size:.85rem;font-weight:700;display:flex}.sp-manager-picker{border:1.5px solid var(--color-gray-200);background:var(--color-gray-50);border-radius:12px;flex-direction:column;gap:4px;max-height:220px;padding:6px;display:flex;overflow-y:auto}.sp-mgr-opt{cursor:pointer;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.sp-mgr-opt:hover{background:var(--color-gray-100)}.sp-mgr-opt--active{background:#ede9fe}.sp-mgr-opt--active:hover{background:#e4ddf7}.sp-mgr-radio{border:2px solid var(--color-gray-300);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:border-color .15s;display:flex}.sp-mgr-opt--active .sp-mgr-radio{border-color:#7c3aed}.sp-mgr-radio-dot{background:#7c3aed;border-radius:50%;width:10px;height:10px}.sp-mgr-avatar{color:#7c3aed;background:#ede9fe;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.sp-mgr-info{flex-direction:column;min-width:0;display:flex}.sp-mgr-name{color:var(--color-gray-800);font-size:.88rem;font-weight:600}.sp-mgr-site{color:var(--color-gray-400);font-size:.72rem}.sp-worker-picker{border:1.5px solid var(--color-gray-200);background:var(--color-gray-50);border-radius:12px;flex-direction:column;gap:4px;max-height:220px;padding:6px;display:flex;overflow-y:auto}.sp-wk-opt{cursor:pointer;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.sp-wk-opt:hover{background:var(--color-gray-100)}.sp-wk-opt--active{background:#dbeafe}.sp-wk-opt--active:hover{background:#c7d9f5}.sp-wk-check{border:2px solid var(--color-gray-300);color:#0000;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex}.sp-wk-check--on{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.sp-wk-opt--vehicle.sp-wk-opt--active{background:#fef3c7}.sp-wk-opt--vehicle.sp-wk-opt--active:hover{background:#fde68a}.sp-wk-check--vehicle.sp-wk-check--on{color:#fff;background:#d97706;border-color:#d97706}.sp-wk-name{color:var(--color-gray-800);flex:1;font-size:.88rem;font-weight:600}.sp-wk-phone{color:var(--color-gray-400);font-size:.74rem}.sp-stages-list{border:1.5px solid var(--color-gray-200);background:var(--color-gray-50);border-radius:12px;flex-direction:column;gap:4px;max-height:280px;padding:6px;display:flex;overflow-y:auto}.sp-stage-row{border:1px solid var(--color-gray-200);background:#fff;border-radius:8px;align-items:center;gap:6px;padding:5px 6px;display:flex}.sp-stage-num{color:var(--color-gray-400);text-align:center;flex-shrink:0;min-width:20px;font-size:.72rem;font-weight:700}.sp-stage-input{color:var(--color-gray-800);background:0 0;border:none;outline:none;flex:1;min-width:0;padding:2px 0;font-size:.84rem}.sp-stage-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.sp-stage-btn{cursor:pointer;width:24px;height:24px;color:var(--color-gray-400);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:.65rem;transition:background .15s;display:flex}.sp-stage-btn:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.sp-stage-btn:disabled{opacity:.25;pointer-events:none}.sp-stage-btn--del{color:#ef4444}.sp-stage-btn--del:hover{color:#dc2626;background:#fef2f2}.sp-stage-add-row{gap:8px;margin-top:6px;display:flex}.sp-stage-add-input{flex:1;min-width:0}.sp-stage-add-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#008ce3;border:none;border-radius:12px;flex-shrink:0;align-items:center;gap:5px;height:44px;padding:0 14px;font-size:.85rem;font-weight:600;transition:background .15s;display:flex}.sp-stage-add-btn:hover{background:#0074c2}.sp-stage-add-btn:disabled{background:var(--color-gray-300);cursor:default}.sp-create-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#008ce3,#0074c2);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;padding:14px 24px;font-size:1rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 14px #008ce34d}.sp-create-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #008ce359}.sp-create-btn:active{transform:translateY(0)}.sp-create-btn:disabled{opacity:.7;pointer-events:none}.spinner{animation:.8s linear infinite spin}[data-theme=dark] .sites-hero{background:linear-gradient(135deg,#0a2040 0%,#0f2f50 50%,#1a3a5a 100%)}[data-theme=dark] .sites-card{background:var(--color-white)}[data-theme=dark] .sites-card-badge--active{background:var(--badge-info-bg);color:var(--badge-info-text)}[data-theme=dark] .sites-card-badge--done{background:var(--badge-success-bg);color:var(--badge-success-text)}[data-theme=dark] .sp-worker-tag,[data-theme=dark] .sp-worker-tag:hover{background:var(--badge-info-bg)}[data-theme=dark] .sp-form-card{background:var(--color-white)}[data-theme=dark] .sp-form-error{background:var(--badge-danger-bg);color:var(--color-danger)}[data-theme=dark] .sp-mgr-pick{background:var(--color-gray-100)}[data-theme=dark] .sp-mgr-pick:hover{background:var(--color-gray-200)}[data-theme=dark] .sp-mgr-badge{color:#c4b5fd;background:#3b1f7e}[data-theme=dark] .sp-stage-tag,[data-theme=dark] .sp-stage-tag:hover{background:var(--badge-info-bg)}[data-theme=dark] .sp-stage-add,[data-theme=dark] .sp-stage-add:hover{background:var(--badge-warning-bg)}[data-theme=dark] .sp-veh-tag{background:var(--color-gray-100)}[data-theme=dark] .sp-stage-row{background:var(--color-gray-200);border-color:var(--color-gray-300)}[data-theme=dark] .sp-mgr-opt--active{background:#3b1f7e33}[data-theme=dark] .sp-mgr-opt--active:hover{background:#3b1f7e55}[data-theme=dark] .sp-mgr-avatar{color:#c4b5fd;background:#3b1f7e33}[data-theme=dark] .sp-wk-opt--active{background:var(--badge-info-bg)}[data-theme=dark] .sp-wk-opt--active:hover{background:var(--badge-info-bg);filter:brightness(1.2)}[data-theme=dark] .sp-wk-opt--vehicle.sp-wk-opt--active{background:var(--badge-warning-bg)}[data-theme=dark] .sp-fi:focus{background:var(--color-gray-100)}[data-theme=dark] .sp-modal-hicon{background:#1e3a5f}[data-theme=dark] .sp-manager-picker,[data-theme=dark] .sp-worker-picker{background:var(--color-gray-100);border-color:var(--color-gray-300)}[data-theme=dark] .sp-mgr-opt:hover,[data-theme=dark] .sp-wk-opt:hover{background:var(--color-gray-200)}[data-theme=dark] .sp-mgr-name{color:var(--color-gray-900)}.back-btn{color:var(--color-primary);background:0 0;align-items:center;gap:6px;margin:8px 0;padding:8px 0;font-size:.9rem;font-weight:600;display:inline-flex}.sdp-page-active{padding-bottom:142px}.detail-hero{align-items:center;gap:16px;padding:20px;display:flex}.detail-hero-icon{border-radius:var(--radius-md);background:var(--sdp-tc-bg);flex-shrink:0;padding:8px}[data-theme=dark] .detail-hero-icon{background:color-mix(in srgb, var(--sdp-tc-color) 25%, #0d0d1a)}.detail-hero-icon .site-icon{background:0 0!important}.detail-type-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--sdp-tc-bg);color:var(--sdp-tc-color);border-radius:6px;margin-bottom:4px;padding:3px 8px;font-size:.7rem;font-weight:700;display:inline-block}[data-theme=dark] .detail-type-badge{background:color-mix(in srgb, var(--sdp-tc-color) 25%, #0d0d1a);color:color-mix(in srgb, var(--sdp-tc-color) 90%, #fff)}.detail-hero-info{flex:1}.detail-name{color:var(--color-gray-900);margin-bottom:6px;font-size:1.2rem;font-weight:700;line-height:1.3}.detail-info{margin-top:12px}.detail-row{color:var(--color-gray-600);align-items:flex-start;gap:10px;padding:10px 0;font-size:.85rem;display:flex}.detail-row:not(:last-child){border-bottom:1px solid var(--color-gray-100)}.detail-row svg{color:var(--color-gray-400);flex-shrink:0;margin-top:2px}.checkin-section{margin-top:16px}.checkin-btn{border-radius:var(--radius-md);padding:18px 28px;font-size:1.1rem;box-shadow:0 4px 16px #008ce34d}.checkin-btn:active{transform:scale(.97)}.checkin-done{border-radius:var(--radius-md);color:#166534;background:#dcfce7;align-items:center;gap:14px;padding:20px;display:flex}.checkin-done-title{font-size:1rem;font-weight:700}.checkin-done-sub{opacity:.8;margin-top:2px;font-size:.82rem}.checkin-location-ok{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;align-items:center;gap:6px;margin-top:10px;padding:8px 12px;font-size:.78rem;font-weight:600;display:flex}.checkin-location-missing{flex-direction:column;gap:8px;margin-top:10px;display:flex}.checkin-location-warning{color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;align-items:center;gap:6px;padding:8px 12px;font-size:.78rem;font-weight:600;display:flex}.checkin-location-hint{color:var(--color-gray-500);margin:0;padding:0 2px;font-size:.75rem;line-height:1.5}.checkin-location-hint-box{border-radius:10px;margin-top:2px;padding:10px 13px;font-size:.78rem;line-height:1.55}.checkin-location-hint-box--warn{color:#7c2d12;background:#fff7ed;border:1px solid #fed7aa}.checkin-location-steps{flex-direction:column;gap:5px;margin:8px 0 0;padding-left:18px;font-size:.78rem;line-height:1.5;display:flex}.checkin-gps-debug{color:#4ade80;white-space:pre-wrap;word-break:break-all;background:#1e1e1e;border-radius:8px;margin:2px 0 0;padding:8px 10px;font-family:monospace;font-size:.68rem;line-height:1.5}.checkin-location-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:11px 16px;font-family:inherit;font-size:.85rem;font-weight:700;transition:opacity .15s;display:inline-flex}.checkin-location-btn:disabled{opacity:.6;cursor:not-allowed}.attendance-list{flex-direction:column;gap:8px;margin-top:12px;display:flex}.attendance-item{background:var(--color-white);border-radius:var(--radius-sm);border:1px solid var(--color-gray-200);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.att-left{align-items:center;gap:10px;display:flex}.att-icon{border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.att-icon-present{color:#166534;background:#dcfce7}.att-icon-absent{color:#991b1b;background:#fee2e2}.att-name{color:var(--color-gray-800);font-size:.9rem;font-weight:600}.att-phone{color:var(--color-gray-400);font-size:.75rem}.att-time{color:var(--color-success);align-items:center;gap:4px;font-size:.82rem;font-weight:600;display:flex}.att-present-info{flex-direction:column;align-items:flex-end;gap:5px;display:flex}.att-times{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.att-time-row{align-items:center;gap:6px;display:flex}.att-time-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.att-time-dot--in{background:#22c55e}.att-time-dot--out{background:#ef4444}.att-time-label{letter-spacing:.04em;color:var(--color-gray-400);width:28px;font-size:.68rem;font-weight:700}.att-time-val{color:var(--color-gray-700);font-size:.82rem;font-weight:600}.att-time-val--link{color:var(--color-primary);align-items:center;gap:2px;text-decoration:none;display:inline-flex}.att-time-val--link:hover{text-decoration:underline}.att-time-val--out{color:#dc2626}.att-time-val--absent{color:var(--color-gray-300);font-weight:500}.att-duration-chip{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:99px;align-items:center;gap:4px;margin-top:4px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-flex}[data-theme=dark] .att-duration-chip{color:#86efac;background:#14291b;border-color:#166534}.att-location-link{color:var(--color-primary);background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;align-items:center;gap:3px;padding:2px 7px;font-size:.72rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.att-location-link:hover{background:#dbeafe}.att-no-location{color:var(--color-gray-300);align-items:center;gap:3px;font-size:.72rem;display:inline-flex}.att-checkout-time{color:#dc2626;align-items:center;gap:4px;font-size:.82rem;font-weight:600;display:flex}.att-location-link--checkout{color:#be123c;background:#fff1f2;border-color:#fecdd3}.att-location-link--checkout:hover{background:#ffe4e6}.att-no-checkout{color:var(--color-gray-300);align-items:center;gap:3px;font-size:.72rem;display:inline-flex}.checkout-btn{color:#991b1b;border-radius:var(--radius-md);cursor:pointer;background:#fee2e2;border:1.5px solid #fca5a5;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:12px;padding:13px 16px;font-family:inherit;font-size:.95rem;font-weight:700;transition:background .15s,opacity .15s;display:flex}.checkout-btn:hover:not(:disabled){background:#fecaca}.checkout-btn:disabled{opacity:.6;cursor:not-allowed}.checkout-done{border-radius:var(--radius-md);color:#be123c;background:#fff1f2;border:1px solid #fecdd3;align-items:center;gap:14px;margin-top:12px;padding:14px 16px;display:flex}.checkout-done-title{font-size:.95rem;font-weight:700}.checkout-done-sub{opacity:.8;margin-top:2px;font-size:.82rem;font-weight:600}.checkout-location-link{color:#be123c;opacity:.85;align-items:center;gap:4px;margin-top:4px;font-size:.78rem;font-weight:600;text-decoration:none;display:inline-flex}.checkout-location-link:hover{opacity:1;text-decoration:underline}.no-workers{color:var(--color-gray-400);text-align:center;padding:20px;font-size:.85rem}.sdp-progress-section{background:var(--color-white);border-radius:var(--radius-md);margin-top:16px;padding:16px 18px;box-shadow:0 2px 8px #0000000f}.sdp-progress-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.sdp-progress-title{color:var(--color-gray-800);align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.sdp-progress-title svg{color:var(--color-primary)}.sdp-progress-pct{color:var(--color-primary);font-size:1.5rem;font-weight:800;line-height:1}.sdp-progress-bar-wrap{margin-bottom:8px}.sdp-progress-bar{background:var(--color-gray-100);border-radius:99px;width:100%;height:10px;overflow:hidden}.sdp-progress-fill{background:linear-gradient(90deg,#008ce3,#00c6ff);border-radius:99px;height:100%;transition:width .6s}.sdp-progress-sub{color:var(--color-gray-400);text-align:right;font-size:.78rem}.sdp-cp-list{background:var(--color-white);border-radius:var(--radius-md);flex-direction:column;gap:0;margin-top:12px;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000000f}.sdp-cp-item{border-bottom:1px solid var(--color-gray-100)}.sdp-cp-item:last-child{border-bottom:none}.sdp-cp-item.sdp-cp-done{background:#f0fdf4}.sdp-cp-row{align-items:center;gap:10px;min-height:52px;padding:12px 14px;display:flex}.sdp-cp-check{border:2px solid var(--color-gray-300);background:var(--color-white);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex}.sdp-cp-check:hover{border-color:var(--color-primary);background:#008ce312}.sdp-cp-check.sdp-cp-check-done{color:#fff;background:#22c55e;border-color:#22c55e}.sdp-cp-check-static{border:2px solid var(--color-gray-300);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.sdp-cp-check-static.sdp-cp-check-done{color:#fff;background:#22c55e;border-color:#22c55e}.sdp-cp-info{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.sdp-cp-num{color:var(--color-gray-400);min-width:18px;font-size:.7rem;font-weight:700}.sdp-cp-label{color:var(--color-gray-800);font-size:.875rem;font-weight:500;line-height:1.35}.sdp-cp-label.sdp-cp-label-done{color:var(--color-gray-400);text-decoration:line-through}.sdp-cp-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.sdp-cp-photo-count{color:var(--color-primary);background:#008ce314;border-radius:99px;align-items:center;gap:3px;padding:2px 6px;font-size:.72rem;font-weight:600;display:flex}.sdp-cp-date{color:var(--color-gray-400);white-space:nowrap;font-size:.7rem}.sdp-cp-expand{background:var(--color-gray-100);width:28px;height:28px;color:var(--color-gray-500);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sdp-cp-details{flex-direction:column;gap:10px;padding:0 14px 14px 52px;display:flex}.sdp-cp-by{color:var(--color-gray-500);font-size:.78rem}.sdp-cp-notes-wrap{flex-direction:column;gap:4px;display:flex}.sdp-cp-notes{resize:vertical;min-height:60px;font-size:.82rem}.sdp-cp-notes-ro{color:var(--color-gray-600);background:var(--color-gray-50);border-radius:var(--radius-sm);padding:8px 10px;font-size:.82rem;line-height:1.5}.sdp-photo-gallery{flex-wrap:wrap;gap:8px;display:flex}.sdp-photo-thumb{border:2px solid var(--color-gray-200);cursor:pointer;background:0 0;border-radius:8px;width:72px;height:72px;padding:0;display:block;position:relative;overflow:hidden}.sdp-photo-thumb:hover .sdp-photo-zoom,.sdp-photo-thumb:focus .sdp-photo-zoom{opacity:1}.sdp-photo-zoom{color:#fff;opacity:0;background:#00000059;border-radius:6px;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.sdp-photo-thumb img{object-fit:cover;width:100%;height:100%}.sdp-upload-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;width:fit-content;padding:10px 16px;font-size:.85rem;font-weight:600;transition:opacity .2s;display:inline-flex}.sdp-upload-btn:active{opacity:.85}.sdp-photo-error{color:#dc2626;align-items:center;gap:6px;font-size:.8rem;display:flex}.sdp-team-list{flex-direction:column;gap:8px;margin-top:4px;display:flex}.sdp-team-item{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:12px;align-items:center;gap:12px;padding:12px 14px;display:flex}.sdp-team-item--manager{background:#f0f7ff;border-color:#bfdbfe}.sdp-team-avatar{background:var(--color-gray-200);width:36px;height:36px;color:var(--color-gray-500);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sdp-team-avatar--manager{color:var(--color-primary);background:#dbeafe}.sdp-team-info{flex-direction:column;gap:2px;display:flex}.sdp-team-name{color:var(--color-gray-800);font-size:.9rem;font-weight:600}.sdp-team-role{color:var(--color-primary);font-size:.75rem;font-weight:500}.sdp-team-phone{color:var(--color-gray-400);font-size:.75rem}.sdp-admin-actions{flex-direction:column;gap:8px;margin-top:14px;display:flex}.sdp-action-btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 16px;font-size:.85rem;font-weight:700;transition:opacity .15s,transform .1s;display:flex}.sdp-action-btn:active{transform:scale(.98)}.sdp-action-btn--edit{color:#fff;background:#008ce3}.sdp-action-btn--status{background:var(--color-gray-100);color:var(--color-gray-700)}.sdp-action-btn--reactivate{color:#16a34a;background:#22c55e15}.sdp-action-btn--delete{color:#dc2626;background:#fef2f2}.sdp-chat-fab{bottom:calc(65px + env(safe-area-inset-bottom,0px));background:var(--color-primary);color:#fff;cursor:pointer;z-index:150;letter-spacing:.01em;border:none;border-radius:21px;justify-content:center;align-items:center;gap:8px;width:auto;min-width:160px;max-width:220px;height:42px;padding:0 24px;font-family:inherit;font-size:.88rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;left:50%;overflow:visible;transform:translate(-50%);box-shadow:0 4px 16px #008ce359}.sdp-chat-fab:active{transform:translate(-50%)scale(.97)}.sdp-chat-fab-badge{color:#fff;border:2px solid var(--color-primary);background:#ef4444;border-radius:99px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 5px;font-size:.68rem;font-weight:800;animation:.2s both badgePop;display:flex;position:absolute;top:-6px;right:12px}.sdp-chat-panel{background:var(--color-white);z-index:300;border-radius:20px 20px 0 0;flex-direction:column;height:calc(100dvh - 130px);animation:.3s sdp-chat-slide-up;display:flex;position:fixed;bottom:65px;left:0;right:0;box-shadow:0 -8px 40px #0000002e}@keyframes sdp-chat-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sdp-chat-header{border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-800);flex-shrink:0;align-items:center;gap:10px;padding:16px 18px;font-size:.95rem;font-weight:700;display:flex}.sdp-chat-header svg:first-child{color:var(--color-primary)}.sdp-chat-close{background:var(--color-gray-100);cursor:pointer;width:32px;height:32px;color:var(--color-gray-500);border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:auto;display:flex}.sdp-chat-messages{flex-direction:column;flex:1;gap:4px;padding:16px;display:flex;overflow-y:auto}.sdp-chat-empty{color:var(--color-gray-400);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:40px 20px;display:flex}.sdp-chat-empty p{margin:0;font-size:.85rem}.sdp-chat-empty svg{color:var(--color-gray-300)}.sdp-msg{flex-direction:column;max-width:80%;display:flex}.sdp-msg--me{align-self:flex-end;align-items:flex-end}.sdp-msg--other{align-self:flex-start;align-items:flex-start}.sdp-msg-author{color:var(--color-primary);margin-top:8px;margin-bottom:2px;padding-left:10px;font-size:.7rem;font-weight:600}.sdp-msg-author--me{text-align:right;color:var(--color-gray-500);padding-left:0;padding-right:10px}.sdp-msg-bubble{background:var(--color-gray-100);color:var(--color-gray-800);border-radius:18px;padding:10px 14px;position:relative}.sdp-msg-bubble p{word-wrap:break-word;margin:0;font-size:.88rem;line-height:1.4}.sdp-msg-bubble--me{background:var(--color-primary);color:#fff}.sdp-msg-time{opacity:.6;text-align:right;margin-top:2px;font-size:.65rem;display:block}.sdp-chat-input{border-top:1px solid var(--color-gray-100);background:var(--color-white);flex-shrink:0;align-items:center;gap:8px;padding:12px 14px;display:flex}.sdp-chat-input input{border:1px solid var(--color-gray-200);background:var(--color-gray-50);border-radius:24px;outline:none;flex:1;padding:10px 16px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.sdp-chat-input input:focus{border-color:var(--color-primary)}.sdp-chat-send{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;transition:opacity .2s;display:flex}.sdp-chat-send:disabled{opacity:.4;cursor:default}.sdp-msg-row{align-items:flex-end;gap:4px;display:flex}.sdp-msg--me .sdp-msg-row{flex-direction:row-reverse}.sdp-msg-actions{opacity:0;flex-direction:column;gap:2px;transition:opacity .15s;display:flex}.sdp-msg-row:hover .sdp-msg-actions{opacity:1}@media (hover:none){.sdp-msg-actions{opacity:1}}.sdp-msg-action-btn{background:var(--color-gray-100);width:26px;height:26px;color:var(--color-gray-500);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.sdp-msg-action-btn:hover{background:var(--color-gray-200);color:var(--color-gray-800)}.sdp-msg-action-btn--del:hover{color:#dc2626;background:#fee2e2}.sdp-msg-edit{flex-direction:column;gap:6px;max-width:70vw;display:flex}.sdp-msg-edit-input{border:1.5px solid var(--color-primary);resize:none;background:var(--color-white);color:var(--color-gray-900);border-radius:12px;outline:none;padding:8px 12px;font-family:inherit;font-size:.88rem;line-height:1.4}.sdp-msg-edit-actions{gap:6px;display:flex}.sdp-msg-edit-save,.sdp-msg-edit-cancel{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:4px;padding:5px 10px;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .15s;display:flex}.sdp-msg-edit-save{background:var(--color-primary);color:#fff}.sdp-msg-edit-save:hover{background:#006bb5}.sdp-msg-edit-cancel{background:var(--color-gray-100);color:var(--color-gray-700)}.sdp-msg-edit-cancel:hover{background:var(--color-gray-200)}.sdp-msg-edited{opacity:.7;font-size:.6rem;font-style:italic}.sdp-typing-indicator{align-self:flex-start;align-items:center;gap:8px;padding:4px 10px;display:flex}.sdp-typing-names{color:var(--color-gray-500);font-size:.72rem;font-style:italic}.sdp-typing-dots{background:var(--color-gray-100);border-radius:12px;align-items:center;gap:3px;padding:6px 10px;display:inline-flex}.sdp-typing-dots span{background:var(--color-gray-400);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite sdp-bounce}.sdp-typing-dots span:nth-child(2){animation-delay:.2s}.sdp-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes sdp-bounce{0%,80%,to{opacity:.5;transform:scale(.7)}40%{opacity:1;transform:scale(1)}}.sdp-permits-section{background:var(--color-white);border-radius:16px;padding:16px;box-shadow:0 1px 4px #0000000f}.sdp-permits-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.sdp-permits-title{color:var(--color-gray-800);align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.sdp-permits-count{background:var(--color-primary);color:#fff;text-align:center;border-radius:99px;min-width:20px;padding:1px 7px;font-size:.7rem;font-weight:700}.sdp-permit-upload-btn{background:var(--color-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:opacity .15s;display:inline-flex}.sdp-permit-upload-btn:hover{opacity:.88}.sdp-permit-upload-btn--loading{opacity:.7;cursor:default}.sdp-permits-empty{color:var(--color-gray-400);flex-direction:column;align-items:center;gap:8px;padding:24px 0;font-size:.85rem;display:flex}.sdp-permits-list{flex-direction:column;gap:8px;display:flex}.sdp-permit-item{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:12px;align-items:center;gap:12px;padding:10px 12px;display:flex}.sdp-permit-icon{width:38px;height:38px;color:var(--color-primary);background:#dbeafe;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sdp-permit-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sdp-permit-name{color:var(--color-gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sdp-permit-meta{color:var(--color-gray-500);font-size:.7rem}.sdp-permit-size{color:var(--color-text-secondary);font-weight:600}.sdp-permit-actions{flex-shrink:0;gap:6px;display:flex}.sdp-permit-action-btn{background:var(--color-gray-100);width:32px;height:32px;color:var(--color-gray-600);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;text-decoration:none;transition:background .15s,color .15s;display:flex}.sdp-permit-action-btn:hover{color:var(--color-primary);background:#dbeafe}.sdp-permit-action-btn--del:hover{color:#dc2626;background:#fee2e2}.sdp-vehicles-section{margin-top:16px}.sdp-vehicles-section .section-title{align-items:center;gap:8px;display:flex}.sdp-veh-list{flex-direction:column;gap:8px;display:flex}.sdp-veh-card{background:var(--color-white);border:1.5px solid var(--color-gray-200);border-radius:12px;align-items:center;gap:10px;padding:12px 14px;transition:border-color .2s;display:flex}.sdp-veh-card--active{background:#fffbeb;border-color:#fbbf24}.sdp-veh-icon{background:#fef3c7;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.4rem;display:flex}.sdp-veh-icon svg{width:26px;height:26px}.sdp-veh-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sdp-veh-name{color:var(--color-gray-900);font-size:.88rem;font-weight:700}.sdp-veh-sub{color:var(--color-gray-500);font-size:.74rem}.sdp-veh-active-label{color:#d97706;align-items:center;gap:4px;margin-top:2px;font-size:.72rem;font-weight:600;display:flex}.sdp-veh-action{flex-shrink:0}.sdp-veh-btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:5px;padding:8px 14px;font-size:.8rem;font-weight:700;transition:background .15s;display:flex}.sdp-veh-btn--start{color:#15803d;background:#dcfce7}.sdp-veh-btn--start:hover{background:#bbf7d0}.sdp-veh-btn--stop{color:#dc2626;background:#fee2e2}.sdp-veh-btn--stop:hover{background:#fecaca}.sdp-veh-btn:disabled{opacity:.6;pointer-events:none}.sdp-veh-history{border-top:1px solid var(--color-gray-200);margin-top:14px;padding-top:10px}.sdp-veh-history-title{color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.3px;margin:0 0 8px;font-size:.75rem;font-weight:700}.sdp-veh-hist-row{align-items:center;gap:8px;padding:6px 0;font-size:.82rem;display:flex}.sdp-veh-hist-row:not(:last-child){border-bottom:1px solid var(--color-gray-100)}.sdp-veh-hist-name{color:var(--color-gray-800);flex:1;font-weight:600}.sdp-veh-hist-time{color:var(--color-gray-500);font-variant-numeric:tabular-nums;font-size:.78rem}.sdp-veh-hist-loc{font-size:.85rem;text-decoration:none}.sdp-veh-admin-list{flex-direction:column;gap:8px;display:flex}.sdp-veh-admin-row{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:10px;align-items:center;gap:10px;padding:10px 14px;display:flex}.sdp-veh-admin-icon{background:#fef3c7;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.sdp-veh-admin-icon svg{width:26px;height:26px}.sdp-veh-admin-left{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sdp-veh-admin-vehicle{color:var(--color-gray-900);font-size:.85rem;font-weight:700}.sdp-veh-admin-worker{color:var(--color-gray-500);font-size:.75rem}.sdp-vehicle-mgmt-section{background:var(--color-white);border:1px solid var(--color-gray-100);border-radius:16px;margin-top:14px;padding:14px 16px;box-shadow:0 1px 4px #0000000f}.sdp-vehicle-mgmt-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.sdp-vehicle-mgmt-title{color:var(--color-gray-800);align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.sdp-vehicle-mgmt-title svg{color:#d97706}.sdp-vehicle-mgmt-count{color:#fff;text-align:center;background:#d97706;border-radius:99px;min-width:20px;padding:1px 7px;font-size:.7rem;font-weight:700}.sdp-vehicle-mgmt-edit-btn{color:#b45309;cursor:pointer;background:#fef3c7;border:none;border-radius:10px;align-items:center;gap:5px;padding:7px 12px;font-family:inherit;font-size:.78rem;font-weight:700;transition:background .15s;display:inline-flex}.sdp-vehicle-mgmt-edit-btn:hover{background:#fde68a}.sdp-vehicle-mgmt-empty{color:var(--color-gray-400);flex-direction:column;align-items:center;gap:6px;padding:18px 0;font-size:.85rem;display:flex}.sdp-vehicle-mgmt-list{flex-direction:column;gap:6px;display:flex}.sdp-vehicle-mgmt-item{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:10px;align-items:center;gap:10px;padding:8px 10px;display:flex}.sdp-vehicle-mgmt-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sdp-vehicle-mgmt-icon svg{width:24px;height:24px}.sdp-vehicle-mgmt-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sdp-vehicle-mgmt-name{color:var(--color-gray-900);font-size:.875rem;font-weight:600}.sdp-vehicle-mgmt-sub{color:var(--color-gray-500);font-size:.74rem}.sp-wk-veh-icon{border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-right:2px;display:flex}.sp-wk-veh-icon svg{width:20px;height:20px}.sp-wk-veh-type{white-space:nowrap;flex-shrink:0;font-size:.7rem;font-weight:600}[data-theme=dark] .checkin-done{color:#86efac;background:#14532d}[data-theme=dark] .checkin-done .checkin-time{color:#86efac}[data-theme=dark] .att-card--present{background:#0f2b1a;border-color:#166534}[data-theme=dark] .att-card--present .att-name{color:#86efac}[data-theme=dark] .att-card--absent{background:#2a1a0a;border-color:#78350f}[data-theme=dark] .att-card--absent .att-name{color:#fbbf24}[data-theme=dark] .att-late-badge{color:#fbbf24;background:#2a1a0a;border-color:#78350f}[data-theme=dark] .att-gps-badge{color:#4ade80;background:#1e1e2e}[data-theme=dark] .att-badge--in{color:#86efac;background:#14532d}[data-theme=dark] .att-badge--out{color:#fca5a5;background:#7f1d1d}[data-theme=dark] .att-time-dot--in{background:#4ade80}[data-theme=dark] .att-time-dot--out{background:#f87171}[data-theme=dark] .att-time-val--out{color:#f87171}[data-theme=dark] .att-loc-btn{background:#1e3a5f;border-color:#2563eb}[data-theme=dark] .att-loc-btn:hover,[data-theme=dark] .att-loc-icon{background:#1e3a5f}[data-theme=dark] .att-remove-btn{color:#f87171}[data-theme=dark] .att-remove-btn--sure{color:#fca5a5;background:#7f1d1d;border-color:#fca5a5}[data-theme=dark] .att-remove-btn--sure:hover{background:#991b1b}[data-theme=dark] .att-checkout-block{color:#fca5a5;background:#7f1d1d;border-color:#fca5a5}[data-theme=dark] .att-checkout-badge{color:#fca5a5}[data-theme=dark] .sdp-progress-bar-fill{background:linear-gradient(90deg,#3b9fe8,#00c6ff)}[data-theme=dark] .sdp-chk-inner--done{background:#0f2b1a}[data-theme=dark] .sdp-chk-box:checked{background:var(--color-success);border-color:var(--color-success)}[data-theme=dark] .sdp-chk-photo-btn,[data-theme=dark] .sdp-chk-photo-btn:hover{background:var(--badge-info-bg)}[data-theme=dark] .team-avatar,[data-theme=dark] .msg-own .msg-bubble{background:var(--color-primary)}[data-theme=dark] .msg-other .msg-bubble{background:var(--color-gray-200)}[data-theme=dark] .msg-input-area{background:var(--color-white)}[data-theme=dark] .msg-input-field{background:var(--color-gray-100);color:var(--color-gray-900)}[data-theme=dark] .msg-send-btn{background:var(--color-primary)}[data-theme=dark] .msg-send-btn:hover{background:var(--color-primary-hover)}[data-theme=dark] .chat-panel{background:var(--color-gray-50)}[data-theme=dark] .sdp-modal-overlay .sdp-modal{background:var(--color-white)}[data-theme=dark] .sdp-modal-body input,[data-theme=dark] .sdp-modal-body select{background:var(--color-gray-100);color:var(--color-gray-900);border-color:var(--color-gray-300)}[data-theme=dark] .vu-badge--start{color:#4ade80;background:#22c55e15}[data-theme=dark] .vu-badge--stop,[data-theme=dark] .veh-del-btn{color:#f87171;background:#7f1d1d}[data-theme=dark] .vu-card{background:var(--color-gray-100)}[data-theme=dark] .sdp-perm-card{background:var(--color-white)}[data-theme=dark] .sdp-perm-card--pending{border-color:var(--color-warning);background:#422006}[data-theme=dark] .sdp-perm-status--pending{background:#78350f}[data-theme=dark] .sdp-perm-action{color:var(--color-warning)}[data-theme=dark] .sdp-perm-action--approve-btn{background:var(--color-warning);color:#fff}[data-theme=dark] .sdp-perm-status-badge--approved{color:#4ade80;background:#14532d}[data-theme=dark] .sdp-perm-status-badge--approved:hover{background:#166534}[data-theme=dark] .sdp-perm-status-badge--rejected{color:#f87171;background:#7f1d1d}[data-theme=dark] .sdp-perm-status-badge--rejected:hover{background:#991b1b}[data-theme=dark] .sdp-perm-upload-area{background:var(--color-gray-100)}[data-theme=dark] .sdp-perm-upload-note{background:#78350f}[data-theme=dark] .sdp-perm-modal{background:var(--color-white)}[data-theme=dark] .sdp-perm-confirm-btn{color:var(--color-warning)}[data-theme=dark] .sdp-perm-confirm-btn--yes{background:var(--color-warning)}[data-theme=dark] .sdp-perm-reject-reason{color:#fde68a;background:#78350f}[data-theme=dark] .sdp-perm-reject-reason:hover{background:#92400e}[data-theme=dark] .sdp-chat-bar{background:var(--color-gray-100)}[data-theme=dark] .sdp-chat-panel{background:var(--color-white)}[data-theme=dark] .sdp-chat-header{border-bottom-color:var(--color-gray-200);color:var(--color-gray-900)}[data-theme=dark] .sdp-chat-close{background:var(--color-gray-200);color:var(--color-gray-400)}[data-theme=dark] .sdp-chat-input{background:var(--color-white);border-top-color:var(--color-gray-200)}[data-theme=dark] .sdp-chat-input input{background:var(--color-gray-100);color:var(--color-gray-900);border-color:var(--color-gray-300)}[data-theme=dark] .sdp-msg-bubble{color:#e2e8f0;background:#2c2f4a}[data-theme=dark] .sdp-msg-bubble--me{background:var(--color-primary);color:#fff}[data-theme=dark] .sdp-msg-action-btn{background:var(--color-gray-200);color:var(--color-gray-400)}[data-theme=dark] .sdp-msg-edit-input{background:var(--color-gray-100);color:var(--color-gray-900)}[data-theme=dark] .sdp-msg-edit-cancel{background:var(--color-gray-200);color:var(--color-gray-700)}[data-theme=dark] .sdp-progress-section,[data-theme=dark] .sdp-cp-list{background:var(--color-white);box-shadow:0 2px 8px #00000040}[data-theme=dark] .sdp-cp-item{border-bottom-color:var(--color-gray-200)}[data-theme=dark] .sdp-cp-item.sdp-cp-done{background:#0f2b1a}[data-theme=dark] .sdp-cp-check{background:var(--color-white);border-color:var(--color-gray-400)}[data-theme=dark] .sdp-cp-notes-ro{background:var(--color-gray-100);color:var(--color-gray-400)}[data-theme=dark] .sdp-cp-expand{background:var(--color-gray-200);color:var(--color-gray-400)}[data-theme=dark] .sdp-photo-thumb{border-color:var(--color-gray-300)}[data-theme=dark] .sdp-veh-card{background:var(--color-white);border-color:var(--color-gray-300)}[data-theme=dark] .sdp-veh-card--active{background:#2a1f00;border-color:#d97706}[data-theme=dark] .sdp-veh-icon{background:#2a1f00}[data-theme=dark] .sdp-veh-admin-row{background:var(--color-white);border-color:var(--color-gray-300)}[data-theme=dark] .sdp-veh-admin-icon{background:#2a1f00}[data-theme=dark] .sdp-vehicle-mgmt-section{background:var(--color-white);border-color:var(--color-gray-200)}[data-theme=dark] .sdp-permits-section{background:var(--color-white)}[data-theme=dark] .checkin-location-warning{color:#fbbf24;background:#2a1500;border-color:#92400e}[data-theme=dark] .checkin-location-hint-box--warn{color:#fcd34d;background:#2a1500;border-color:#92400e}[data-theme=dark] .checkout-done,[data-theme=dark] .att-location-link--checkout{color:#fca5a5;background:#2d0a0a;border-color:#991b1b}[data-theme=dark] .sdp-shift-row{background:var(--color-gray-100);border-color:var(--color-gray-200)}[data-theme=dark] .sdp-shift-worker{color:var(--color-gray-900)}[data-theme=dark] .sdp-shifts-date{background:var(--color-gray-100);color:var(--color-gray-900)}[data-theme=dark] .sdp-events-toggle{background:var(--color-white);border-color:var(--color-gray-200);color:var(--color-gray-900)}[data-theme=dark] .sdp-events-toggle:hover{background:var(--color-gray-100)}[data-theme=dark] .sdp-event-row{border-bottom-color:var(--color-gray-200)}[data-theme=dark] .sdp-team-section{background:var(--color-white)}[data-theme=dark] .sdp-team-member{border-bottom-color:var(--color-gray-200)}[data-theme=dark] .sdp-action-btn--status{background:var(--color-gray-200);color:var(--color-gray-700)}[data-theme=dark] .sdp-action-btn--reactivate{color:#4ade80;background:#14532d}[data-theme=dark] .sdp-action-btn--delete{color:#f87171;background:#2d0a0a}[data-theme=dark] .sp-modal-close{background:var(--color-gray-200);color:var(--color-gray-400)}[data-theme=dark] .sp-modal-hicon{color:var(--color-primary);background:#1e3a5f}[data-theme=dark] .sp-manager-picker{border-color:var(--color-gray-200)}[data-theme=dark] .sp-mgr-opt{background:var(--color-gray-100)}[data-theme=dark] .sp-mgr-opt--active{background:#1e1a3e;border-color:#7c3aed}[data-theme=dark] .sp-wk-opt{background:var(--color-gray-100)}[data-theme=dark] .sp-wk-opt--active{border-color:var(--color-primary);background:#1e2a3a}.sdp-deadline-chip{vertical-align:middle;border-radius:10px;margin-left:8px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-block}.sdp-deadline-chip--ok{color:#15803d;background:#dcfce7}.sdp-deadline-chip--soon{color:#d97706;background:#fef3c7}.sdp-deadline-chip--overdue{color:#dc2626;background:#fee2e2}[data-theme=dark] .sdp-deadline-chip--ok{color:#4ade80;background:#14532d}[data-theme=dark] .sdp-deadline-chip--soon{color:#fbbf24;background:#78350f}[data-theme=dark] .sdp-deadline-chip--overdue{color:#f87171;background:#7f1d1d}.sdp-events-section{margin-top:20px}.sdp-events-toggle{width:100%;color:var(--color-gray-900);cursor:pointer;border-radius:var(--radius-md);background:0 0;background:var(--color-white);border:none;border:1px solid var(--color-gray-200);align-items:center;gap:8px;padding:12px 16px;font-size:.95rem;font-weight:600;display:flex}.sdp-events-toggle:hover{background:var(--color-gray-50)}.sdp-events-list{max-height:400px;margin-top:8px;overflow-y:auto}.sdp-event-row{border-bottom:1px solid var(--color-gray-100);flex-wrap:wrap;align-items:center;gap:6px;padding:8px 12px;font-size:.82rem;display:flex}.sdp-event-row:last-child{border-bottom:none}.sdp-event-type{min-width:120px;font-weight:600}.sdp-event-user{color:var(--color-primary);font-weight:500}.sdp-event-detail{color:var(--color-gray-500);font-style:italic}.sdp-event-time{color:var(--color-gray-400);white-space:nowrap;margin-left:auto;font-size:.75rem}.sdp-events-empty{text-align:center;color:var(--color-gray-400);padding:20px 0;font-size:.85rem}.sdp-events-more{text-align:center;width:100%;color:var(--color-primary);cursor:pointer;background:0 0;border:none;padding:10px;font-size:.85rem;font-weight:600;display:block}.sdp-events-more:hover{text-decoration:underline}.sdp-lightbox{z-index:10000;background:#000000eb;justify-content:center;align-items:center;animation:.2s sdpLbIn;display:flex;position:fixed;inset:0}@keyframes sdpLbIn{0%{opacity:0}to{opacity:1}}.sdp-lightbox-close{color:#fff;cursor:pointer;z-index:2;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:absolute;top:16px;right:16px}.sdp-lightbox-content{align-items:center;max-width:90vw;max-height:85vh;display:flex;position:relative}.sdp-lightbox-img{object-fit:contain;-webkit-user-select:none;user-select:none;border-radius:8px;max-width:90vw;max-height:85vh}.sdp-lightbox-nav{color:#fff;cursor:pointer;z-index:2;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.sdp-lightbox-prev{left:-54px}.sdp-lightbox-next{right:-54px}@media (width<=600px){.sdp-lightbox-prev{left:4px}.sdp-lightbox-next{right:4px}}.sdp-lightbox-counter{color:#ffffffb3;font-size:.85rem;font-weight:600;position:absolute;bottom:-32px;left:50%;transform:translate(-50%)}.sdp-shifts-body{margin-top:8px}.sdp-shifts-date-row{gap:8px;margin-bottom:10px;display:flex}.sdp-shifts-date{max-width:180px;font-size:.85rem}.sdp-shifts-empty{text-align:center;color:var(--color-gray-400);padding:12px 0;font-size:.85rem}.sdp-shifts-list{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.sdp-shift-row{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.sdp-shift-info{flex-direction:column;display:flex}.sdp-shift-worker{color:var(--color-gray-900);font-size:.88rem;font-weight:600}.sdp-shift-time{color:var(--color-gray-500);font-size:.78rem}.sdp-shift-del{color:var(--color-gray-400);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px}.sdp-shift-del:hover{color:#ef4444;background:#fef2f2}.sdp-shift-add{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.sdp-shift-select{flex:1;min-width:140px;font-size:.82rem}.sdp-shift-time-input{width:80px;font-size:.82rem}.sdp-shift-add-btn{white-space:nowrap;padding:6px 14px;font-size:.82rem}.workers-page{padding-bottom:90px}.workers-loading{color:var(--color-gray-500);flex-direction:column;justify-content:center;align-items:center;gap:14px;padding-top:80px;font-size:.9rem;display:flex}.workers-hero{color:#fff;background:linear-gradient(135deg,#0077c8 0%,#008ce3 60%,#33a8f5 100%);flex-direction:column;gap:16px;padding:20px;display:flex}.workers-hero-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.workers-hero-text h1{color:#fff;letter-spacing:-.3px;margin:0 0 2px;font-size:1.5rem;font-weight:800;line-height:1.1}.workers-hero-btn{color:#fff;cursor:pointer;white-space:nowrap;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff2e;border:1.5px solid #ffffff59;border-radius:20px;flex-shrink:0;align-items:center;gap:7px;padding:8px 14px;font-size:.82rem;font-weight:700;transition:background .2s,border-color .2s;display:flex}.workers-hero-btn:hover{background:#ffffff47;border-color:#ffffff8c}.workers-stats{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff1f;border-radius:14px;align-items:center;gap:0;padding:12px 16px;display:flex}.workers-stat{flex:1;align-items:center;gap:10px;display:flex}.workers-stat-divider{background:#ffffff4d;width:1px;height:36px;margin:0 16px}.workers-stat-icon{border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;padding:8px;display:flex}.workers-stat-icon--blue{color:#fff;background:#ffffff40}.workers-stat-icon--green{color:#6ee7b7;background:#34d3994d}.workers-stat-icon--yellow{color:#1a1a1a;background:#fff700}.workers-stat-icon--purple{color:#fff;background:#7c3aed40}.workers-stat-value{color:#fff;font-size:1.5rem;font-weight:800;line-height:1;display:block}.workers-stat-label{color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:.72rem;font-weight:600;display:block}.workers-list{flex-direction:column;gap:0;padding:16px 0 0;display:flex}.worker-card{background:#fff;border-radius:16px;margin-bottom:12px;transition:box-shadow .2s,transform .2s,opacity .2s;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000000f,0 0 0 1px #0000000a}.worker-card:hover{transform:translateY(-1px);box-shadow:0 4px 20px #0000001a,0 0 0 1px #0000000d}.worker-card--deleting{opacity:.5;pointer-events:none}.worker-card-accent{border-radius:4px 0 0 4px;width:4px;height:100%;position:absolute;top:0;left:0}.worker-card-body{align-items:center;gap:14px;padding:16px 14px 14px 18px;display:flex}.worker-avatar{letter-spacing:-.5px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex;box-shadow:0 2px 8px #0003}.worker-info{flex:1;min-width:0}.worker-name{color:var(--color-gray-900);white-space:nowrap;text-overflow:ellipsis;margin:0 0 2px;font-size:1rem;font-weight:700;overflow:hidden}.worker-username{color:var(--color-gray-400);margin-bottom:3px;font-size:.78rem;font-weight:500;display:block}.worker-phone{color:var(--color-primary);background:#eff8ff;border-radius:20px;align-items:center;gap:4px;margin-top:2px;padding:2px 8px;font-size:.8rem;font-weight:600;text-decoration:none;display:inline-flex}.worker-phone:hover{background:#dbeafe}.worker-delete-btn{color:var(--color-gray-300);cursor:pointer;background:0 0;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:9px;transition:background .15s,color .15s;display:flex}.worker-delete-btn:hover{color:#dc2626;background:#fee2e2}.worker-sites{border-top:1px solid #f1f5f9;flex-direction:column;gap:8px;padding:10px 18px 14px;display:flex}.worker-sites-label{color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.6px;align-items:center;gap:5px;font-size:.7rem;font-weight:700;display:inline-flex}.worker-sites-tags{flex-wrap:wrap;gap:6px;display:flex}.worker-site-tag{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:20px;align-items:center;padding:4px 11px;font-size:.78rem;font-weight:600;display:inline-flex}.worker-no-sites{color:var(--color-gray-400);border-top:1px solid #f1f5f9;padding:8px 18px 12px;font-size:.78rem;font-style:italic}.workers-empty{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:60px 24px 40px;display:flex}.workers-empty-icon{width:88px;height:88px;color:var(--color-primary);background:#eff8ff;border-radius:50%;justify-content:center;align-items:center;margin-bottom:8px;display:flex}.workers-empty h3{color:var(--color-gray-700);margin:0;font-size:1.1rem;font-weight:700}.workers-empty p{color:var(--color-gray-500);max-width:260px;margin:0 0 12px;font-size:.88rem;line-height:1.5}.wk-overlay{z-index:300;background:#0000008c;justify-content:center;align-items:flex-end;padding:0;animation:.2s wkFadeIn;display:flex;position:fixed;inset:0}@keyframes wkFadeIn{0%{opacity:0}to{opacity:1}}.wk-sheet{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:480px;max-height:92dvh;padding:0 0 32px;animation:.28s cubic-bezier(.32,.72,0,1) wkSlideUp;overflow-y:auto;box-shadow:0 -8px 40px #0000002e}.wk-sheet--sm{text-align:center;padding:0 24px 28px}@keyframes wkSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.wk-sheet-handle{background:#e5e7eb;border-radius:99px;width:40px;height:4px;margin:12px auto 0}.wk-modal-header{border-bottom:1px solid #f3f4f6;align-items:center;gap:14px;padding:20px 20px 16px;display:flex}.wk-modal-titles{flex:1;min-width:0}.wk-modal-title{color:#111827;margin:0 0 2px;font-size:1.05rem;font-weight:800}.wk-modal-sub{color:#9ca3af;margin:0;font-size:.8rem}.wk-modal-close{color:#6b7280;cursor:pointer;background:#f3f4f6;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s;display:flex}.wk-modal-close:hover{color:#111827;background:#e5e7eb}.wk-modal-actions{gap:10px;margin-top:4px;padding:0 20px;display:flex}.wk-modal-actions .btn{flex:1}.worker-form{flex-direction:column;gap:16px;padding:20px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-label{color:#4b5563;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:5px;margin-bottom:7px;font-size:.75rem;font-weight:700;display:flex}.form-label-at{color:#9ca3af;font-size:.88rem;font-weight:800}.input-with-icon{position:relative}.input-with-icon .form-input{padding-right:40px}.input-icon-btn{cursor:pointer;color:#9ca3af;background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.input-icon-btn:hover{color:#374151}.input-static-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.form-error-banner{color:#dc2626;background:#fef2f2;border:1.5px solid #fecaca;border-radius:10px;align-items:center;gap:8px;padding:10px 14px;font-size:.84rem;font-weight:600;display:flex}.delete-modal-icon{color:#dc2626;background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;margin:20px auto 16px;display:flex}.delete-modal-title{color:#111827;margin:0 0 10px;font-size:1.15rem;font-weight:800}.confirm-text{color:#6b7280;margin:0 0 24px;font-size:.9rem;line-height:1.6}.btn-danger{color:#fff;background:#dc2626;border:none;align-items:center;gap:6px;display:flex}.btn-danger:hover{background:#b91c1c}.wk-tabs{background:var(--color-gray-100);border-radius:12px;gap:8px;margin:16px 0 4px;padding:4px;display:flex}.wk-tab{color:var(--color-gray-500);background:0 0;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.wk-tab-active{background:var(--color-white);color:var(--color-primary);box-shadow:0 1px 4px #0000001a}.wk-mgr-badge{text-transform:uppercase;letter-spacing:.5px;color:#7c3aed;background:#7c3aed22;border-radius:6px;padding:2px 6px;font-size:.65rem;font-weight:700}.wk-manager-sites{color:#7c3aed;background:#7c3aed0d;border-radius:6px;align-items:center;gap:6px;margin-top:4px;padding:4px 8px;font-size:.75rem;display:flex}.wk-manager-sites svg{flex-shrink:0}.workers-hero-text h1{color:#fff;margin:0 0 2px;font-size:1.5rem;font-weight:800}.workers-hero-text p{color:#ffffffbf;margin:0;font-size:.84rem}.workers-stat-val{color:#fff;font-size:1.5rem;font-weight:800;line-height:1;display:block}.workers-toolbar{justify-content:flex-end;padding:12px 0 4px;display:flex}.wk-search-wrap{align-items:center;margin-top:20px;margin-bottom:12px;display:flex;position:relative}.wk-search-icon{color:var(--color-gray-400);pointer-events:none;position:absolute;left:12px}.wk-search{border:1.5px solid var(--color-gray-200);border-radius:var(--radius-md);background:var(--color-white);width:100%;color:var(--color-gray-800);outline:none;padding:10px 36px;font-size:.88rem;transition:border-color .2s}.wk-search:focus{border-color:var(--color-primary)}.wk-search-clear{cursor:pointer;color:var(--color-gray-400);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;right:10px}[data-theme=dark] .wk-search{background:var(--color-gray-100);border-color:var(--color-gray-600);color:var(--color-gray-100)}.wk-card{background:#fff;border-radius:16px;align-items:stretch;margin-bottom:12px;transition:box-shadow .2s,transform .15s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000000f,0 0 0 1px #0000000a}.wk-card:hover{transform:translateY(-1px);box-shadow:0 4px 18px #0000001a}.wk-card-mgr{border-left:none}.wk-card-accent{background:var(--color-primary);border-radius:4px 0 0 4px;flex-shrink:0;width:4px}.wk-card-accent-purple{background:#7c3aed}.wk-avatar{letter-spacing:-.5px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;margin:auto 0 auto 14px;font-size:.95rem;font-weight:800;display:flex;box-shadow:0 2px 8px #0000001f}.wk-card-body{flex:1;min-width:0;padding:14px 12px 12px}.wk-card-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.wk-card-name{color:var(--color-gray-900);margin:0;font-size:.95rem;font-weight:700}.wk-card-phone{color:var(--color-gray-500);align-items:center;gap:4px;margin-top:2px;font-size:.78rem;display:flex}.wk-delete-btn{color:#ef4444;background:#fff0f0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:background .15s;display:flex}.wk-delete-btn:hover{background:#fee2e2}.wk-sites{flex-wrap:wrap;gap:5px;display:flex}.wk-site-tag{border-radius:999px;padding:3px 9px;font-size:.74rem;font-weight:600}.wk-site-tag-active{color:#1d4ed8;background:#dbeafe}.wk-site-tag-done{background:var(--color-gray-100);color:var(--color-gray-500)}.wk-no-sites{color:var(--color-gray-400);font-size:.78rem;font-style:italic}.wk-modal{background:var(--color-white);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:24px 24px calc(env(safe-area-inset-bottom,0px) + 80px);width:100%;max-width:480px;max-height:88dvh;animation:.3s slideUp;overflow-y:auto}.wk-modal-sm{max-height:60dvh}.wk-modal-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.wk-modal-icon{width:42px;height:42px;color:var(--color-primary);background:#dbeafe;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.wk-modal-icon--danger{color:#ef4444;background:#fee2e2}.wk-modal-title{flex:1;margin:0;font-size:1.15rem;font-weight:700}.wk-modal-close{background:var(--color-gray-100);width:32px;height:32px;color:var(--color-gray-500);border-radius:50%;justify-content:center;align-items:center;margin-left:auto;display:flex}.wk-modal-body{flex-direction:column;gap:4px;display:flex}.wk-delete-text{color:var(--color-gray-700);font-size:.95rem;line-height:1.5}[data-theme=dark] .workers-hero{background:linear-gradient(135deg,#0a2a4a 0%,#1a3a5a 60%,#1e4a6e 100%)}[data-theme=dark] .worker-card,[data-theme=dark] .wk-card{background:var(--color-white);box-shadow:0 2px 12px #0000004d}[data-theme=dark] .worker-phone{background:var(--badge-info-bg);color:var(--color-primary)}[data-theme=dark] .worker-phone:hover{background:var(--badge-info-bg)}[data-theme=dark] .worker-delete-btn:hover{background:var(--badge-danger-bg);color:var(--color-danger)}[data-theme=dark] .worker-sites{border-top-color:var(--color-gray-200)}[data-theme=dark] .worker-site-tag{background:var(--badge-info-bg);color:#93c5fd;border-color:#2563eb}[data-theme=dark] .worker-no-sites{border-top-color:var(--color-gray-200)}[data-theme=dark] .workers-empty-icon{background:var(--badge-info-bg)}[data-theme=dark] .wk-sheet{background:var(--color-white)}[data-theme=dark] .wk-sheet-handle{background:var(--color-gray-300)}[data-theme=dark] .wk-modal-header{border-bottom-color:var(--color-gray-200)}[data-theme=dark] .wk-modal-icon{background:var(--badge-info-bg)}[data-theme=dark] .wk-modal-icon--danger{background:var(--badge-danger-bg)}[data-theme=dark] .wk-modal-close{background:var(--color-gray-200)}[data-theme=dark] .wk-modal{background:var(--color-white)}[data-theme=dark] .wk-modal-title{color:var(--color-gray-900)}[data-theme=dark] .wk-modal-sub{color:var(--color-gray-500)}[data-theme=dark] .wk-site-tag-active{background:var(--badge-info-bg);color:#93c5fd}[data-theme=dark] .wk-delete-btn{color:#f87171;background:#7f1d1d}[data-theme=dark] .wk-delete-btn:hover{background:#991b1b}[data-theme=dark] .form-error-banner{background:var(--badge-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}[data-theme=dark] .form-label{color:var(--color-gray-600)}[data-theme=dark] .delete-modal-icon{background:var(--badge-danger-bg);color:var(--color-danger)}[data-theme=dark] .delete-modal-title{color:var(--color-gray-900)}[data-theme=dark] .confirm-text{color:var(--color-gray-500)}[data-theme=dark] .workers-add-btn{color:#1a1a1a;background:#fff700}[data-theme=dark] .wk-mgr-badge{color:#c4b5fd;background:#3b1f7e44}[data-theme=dark] .wk-manager-sites{color:#c4b5fd;background:#3b1f7e22}.wk-notes-section{margin-top:8px}.wk-notes-toggle{color:var(--color-gray-400);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:6px;width:100%;padding:4px 0;font-size:.78rem;display:flex}.wk-notes-toggle:hover{color:var(--color-primary)}.wk-notes-preview{color:var(--color-gray-600);white-space:nowrap;text-overflow:ellipsis;max-width:220px;font-style:italic;overflow:hidden}.wk-notes-placeholder{color:var(--color-gray-400)}.wk-notes-edit{margin-top:4px}.wk-notes-textarea{border:1px solid var(--color-gray-200);resize:vertical;background:var(--color-white);width:100%;color:var(--color-gray-900);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:.82rem}.wk-notes-textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #008ce31a}.wk-notes-actions{gap:8px;margin-top:6px;display:flex}.wk-notes-save,.wk-notes-cancel{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.wk-notes-save{background:var(--color-primary);color:#fff}.wk-notes-save:hover{opacity:.9}.wk-notes-cancel{background:var(--color-gray-100);color:var(--color-gray-600)}.wk-notes-cancel:hover{background:var(--color-gray-200)}[data-theme=dark] .wk-notes-textarea{background:var(--color-gray-100);color:var(--color-gray-900);border-color:var(--color-gray-300)}.wk-vehicle-access-badge{align-items:center;margin-top:6px;display:inline-flex}.wk-vehicle-access-badge span{color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}[data-theme=dark] .wk-vehicle-access-badge span{color:#fcd34d;background:#451a03;border-color:#78350f}.wk-vehicle-toggle-btn{border:1px solid var(--color-gray-300);color:var(--color-gray-500);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:4px;margin-top:6px;padding:3px 10px;font-size:11px;font-weight:500;transition:all .15s;display:inline-flex}.wk-vehicle-toggle-btn:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.wk-vehicle-toggle-btn.wk-vehicle-toggle-on{color:#92400e;background:#fef3c7;border-color:#fde68a}.wk-vehicle-toggle-btn.wk-vehicle-toggle-on:hover{opacity:.8}[data-theme=dark] .wk-vehicle-toggle-btn.wk-vehicle-toggle-on{color:#fcd34d;background:#451a03;border-color:#78350f}.wk-toggle-row{justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.wk-toggle-label{flex-direction:column;flex:1;gap:2px;display:flex}.wk-toggle-label span:first-child{color:var(--color-gray-900);font-size:14px;font-weight:500}.wk-toggle-desc{color:var(--color-gray-500);font-size:12px}.wk-toggle-btn{background:var(--color-gray-300);cursor:pointer;border:none;border-radius:12px;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .2s;position:relative}.wk-toggle-btn.wk-toggle-on{background:var(--color-primary)}.wk-toggle-thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.wk-toggle-btn.wk-toggle-on .wk-toggle-thumb{transform:translate(20px)}.prof-page{background:var(--color-gray-50);width:100%;min-height:100vh;padding-bottom:100px;overflow-x:hidden}.prof-hero{width:100%;margin-top:-58px;position:relative;overflow:hidden}.prof-hero-bg{background:linear-gradient(135deg,#1d4ed8 0%,#7c3aed 60%,#a855f7 100%);position:absolute;inset:0}.prof-hero-body{text-align:center;box-sizing:border-box;flex-direction:column;align-items:center;width:100%;padding:80px 20px 36px;display:flex;position:relative}.prof-avatar{color:#fff;letter-spacing:-.02em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff2e;border:3px solid #ffffff73;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:14px;font-size:1.8rem;font-weight:800;display:flex}.prof-name{color:#fff;letter-spacing:-.02em;text-shadow:0 1px 6px #0003;margin:0 0 10px;font-size:1.35rem;font-weight:800}.prof-meta{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-bottom:14px;display:flex}.prof-role-badge{color:#fff;text-transform:uppercase;letter-spacing:.06em;background:#fff3;border:1px solid #ffffff59;border-radius:20px;padding:4px 12px;font-size:.7rem;font-weight:700}.prof-phone{color:#ffffffd9;align-items:center;gap:5px;font-size:.78rem;font-weight:600;text-decoration:none;display:flex}.prof-phone:hover{color:#fff}.prof-edit-trigger{color:#ffffffd9;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .15s;display:inline-flex}.prof-edit-trigger:hover{background:#ffffff40}.prof-edit-form{flex-direction:column;align-items:center;gap:10px;width:100%;max-width:300px;display:flex}.prof-edit-input{color:#fff;text-align:center;box-sizing:border-box;background:#ffffff26;border:1px solid #fff6;border-radius:10px;outline:none;width:100%;padding:9px 13px;font-family:inherit;font-size:.95rem;font-weight:600}.prof-edit-input::placeholder{color:#ffffff80}.prof-edit-input--sm{font-size:.82rem;font-weight:500}.prof-edit-input:focus{background:#ffffff38;border-color:#ffffffbf}.prof-edit-phone-row{color:#ffffffb3;align-items:center;gap:8px;width:100%;display:flex}.prof-edit-phone-row .prof-edit-input{flex:1}.prof-edit-error{color:#fca5a5;margin:0;font-size:.77rem;font-weight:600}.prof-edit-actions{gap:8px;display:flex}.prof-edit-btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:5px;padding:8px 16px;font-family:inherit;font-size:.78rem;font-weight:700;transition:opacity .15s;display:inline-flex}.prof-edit-btn--save{color:#1d4ed8;background:#fff}.prof-edit-btn--cancel{color:#fff;background:#ffffff26;border:1px solid #ffffff4d}.prof-edit-btn:disabled{opacity:.6;cursor:not-allowed}.prof-content{flex-direction:column;gap:14px;padding:16px 14px 0;display:flex}.prof-actions-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.prof-action-tile{background:var(--color-white);border:1px solid var(--color-gray-100);cursor:pointer;border-radius:16px;flex-direction:column;align-items:center;gap:7px;padding:14px 6px 12px;font-family:inherit;transition:box-shadow .15s,transform .12s;display:flex;box-shadow:0 1px 4px #0000000d}.prof-action-tile:hover{transform:translateY(-2px);box-shadow:0 4px 14px #0000001a}.prof-action-tile:active{transform:translateY(0)}.prof-action-icon{border-radius:13px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.prof-action-label{color:var(--color-gray-600);text-align:center;font-size:.65rem;font-weight:700;line-height:1.2}.prof-card{background:var(--color-white);border:1px solid var(--color-gray-100);border-radius:18px;overflow:hidden;box-shadow:0 1px 4px #0000000d}.prof-card-title{text-transform:uppercase;letter-spacing:.07em;color:var(--color-gray-400);border-bottom:1px solid var(--color-gray-100);padding:13px 16px 10px;font-size:.68rem;font-weight:800}.prof-info-row{border-bottom:1px solid var(--color-gray-100);justify-content:space-between;align-items:center;padding:13px 16px;display:flex}.prof-info-row:last-child{border-bottom:none}.prof-info-label{color:var(--color-gray-500);align-items:center;gap:6px;font-size:.83rem;font-weight:500;display:flex}.prof-info-value{color:var(--color-gray-800);font-size:.88rem;font-weight:700}.prof-info-phone{color:var(--color-primary);font-size:.88rem;font-weight:700;text-decoration:none}.prof-info-phone:hover{text-decoration:underline}.prof-section-toggle{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:14px 16px;font-family:inherit;display:flex}.prof-section-toggle-icon{color:#7c3aed;background:#ede9fe;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.prof-section-toggle-label{color:var(--color-gray-800);flex:1;font-size:.88rem;font-weight:700}.prof-section-chevron{color:var(--color-gray-400);font-size:1.3rem;line-height:1;transition:transform .2s;display:inline-block}.prof-section-chevron--open{transform:rotate(90deg)}.prof-pw-form{border-top:1px solid var(--color-gray-100);flex-direction:column;gap:13px;padding:4px 16px 18px;display:flex}.prof-pw-field{flex-direction:column;gap:5px;display:flex}.prof-pw-label{color:var(--color-gray-500);font-size:.78rem;font-weight:600}.prof-input{border:1.5px solid var(--color-gray-200);width:100%;color:var(--color-gray-800);background:var(--color-gray-50);box-sizing:border-box;border-radius:11px;outline:none;padding:11px 14px;font-family:inherit;font-size:.88rem;transition:border-color .15s,box-shadow .15s}.prof-input:focus{border-color:var(--color-primary);background:var(--color-white);box-shadow:0 0 0 3px #3b82f626}.prof-pw-wrap{align-items:center;display:flex;position:relative}.prof-pw-wrap .prof-input{padding-right:44px}.prof-pw-eye{cursor:pointer;color:var(--color-gray-400);background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;right:12px}.prof-pw-eye:hover{color:var(--color-gray-600)}.prof-btn-primary{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:12px;font-family:inherit;font-size:.9rem;font-weight:700;transition:opacity .15s}.prof-btn-primary:hover{opacity:.88}.prof-btn-primary:disabled{opacity:.55;cursor:not-allowed}.prof-alert{border-radius:10px;align-items:center;gap:8px;padding:9px 13px;font-size:.82rem;font-weight:600;display:flex}.prof-alert--ok{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.prof-alert--err{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.prof-logout{color:#dc2626;cursor:pointer;background:#fee2e2;border:none;border-radius:16px;justify-content:center;align-items:center;gap:9px;width:100%;padding:14px;font-family:inherit;font-size:.92rem;font-weight:700;transition:background .15s,transform .1s;display:flex}.prof-logout:hover{background:#fecaca;transform:scale(.99)}.prof-version{text-align:center;color:var(--color-gray-300);margin:4px 0 0;font-size:.7rem}[data-theme=dark] .prof-page{background:#11131f}[data-theme=dark] .prof-action-tile{background:#1a1d2e;border-color:#252840}[data-theme=dark] .prof-action-label{color:#94a3b8}[data-theme=dark] .prof-card{background:#1a1d2e;border-color:#252840}[data-theme=dark] .prof-card-title{color:#475569;border-bottom-color:#252840}[data-theme=dark] .prof-info-row{border-bottom-color:#252840}[data-theme=dark] .prof-info-label{color:#64748b}[data-theme=dark] .prof-info-value,[data-theme=dark] .prof-section-toggle-label{color:#e2e8f0}[data-theme=dark] .prof-section-toggle-icon{color:#a78bfa;background:#2d2060}[data-theme=dark] .prof-section-chevron{color:#475569}[data-theme=dark] .prof-pw-form{border-top-color:#252840}[data-theme=dark] .prof-pw-label{color:#64748b}[data-theme=dark] .prof-input{color:#e2e8f0;background:#11131f;border-color:#2d3148}[data-theme=dark] .prof-input:focus{border-color:var(--color-primary);background:#1a1d2e}[data-theme=dark] .prof-pw-eye{color:#475569}[data-theme=dark] .prof-alert--ok{color:#86efac;background:#0a2018;border-color:#166534}[data-theme=dark] .prof-alert--err{color:#fca5a5;background:#2d1515;border-color:#7f1d1d}[data-theme=dark] .prof-logout{color:#f87171;background:#2d1515}[data-theme=dark] .prof-logout:hover{background:#3b1a1a}[data-theme=dark] .prof-version{color:#334155}.pp-page{background:var(--color-gray-50);min-height:100vh;padding:0 0 90px}.pp-hero{border-bottom:1px solid var(--color-gray-100);background:#fff;align-items:center;gap:16px;padding:20px 20px 16px;display:flex}.pp-hero-icon{width:52px;height:52px;color:var(--color-primary);background:#dbeafe;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pp-hero-title{color:var(--color-gray-900);margin:0 0 2px;font-size:1.25rem;font-weight:800}.pp-hero-sub{color:var(--color-gray-500);margin:0;font-size:.82rem}.pp-view-tabs{border-bottom:1px solid var(--color-gray-100);background:#fff;gap:6px;padding:12px 16px 0;display:flex}.pp-view-tab{cursor:pointer;color:var(--color-gray-500);background:0 0;border:none;border-bottom:2px solid #0000;border-radius:10px 10px 0 0;align-items:center;gap:5px;padding:7px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:color .15s,border-color .15s;display:inline-flex}.pp-view-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:#f0f7ff}.pp-content{flex-direction:column;gap:14px;padding:16px;display:flex}.pp-site-section{background:#fff;border-radius:16px;padding:14px 16px;box-shadow:0 1px 4px #0000000f}.pp-site-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.pp-site-title{color:var(--color-gray-800);flex:1;align-items:center;gap:7px;min-width:0;font-size:.95rem;font-weight:700;display:flex}.pp-site-title>span:not(.pp-permits-count){white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.pp-permits-count{background:var(--color-primary);color:#fff;text-align:center;border-radius:99px;flex-shrink:0;min-width:20px;padding:1px 7px;font-size:.7rem;font-weight:700}.pp-permits-count--archived{background:var(--color-gray-400)}.pp-site-header-actions{flex-shrink:0;align-items:center;gap:7px;display:flex}.pp-toggle-archived-btn{border:1px solid var(--color-gray-200);color:var(--color-gray-500);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:5px;padding:5px 10px;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.pp-toggle-archived-btn:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.pp-toggle-archived-btn--full{justify-content:center;width:100%;padding:9px 14px;font-size:.82rem}.pp-archived-divider{color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;padding:4px 0 2px;font-size:.72rem;font-weight:600;display:flex}.pp-archived-section{flex-direction:column;gap:14px;display:flex}.pp-upload-wrap{flex-shrink:0}.pp-upload-btn{background:var(--color-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:6px;padding:7px 13px;font-family:inherit;font-size:.8rem;font-weight:600;transition:opacity .15s;display:inline-flex}.pp-upload-btn:hover{opacity:.88}.pp-upload-btn--loading{opacity:.7;cursor:default}.pp-permits-loading{text-align:center;color:var(--color-gray-400);padding:16px 0;font-size:.85rem}.pp-permits-empty{color:var(--color-gray-400);flex-direction:column;align-items:center;gap:8px;padding:20px 0;font-size:.85rem;display:flex}.pp-permits-list{flex-direction:column;gap:8px;display:flex}.pp-permit-item{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:12px;align-items:center;gap:12px;padding:10px 12px;transition:opacity .2s;display:flex}.pp-permit-item--archived{opacity:.55}.pp-permit-icon{width:38px;height:38px;color:var(--color-primary);background:#dbeafe;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pp-permit-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.pp-permit-name{color:var(--color-gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.pp-permit-meta{color:var(--color-gray-500);font-size:.7rem}.pp-permit-site-tag{color:var(--color-primary);font-weight:600}.pp-permit-archived-badge{color:var(--color-gray-400);font-style:italic}.pp-permit-size{color:var(--color-text-secondary);font-weight:600}.pp-permit-actions{flex-shrink:0;gap:6px;display:flex}.pp-permit-action-btn{background:var(--color-gray-100);width:32px;height:32px;color:var(--color-gray-600);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;text-decoration:none;transition:background .15s,color .15s;display:flex}.pp-permit-action-btn:hover{color:var(--color-primary);background:#dbeafe}.pp-permit-action-btn--archive{background:var(--color-gray-100);color:var(--color-gray-500)}.pp-permit-action-btn--archive:hover{color:#b45309;background:#fef3c7}.pp-permit-action-btn--unarchive:hover{color:#166534;background:#dcfce7}.pp-permit-action-btn--del{border:none;font-family:inherit}.pp-permit-action-btn--del:hover{color:#dc2626;background:#fee2e2}.pp-list-date-group{flex-direction:column;gap:6px;display:flex}.pp-list-date-label{color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.06em;padding:0 2px;font-size:.75rem;font-weight:700}.pp-list-date-group--archived .pp-list-date-label{color:var(--color-gray-400)}.pp-cal{background:#fff;border-radius:16px;padding:16px;box-shadow:0 1px 4px #0000000f}.pp-cal-nav{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.pp-cal-month-label{color:var(--color-gray-800);font-size:.95rem;font-weight:700}.pp-cal-nav-btn{border:1px solid var(--color-gray-200);width:34px;height:34px;color:var(--color-gray-600);cursor:pointer;background:0 0;border-radius:9px;justify-content:center;align-items:center;transition:background .15s;display:flex}.pp-cal-nav-btn:hover{background:var(--color-gray-100)}.pp-cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.pp-cal-dow{color:var(--color-gray-400);text-align:center;text-transform:uppercase;padding:4px 0;font-size:.68rem;font-weight:700}.pp-cal-cell{aspect-ratio:1;color:var(--color-gray-700);cursor:pointer;background:0 0;border:none;border-radius:9px;flex-direction:column;justify-content:center;align-items:center;gap:1px;font-family:inherit;font-size:.82rem;font-weight:500;transition:background .12s,color .12s;display:flex;position:relative}.pp-cal-cell--empty{cursor:default}.pp-cal-cell:not(.pp-cal-cell--empty):hover{background:var(--color-gray-100)}.pp-cal-cell--has{color:var(--color-primary);font-weight:700}.pp-cal-cell--today{background:#f0f7ff;font-weight:700}.pp-cal-cell--selected{background:var(--color-primary)!important;color:#fff!important}.pp-cal-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:4px;height:4px;display:block}.pp-cal-cell--selected .pp-cal-dot{background:#fffc}.pp-cal-day-panel{background:#fff;border-radius:16px;padding:14px 16px;box-shadow:0 1px 4px #0000000f}.pp-cal-day-label{color:var(--color-gray-800);align-items:center;gap:7px;margin-bottom:12px;font-size:.9rem;font-weight:700;display:flex}.pp-cal-hint{color:var(--color-gray-400);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:32px 20px;font-size:.88rem;display:flex}.pp-cal-hint p{margin:0}.pp-global-loading,.pp-global-empty{color:var(--color-gray-400);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;font-size:.9rem;display:flex}[data-theme=dark] .pp-hero{background:#1e2035;border-bottom-color:#ffffff14}[data-theme=dark] .pp-hero-icon{background:var(--badge-info-bg)}[data-theme=dark] .pp-view-tabs{background:#1e2035;border-bottom-color:#ffffff14}[data-theme=dark] .pp-view-tab--active{background:#3b9fe81f}[data-theme=dark] .pp-site-section{background:var(--color-white)}[data-theme=dark] .pp-permit-item{background:var(--color-gray-100);border-color:var(--color-gray-200)}[data-theme=dark] .pp-permit-icon{background:var(--badge-info-bg)}[data-theme=dark] .pp-permit-action-btn{background:var(--color-gray-200);color:var(--color-gray-600)}[data-theme=dark] .pp-permit-action-btn:hover{background:var(--badge-info-bg);color:var(--color-primary)}[data-theme=dark] .pp-permit-action-btn--del:hover{background:var(--badge-danger-bg);color:var(--color-danger)}[data-theme=dark] .pp-cal{background:var(--color-white)}[data-theme=dark] .pp-cal-nav-btn{color:var(--color-gray-400);border-color:#ffffff1a}[data-theme=dark] .pp-cal-nav-btn:hover,[data-theme=dark] .pp-cal-cell:not(.pp-cal-cell--empty):hover{background:#ffffff12}[data-theme=dark] .pp-cal-cell--today{background:#3b9fe81a}[data-theme=dark] .pp-cal-day-panel{background:var(--color-white)}[data-theme=dark] .pp-toggle-archived-btn{color:var(--color-gray-400);border-color:#ffffff1a}[data-theme=dark] .pp-toggle-archived-btn:hover{color:var(--color-gray-300);background:#ffffff12}.rp-page{background:var(--color-gray-50);min-height:100vh;padding:0 0 100px}.rp-hero{border-bottom:1px solid var(--color-gray-100);background:#fff;align-items:center;gap:14px;padding:20px 20px 16px;display:flex}.rp-hero-icon{width:50px;height:50px;color:var(--color-primary);background:#dbeafe;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.rp-hero-title{color:var(--color-gray-900);margin:0 0 2px;font-size:1.2rem;font-weight:800}.rp-hero-sub{color:var(--color-gray-500);margin:0;font-size:.8rem}.rp-filters{border-bottom:1px solid var(--color-gray-100);background:#fff;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 16px;display:flex}.rp-presets{gap:6px;display:flex}.rp-preset-btn{border:1.5px solid var(--color-gray-200);color:var(--color-gray-600);cursor:pointer;background:#fff;border-radius:20px;padding:5px 12px;font-family:inherit;font-size:.78rem;font-weight:600;transition:all .15s}.rp-preset-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.rp-date-range{align-items:center;gap:8px;margin-left:auto;display:flex}.rp-date-input{border:1.5px solid var(--color-gray-200);color:var(--color-gray-700);background:#fff;border-radius:8px;outline:none;padding:5px 8px;font-family:inherit;font-size:.78rem}.rp-date-input:focus{border-color:var(--color-primary)}.rp-date-sep{color:var(--color-gray-400);font-size:.85rem}.rp-content{flex-direction:column;gap:12px;padding:14px 16px;display:flex}.rp-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-gray-500);align-items:center;gap:6px;margin-top:4px;font-size:.82rem;font-weight:700;display:flex}.rp-section-header{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.rp-sort-btns{gap:4px;display:flex}.rp-sort-btn{border:1.5px solid var(--color-gray-200);color:var(--color-gray-500);cursor:pointer;background:#fff;border-radius:8px;padding:4px 9px;font-family:inherit;font-size:.72rem;font-weight:600;transition:all .15s}.rp-sort-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.rp-export-btn{color:#15803d;background:#dcfce7;border-color:#86efac;align-items:center;gap:4px;font-weight:600;display:inline-flex}.rp-export-btn:hover{background:#bbf7d0}.rp-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 1px 4px #0000000f}.rp-card--flush{padding:0;overflow:hidden}.rp-stats-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.rp-stat-card{background:#fff;border-radius:14px;align-items:center;gap:12px;padding:14px;display:flex;box-shadow:0 1px 4px #0000000f}.rp-stat-icon{background:var(--rsi-bg);width:42px;height:42px;color:var(--rsi-color);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}[data-theme=dark] .rp-stat-icon{background:color-mix(in srgb, var(--rsi-color) 25%, #0d0d1a);color:color-mix(in srgb, var(--rsi-color) 90%, #fff)}.rp-stat-info{flex-direction:column;gap:1px;min-width:0;display:flex}.rp-stat-value{color:var(--color-gray-900);font-size:1.4rem;font-weight:800;line-height:1}.rp-stat-label{color:var(--color-gray-500);font-size:.72rem;font-weight:500}.rp-stat-sub{color:var(--color-gray-400);font-size:.65rem}.rp-highlights{gap:10px;display:flex}.rp-highlight-card{border-radius:14px;flex:1;align-items:flex-start;gap:10px;padding:14px;font-size:.82rem;display:flex}.rp-highlight--gold{color:#92400e;background:linear-gradient(135deg,#fef3c7,#fde68a)}.rp-highlight--blue{color:#1e40af;background:linear-gradient(135deg,#dbeafe,#bfdbfe)}[data-theme=dark] .rp-highlight--gold{color:#fcd34d;background:#ca8a0426}[data-theme=dark] .rp-highlight--blue{color:#93c5fd;background:#2563eb26}.rp-highlight-label{opacity:.75;text-transform:uppercase;letter-spacing:.4px;font-size:.7rem;font-weight:600}.rp-highlight-value{margin:2px 0;font-size:1rem;font-weight:800}.rp-highlight-sub{opacity:.7;font-size:.7rem}.rp-chart{flex-direction:column;gap:6px;display:flex}.rp-chart-bars{align-items:flex-end;gap:3px;height:100px;padding-bottom:4px;display:flex}.rp-bar-col{flex-direction:column;flex:1;align-items:center;gap:3px;height:100%;display:flex}.rp-bar-wrap{flex:1;align-items:flex-end;width:100%;display:flex}.rp-bar{background:var(--color-primary);opacity:.85;border-radius:3px 3px 0 0;width:100%;min-height:0;transition:height .4s}.rp-bar-label{color:var(--color-gray-400);white-space:nowrap;transform-origin:top;font-size:.58rem;transform:rotate(-35deg)}.rp-chart-legend{justify-content:flex-end;display:flex}.rp-chart-max{color:var(--color-gray-400);font-size:.7rem}.rp-ring{flex-shrink:0}.rp-worker-list{flex-direction:column;display:flex}.rp-worker-row{text-align:left;cursor:pointer;border:none;border-bottom:1px solid var(--color-gray-50);background:0 0;align-items:center;gap:10px;width:100%;padding:12px 16px;font-family:inherit;transition:background .12s;display:flex}.rp-worker-row:last-child{border-bottom:none}.rp-worker-row:hover{background:var(--color-gray-50)}.rp-worker-rank{color:var(--color-gray-400);min-width:22px;font-size:.7rem;font-weight:700}.rp-worker-avatar{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.75rem;font-weight:700;display:flex}.rp-worker-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.rp-worker-name{color:var(--color-gray-800);font-size:.88rem;font-weight:700}.rp-worker-sites{color:var(--color-gray-400);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.rp-worker-bar-wrap{background:var(--color-gray-100);border-radius:2px;height:4px;margin-top:4px;overflow:hidden}.rp-worker-bar{background:var(--color-primary);border-radius:2px;height:100%;transition:width .5s}.rp-worker-days{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.rp-worker-days-num{color:var(--color-primary);font-size:1.15rem;font-weight:800;line-height:1}.rp-worker-days-label{color:var(--color-gray-400);font-size:.65rem}.rp-site-list{flex-direction:column;display:flex}.rp-site-item{border-bottom:1px solid var(--color-gray-50)}.rp-site-item:last-child{border-bottom:none}.rp-site-row{text-align:left;cursor:pointer;background:0 0;border:none;flex-direction:column;gap:8px;width:100%;padding:12px 16px;font-family:inherit;transition:background .12s;display:flex;position:relative}.rp-site-row:hover{background:var(--color-gray-50)}.rp-site-main{align-items:center;gap:8px;display:flex}.rp-site-chevron{color:var(--color-gray-400);position:absolute;top:14px;right:16px}.rp-site-status{text-transform:uppercase;letter-spacing:.5px;border-radius:99px;flex-shrink:0;padding:2px 7px;font-size:.65rem;font-weight:700}.rp-site-status--active{color:#065f46;background:#d1fae5}.rp-site-status--done{background:var(--color-gray-100);color:var(--color-gray-500)}.rp-site-name{color:var(--color-gray-800);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;padding-right:24px;font-size:.9rem;font-weight:700;overflow:hidden}.rp-site-meta-row{align-items:center;gap:8px;display:flex}.rp-site-chip{color:var(--color-gray-500);background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;display:inline-flex}.rp-site-detail{border-top:1px solid var(--color-gray-100);background:#f8faff;padding:0 16px 14px}.rp-site-detail-grid{grid-template-columns:1fr 1fr;gap:8px;padding-top:12px;display:grid}.rp-site-detail-item{color:var(--color-gray-600);align-items:center;gap:6px;font-size:.78rem;display:flex}.rp-site-detail-item svg{color:var(--color-primary);flex-shrink:0}.rp-modal-backdrop{z-index:1000;background:#00000073;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.rp-modal{background:#fff;border-radius:20px 20px 0 0;flex-direction:column;width:100%;max-width:560px;max-height:80vh;animation:.25s cubic-bezier(.32,.72,0,1) slideUp;display:flex;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.rp-modal-header{border-bottom:1px solid var(--color-gray-100);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 16px 14px;display:flex}.rp-modal-title{align-items:center;gap:12px;display:flex}.rp-modal-avatar{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:.85rem;font-weight:700;display:flex}.rp-modal-name{color:var(--color-gray-900);font-size:1rem;font-weight:800}.rp-modal-period{color:var(--color-gray-400);margin-top:2px;font-size:.72rem}.rp-modal-close{background:var(--color-gray-100);cursor:pointer;width:34px;height:34px;color:var(--color-gray-600);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.rp-modal-body{padding:12px 16px calc(env(safe-area-inset-bottom,0px) + 80px);-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.rp-att-list{flex-direction:column;gap:8px;display:flex}.rp-att-row{color:var(--color-gray-700);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;font-size:.82rem;display:flex}.rp-att-row svg{color:#16a34a;flex-shrink:0}.rp-att-row--absent{background:var(--color-gray-50);border-color:var(--color-gray-100)}.rp-att-date{color:var(--color-gray-800);min-width:90px;font-weight:700}.rp-att-site{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.rp-att-time{color:var(--color-gray-400);flex-shrink:0;align-items:center;gap:3px;font-size:.72rem;display:flex}.rp-att-time--link{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:5px;padding:1px 5px;font-weight:600;text-decoration:none;transition:background .15s}.rp-att-time--link:hover{background:#dcfce7}.rp-att-checkout{color:#dc2626;flex-shrink:0;align-items:center;gap:3px;font-size:.72rem;display:flex}.rp-att-checkout-loc{color:#be123c;background:#fff1f2;border:1px solid #fecdd3;border-radius:5px;flex-shrink:0;align-items:center;gap:3px;padding:1px 5px;font-size:.72rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.rp-att-checkout-loc:hover{background:#ffe4e6}.rp-att-duration{color:#7c3aed;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:5px;flex-shrink:0;padding:1px 6px;font-size:.7rem;font-weight:700}.rp-global-loading{color:var(--color-gray-400);flex-direction:column;align-items:center;gap:12px;padding:80px 20px;font-size:.9rem;display:flex}.rp-loading,.rp-empty{text-align:center;color:var(--color-gray-400);padding:30px 16px;font-size:.85rem}.rp-cal-handle{background:var(--color-gray-300,#d1d5db);border-radius:99px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.rp-modal--calendar{border-radius:24px 24px 0 0;max-width:480px;max-height:88vh;overflow:hidden}.rp-hours-strip{background:linear-gradient(135deg,#1e3a5f 0%,#1d4ed8 100%);border-radius:16px;align-items:center;gap:0;margin-bottom:14px;padding:14px 8px;display:flex}.rp-hours-stat{flex-direction:column;flex:1;align-items:center;gap:3px;display:flex}.rp-hours-stat-num{color:#fff;font-size:1.22rem;font-weight:800;line-height:1}.rp-hours-stat-lbl{color:#ffffffa6;text-transform:uppercase;letter-spacing:.4px;font-size:.64rem;font-weight:700}.rp-hours-divider{background:#ffffff2e;flex-shrink:0;width:1px;height:36px}.rp-date-modal-backdrop{z-index:1100;background:#0000008c;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.rp-date-modal{-webkit-overflow-scrolling:touch;width:100%;max-width:480px;max-height:80vh;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 80px);background:#fff;border-radius:24px 24px 0 0;flex-direction:column;animation:.25s cubic-bezier(.32,.72,0,1) slideUp;display:flex;overflow-y:auto}.rp-date-modal-handle{background:var(--color-gray-200,#e5e7eb);border-radius:99px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.rp-date-modal-head{border-bottom:1px solid var(--color-gray-100,#f3f4f6);flex-shrink:0;align-items:center;gap:12px;padding:14px 16px 12px;display:flex}.rp-date-modal-icon{color:#1d4ed8;background:#dbeafe;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.rp-date-modal-title{color:var(--color-gray-900);text-transform:capitalize;flex:1;font-size:.95rem;font-weight:800}.rp-date-modal-close{background:var(--color-gray-100,#f3f4f6);width:32px;height:32px;color:var(--color-gray-500);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;font-family:inherit;display:flex}.rp-date-modal-body{flex-direction:column;gap:10px;padding:14px 16px;display:flex}.rp-date-total-box{background:linear-gradient(135deg,#1e3a5f,#1d4ed8);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:18px 14px;display:flex}.rp-date-total-label{color:#ffffffa6;text-transform:uppercase;letter-spacing:.5px;font-size:.72rem;font-weight:700}.rp-date-total-value{color:#fff;font-size:2rem;font-weight:800;line-height:1}.rp-date-record{background:var(--color-gray-50,#f9fafb);border:1px solid var(--color-gray-200,#e5e7eb);border-radius:14px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.rp-date-record-site{color:var(--color-gray-800);align-items:center;gap:6px;font-size:.85rem;font-weight:700;display:flex}.rp-date-times-row{gap:8px;display:flex}.rp-date-time-box{border-radius:11px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:10px 6px;display:flex}.rp-date-time-box--in{background:#f0fdf4;border:1px solid #bbf7d0}.rp-date-time-box--out{background:#fef2f2;border:1px solid #fecaca}.rp-date-time-box--dur{background:#f5f3ff;border:1px solid #ede9fe}.rp-date-time-icon{justify-content:center;align-items:center;display:flex}.rp-date-time-box--in .rp-date-time-icon{color:#16a34a}.rp-date-time-box--out .rp-date-time-icon{color:#dc2626}.rp-date-time-box--dur .rp-date-time-icon{color:#7c3aed}.rp-date-time-value{font-size:1.1rem;font-weight:800;line-height:1}.rp-date-time-box--in .rp-date-time-value{color:#166534}.rp-date-time-box--out .rp-date-time-value{color:#dc2626}.rp-date-time-box--dur .rp-date-time-value{color:#6d28d9}.rp-date-time-label{text-transform:uppercase;letter-spacing:.4px;color:var(--color-gray-400);font-size:.62rem;font-weight:700}.rp-date-no-data{text-align:center;color:var(--color-gray-400);padding:20px;font-size:.84rem}[data-theme=dark] .rp-date-modal{background:var(--color-white)}[data-theme=dark] .rp-date-modal-head{border-bottom-color:#ffffff14}[data-theme=dark] .rp-date-modal-close{background:#ffffff14}[data-theme=dark] .rp-date-record{background:#ffffff0d;border-color:#ffffff1a}.rp-cal-nav{justify-content:space-between;align-items:center;padding:8px 0 12px;display:flex}.rp-cal-nav-btn{border:1.5px solid var(--color-gray-200);width:32px;height:32px;color:var(--color-gray-600);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex}.rp-cal-nav-btn:hover{background:var(--color-gray-50)}.rp-cal-month-label{color:var(--color-gray-800);text-transform:capitalize;font-size:.92rem;font-weight:700}.rp-cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:12px;display:grid}.rp-cal-head{text-align:center;color:var(--color-gray-400);text-transform:uppercase;padding:4px 0;font-size:.68rem;font-weight:700}.rp-cal-cell{aspect-ratio:1;color:var(--color-gray-600);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-family:inherit;font-size:.78rem;font-weight:600;transition:all .15s;display:flex}.rp-cal-cell--empty{cursor:default}.rp-cal-cell:hover:not(.rp-cal-cell--empty){background:var(--color-gray-100)}.rp-cal-cell--present{color:#16a34a;background:#dcfce7;font-weight:700}.rp-cal-cell--present:hover{background:#bbf7d0}.rp-cal-cell--selected{box-shadow:0 2px 8px #0077c84d;background:var(--color-primary)!important;color:#fff!important}.rp-cal-cell--today{border:2px solid var(--color-primary)}.rp-cal-details{background:var(--color-gray-50);border-radius:12px;margin-top:4px;padding:12px;animation:.2s calDetailSlide}@keyframes calDetailSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.rp-cal-details-title{color:var(--color-gray-700);text-transform:capitalize;align-items:center;gap:6px;margin-bottom:8px;font-size:.82rem;font-weight:700;display:flex}.rp-cal-total-badge{color:#7c3aed;background:#f5f3ff;border:1px solid #ede9fe;border-radius:8px;align-items:center;gap:3px;margin-left:auto;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.rp-cal-no-data{color:var(--color-gray-400);text-align:center;padding:8px 0;font-size:.8rem}.rp-cal-records{flex-direction:column;gap:6px;display:flex}.rp-cal-record{border:1px solid var(--color-gray-100);background:#fff;border-radius:10px;padding:8px 10px}.rp-cal-record-site{color:var(--color-gray-700);align-items:center;gap:4px;margin-bottom:4px;font-size:.8rem;font-weight:700;display:flex}.rp-cal-record-times{flex-wrap:wrap;gap:8px;font-size:.75rem;display:flex}.rp-cal-record-in{color:#16a34a;align-items:center;gap:3px;font-weight:600;display:inline-flex}.rp-cal-record-out{color:#dc2626;align-items:center;gap:3px;font-weight:600;display:inline-flex}.rp-cal-record-dur{color:#7c3aed;background:#f5f3ff;border-radius:6px;align-items:center;gap:3px;padding:0 6px;font-size:.72rem;font-weight:700;display:inline-flex}[data-theme=dark] .reports-header{background:var(--color-white)}[data-theme=dark] .reports-header-icon{background:var(--badge-info-bg)}[data-theme=dark] .reports-tab-card{background:var(--color-white)}[data-theme=dark] .reports-tab--active{background:var(--color-primary)}[data-theme=dark] .reports-card,[data-theme=dark] .rp-stat-card,[data-theme=dark] .rp-modal-content{background:var(--color-white)}[data-theme=dark] .rp-checkin-badge{background:var(--badge-success-bg);color:var(--badge-success-text)}[data-theme=dark] .rp-hero{background:var(--color-white);border-bottom-color:var(--color-gray-200)}[data-theme=dark] .rp-hero-icon{background:var(--badge-info-bg)}[data-theme=dark] .rp-filters{background:var(--color-white);border-bottom-color:var(--color-gray-200)}[data-theme=dark] .rp-preset-btn{background:var(--color-gray-100);border-color:var(--color-gray-200);color:var(--color-gray-600)}[data-theme=dark] .rp-date-input{background:var(--color-gray-100);border-color:var(--color-gray-200);color:var(--color-gray-700)}[data-theme=dark] .rp-sort-btn{background:var(--color-gray-100);border-color:var(--color-gray-200);color:var(--color-gray-500)}[data-theme=dark] .rp-card{background:var(--color-white)}[data-theme=dark] .rp-highlight--gold{background:linear-gradient(135deg, var(--badge-warning-bg), #4d2a05);color:#fde68a}[data-theme=dark] .rp-highlight--blue{background:linear-gradient(135deg, var(--badge-info-bg), #1e3a6e);color:#93c5fd}[data-theme=dark] .rp-site-detail{background:var(--color-gray-100);border-top-color:var(--color-gray-200)}[data-theme=dark] .rp-site-status--active{background:var(--badge-success-bg);color:var(--badge-success-text)}[data-theme=dark] .rp-site-status--done{background:var(--color-gray-200);color:var(--color-gray-500)}[data-theme=dark] .rp-modal{background:var(--color-white)}[data-theme=dark] .rp-att-row{background:var(--badge-success-bg);color:var(--color-gray-700);border-color:#14532d}[data-theme=dark] .rp-att-row--absent{background:var(--color-gray-100);border-color:var(--color-gray-200)}[data-theme=dark] .rp-att-time--link{background:var(--badge-success-bg);color:#86efac;border-color:#14532d}[data-theme=dark] .rp-att-checkout-loc{background:var(--badge-danger-bg);border-color:var(--color-danger);color:#fca5a5}[data-theme=dark] .rp-att-duration{color:#c4b5fd;background:#3b1f7e33;border-color:#7c3aed44}.np-page{background:var(--color-gray-50);min-height:100vh;padding:0 0 100px}.np-hero{background:var(--color-white);border-bottom:1px solid var(--color-gray-100);align-items:center;gap:14px;padding:20px 20px 18px;display:flex}.np-hero-icon{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 100%);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex;box-shadow:0 4px 12px #7c3aed59}.np-hero-text{flex:1}.np-hero-title{color:var(--color-gray-900);letter-spacing:-.02em;margin:0 0 2px;font-size:1.15rem;font-weight:800}.np-hero-sub{color:var(--color-gray-400);margin:0;font-size:.75rem}.np-clear-btn{color:#dc2626;cursor:pointer;letter-spacing:.01em;background:#fee2e2;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:5px;padding:7px 12px;font-family:inherit;font-size:.72rem;font-weight:700;transition:background .15s,transform .1s;display:inline-flex}.np-clear-btn:hover{background:#fecaca;transform:scale(.97)}.np-content{padding:16px 14px 0}.np-empty{color:var(--color-gray-300);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:80px 20px;display:flex}.np-empty p{color:var(--color-gray-400);margin:0;font-size:1rem;font-weight:700}.np-empty span{color:var(--color-gray-300);max-width:240px;font-size:.78rem;line-height:1.5}.np-list{flex-direction:column;display:flex}.np-date-group{margin-bottom:12px}.np-date-group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-gray-400);align-items:center;gap:8px;padding:4px 2px 10px;font-size:.68rem;font-weight:800;display:flex}.np-date-group-label:after{content:"";background:var(--color-gray-100);flex:1;height:1px}.np-item{background:var(--color-white);border:1px solid var(--color-gray-100);text-align:left;cursor:pointer;border-left:3px solid #0000;border-radius:16px;align-items:flex-start;gap:13px;width:100%;margin-bottom:7px;padding:13px 13px 13px 14px;font-family:inherit;transition:box-shadow .15s,transform .12s;display:flex;box-shadow:0 1px 4px #0000000d}.np-item:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000017}.np-item:active{transform:translateY(0);box-shadow:0 1px 4px #0000000d}.np-item--unread{box-shadow:0 2px 10px #00000012}.np-item--unread.np-item--message{background:#f0f7ff;border-left-color:#3b82f6}.np-item--unread.np-item--permit{background:#f0fdf8;border-left-color:#10b981}.np-item--unread.np-item--checkin{background:#fffbeb;border-left-color:#f59e0b}.np-item--unread.np-item--assignment{background:#fdf2f8;border-left-color:#ec4899}.np-item--unread.np-item--default{background:#f5f3ff;border-left-color:#8b5cf6}.np-item-icon{border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:relative}.np-item-icon--message{color:#2563eb;background:#dbeafe}.np-item-icon--permit{color:#059669;background:#d1fae5}.np-item-icon--checkin{color:#d97706;background:#fef3c7}.np-item-icon--assignment{color:#db2777;background:#fce7f3}.np-item-icon--default{color:#7c3aed;background:#ede9fe}.np-item-count{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.58rem;font-weight:800;display:flex;position:absolute;top:-5px;right:-5px}.np-item-body{flex:1;min-width:0}.np-item-title{color:var(--color-gray-800);margin-bottom:3px;font-size:.85rem;font-weight:700;line-height:1.35}.np-item-body-text{color:var(--color-gray-500);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-size:.77rem;line-height:1.45;display:-webkit-box;overflow:hidden}.np-item-merge-hint{color:#2563eb;background:#dbeafe;border-radius:6px;margin-top:5px;padding:2px 7px;font-size:.68rem;font-weight:700;display:inline-block}.np-item-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;padding-top:1px;display:flex}.np-item-time{color:var(--color-gray-400);white-space:nowrap;font-size:.67rem;font-weight:600}.np-item-dot{background:#3b82f6;border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 2px #3b82f633}.np-item:not(.np-item--unread){opacity:.65}.np-item:not(.np-item--unread):hover{opacity:1}.np-footer{color:var(--color-gray-300);justify-content:center;align-items:center;gap:6px;margin-top:16px;font-size:.7rem;display:flex}[data-theme=dark] .np-page{background:#11131f}[data-theme=dark] .np-hero{background:#1a1d2e;border-bottom-color:#252840}[data-theme=dark] .np-hero-title{color:#f1f5f9}[data-theme=dark] .np-hero-sub{color:#64748b}[data-theme=dark] .np-clear-btn{color:#f87171;background:#2d1515}[data-theme=dark] .np-clear-btn:hover{background:#3b1a1a}[data-theme=dark] .np-date-group-label{color:#475569}[data-theme=dark] .np-date-group-label:after{background:#252840}[data-theme=dark] .np-item{background:#1a1d2e;border-color:#252840;box-shadow:0 2px 8px #0000004d}[data-theme=dark] .np-item:hover{box-shadow:0 4px 20px #00000073}[data-theme=dark] .np-item:not(.np-item--unread){opacity:.5}[data-theme=dark] .np-item:not(.np-item--unread):hover{opacity:.85}[data-theme=dark] .np-item--unread.np-item--message{background:#0f1c30;border-left-color:#3b82f6}[data-theme=dark] .np-item--unread.np-item--permit{background:#0a2018;border-left-color:#10b981}[data-theme=dark] .np-item--unread.np-item--checkin{background:#1e1508;border-left-color:#f59e0b}[data-theme=dark] .np-item--unread.np-item--assignment{background:#200d1c;border-left-color:#ec4899}[data-theme=dark] .np-item--unread.np-item--default{background:#160f30;border-left-color:#8b5cf6}[data-theme=dark] .np-item-icon--message{color:#60a5fa;background:#1e3154}[data-theme=dark] .np-item-icon--permit{color:#34d399;background:#14312a}[data-theme=dark] .np-item-icon--checkin{color:#fbbf24;background:#332108}[data-theme=dark] .np-item-icon--assignment{color:#f472b6;background:#3b1238}[data-theme=dark] .np-item-icon--default{color:#a78bfa;background:#2d2060}[data-theme=dark] .np-item-title{color:#e2e8f0}[data-theme=dark] .np-item-body-text{color:#94a3b8}[data-theme=dark] .np-item-time{color:#64748b}[data-theme=dark] .np-item-count{border-color:#1a1d2e}[data-theme=dark] .np-item-dot{background:#60a5fa;box-shadow:0 0 0 2px #60a5fa33}[data-theme=dark] .np-item-merge-hint{color:#60a5fa;background:#1e3154}[data-theme=dark] .np-footer,[data-theme=dark] .np-empty{color:#334155}[data-theme=dark] .np-empty p{color:#475569}[data-theme=dark] .np-empty span{color:#334155}.settings-section{margin-bottom:24px}.settings-section-title{letter-spacing:.08em;color:var(--color-gray-400);margin-bottom:8px;padding:0 4px;font-size:.7rem;font-weight:700}.settings-card{padding:0;overflow:hidden}.settings-row{align-items:center;gap:14px;padding:14px 16px;display:flex}.settings-row--border{border-bottom:1px solid var(--color-gray-100)}.settings-row-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.settings-row-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.settings-row-label{color:var(--color-gray-800);font-size:.92rem;font-weight:600}.settings-row-desc{color:var(--color-gray-400);font-size:.75rem;line-height:1.4}.settings-row-control{flex-shrink:0}.settings-toggle{background:var(--color-gray-300);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:999px;width:48px;height:28px;transition:background .2s;position:relative}.settings-toggle:after{content:"";background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #00000040}.settings-toggle--on{background:var(--color-primary)}.settings-toggle--on:after{transform:translate(20px)}.settings-toggle:disabled{opacity:.4;cursor:not-allowed}.settings-banner{border-bottom:1px solid var(--color-gray-100);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;font-size:.82rem;line-height:1.4;display:flex}.settings-banner--warn{background:var(--banner-warn-bg);color:var(--banner-warn-text)}.settings-banner--info{background:var(--banner-info-bg);color:var(--banner-info-text)}.settings-banner-btn{background:var(--color-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;padding:7px 14px;font-size:.82rem;font-weight:700}.settings-save-status{text-align:center;color:var(--color-gray-400);padding:10px 0 4px;font-size:.78rem;animation:.2s fade-in}.settings-save-status--ok{color:var(--color-success);font-weight:600}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.settings-version{text-align:center;color:var(--color-gray-300);margin-top:8px;padding-bottom:8px;font-size:.72rem}.notif-prompt{bottom:calc(64px + env(safe-area-inset-bottom,0px) + 12px);color:#fff;z-index:9999;background:#1a1a2e;border-radius:16px;flex-wrap:wrap;align-items:center;gap:10px;width:calc(100% - 32px);max-width:440px;padding:14px 16px;animation:.3s notif-prompt-slide-up;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000059}@keyframes notif-prompt-slide-up{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.notif-prompt__icon{flex-shrink:0;font-size:1.5rem}.notif-prompt__text{flex:1;min-width:140px;margin:0;font-size:.88rem;line-height:1.4}.notif-prompt__actions{flex-shrink:0;gap:8px;display:flex}.notif-prompt__btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:8px 14px;font-size:.85rem;font-weight:600}.notif-prompt__btn--yes{color:#fff;background:#008ce3}.notif-prompt__btn--yes:active{background:#0070b8}.notif-prompt__btn--no{color:#ffffffbf;background:#ffffff1f}.notif-prompt__btn--no:active{background:#ffffff38}.splash{z-index:9999;opacity:0;background:linear-gradient(160deg,#0050a0 0%,#008ce3 45%,#00bfff 100%);flex-direction:column;justify-content:center;align-items:center;transition:opacity .5s,transform .5s;display:flex;position:fixed;inset:0;overflow:hidden;transform:scale(1.04)}.splash--enter{animation:.55s cubic-bezier(.22,1,.36,1) forwards splashEnter}.splash--hold{opacity:1;transform:scale(1)}.splash--exit{animation:.45s cubic-bezier(.55,0,1,.45) forwards splashExit}@keyframes splashEnter{0%{opacity:0;transform:scale(1.06)}to{opacity:1;transform:scale(1)}}@keyframes splashExit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}.splash-glow{aspect-ratio:1;pointer-events:none;background:radial-gradient(circle,#ffffff2e 0%,#0000 65%);border-radius:50%;width:140%;position:absolute;top:-30%;left:50%;transform:translate(-50%)}.splash-road{opacity:.18;flex-direction:column;justify-content:space-evenly;height:90px;padding:12px 0;display:flex;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.splash-road-line{background:repeating-linear-gradient(90deg,#fff 0 40px,#0000 40px 80px);width:200%;height:3px;margin-left:-50%;animation:1.2s linear infinite roadScroll}.splash-road-line:nth-child(2){opacity:.7;animation-delay:-.4s}.splash-road-line:nth-child(3){opacity:.4;animation-delay:-.8s}@keyframes roadScroll{0%{transform:translate(0)}to{transform:translate(80px)}}.splash-logo-wrap{flex-direction:column;align-items:center;gap:20px;animation:.7s cubic-bezier(.34,1.56,.64,1) .1s both splashLogoIn;display:flex}@keyframes splashLogoIn{0%{opacity:0;transform:translateY(28px)scale(.85)}to{opacity:1;transform:translateY(0)scale(1)}}.splash-icon{-webkit-backdrop-filter:blur(12px);background:#ffffff26;border-radius:24px;justify-content:center;align-items:center;width:96px;height:96px;padding:16px;animation:2s ease-in-out infinite iconPulse;display:flex;box-shadow:0 8px 32px #00000040,inset 0 0 0 1px #ffffff40}.splash-icon svg{filter:drop-shadow(0 2px 8px #0003);width:100%;height:100%}@keyframes iconPulse{0%,to{box-shadow:0 8px 32px #00000040,inset 0 0 0 1px #ffffff40}50%{box-shadow:0 8px 32px #00000040,inset 0 0 0 1px #ffffff40,0 0 40px #fff3}}.splash-text-block{text-align:center;animation:.7s cubic-bezier(.34,1.56,.64,1) .2s both splashTextIn}@keyframes splashTextIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.splash-title{letter-spacing:-.03em;color:#fff;margin-bottom:8px;font-size:2.8rem;font-weight:800;line-height:1}.splash-title-mika{color:#fff}.splash-title-trans{color:#ffffffbf}.splash-tagline{color:#ffffffb3;letter-spacing:.02em;font-size:.9rem;font-weight:500}.splash-bottom{flex-direction:column;align-items:center;gap:10px;width:160px;animation:.6s .35s both splashBarIn;display:flex;position:absolute;bottom:48px;left:50%;transform:translate(-50%)}@keyframes splashBarIn{0%{opacity:0}to{opacity:1}}.splash-bar{background:#fff3;border-radius:99px;width:100%;height:3px;overflow:hidden}.splash-bar-fill{background:#fff;border-radius:99px;height:100%;animation:1.6s cubic-bezier(.4,0,.2,1) .35s forwards barFill}@keyframes barFill{0%{width:0%}to{width:100%}}.splash-loading-text{color:#ffffff8c;letter-spacing:.06em;text-transform:uppercase;font-size:.72rem;font-weight:500}[data-theme=dark] .splash{background:linear-gradient(160deg,#001f4d 0%,#0050a0 45%,#0078c8 100%)}.offline-banner{z-index:9999;color:#f3f4f6;background:#1f2937;justify-content:center;align-items:center;gap:8px;padding:9px 16px;font-size:.82rem;font-weight:600;animation:.3s both bannerSlideDown;display:flex;position:fixed;top:0;left:0;right:0}.offline-banner--back{color:#86efac;background:#14532d}@keyframes bannerSlideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.app-loading{min-height:100dvh;color:var(--color-primary);justify-content:center;align-items:center;font-size:1.2rem;font-weight:600;display:flex}.page-transition{flex-direction:column;flex:1;display:flex}@keyframes pageFadeIn{0%{opacity:0}to{opacity:1}}.page-anim-fade,.page-anim-right,.page-anim-left{animation:.18s both pageFadeIn}
