:root{--bg: #f2f4f1;--surface: #ffffff;--surface-2: #edf1ea;--surface-3: #e3e8df;--border: #dbe0d8;--border-subtle: #ebeee8;--text: #14181a;--text-dim: #586169;--text-faint: #949ca1;--primary: #4d8c0a;--primary-hover: #3f7508;--primary-dim: #e7f4cf;--primary-bold: #9fdc28;--primary-bold-hover: #8fce18;--on-primary-bold: #1c2b06;--danger: #d83a3a;--warning: #b67400;--success: #2f9d3f;--info: #1f8fb0;--shadow: 0 4px 14px rgba(20, 30, 10, .07);--radius: 14px;--radius-sm: 10px;--sidebar-w: 232px;color-scheme:light}html[data-theme=dark]{--bg: #0e0f10;--surface: #161719;--surface-2: #1f2123;--surface-3: #2a2c2f;--border: #33363a;--border-subtle: #232628;--text: #f3f4f3;--text-dim: #9da1a3;--text-faint: #6a6e70;--primary: #c2f23f;--primary-hover: #b1e826;--primary-dim: #222b0f;--primary-bold: #c2f23f;--primary-bold-hover: #b1e826;--on-primary-bold: #11140a;--danger: #ff5c5c;--warning: #f5b53d;--success: #8be36b;--info: #7fd1e6;--shadow: 0 6px 18px rgba(0, 0, 0, .4);color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:none}h1,h2,h3{margin:0;font-weight:700}h1{font-size:1.7rem;font-weight:800}h2{font-size:1.25rem}h3{font-size:1.05rem}input,select,textarea,button{font:inherit}.app-layout{display:flex;min-height:100%}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:1.25rem .85rem;position:sticky;top:0;height:100vh}.sidebar .brand{display:flex;align-items:center;gap:.6rem;font-size:1.25rem;font-weight:800;color:var(--text);padding:.25rem .6rem 1.25rem}.sidebar .brand .logo{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#7ec828,var(--primary));display:grid;place-items:center;color:#fff}.sidebar-nav{display:flex;flex-direction:column;gap:.2rem;flex:1}.sidebar-link{display:flex;align-items:center;gap:.7rem;padding:.65rem .7rem;border-radius:var(--radius-sm);color:var(--text-dim);font-weight:600;font-size:.92rem;transition:background .12s,color .12s}.sidebar-link:hover{background:var(--surface-2);color:var(--text)}.sidebar-link.active{background:var(--primary-dim);color:var(--primary)}.sidebar-foot{border-top:1px solid var(--border-subtle);padding-top:.85rem}.sidebar-user{display:flex;align-items:center;gap:.6rem;padding:.4rem .6rem}.sidebar-user .who{flex:1;min-width:0}.sidebar-user .who .nm{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .who .rl{font-size:.75rem;color:var(--text-faint);text-transform:capitalize}.content{flex:1;min-width:0}.content-inner{max-width:1080px;margin:0 auto;padding:1.75rem 1.75rem 4rem}@media (max-width: 820px){.app-layout{flex-direction:column}.sidebar{width:100%;height:auto;position:sticky;top:0;z-index:20;flex-direction:row;align-items:center;gap:.25rem;padding:.6rem .75rem;overflow-x:auto;border-right:none;border-bottom:1px solid var(--border-subtle)}.sidebar .brand{padding:0 .5rem 0 .25rem;font-size:1.1rem}.sidebar .brand .label{display:none}.sidebar-nav{flex-direction:row;flex:1;gap:.15rem}.sidebar-link span.lbl{display:none}.sidebar-link{padding:.55rem .7rem}.sidebar-foot{border-top:none;padding-top:0}.sidebar-user .who{display:none}.content-inner{padding:1.1rem 1.1rem 3rem}}.avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-dim);color:var(--primary);display:grid;place-items:center;font-weight:800;font-size:.85rem;flex-shrink:0}.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-head .sub{color:var(--text-dim);font-size:.95rem;margin-top:.2rem}.back-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--text-dim);font-size:.9rem;margin-bottom:.4rem}.back-link:hover{color:var(--text)}.section-head{display:flex;align-items:center;justify-content:space-between;margin:1.75rem 0 .9rem}.card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:1.15rem 1.25rem;box-shadow:var(--shadow)}.card+.card{margin-top:1rem}.card-link{display:block;color:inherit;transition:border-color .12s,transform .08s}.card-link:hover{border-color:var(--primary);text-decoration:none}.card-link:active{transform:scale(.995)}.grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.chart-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1.25rem}.chart-card h3{margin-bottom:1rem}.chart-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.85rem}.chart-head .muted{font-size:.85rem}.chart-head strong{font-size:1.15rem}.chart-body{display:flex;align-items:center;gap:1.25rem}@media (max-width: 520px){.chart-body{flex-direction:column;align-items:center}}.stat-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:1.1rem;cursor:pointer;transition:border-color .12s}.stat:hover{border-color:var(--border)}.stat .ic{width:38px;height:38px;border-radius:var(--radius-sm);display:grid;place-items:center;margin-bottom:.7rem}.stat .val{font-size:1.9rem;font-weight:800;line-height:1}.stat .lbl{color:var(--text-faint);font-size:.82rem;margin-top:.3rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.6rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:.92rem;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,opacity .12s;white-space:nowrap}.btn:hover{border-color:var(--primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-bold);border-color:var(--primary-bold);color:var(--on-primary-bold)}.btn-primary:hover{background:var(--primary-bold-hover);border-color:var(--primary-bold-hover)}.btn-danger{color:var(--danger);border-color:transparent;background:transparent}.btn-danger:hover{border-color:var(--danger)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-dim)}.btn-ghost:hover{color:var(--text);border-color:transparent}.btn-sm{padding:.4rem .7rem;font-size:.84rem}.btn-block{width:100%}.field{margin-bottom:1rem;display:flex;flex-direction:column;gap:.4rem}.field label{font-size:.82rem;color:var(--text-dim);font-weight:600}input,select,textarea{width:100%;padding:.6rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}textarea{resize:vertical;min-height:90px}.row{display:flex;gap:.75rem;flex-wrap:wrap}.row>*{flex:1;min-width:120px}.search-bar{display:flex;align-items:center;gap:.55rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 .75rem;height:42px;transition:border-color .12s}.search-bar:focus-within{border-color:var(--primary)}.search-bar svg{color:var(--text-faint);flex-shrink:0}.search-bar input{border:none;background:transparent;padding:0;height:100%;width:100%}.search-bar input:focus{outline:none}.group-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.group-head .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.group-head .ttl{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--text);flex:1}.group-head .count-pill{padding:.1rem .5rem;border-radius:999px;font-size:.74rem;font-weight:800}.chip .chip-count{opacity:.6;margin-left:.35rem;font-weight:700}.user-list{padding:.25rem 1rem}.user-row{display:flex;align-items:flex-start;gap:.85rem;padding:.9rem 0}.user-row+.user-row{border-top:1px solid var(--border-subtle)}.user-row .u-main{flex:1;min-width:0}.user-row .u-name{display:flex;align-items:center;gap:.5rem;font-size:.98rem}.user-row .u-contact{display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin-top:.25rem}.user-row .u-tags{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .9rem;margin-top:.45rem}.u-tag{display:inline-flex;align-items:center;gap:.32rem;font-size:.82rem;color:var(--text-dim);min-width:0}.u-tag svg{color:var(--text-faint);flex-shrink:0}.u-pending{background:#f5a62329;color:#f5a623;font-size:.66rem;font-weight:800;padding:.1rem .4rem;border-radius:5px;text-transform:uppercase;letter-spacing:.4px}.user-row .u-side{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;flex-shrink:0}.wo-ic{width:38px;height:38px;border-radius:10px;flex-shrink:0;display:grid;place-items:center}.banner-ok{background:var(--primary-dim);color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius-sm);padding:.6rem .85rem;font-weight:600;font-size:.9rem;margin-bottom:1rem}.audit-feed{display:flex;flex-direction:column;gap:.5rem}.audit-row{display:flex;align-items:flex-start;gap:.7rem;position:relative;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.7rem .85rem .7rem 1rem;overflow:hidden}.audit-rail{position:absolute;left:0;top:0;bottom:0;width:3px}.audit-tag{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.72rem;font-weight:700;padding:.1rem .45rem;border-radius:5px}.map-wrap{height:70vh;min-height:420px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);position:relative;z-index:0}.leaflet-container{background:var(--surface-2);font:inherit}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#14181a}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:999px;font-size:.74rem;font-weight:700}.badge .dot{width:6px;height:6px;border-radius:50%}.badge.outline{border:1px solid var(--border);background:transparent}.cat-tag{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:600}.filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:1.25rem}.filter-bar select,.filter-bar input[type=date]{width:auto;height:42px;padding:0 .7rem;flex:0 0 auto}.filter-bar .search-bar{margin-bottom:0}.filter-bar .chip{height:42px;display:inline-flex;align-items:center;gap:.35rem}.sla-flag{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:800;padding:.1rem .4rem;border-radius:5px;white-space:nowrap}.seg{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.seg button{display:inline-flex;align-items:center;gap:.35rem;padding:.42rem .75rem;background:var(--surface);color:var(--text-dim);border:none;font-size:.84rem;font-weight:600;cursor:pointer}.seg button+button{border-left:1px solid var(--border)}.seg button.active{background:var(--primary-bold);color:var(--on-primary-bold)}.wo-table-card{padding:0;overflow-x:auto}.wo-table{display:flex;flex-direction:column;min-width:780px}.wo-trow{display:grid;grid-template-columns:minmax(0,2.4fr) minmax(0,1.4fr) minmax(0,1fr) auto minmax(0,1.3fr) minmax(0,1.1fr) 56px;gap:.85rem;align-items:center;padding:.72rem 1rem;color:inherit}a.wo-trow:hover{background:var(--surface-2);text-decoration:none}.wo-trow+.wo-trow{border-top:1px solid var(--border-subtle)}.wo-thead,.wo-thead:hover{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint);font-weight:700;background:var(--surface-2)}.wo-cell-title{display:inline-flex;align-items:center;gap:.5rem;min-width:0}.wo-tic{width:30px;height:30px;border-radius:8px;background:var(--surface-3);display:grid;place-items:center;flex-shrink:0}.wo-ttext{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wo-ellip{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-flex;align-items:center;gap:.3rem}.wo-cell-status{display:inline-flex;align-items:center;gap:.4rem;flex-wrap:wrap}.wo-age-col{text-align:right}.board{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));align-items:start}.board-col{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:.85rem}.board-col h3{display:flex;justify-content:space-between;align-items:center;color:var(--text-dim);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.board-col .count{background:var(--surface-3);color:var(--text-dim);border-radius:999px;padding:.05rem .5rem;font-size:.72rem}.wo-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:.8rem;margin-top:.6rem;display:block;color:inherit}.wo-card:hover{border-color:var(--primary);text-decoration:none}.wo-card .top{display:flex;align-items:center;gap:.55rem}.wo-card .ic{width:34px;height:34px;border-radius:9px;background:var(--surface-3);display:grid;place-items:center;flex-shrink:0}.wo-card .title{font-weight:700;font-size:.95rem}.wo-card .meta{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-top:.6rem;color:var(--text-faint);font-size:.78rem}.wo-list{display:flex;flex-direction:column;gap:.7rem}.timeline{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.6rem}.timeline li{display:flex;align-items:center;gap:.6rem;font-size:.88rem;color:var(--text-dim)}.timeline li strong{color:var(--text)}.photo-grid{display:grid;gap:.6rem;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));margin-top:.5rem}.photo-grid img{width:100%;height:110px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border)}.comment{display:flex;gap:.7rem;padding:.7rem 0;border-bottom:1px solid var(--border-subtle)}.comment:last-child{border-bottom:none}.comment .who{font-size:.8rem;color:var(--text-dim);margin-bottom:.15rem}.list-row{display:flex;align-items:center;gap:.85rem}.list-row .ic{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--primary-dim);color:var(--primary);display:grid;place-items:center;flex-shrink:0}.list-row .body{flex:1;min-width:0}.list-row .body .t{font-weight:600}.list-row .body .s{color:var(--text-faint);font-size:.85rem}.muted{color:var(--text-dim)}.faint{color:var(--text-faint)}.error-text{color:var(--danger);font-size:.88rem}.ok-text{color:var(--success);font-size:.88rem}.empty{text-align:center;color:var(--text-dim);padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.6rem}.empty .ei{color:var(--text-faint)}.empty .et{font-weight:700;color:var(--text);font-size:1.05rem}.spinner-wrap{display:flex;justify-content:center;padding:3rem}.spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stack{display:flex;flex-direction:column;gap:.6rem}.inline{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.chips{display:flex;gap:.5rem;flex-wrap:wrap}.chip{padding:.4rem .8rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:.84rem;font-weight:600;cursor:pointer}.chip.active{background:var(--primary-bold);border-color:var(--primary-bold);color:var(--on-primary-bold)}.divider{height:1px;background:var(--border-subtle);margin:.25rem 0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f0573;display:grid;place-items:center;padding:1.5rem;z-index:50}.modal-card{width:100%;max-width:440px;max-height:90vh;overflow-y:auto}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:2.5rem 1.5rem;text-align:center;color:var(--text-dim);transition:border-color .12s,background .12s;cursor:pointer}.dropzone.over{border-color:var(--primary);background:var(--primary-dim);color:var(--text)}.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr}.auth-aside{position:relative;overflow:hidden;padding:3rem;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(1100px 500px at -10% -10%,rgba(126,200,40,.22),transparent 60%),radial-gradient(900px 500px at 110% 110%,rgba(95,163,10,.18),transparent 55%),linear-gradient(160deg,var(--surface),var(--bg));border-right:1px solid var(--border-subtle)}.auth-aside .a-brand{display:flex;align-items:center;gap:.7rem;font-size:1.4rem;font-weight:800}.auth-aside .a-logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,#7ec828,var(--primary));display:grid;place-items:center;color:#fff}.auth-aside .a-hero{max-width:420px}.auth-aside .a-hero h2{font-size:2.2rem;line-height:1.15;font-weight:800;margin-bottom:.8rem}.auth-aside .a-hero p{color:var(--text-dim);font-size:1.05rem}.auth-aside .a-feats{display:flex;flex-direction:column;gap:1rem}.auth-aside .a-feat{display:flex;align-items:center;gap:.85rem}.auth-aside .a-feat .fi{width:40px;height:40px;border-radius:11px;background:#5fa30a1a;border:1px solid var(--border);display:grid;place-items:center;color:var(--primary);flex-shrink:0}.auth-aside .a-feat .ft{font-weight:700}.auth-aside .a-feat .fs{color:var(--text-dim);font-size:.88rem}.auth-main{display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem}.auth-card{width:100%;max-width:380px}.auth-card .brand{font-size:1.6rem;font-weight:800;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem}.auth-card .logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#7ec828,var(--primary));display:grid;place-items:center;color:#fff}.auth-card .tagline{text-align:center;color:var(--text-dim);margin:.4rem 0 1.5rem}.auth-card .alt{text-align:center;margin-top:1.1rem;font-size:.88rem;color:var(--text-dim)}.seg{display:flex;gap:.4rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.25rem;margin-bottom:1.25rem}.seg button{flex:1;background:transparent;border:none;color:var(--text-dim);padding:.5rem;border-radius:7px;cursor:pointer;font-weight:600}.seg button.active{background:var(--surface-2);color:var(--text)}@media (max-width: 860px){.auth-wrap{grid-template-columns:1fr}.auth-aside{display:none}}.walk{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;position:relative;overflow:hidden}.walk:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(900px 480px at 50% -10%,rgba(126,200,40,.18),transparent 60%),radial-gradient(700px 420px at 50% 120%,rgba(95,163,10,.14),transparent 55%);pointer-events:none}.walk-top{position:absolute;top:1.1rem;right:1.25rem}.walk-slide{width:100%;max-width:460px;text-align:center;z-index:1}.walk-ic{width:96px;height:96px;margin:0 auto 1.75rem;border-radius:26px;display:grid;place-items:center;box-shadow:0 14px 40px #00000059}.walk-slide h2{font-size:1.9rem;font-weight:800;margin-bottom:.7rem}.walk-slide p{color:var(--text-dim);font-size:1.05rem;line-height:1.6}.walk-dots{display:flex;gap:.5rem;justify-content:center;margin:2rem 0 1.75rem}.walk-dots .d{width:8px;height:8px;border-radius:999px;background:var(--border);transition:width .2s,background .2s}.walk-dots .d.on{width:24px;background:var(--primary)}.walk-nav{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;max-width:460px;z-index:1}.walk-nav .btn{min-width:110px}
