@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Sora:wght@600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:light;--font-body: "Manrope", "Segoe UI", sans-serif;--font-display: "Sora", "Segoe UI", sans-serif;--color-primary: oklch(.56 .16 258);--color-primary-dark: oklch(.48 .16 258);--color-success: oklch(.67 .16 150);--color-danger: oklch(.58 .2 28);--color-warning: oklch(.71 .16 80);--color-surface: oklch(.985 .008 240);--color-surface-strong: oklch(.965 .014 240);--color-bg: oklch(.955 .012 248);--color-bg-accent: oklch(.92 .03 250);--color-text: oklch(.23 .03 255);--color-text-muted: oklch(.48 .025 255);--color-border: oklch(.86 .02 250);--radius: 1rem;--radius-lg: 1.5rem;--shadow: 0 10px 30px rgb(35 52 87 / .08), 0 1px 2px rgb(35 52 87 / .08);font-family:var(--font-body);font-size:16px;line-height:1.5;color:var(--color-text);background:radial-gradient(circle at top left,oklch(.97 .03 255) 0,transparent 24rem),radial-gradient(circle at top right,oklch(.95 .04 210) 0,transparent 18rem),var(--color-bg);-webkit-font-smoothing:antialiased}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.72rem 1.2rem;border-radius:var(--radius);font-size:.875rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:transform .18s ease,background .18s ease,opacity .18s ease,border-color .18s ease;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn-primary{background:var(--color-text);color:var(--color-surface)}.btn-primary:hover:not(:disabled){background:color-mix(in oklab,var(--color-text) 88%,var(--color-primary))}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-strong)}.btn-danger{background:var(--color-danger);color:#fff}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover{background:#ffffffa6}.spinner{width:2rem;height:2rem;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:color-mix(in oklab,var(--color-surface) 84%,white);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.header-brand-group{display:flex;align-items:center;gap:1rem;min-width:0}.brand-mark{display:inline-flex;align-items:center;gap:.85rem;color:var(--color-text);text-decoration:none}.brand-mark-logo{width:3rem;height:auto;display:block;filter:drop-shadow(0 6px 10px rgb(95 143 68 / .18))}.brand-mark-copy{display:flex;flex-direction:column;gap:.08rem;min-width:0}.brand-mark-copy strong{font-family:var(--font-display);font-size:1rem;letter-spacing:-.03em}.brand-mark-copy span{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.brand-mark-compact .brand-mark-logo{width:2.6rem}.brand-mark-compact .brand-mark-copy strong{font-size:.95rem}.greeting{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em}.dashboard-main{padding:1.75rem;max-width:48rem;width:100%;margin:0 auto}.dashboard-main-wide{max-width:72rem}.dashboard-toolbar{display:flex;align-items:center;gap:.75rem}.capability-panel{background:color-mix(in oklab,var(--color-surface) 88%,white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1rem 1.2rem;margin-bottom:1.25rem}.capability-toggle{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer}.capability-toggle::-webkit-details-marker{display:none}.capability-header{display:flex;flex-direction:column;gap:.3rem}.capability-eyebrow,.panel-eyebrow,.workspace-kicker,.workspace-stat-label{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted)}.capability-header h2,.workspace-hero h1,.panel-header-row h2,.panel h3{font-family:var(--font-display);letter-spacing:-.03em}.capability-header h2{font-size:1.05rem}.capability-header p{color:var(--color-text-muted);font-size:.92rem}.capability-toggle-chip{white-space:nowrap;padding:.45rem .8rem;border-radius:999px;background:var(--color-bg-accent);color:var(--color-text);font-size:.82rem;font-weight:700}.capability-list{list-style:none;display:grid;gap:.6rem}.capability-list li{background:color-mix(in oklab,var(--color-bg) 72%,white);padding:.85rem .95rem;border-radius:var(--radius);border:1px solid color-mix(in oklab,var(--color-border) 84%,white)}.workspace-hero{display:grid;grid-template-columns:minmax(0,1.9fr) minmax(16rem,1fr);gap:1.2rem;padding:1.5rem;margin-bottom:1rem;background:linear-gradient(135deg,color-mix(in oklab,white 78%,var(--color-bg-accent)),color-mix(in oklab,white 86%,var(--color-surface)));border:1px solid color-mix(in oklab,var(--color-border) 84%,white);border-radius:1.75rem;box-shadow:var(--shadow)}.workspace-hero-copy{display:flex;flex-direction:column;gap:.65rem;max-width:60ch}.workspace-hero h1{font-size:2rem;line-height:1.05}.workspace-hero p{color:var(--color-text-muted);max-width:58ch}.workspace-stat-row{display:grid;gap:.8rem;align-content:start}.workspace-stat{background:#ffffffb8;border:1px solid color-mix(in oklab,var(--color-border) 84%,white);border-radius:1.15rem;padding:1rem;display:grid;gap:.2rem}.workspace-stat strong{font-family:var(--font-display);font-size:1.8rem;letter-spacing:-.04em}.workspace-tabs{display:flex;flex-wrap:wrap;gap:.65rem;margin-bottom:1.1rem}.workspace-tab{border:1px solid var(--color-border);background:#ffffff8c;border-radius:999px;padding:.72rem 1rem;font:inherit;font-weight:700;color:var(--color-text-muted);cursor:pointer}.workspace-tab-active{background:var(--color-text);color:var(--color-surface);border-color:var(--color-text)}.workspace-stage{display:grid;gap:1rem}.workspace-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:1.25rem}.workspace-grid-secondary,.setup-grid{margin-bottom:0}.panel{background:color-mix(in oklab,var(--color-surface) 90%,white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.2rem;display:flex;flex-direction:column;gap:.95rem}.panel-full{margin-bottom:1.25rem}.panel h3{font-size:1.05rem}.panel-note{color:var(--color-text-muted);font-size:.875rem}.panel-header-row{display:flex;align-items:start;justify-content:space-between;gap:1rem}.panel-primary{background:linear-gradient(180deg,color-mix(in oklab,white 92%,var(--color-bg-accent)),color-mix(in oklab,var(--color-surface) 92%,white))}.panel-muted{background:color-mix(in oklab,var(--color-surface-strong) 72%,white)}.form-stack{display:flex;flex-direction:column;gap:.75rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.inline-field{max-width:22rem}.empty-block{display:grid;gap:.55rem;padding:1.25rem;border-radius:1.1rem;background:#ffffff85;border:1px dashed color-mix(in oklab,var(--color-border) 80%,white)}.empty-block h3{font-size:1.05rem}.signal-list{list-style:none;display:grid;gap:.6rem}.signal-list li{padding:.75rem .85rem;background:#ffffffb3;border:1px solid color-mix(in oklab,var(--color-border) 84%,white);border-radius:.95rem}.compact-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}.compact-list li{display:flex;justify-content:space-between;gap:1rem;padding:.65rem .8rem;border-radius:var(--radius);background:var(--color-bg);color:var(--color-text-muted)}.compact-list strong{color:var(--color-text)}.table-wrap{overflow-x:auto}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.login-card{background:color-mix(in oklab,var(--color-surface) 90%,white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:2.5rem;text-align:center;display:flex;flex-direction:column;gap:1.25rem;width:min(22rem,90vw)}.login-card .brand-mark{justify-content:center}.login-card .brand-mark-logo{width:3.5rem}.login-card h1{font-family:var(--font-display);font-size:1.9rem;letter-spacing:-.04em}.btn-google{background:#fff;color:#374151;border:1px solid var(--color-border)}.btn-google:hover{background:#f9fafb}.checkin-scan,.checkin-pin,.checkin-success,.checkin-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;padding:1.5rem;text-align:center}.qr-video{width:min(320px,90vw);height:min(320px,90vw);border-radius:var(--radius);background:#000;object-fit:cover}.pin-input{font-size:2rem;letter-spacing:.5rem;font-weight:700;width:10rem;text-align:center;padding:.75rem;border:2px solid var(--color-border);border-radius:var(--radius);outline:none}.pin-input:focus{border-color:var(--color-primary)}.success-icon{width:4rem;height:4rem;border-radius:50%;background:var(--color-success);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700}.error-msg{color:var(--color-danger);font-size:.875rem}.display-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;background:#0f172a;color:#fff;padding:2rem}.display-qr-wrapper{background:#fff;padding:1.5rem;border-radius:var(--radius)}.display-qr-placeholder{font-family:monospace;font-size:.75rem;color:#0f172a}.display-pin-wrapper{display:flex;flex-direction:column;align-items:center;gap:.5rem}.display-label{font-size:.875rem;opacity:.7;text-transform:uppercase;letter-spacing:.1em}.display-pin{font-size:5rem;font-weight:800;letter-spacing:.5rem;line-height:1}.display-timer{font-size:1.125rem;opacity:.6}.display-inactive{text-align:center}.status-badge{font-size:.75rem;font-weight:700;padding:.32rem .78rem;border-radius:999px;text-transform:uppercase}.status-active{background:#dcfce7;color:#15803d}.status-paused{background:#fef9c3;color:#854d0e}.status-closed{background:#f1f5f9;color:var(--color-text-muted)}.status-cancelled{background:#fee2e2;color:#991b1b}.session-page{padding:1.5rem;max-width:48rem;margin:0 auto}.session-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.session-actions{display:flex;flex-wrap:wrap;gap:.75rem}.empty-state{color:var(--color-text-muted);font-size:.875rem;margin-top:1rem}.section-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.section-card{background:#ffffffbd;border:1px solid color-mix(in oklab,var(--color-border) 84%,white);border-radius:1.2rem;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow)}.section-list-prominent{margin-top:0;gap:.8rem}.loading{display:flex;align-items:center;justify-content:center;padding:4rem}.scanning-msg{color:var(--color-text-muted);font-size:.875rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.section-card-info{display:flex;flex-direction:column;gap:.2rem;flex:1}.section-card-name{font-weight:600}.section-card-term,.section-card-code{font-size:.8rem;color:var(--color-text-muted)}.section-card-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.section-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-list-header h2{margin:0}.btn-sm{padding:.375rem .875rem;font-size:.8125rem}.btn-warning{background:var(--color-warning);color:#fff}.spinner-sm{width:1.25rem;height:1.25rem;border-width:2px}.session-counts{display:flex;gap:.75rem;flex-wrap:wrap;margin:1rem 0}.count-chip{display:flex;align-items:center;gap:.4rem;padding:.35rem .8rem;border-radius:999px;font-size:.8125rem}.count-present{background:#dcfce7;color:#15803d}.count-late{background:#fef9c3;color:#854d0e}.count-absent{background:#fee2e2;color:#991b1b}.count-unchecked{background:var(--color-border);color:var(--color-text-muted)}.live-indicator{font-size:.75rem}.live-connected{color:#16a34a}.live-disconnected{color:var(--color-warning);animation:pulse 1.2s ease-in-out infinite}.roster-section{margin-top:1.5rem}.roster-section h2{margin-bottom:.75rem}.roster-table{width:100%;border-collapse:collapse;font-size:.875rem}.roster-table th{text-align:left;padding:.5rem .75rem;border-bottom:2px solid var(--color-border);color:var(--color-text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase}.roster-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border)}.roster-row-present td:first-child{border-left:3px solid #16a34a}.roster-row-late td:first-child{border-left:3px solid var(--color-warning)}.roster-row-absent td:first-child{border-left:3px solid var(--color-danger)}.roster-row-unchecked td:first-child{border-left:3px solid var(--color-border)}.roster-time{color:var(--color-text-muted);font-variant-numeric:tabular-nums}.status-unchecked{background:var(--color-border);color:var(--color-text-muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal-card{background:color-mix(in oklab,var(--color-surface) 92%,white);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;padding:2rem;width:min(24rem,100%);display:flex;flex-direction:column;gap:1rem}.modal-card h2{font-size:1.25rem}.modal-hint{font-size:.875rem;color:var(--color-text-muted)}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.form-label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:500}.form-input{padding:.5rem .75rem;border:1.5px solid var(--color-border);border-radius:.9rem;font-size:.9375rem;outline:none;background:#ffffffc7;transition:border-color .15s,background .15s}.form-input:focus{border-color:var(--color-primary);background:#fff}.link-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}@media (max-width: 860px){.workspace-hero{grid-template-columns:1fr}.dashboard-header,.panel-header-row,.capability-toggle,.section-card,.section-list-header{flex-direction:column;align-items:stretch}.header-brand-group{gap:.75rem}.brand-mark{justify-content:flex-start}.workspace-tabs{overflow-x:auto;padding-bottom:.2rem}}
