:root{font-family:Space Grotesk,Avenir Next,sans-serif;color:#14213d;background:radial-gradient(circle at top left,rgba(255,196,61,.35),transparent 24rem),linear-gradient(180deg,#f7f4ea,#eef3f8);color-scheme:light}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;color:#14213d;line-height:1.5}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;font-size:16px}.shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr}.shell-content{min-width:0}.sidebar{padding:1.5rem;background:#102542;color:#f5f0e1}.sidebar-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.sidebar h1{margin:0 0 1rem;font-size:1.2rem;line-height:1.3}.sidebar-user{margin-top:-.25rem}.sidebar-nav{display:grid;gap:.75rem}.sidebar-section-label{margin-top:.85rem;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#f5f0e1a3}.sidebar-link{display:block;padding:.7rem .9rem;border-radius:12px;background:#ffffff14;transition:background .12s ease,transform .12s ease}.sidebar-link.active{background:#fff3;color:#fff}.sidebar-actions{margin-top:2rem}.sidebar-actions .button.subtle{width:100%;border-color:#f5f0e13d;background:#ffffff14;color:#f5f0e1}.sidebar-close,.nav-toggle{display:none;border:none;background:transparent;color:inherit;font-weight:700;cursor:pointer}.mobile-topbar,.sidebar-backdrop{display:none}.main{padding:2rem;min-width:0}.page{display:grid;gap:1.5rem;max-width:1280px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.page-header h2,.card h3{margin:0}.card{background:#ffffffe6;border:1px solid rgba(16,37,66,.08);border-radius:20px;padding:1.25rem;box-shadow:0 18px 50px #10254214;min-width:0}.grid{display:grid;gap:1rem}.grid.two{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.grid.three{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.form-grid{display:grid;gap:.9rem}.field{display:grid;gap:.35rem}.field label{font-size:.9rem;font-weight:700}.field input,.field textarea,.field select{width:100%;border:1px solid #c8d0db;border-radius:12px;padding:.8rem .9rem;background:#fff;min-height:48px}.field textarea{min-height:112px;resize:vertical}.actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.directory-toolbar{display:grid;gap:.9rem}.segmented-control{display:inline-grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem;width:min(100%,360px);padding:.35rem;border-radius:16px;border:1px solid #d7dfeb;background:#f5f7fb}.segmented-button{border:none;border-radius:12px;min-height:44px;padding:.7rem 1rem;background:transparent;color:#58657b;font-weight:700;cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease}.segmented-button.active{background:#102542;color:#f5f0e1;box-shadow:0 8px 20px #1025422e}.button{border:none;border-radius:999px;padding:.75rem 1.15rem;cursor:pointer;background:#ff7b00;color:#fff;font-weight:700;min-height:48px;display:inline-flex;align-items:center;justify-content:center;text-align:center}.button.secondary{background:#d7dfeb;color:#102542}.button.subtle{background:transparent;border:1px solid #c8d0db;color:#102542}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .8rem;border-radius:999px;font-size:.85rem;font-weight:800}.badge.ready{background:#d7f6dd;color:#116329}.badge.already_checked_in{background:#ffe6bf;color:#995b00}.badge.match_uncertain,.badge.not_found{background:#fde0df;color:#97362f}.table{width:100%;border-collapse:collapse}.table-scroll{width:100%;overflow-x:auto}.desktop-only{display:block}.mobile-only{display:none}.table th,.table td{padding:.8rem;text-align:left;border-bottom:1px solid #e7ebf1;vertical-align:top}.muted{color:#58657b}.hero{min-height:100vh;display:grid;place-items:center;padding:2rem}.hero-card{width:min(720px,100%)}.checkin-grid{display:grid;grid-template-columns:minmax(320px,420px) 1fr;gap:1rem;align-items:start}.checkin-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.checkin-title-row{display:flex;align-items:center;gap:.65rem}.checkin-info-button{width:2rem;height:2rem;border:1px solid #c8d0db;border-radius:999px;background:#fbfcfe;color:#102542;font-weight:800;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.checkin-summary-stat{display:grid;gap:.25rem;padding:.9rem 1rem;border:1px solid #e7ebf1;border-radius:16px;background:#fbfcfe}.checkin-mock-field{grid-column:1 / -1}.checkin-capture-card .page-header{margin-bottom:.9rem}.checkin-manual-card{padding:0;overflow:hidden}.checkin-section-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1.25rem}.checkin-section-header h3{margin:0}.checkin-section-meta{display:flex;align-items:center;gap:.75rem}.checkin-section-toggle-button{-webkit-appearance:none;appearance:none;width:2rem;height:2rem;margin:0;border:1px solid #d7dfeb;border-radius:999px;background:#fbfcfe;color:#58657b;font:inherit;font-size:1.2rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto}.checkin-section-toggle-button:focus-visible{outline:2px solid rgba(255,123,0,.6);outline-offset:2px}.checkin-manual-card>.grid{padding:0 1.25rem 1.25rem}.checkin-roster-card{padding:0;overflow:hidden}.checkin-roster-card>.grid{padding:0 1.25rem 1.25rem}.roster-list{display:grid;gap:.75rem}.roster-item-card{border:1px solid #e7ebf1;border-radius:16px;background:#fbfcfe}.roster-item-summary{list-style:none;cursor:pointer;padding:.95rem 1rem;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.roster-item-summary::-webkit-details-marker{display:none}.roster-item-summary:after{content:"+";color:#58657b;font-size:1.2rem;line-height:1;flex-shrink:0}.roster-item-card[open] .roster-item-summary:after{content:"−"}.roster-item-body{display:grid;gap:.8rem;padding:0 1rem 1rem}.roster-item-field{display:grid;gap:.2rem}.checkin-primary-button{width:100%;min-height:56px;font-size:1rem}.checkin-fallback-callout{display:grid;gap:.3rem}.occupancy-layout{display:grid;grid-template-columns:minmax(360px,1.2fr) minmax(300px,.8fr);gap:1rem}.directory-mobile-list{display:grid;gap:.75rem}.directory-person-card{border:1px solid #e7ebf1;border-radius:16px;background:#fbfcfe}.directory-person-summary{list-style:none;cursor:pointer;padding:.95rem 1rem;font-weight:700;display:flex;align-items:center;justify-content:space-between}.directory-person-summary::-webkit-details-marker{display:none}.directory-person-summary:after{content:"+";color:#58657b;font-size:1.2rem;line-height:1}.directory-person-card[open] .directory-person-summary:after{content:"−"}.directory-person-body{display:grid;gap:.8rem;padding:0 1rem 1rem}.directory-person-field{display:grid;gap:.2rem}.camera-frame{position:relative;overflow:hidden;border-radius:18px;min-height:280px;background:#0d1b2a}.camera-frame video,.camera-frame img{width:100%;height:100%;object-fit:cover;display:block}.occupancy-camera-frame{min-height:360px}.occupancy-overlay{position:absolute;inset:0;border:0;padding:0;background:transparent;cursor:crosshair}.occupancy-svg{width:100%;height:100%;display:block}.occupancy-line{stroke:#ffd166;stroke-width:.9;stroke-linecap:round}.occupancy-handle{fill:#ffd166;stroke:#102542cc;stroke-width:.35}.occupancy-track-box{fill:#0000;stroke-width:.45}.occupancy-track-box.positive{stroke:#6ee7b7}.occupancy-track-box.negative{stroke:#93c5fd}.occupancy-track-box.neutral{stroke:#fcd34d}.occupancy-track-box.counted{stroke:#ff7b00}.occupancy-track-anchor{fill:#fff;stroke:#102542;stroke-width:.25}.occupancy-track-label{fill:#f7fafc;font-size:3.2px;font-weight:700;paint-order:stroke;stroke:#0e1824d1;stroke-width:.45px}.occupancy-stat{display:grid;gap:.4rem}.occupancy-stat strong{font-size:2rem;line-height:1}.occupancy-analytics{height:220px;margin-bottom:1rem;border-radius:18px;padding:.75rem;background:linear-gradient(180deg,#ffffffb3,#f3f7fbeb),linear-gradient(90deg,rgba(16,37,66,.03) 1px,transparent 1px),linear-gradient(180deg,rgba(16,37,66,.03) 1px,transparent 1px);background-size:auto,16.6% 100%,100% 20%}.occupancy-analytics svg{width:100%;height:100%}.occupancy-chart-path{fill:none;stroke:#ff7b00;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.camera-guide-frame{position:absolute;inset:14% 18%;border:3px solid rgba(255,255,255,.92);border-radius:28px;box-shadow:0 0 0 999px #04101c42,inset 0 0 0 1px #ffffff47;pointer-events:none}.camera-face-box{position:absolute;border:2px solid #8de3b7;border-radius:18px;box-shadow:0 0 0 1px #03231c40;pointer-events:none}.camera-guidance-chip{position:absolute;left:1rem;right:1rem;bottom:1rem;padding:.8rem .95rem;border-radius:16px;color:#f7fafc;background:#0e1824b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-weight:700;line-height:1.35}.camera-guidance-chip.warning{background:#8b3018c7}.camera-guidance-chip.ready{background:#0c5935cc}.camera-countdown{position:absolute;top:1rem;right:1rem;width:3.2rem;height:3.2rem;border-radius:999px;display:grid;place-items:center;font-size:1.5rem;font-weight:800;color:#102542;background:#ffffffe6;box-shadow:0 8px 24px #10254233}.modal-backdrop{position:fixed;inset:0;background:#09111d73;display:grid;place-items:center;padding:1.5rem;z-index:1000}.modal-card{width:min(520px,100%);background:#fffffff5;border:1px solid rgba(16,37,66,.08);border-radius:22px;padding:1.25rem;box-shadow:0 28px 80px #10254238}.inline-list{display:flex;flex-wrap:wrap;gap:.75rem}.alert{padding:.9rem 1rem;border-radius:14px;background:#fff1c9}.alert.success{background:#dff5e3;color:#116329}.alert.warning{background:#fff1c9;color:#995b00}.alert.info{background:#e8eef7;color:#26456a}.error{color:#9f2222;padding:.85rem 1rem;border-radius:14px;background:#9f222214;border:1px solid rgba(159,34,34,.16)}@media(max-width:1024px){.main{padding:1.25rem}.occupancy-layout{grid-template-columns:1fr}}@media(max-width:900px){.shell{display:block}.sidebar{position:fixed;top:0;bottom:0;left:0;width:min(82vw,320px);max-width:320px;transform:translate(-100%);transition:transform .18s ease;z-index:30;overflow-y:auto;padding-bottom:1.5rem}.sidebar.open{transform:translate(0)}.sidebar-close,.nav-toggle{display:inline-flex;align-items:center;justify-content:center}.sidebar-close{width:2.5rem;height:2.5rem;border-radius:999px;background:#ffffff14}.sidebar-backdrop.visible{position:fixed;inset:0;display:block;border:none;background:#09111d5c;z-index:20;cursor:pointer}.mobile-topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.9rem 1rem;background:#f7f4eaf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(16,37,66,.08)}.mobile-topbar-title{font-weight:700;text-align:center;flex:1}.nav-toggle{min-height:44px;padding:.65rem .9rem;border-radius:999px;background:#102542;color:#f5f0e1}.main{padding:1rem}.page,.grid.two,.grid.three,.checkin-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:stretch}.camera-frame{min-height:240px}.checkin-manual-card>.grid{padding:0 1rem 1rem}.checkin-roster-card>.grid{padding:0 1rem 1rem}.occupancy-camera-frame{min-height:280px}.modal-backdrop{padding:1rem}}@media(max-width:720px){.card{padding:1rem;border-radius:18px}.checkin-section-header{padding:1rem}.table.responsive thead{display:none}.table.responsive,.table.responsive tbody,.table.responsive tr,.table.responsive td{display:block;width:100%}.table.responsive tr{padding:.85rem 0;border-bottom:1px solid #e7ebf1}.table.responsive td{padding:.35rem 0;border-bottom:none}.table.responsive td:before{content:attr(data-label);display:block;margin-bottom:.2rem;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:#58657b;font-weight:700}}@media(max-width:640px){.hero,.main{padding:1rem}.desktop-only{display:none}.mobile-only{display:block}.segmented-control{width:100%}.actions{flex-direction:column;align-items:stretch}.actions>*{width:100%}.inline-list{flex-direction:column;gap:.35rem}.camera-guide-frame{inset:12% 10%}.camera-guidance-chip{left:.75rem;right:.75rem;bottom:.75rem;font-size:.92rem}.camera-countdown{width:2.9rem;height:2.9rem;font-size:1.25rem}}
