:root{color-scheme:light;font-family:Avenir Next,Helvetica Neue,sans-serif;background:radial-gradient(circle at top left,rgba(238,170,90,.24),transparent 38%),radial-gradient(circle at bottom right,rgba(24,49,79,.14),transparent 34%),linear-gradient(180deg,#f4efe7,#ebe3d6);color:#182027;line-height:1.4;font-weight:500;font-synthesis-weight:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{touch-action:manipulation}img{max-width:100%;display:block}p,h1,h2{margin-top:0}.app-shell,.admin-shell{min-height:100vh;min-height:100dvh;padding:calc(20px + env(safe-area-inset-top)) calc(20px + env(safe-area-inset-right)) calc(20px + env(safe-area-inset-bottom)) calc(20px + env(safe-area-inset-left))}.kiosk-shell{display:grid;gap:clamp(16px,2vw,24px);align-items:stretch;min-height:100dvh;height:100dvh;grid-template-rows:auto minmax(0,1fr);overflow:hidden}.brand-panel,.kiosk-card,.metric-card,.table-card,.admin-header{border:1px solid rgba(24,32,39,.08);border-radius:28px;background:#ffffffe0;box-shadow:0 18px 45px #221b1214;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand-panel,.kiosk-card,.metric-card,.table-card,.admin-header{padding:24px}.kiosk-brand-panel{display:grid;gap:12px}.kiosk-info-column{min-height:0;display:grid;gap:12px;align-content:start}.brand-footer,.status-header,.table-header,.table-row,.admin-grid,.admin-columns,.detail-actions,.filters-grid,.admin-access-form,.admin-access-table-head,.admin-access-row{display:flex;gap:16px}.brand-footer,.status-header,.table-header,.table-row,.detail-actions{align-items:center;justify-content:space-between}.brand-footer-copy{display:grid;gap:8px}.eyebrow,.metric-label,.identity-label{margin:0 0 8px;color:#906229;font-size:.85rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.caption{color:#62584a}.timezone{margin:0;color:#62584a}.status-chip{display:inline-flex;align-items:center;justify-content:center;min-width:124px;min-height:46px;padding:10px 16px;border-radius:999px;background:#e8edf2;color:#18314f;font-size:.95rem;font-weight:800}.status-chip.in{background:#d7efdd;color:#174526}.status-chip.out{background:#f8ddd4;color:#8c351b}.status-chip.warning{background:#f8e7b8;color:#7b5600}.status-banner{margin:0;padding:14px 16px;border-radius:18px;font-weight:700}.status-banner.info{background:#e0eefc;color:#1c4e78}.status-banner.warning{background:#fff0c6;color:#7b5600}.status-banner.error{background:#ffe3d9;color:#8c351b}.screen-stack{display:grid;gap:18px;min-height:100%;align-content:start}.center-screen{min-height:min(520px,100%);align-content:center;justify-items:center;text-align:center}.idle-screen{width:100%;min-height:min(520px,100%);display:grid;gap:18px;align-content:center;justify-items:center;padding:24px;border:none;border-radius:24px;background:linear-gradient(145deg,#18314f0f,#18314f05),#fbf8f3;cursor:pointer}.idle-callout{font-size:clamp(2rem,6vw,3.6rem);font-weight:800;letter-spacing:-.03em}.pin-slots{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.pin-slot{min-height:92px;display:inline-flex;align-items:center;justify-content:center;border-radius:24px;background:#f7efe4;font-size:2.2rem;font-weight:800}.pin-slot.filled{background:#f0d39d}.keypad{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.key-button,.submit-button,.ghost-button,.photo-picker,.inline-action{min-height:74px;border:none;border-radius:22px}.key-button,.submit-button{background:#18314f;color:#fffaf3;font-size:1.55rem;font-weight:800}.key-button.clear{background:#e9e6de;color:#584c3b}.key-button.backspace{background:#dce9f7;color:#18314f}.submit-button{width:100%}.submit-button:disabled,.key-button:disabled,.ghost-button:disabled{opacity:.5;cursor:not-allowed}.admin-shell button{transition:background-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease}.admin-shell button:not(:disabled){cursor:pointer}.admin-shell .ghost-button:not(:disabled):hover,.admin-shell .inline-action:not(:disabled):hover{background:#e1d4c1;color:#18314f;box-shadow:0 10px 24px #18314f1f}.admin-shell .submit-button:not(:disabled):hover{background:#224365;box-shadow:0 10px 24px #18314f29}.admin-shell .interactive-row:not(:disabled):hover{background:#f3ebdf;box-shadow:inset 0 0 0 1px #18314f1f}.admin-shell button:disabled{cursor:not-allowed}.ghost-button,.inline-action{display:inline-flex;align-items:center;justify-content:center;padding:0 20px;background:#efe6d8;color:#584c3b;text-decoration:none;font-weight:700}.identity-card,.photo-preview-card,.inline-note{border-radius:22px;background:#f8f3ec;padding:18px}.photo-picker{display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#f8f3ec;color:#18314f;font-weight:800}.photo-capture-block{display:grid;gap:8px}.photo-picker input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0}.photo-preview{width:100%;max-height:320px;object-fit:cover;border-radius:18px;margin-bottom:12px}.kiosk-card{min-height:0;height:100%;overflow:auto;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}.kiosk-clock-panel{display:grid;gap:8px}.kiosk-clock-time{margin:0;font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.04em;color:#18314f}.kiosk-clock-date{margin:0}.admin-grid,.admin-columns{margin-top:20px;flex-wrap:wrap}.admin-view-nav{margin-top:20px;display:flex;flex-wrap:wrap;gap:12px}.admin-view-button.active{background:#18314f;color:#fffaf3}.metric-card,.table-card{flex:1 1 320px}.metric-card strong{font-size:2.6rem}.filters-card{margin-top:20px}.filters-grid{flex-wrap:wrap;align-items:end}.field-stack{display:grid;gap:8px;flex:1 1 220px}.field-group{display:grid;gap:8px;flex:1 1 220px;color:#18314f;font-weight:700}.text-input{min-height:58px;width:100%;padding:0 16px;border:1px solid rgba(24,32,39,.1);border-radius:18px;background:#fffdf9}.filter-button{min-width:160px}.compact-button{min-height:58px}.compact-input{min-height:50px;padding:0 12px}.admin-access-panel,.admin-employee-panel,.geofence-panel{margin-top:20px;display:grid;gap:18px}.admin-access-header{align-items:start}.admin-employee-header{align-items:start;gap:20px}.employee-roster-search{min-width:min(100%,320px)}.admin-access-form{flex-wrap:wrap;align-items:end}.admin-access-table{display:grid;gap:10px}.admin-access-table-head,.admin-access-row{align-items:center;padding:14px 16px;border-radius:18px;background:#fbf8f3}.admin-access-table-head{color:#62584a;font-size:.86rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.admin-access-table-head>*,.admin-access-row>*{min-width:0;flex:1 1 0}.employee-roster-identity,.employee-roster-status,.employee-roster-site,.employee-roster-actions{display:grid;gap:6px}.rotation-run-layout{margin-top:20px}.rotation-run-list{max-height:70vh;overflow:auto}.rotation-run-row,.rotation-recipient-row{display:flex;align-items:start;justify-content:space-between;gap:16px}.rotation-run-summary,.rotation-recipient-copy,.rotation-recipient-meta{display:grid;gap:6px}.rotation-run-summary,.rotation-recipient-meta{justify-items:start;text-align:left}.rotation-run-window{margin-top:16px}.geofence-layout{display:grid;gap:18px;grid-template-columns:minmax(260px,320px) minmax(0,1fr)}.geofence-list,.geofence-editor,.geofence-assignment-list{display:grid;gap:12px}.geofence-list-item{align-items:center}.geofence-circle-editor{gap:16px}.geofence-search-results{display:grid;gap:8px;max-height:220px;overflow:auto}.geofence-search-result{padding:14px 16px;border-radius:18px}.geofence-radius-card{display:grid;gap:12px;padding:18px;border-radius:22px;background:linear-gradient(180deg,#18314f0a,#18314f14),#f8f3ec}.geofence-radius-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.geofence-radius-slider{width:100%;accent-color:#18314f}.geofence-map-card{overflow:hidden;border-radius:22px;border:1px solid rgba(24,49,79,.12);background:#f8f3ec}.geofence-map{width:100%;height:360px;font:inherit}.geofence-map .leaflet-control-attribution{font-size:.76rem}.geofence-manual-panel{display:grid;gap:12px;padding:18px;border-radius:22px;background:#fbf8f3}.geofence-manual-panel summary{cursor:pointer;font-weight:700}.geofence-preview-card{display:grid;place-items:center;min-height:220px;border-radius:22px;background:linear-gradient(180deg,#18314f0a,#18314f14),#f8f3ec;padding:20px}.geofence-preview-svg{width:min(100%,320px);aspect-ratio:1}.geofence-preview-shape{fill:#18314f29;stroke:#18314f;stroke-width:2.5}.geofence-preview-point{fill:#18314f}.geofence-assignment-item{display:flex;gap:12px;align-items:start;padding:14px 16px;border-radius:18px;background:#fbf8f3}.geofence-assignment-toggle{display:flex;gap:12px;align-items:center;padding:10px 4px 4px}.geofence-assignment-item span{display:grid;gap:4px}.geofence-vertex-row{align-items:end}.employee-roster-status,.employee-roster-actions{justify-items:start}.table-list,.detail-stack{display:grid;gap:14px}.interactive-row{width:100%;border:none;background:#fbf8f3;text-align:left;cursor:pointer}.interactive-row.selected{outline:2px solid rgba(24,49,79,.18)}.detail-card{min-height:420px}.pagination-row{margin-top:14px}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#1820275c;z-index:20}.modal-card{width:min(100%,720px);max-height:min(90vh,860px);overflow:auto}.photo-viewer-card{width:min(100%,1080px);display:grid;gap:20px}.photo-viewer-header{align-items:start}.photo-viewer-close-icon{min-width:58px;padding:0 18px}.photo-viewer-stage{display:grid;gap:14px}.photo-viewer-frame{display:grid;place-items:center;min-height:min(60vh,720px);padding:20px;border-radius:24px;background:linear-gradient(180deg,#18314f0a,#18314f14),#f8f3ec}.photo-viewer-image{width:auto;max-width:100%;max-height:min(70vh,760px);object-fit:contain;border-radius:18px;box-shadow:0 16px 40px #18202729}.photo-viewer-actions{justify-content:flex-end}.pin-batch-list{display:grid;gap:12px}.pin-code-display{font-size:1.8rem;letter-spacing:.12em}.pin-batch-item{display:grid;gap:14px}.pin-batch-item-body{display:grid;gap:10px}.pin-delivery-status{display:grid;gap:4px}.pin-delivery-email{word-break:break-word}.login-shell{display:grid;place-items:center}.login-card{width:min(100%,520px)}.login-password-field{margin-bottom:8px}@media(max-width:900px){.admin-access-form,.admin-access-table-head,.admin-access-row{flex-direction:column;align-items:stretch}.rotation-run-row,.rotation-recipient-row{flex-direction:column}.geofence-layout{grid-template-columns:1fr}.geofence-radius-row{align-items:start;flex-direction:column}}@media(max-width:700px){.geofence-map{height:320px}}@media(min-width:900px){.kiosk-shell{grid-template-columns:minmax(240px,320px) minmax(0,1fr);grid-template-rows:minmax(0,1fr);justify-content:center;padding:calc(28px + env(safe-area-inset-top)) calc(28px + env(safe-area-inset-right)) calc(28px + env(safe-area-inset-bottom)) calc(28px + env(safe-area-inset-left))}}@media(min-width:700px)and (max-width:899px){.kiosk-info-column{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}}
