.canvasser-shell{--canv-bg:#f4f7f8;--canv-surface:#fff;--canv-surface-soft:#eef5f1;--canv-ink:#17212b;--canv-muted:#61717d;--canv-line:#d9e3e4;--canv-accent:#167a68;--canv-accent-dark:#0f5c4e;--canv-warning:#b85c38;--canv-sky:#d9ecf4;--canv-shadow:0 12px 30px #17212b14;width:min(100%,1180px);min-height:100vh;color:var(--canv-ink);margin:0 auto;padding:1.25rem 1rem 7rem}.canvasser-shell.is-active-mode{padding-top:.75rem}.canvasser-topbar{justify-content:space-between;align-items:flex-start;gap:1rem;padding-bottom:1rem;display:flex}.canvasser-shell.is-active-mode .canvasser-topbar{display:none}.canvasser-shell .eyebrow,.canvasser-shell .card-kicker{color:var(--canv-muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 .35rem;font-size:.74rem;font-weight:700}.canvasser-topbar h1,.home-summary h2,.session-lock h2,.saved-doors-header h3,.property-panel-header h3,.door-history h3{margin:0;line-height:1.15}.canvasser-topbar h1{font-size:clamp(1.85rem,5vw,2.45rem)}.subhead,.home-summary p,.session-lock p,.stat-card span,.saved-door-item span,.saved-door-item small,.history-item span,.history-item small,.empty-list{color:var(--canv-muted);margin:0;line-height:1.5}.canvasser-panel{display:none}.canvasser-panel.is-active{display:block}.home-summary,.quick-stats,.bottom-dock{border:1px solid var(--canv-line);box-shadow:var(--canv-shadow);background:var(--canv-surface)}.home-summary{border-radius:8px;gap:1rem;padding:1.15rem;display:grid}.home-summary h2{font-size:clamp(1.45rem,4.5vw,2rem)}.week-filter{gap:.5rem;display:flex;overflow-x:auto}.filter-chip,.dock-item,.primary-action,.secondary-action,.warning-action,.compact-session-action,.panel-close,.map-type-toggle,.saved-door-item,.door-details-form input,.field-form select,.field-form textarea{font:inherit;border-radius:8px}.filter-chip{min-height:2.75rem;color:var(--canv-muted);background:var(--canv-surface-soft);cursor:pointer;border:0;flex:none;padding:0 .9rem;font-weight:700}.filter-chip.is-active{color:#fff;background:var(--canv-accent-dark)}.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin:.9rem 0;display:grid}.stat-card{border:1px solid var(--canv-line);background:var(--canv-surface);border-radius:8px;min-height:8.2rem;padding:1rem}.stat-card strong{margin:.35rem 0 .2rem;font-size:clamp(2rem,8vw,3rem);line-height:1;display:block}.quick-stats{border-radius:8px;display:grid}.quick-stat-row{border-bottom:1px solid var(--canv-line);justify-content:space-between;gap:1rem;padding:1rem;display:flex}.quick-stat-row:last-child{border-bottom:0}.quick-stat-row span{color:var(--canv-muted)}.quick-stat-row strong{text-align:right}.session-warning{color:var(--canv-ink);box-shadow:var(--canv-shadow);background:#fff4ed;border:1px solid #b85c386b;border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.9rem;padding:1rem;display:flex}.session-warning strong,.session-warning span{display:block}.session-warning span{color:var(--canv-muted)}.warning-action,.primary-action,.compact-session-action{color:#fff;background:var(--canv-accent);cursor:pointer;border:0;font-weight:800}.warning-action,.compact-session-action.is-danger{background:var(--canv-warning)}.warning-action{min-height:2.75rem;padding:0 1rem}.active-map-layout{gap:.9rem;display:grid;position:relative}.map-panel{border:1px solid var(--canv-line);min-height:18rem;box-shadow:var(--canv-shadow);background:linear-gradient(#d9ecf4b8,#d9ecf4e0),repeating-linear-gradient(45deg,#c7dfe8 0 10px,#d9ecf4 10px 20px);border-radius:8px;position:relative;overflow:hidden}.map-canvas{min-height:100%;color:var(--canv-muted);text-align:center;place-items:center;padding:1rem;display:grid;position:absolute;inset:0}.map-type-toggle{z-index:20;min-height:1.85rem;color:var(--canv-ink);background:#ffffffe6;border:1px solid #14211d38;padding:0 .55rem;font-size:.78rem;font-weight:700;position:absolute;top:.6rem;left:.6rem;box-shadow:0 .25rem .75rem #14211d24}.session-lock{z-index:15;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#f4f7f8e0;place-items:center;padding:1rem;display:grid;position:absolute;inset:0}.session-lock>div,.session-lock>button{width:min(100%,24rem)}.session-lock>div{border:1px solid var(--canv-line);background:var(--canv-surface);box-shadow:var(--canv-shadow);border-radius:8px 8px 0 0;padding:1rem}.session-lock .primary-action{border-radius:0 0 8px 8px}.saved-doors-panel,.property-panel,.door-history,.field-form,.door-details-form{border:1px solid var(--canv-line);background:var(--canv-surface);box-shadow:var(--canv-shadow);border-radius:8px;gap:1rem;padding:1rem;display:grid}.saved-doors-panel{min-height:18rem}.saved-doors-header,.property-panel-header,.history-item-head,.session-card{justify-content:space-between;align-items:center;gap:1rem;display:flex}.saved-doors-list,.history-list{gap:.65rem;display:grid}.saved-door-item{border:1px solid var(--canv-line);width:100%;color:var(--canv-ink);background:var(--canv-surface);text-align:left;gap:.25rem;padding:.85rem;display:grid}.saved-door-item.is-active{border-color:var(--canv-accent);background:var(--canv-surface-soft)}.property-panel{margin:0}.panel-close,.secondary-action{border:1px solid var(--canv-line);min-height:2.5rem;color:var(--canv-ink);background:var(--canv-surface-soft);cursor:pointer;font-weight:800}.panel-close{padding:0 .85rem}.secondary-action{padding:0 1rem}.primary-action{width:100%;min-height:2.75rem;padding:0 1.2rem}.session-card{border:1px solid var(--canv-line);background:var(--canv-surface-soft);border-radius:8px;margin-top:.75rem;padding:.55rem .75rem}.session-card strong,.session-card span{display:block}.session-card span{color:var(--canv-muted);font-size:.84rem}.compact-session-action{min-height:2.25rem;padding:0 .75rem;font-size:.9rem}.door-details-form,.field-form{margin-top:0}.door-details-form{grid-template-columns:repeat(2,minmax(0,1fr))}.door-details-form .full-field,.door-details-form button,.field-form{grid-column:1/-1}.door-details-form label,.field-form label{color:var(--canv-muted);gap:.35rem;font-size:.9rem;font-weight:700;display:grid}.door-details-form input,.field-form select,.field-form textarea{border:1px solid var(--canv-line);width:100%;min-height:2.75rem;color:var(--canv-ink);background:var(--canv-surface);padding:.75rem}.field-form textarea{resize:vertical}.primary-action:disabled,.secondary-action:disabled{cursor:not-allowed;opacity:.55}.form-message{min-height:1.25rem;color:var(--canv-muted);margin:0;font-size:.92rem}.history-item{border:1px solid var(--canv-line);background:var(--canv-surface);border-radius:8px;gap:.35rem;padding:.85rem;display:grid}.history-item p,.empty-list{margin:0}.bottom-dock{z-index:30;width:100%;padding:.75rem max(.75rem, env(safe-area-inset-left)) max(.75rem, env(safe-area-inset-bottom)) max(.75rem, env(safe-area-inset-right));border-bottom:0;border-left:0;border-right:0;border-radius:0;grid-template-columns:repeat(2,1fr);gap:.5rem;display:grid;position:fixed;bottom:0;left:0;right:0}.dock-item{min-height:2.75rem;color:var(--canv-muted);background:var(--canv-surface-soft);cursor:pointer;border:0;font-weight:800}.dock-item.is-active{color:#fff;background:var(--canv-accent-dark)}@media (width>=760px){.canvasser-shell{padding-bottom:5.5rem}.home-summary{grid-template-columns:minmax(0,1fr) auto;align-items:end}.stat-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.quick-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-stat-row:nth-last-child(2){border-bottom:0}.active-map-layout{grid-template-columns:minmax(0,1.3fr) minmax(22rem,.7fr);align-items:start}.map-panel{min-height:34rem}.session-card,.property-panel{grid-column:1/-1}.bottom-dock{border:1px solid var(--canv-line);border-radius:8px;width:min(26rem,100% - 2rem);bottom:1rem;left:50%;right:auto;transform:translate(-50%)}}@media (width<=620px){.canvasser-topbar{flex-direction:column}.session-warning,.saved-doors-header,.property-panel-header,.session-card{flex-direction:column;align-items:stretch}.door-details-form{grid-template-columns:1fr}}:root{color:#16201b;font-synthesis:none;text-rendering:optimizelegibility;background:#f4f7f1;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input{font:inherit}button{color:#fff;cursor:pointer;background:#1f6b4f;border:0;border-radius:6px;min-height:44px;padding:0 18px;font-weight:700}button:hover{background:#18563f}.secondary-button{color:#1e3326;background:#edf2e8}.secondary-button:hover{background:#dfe8d8}.app-shell{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100vh;padding:32px;display:flex}.app-shell--dashboard{justify-content:flex-start}.workspace{grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);align-items:stretch;gap:24px;width:min(1040px,100%);display:grid}.login-view{width:min(420px,100%)}.login-brand{margin-bottom:16px}.login-brand h1{margin-bottom:0;font-size:2.75rem}.brand-panel,.auth-panel{background:#fff;border:1px solid #d8dfd2;border-radius:8px;box-shadow:0 18px 45px #1e332614}.brand-panel{flex-direction:column;justify-content:center;padding:clamp(28px,5vw,64px);display:flex}.auth-panel{padding:24px}.button-row{flex-wrap:wrap;gap:10px;display:flex}.eyebrow{color:#5b6f65;letter-spacing:0;text-transform:uppercase;margin:0 0 12px;font-size:.78rem;font-weight:800}h1,h2,p{margin-top:0}h1{letter-spacing:0;max-width:720px;margin-bottom:22px;font-size:clamp(2.35rem,5vw,4.65rem);line-height:1}h2{margin-bottom:8px;font-size:1.85rem}.lede{color:#4b5d52;max-width:620px;margin-bottom:0;font-size:1.1rem;line-height:1.65}.muted,.status{color:#63736a}.tabs{background:#edf2e8;border-radius:8px;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:20px;padding:6px;display:grid}.tabs button{color:#425048;background:0 0}.tabs button.active{color:#1e3326;background:#fff;box-shadow:0 1px 6px #1e33261a}form{gap:14px;display:grid}label{color:#3b473f;gap:7px;font-size:.94rem;font-weight:700;display:grid}input{color:#16201b;border:1px solid #c9d3c1;border-radius:6px;width:100%;min-height:44px;padding:0 12px}input:focus{border-color:#1f6b4f;outline:3px solid #1f6b4f29}.error{color:#9a261f;background:#fdecec;border-radius:6px;margin:16px 0 0;padding:12px}.role-shell{width:min(1120px,100%)}.role-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.role-header h2{margin-bottom:0}.dashboard-grid{grid-template-columns:minmax(0,1.4fr) repeat(2,minmax(180px,.6fr));gap:16px;display:grid}.dashboard-panel{background:#fff;border:1px solid #d8dfd2;border-radius:8px;padding:24px;box-shadow:0 18px 45px #1e332614}.dashboard-panel h1{font-size:2.75rem}.dashboard-panel h2{font-size:1.2rem}.metric{color:#1f6b4f;margin-bottom:8px;font-size:2.4rem;font-weight:800;line-height:1}@media (width<=780px){.app-shell{justify-content:flex-start;align-items:stretch;padding:16px}.workspace{grid-template-columns:1fr}.login-view,.role-shell{width:100%}.role-header,.dashboard-grid{grid-template-columns:1fr}.role-header{flex-direction:column;align-items:flex-start}}
