:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--text:#0f1419;--text-muted:#5c6c7a;--bg:#f4f6f9;--surface:#fff;--surface-subtle:#f8fafc;--surface-muted:#f1f5f9;--input-bg:#fff;--border:#e2e8f0;--border-strong:#cbd5e1;--accent:#4338ca;--accent-hover:#3730a3;--accent-soft:#4338ca1a;--accent-fg:#fff;--danger:#b91c1c;--shadow-sm:0 1px 2px #0f14190f;--shadow-md:0 4px 12px #0f141914;--shadow-lg:0 12px 40px #0f14191f;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--mono:ui-monospace, "SF Mono", Consolas, monospace;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}body{margin:0}#root{background:var(--bg);min-height:100svh}code{font-family:var(--mono);border-radius:var(--radius-sm);background:var(--surface-muted);border:1px solid var(--border);padding:.12em .4em;font-size:.88em}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.route-loading{min-height:100svh;color:var(--text-muted);place-items:center;font-size:.95rem;display:grid}.login-page{grid-template-columns:1fr;min-height:100svh;display:grid}@media (width>=900px){.login-page{grid-template-columns:minmax(0,1fr) minmax(380px,480px)}}.login-hero{color:#fff;background:linear-gradient(145deg,#312e81 0%,#4338ca 45%,#6366f1 100%);display:none;position:relative;overflow:hidden}@media (width>=900px){.login-hero{justify-content:center;align-items:center;padding:3rem;display:flex}}.login-hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 20% 80%,#ffffff1f 0%,#0000 45%),radial-gradient(circle at 80% 20%,#ffffff14 0%,#0000 40%);position:absolute;inset:0}.login-hero-inner{text-align:left;max-width:22rem;position:relative}.login-hero-mark{border-radius:var(--radius-md);background:#ffffff26;border:1px solid #fff3;place-items:center;width:3rem;height:3rem;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700;display:grid}.login-hero-title{letter-spacing:-.02em;margin:0 0 .75rem;font-size:1.75rem;font-weight:700}.login-hero-text{opacity:.92;margin:0;font-size:1rem;line-height:1.5}.login-panel{background:var(--bg);box-sizing:border-box;flex-direction:column;justify-content:center;min-height:100svh;padding:1.5rem;display:flex}@media (width>=900px){.login-panel{min-height:auto;padding:2.5rem 2rem}}.login-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);width:100%;max-width:22rem;box-shadow:var(--shadow-md);margin:0 auto;padding:2rem}.login-card-head{margin-bottom:1.5rem}.login-title{letter-spacing:-.02em;margin:0 0 .35rem;font-size:1.4rem;font-weight:600}.login-subtitle{color:var(--text-muted);margin:0;font-size:.9rem}.login-form{flex-direction:column;gap:1rem;display:flex}.field{text-align:left;flex-direction:column;gap:.4rem;display:flex}.field-label{color:var(--text-muted);font-size:.8125rem;font-weight:500}.field-checkbox{flex-direction:row;align-items:center;gap:.5rem}.field-checkbox .field-label{color:var(--text);margin:0;font-weight:500}.field-group-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-top:.5rem;font-size:.75rem;font-weight:600}.toolbar-note{color:var(--text-muted);align-self:center;font-size:.875rem}.field-input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--input-bg);color:var(--text);font:inherit;padding:.5rem .75rem;transition:border-color .15s,box-shadow .15s}.field-input:hover{border-color:var(--border-strong)}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.login-error{color:var(--danger);border-radius:var(--radius-sm);background:#b91c1c14;margin:0;padding:.5rem .65rem;font-size:.875rem}.btn-primary{border-radius:var(--radius-md);background:var(--accent);color:var(--accent-fg);font:inherit;cursor:pointer;border:none;padding:.55rem 1rem;font-weight:500;transition:background .15s,transform 50ms}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary-lg{margin-top:.25rem;padding:.65rem 1rem}.btn-primary:disabled{opacity:.65;cursor:not-allowed}.login-footer{text-align:center;max-width:22rem;color:var(--text-muted);margin:1.5rem auto 0;font-size:.75rem}.shell{min-height:100svh;display:flex}.shell-aside{border-right:1px solid var(--border);background:var(--surface);width:260px;box-shadow:var(--shadow-sm);z-index:1;flex-direction:column;flex-shrink:0;padding:1.25rem 0 1rem;display:flex}.shell-brand{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;margin:0 .75rem .5rem;padding:0 1rem 1.25rem;display:flex}.shell-brand-mark{border-radius:var(--radius-md);color:#fff;background:linear-gradient(135deg,#4338ca,#6366f1);flex-shrink:0;place-items:center;width:2.5rem;height:2.5rem;font-size:1.1rem;font-weight:700;display:grid;box-shadow:0 2px 8px #4338ca59}.shell-brand-text{flex-direction:column;gap:.1rem;min-width:0;display:flex}.shell-brand-name{letter-spacing:-.02em;font-size:1.05rem;font-weight:600}.shell-brand-tagline{color:var(--text-muted);font-size:.75rem}.shell-nav{flex-direction:column;gap:4px;padding:0 .5rem;display:flex}.shell-nav-link{border-radius:var(--radius-md);color:var(--text-muted);align-items:center;gap:.65rem;padding:.55rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex}.shell-nav-link:hover{background:var(--surface-muted);color:var(--text)}.shell-nav-link.is-active{background:var(--accent-soft);color:var(--accent)}.shell-nav-icon{opacity:.85;flex-shrink:0}.shell-nav-link.is-active .shell-nav-icon{opacity:1}.shell-main{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex}.shell-header{border-bottom:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);z-index:2;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1.5rem;display:flex;position:sticky;top:0}.shell-header-title-block{min-width:0}.shell-page-title{letter-spacing:-.02em;margin:0;font-size:1.25rem;font-weight:600}.shell-page-sub{color:var(--text-muted);margin:.15rem 0 0;font-size:.8125rem}.shell-header-actions{flex-shrink:0;align-items:center;gap:1rem;display:flex}.shell-user{text-align:right;align-items:center;gap:.65rem;display:flex}.shell-user-avatar{width:2.5rem;height:2.5rem;color:var(--accent);border:1px solid var(--border);background:linear-gradient(145deg,#e0e7ff,#c7d2fe);border-radius:50%;flex-shrink:0;place-items:center;font-size:.8rem;font-weight:600;display:grid}.shell-user-meta{flex-direction:column;gap:.1rem;min-width:0;display:flex}.shell-user-email{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:12rem;font-size:.875rem;font-weight:500;overflow:hidden}.shell-user-role{color:var(--text-muted);font-size:.75rem}.shell-logout{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font:inherit;cursor:pointer;padding:.45rem .85rem;font-size:.875rem;font-weight:500;transition:background .12s,border-color .12s}.shell-logout:hover{background:var(--surface-muted);border-color:var(--border-strong)}.shell-content{flex:1;padding:1.5rem 1.5rem 2rem;overflow:auto}@media (width>=900px){.shell-content{padding:1.75rem 2rem 2.5rem}}.page{max-width:1120px}.page-intro{margin-bottom:1.5rem}.page-title{letter-spacing:-.02em;margin:0 0 .35rem;font-size:1.5rem;font-weight:600}.page-lead{color:var(--text-muted);max-width:42rem;margin:0;font-size:.95rem;line-height:1.55}.page-grid-2{gap:1.25rem;display:grid}@media (width>=800px){.page-grid-2{grid-template-columns:1fr 1fr;align-items:start}}.stat-grid{grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}@media (width>=700px){.stat-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-sm);flex-direction:column;gap:.35rem;padding:1rem 1.1rem;display:flex}.stat-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:500}.stat-card-value{letter-spacing:-.02em;color:var(--text);font-size:1.5rem;font-weight:600}.stat-card-hint{color:var(--text-muted);font-size:.75rem}.card{text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);padding:1.25rem 1.35rem}.card-elevated{box-shadow:var(--shadow-sm)}.card-muted{background:var(--surface-subtle)}.card-head{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.card-title{margin:0;font-size:1rem;font-weight:600}.card-badge{text-transform:uppercase;letter-spacing:.05em;background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:.2rem .5rem;font-size:.7rem;font-weight:600}.kv{grid-template-columns:7.5rem 1fr;gap:.5rem 1rem;margin:0;font-size:.9rem;display:grid}.kv dt{color:var(--text-muted);margin:0;font-weight:500}.kv dd{margin:0}.kv-mono{font-family:var(--mono);word-break:break-all;font-size:.85rem}.role-pill{border-radius:var(--radius-sm);background:var(--surface-muted);border:1px solid var(--border);padding:.15rem .5rem;font-size:.85rem;font-weight:500;display:inline-block}.quick-list{color:var(--text-muted);margin:0;padding-left:1.15rem;font-size:.9rem;line-height:1.6}.quick-list li{margin-bottom:.35rem}.quick-empty{color:var(--text-muted);margin:0;font-size:.9rem}.quick-links{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.quick-link{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--text);justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .85rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s,box-shadow .12s;display:flex}.quick-link:hover{background:var(--surface-muted);border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.quick-link-label{flex:1}.quick-link-arrow{color:var(--accent);font-weight:600}.empty-state{text-align:center;max-width:28rem;padding:2rem 1.5rem}.empty-state-icon{color:var(--accent);opacity:.55;margin-bottom:1rem}.empty-state-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600}.empty-state-text{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.5}@media (width<=768px){.shell{flex-direction:column}.shell-aside{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap;align-items:center;width:100%;padding:.75rem}.shell-brand{border-bottom:1px solid var(--border);width:100%;margin:0 0 .25rem;padding:0 0 .75rem}.shell-nav{flex-flow:wrap;gap:6px;width:100%}.shell-nav-link{padding:.45rem .55rem;font-size:.8rem}.shell-header{flex-wrap:wrap;padding:.75rem 1rem}.shell-page-title{font-size:1.1rem}.shell-user-meta{display:none}.shell-user-avatar{width:2.25rem;height:2.25rem;font-size:.75rem}}.org-page .page-intro{margin-bottom:1rem}.tabs{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.35rem;margin-bottom:1.25rem;padding-bottom:.25rem;display:flex}.tabs-btn{border-radius:var(--radius-md) var(--radius-md) 0 0;color:var(--text-muted);font:inherit;cursor:pointer;background:0 0;border:1px solid #0000;margin-bottom:-1px;padding:.45rem .85rem;font-size:.9rem;font-weight:500}.tabs-btn:hover{color:var(--text);background:var(--surface-muted)}.tabs-btn.is-active{color:var(--accent);border-color:var(--border);border-bottom-color:var(--surface);background:var(--surface)}.tabs-panel{min-height:12rem}.tab-panel{padding-top:.25rem}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1rem;display:flex}.toolbar-filters{flex-wrap:wrap;flex:1;gap:.5rem;min-width:0;display:flex}.toolbar-input{min-width:10rem;max-width:16rem}@media (width<=640px){.toolbar-input{width:100%;max-width:100%}}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);margin-bottom:1rem;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table th{text-align:left;border-bottom:1px solid var(--border);background:var(--surface-subtle);color:var(--text-muted);white-space:nowrap;padding:.65rem .85rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:.65rem .85rem}.data-table tbody tr:last-child td{border-bottom:none}.cell-sub{color:var(--text-muted);margin-top:.25rem;font-size:.75rem}.cell-mono{font-family:var(--mono);font-size:.8rem}.cell-nowrap{white-space:nowrap}.cell-muted{color:var(--text-muted);text-align:center;padding:1.5rem!important}.cell-actions{white-space:nowrap;text-align:right}.cell-actions-row{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.badge{background:var(--surface-muted);border:1px solid var(--border);border-radius:999px;padding:.15rem .45rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-lg{padding:.3rem .65rem;font-size:.85rem}.badge-status.badge-pending{color:#92400e;background:#fef3c7;border-color:#fcd34d}.badge-status.badge-approved{color:#1e40af;background:#dbeafe;border-color:#93c5fd}.badge-status.badge-rejected{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.badge-status.badge-completed{color:#065f46;background:#d1fae5;border-color:#6ee7b7}.pagination-bar{color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;font-size:.875rem;display:flex}.pagination-actions{gap:.5rem;display:flex}.btn-outline{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font:inherit;cursor:pointer;padding:.45rem .85rem;font-size:.875rem;font-weight:500;transition:background .12s,border-color .12s}.btn-outline:hover:not(:disabled){background:var(--surface-muted);border-color:var(--border-strong)}.btn-outline:disabled{opacity:.5;cursor:not-allowed}.btn-outline.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-outline.btn-danger:hover:not(:disabled){border-color:var(--danger);background:#b91c1c14}.btn-sm{padding:.3rem .55rem;font-size:.8rem}.btn-link{color:var(--accent);font:inherit;cursor:pointer;background:0 0;border:none;margin-left:.65rem;padding:0;font-size:.875rem;text-decoration:underline}.btn-link:first-child{margin-left:0}.btn-link:hover:not(:disabled){color:var(--accent-hover)}.btn-link-danger{color:var(--danger)}.banner-error{border-radius:var(--radius-md);color:var(--danger);background:#b91c1c14;margin:0 0 1rem;padding:.65rem .85rem;font-size:.9rem}.banner-success{border-radius:var(--radius-md);color:#166534;background:#1665341a;margin:0 0 1rem;padding:.65rem .85rem;font-size:.9rem}.modal-backdrop{z-index:1000;box-sizing:border-box;background:#0f141973;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal-panel{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);width:100%;max-width:22rem;max-height:min(90svh,640px);box-shadow:var(--shadow-lg);padding:1.25rem 1.35rem;overflow-y:auto}.modal-panel-wide{max-width:28rem}.modal-title{margin:0 0 1rem;font-size:1.15rem;font-weight:600}.modal-lead{color:var(--text-muted);margin:0 0 1rem;font-size:.9rem;line-height:1.45}.modal-meta{color:var(--text-muted);margin:0 0 1rem;font-size:.85rem}.modal-form{flex-direction:column;gap:.85rem;display:flex}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.field-textarea{resize:vertical;min-height:4rem}.invite-code-block{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.invite-code{border-radius:var(--radius-md);background:var(--surface-muted);border:1px solid var(--border);word-break:break-all;flex:1;min-width:0;padding:.65rem .75rem;font-size:.8rem}.public-forms-intro{color:var(--text-muted);max-width:40rem;margin:0 0 1.25rem;font-size:.9rem}.public-form-card{margin-bottom:1.25rem}.public-form-card:last-child{margin-bottom:0}.public-form-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600}.public-form-text{color:var(--text-muted);margin:0 0 1rem;font-size:.85rem}.public-form{flex-direction:column;gap:.85rem;max-width:24rem;display:flex}.req-star{color:var(--danger);font-weight:600}.settings-page .settings-about{margin-bottom:1.25rem}.settings-prose{color:var(--text);font-size:.9rem;line-height:1.55}.settings-prose p{margin:0 0 .75rem}.settings-prose p:last-child{margin-bottom:0}.settings-form-card{max-width:28rem;margin-bottom:1.5rem}.settings-create-form{flex-direction:column;gap:.85rem;display:flex}.settings-page .field-row-checkbox{flex-direction:row;align-items:flex-start;gap:.65rem;display:flex}.settings-page .field-row-checkbox input[type=checkbox]{flex-shrink:0;margin-top:.2rem}.field-hint{color:var(--text-muted);margin-top:.25rem;font-size:.75rem;display:block}.inline-code{font-family:var(--mono);border-radius:var(--radius-sm);background:var(--surface-muted);padding:.1em .35em;font-size:.85em}.settings-table-section{margin-top:.5rem}.settings-table-title{margin:0 0 .75rem;font-size:1.05rem;font-weight:600}.pass-detail-back{margin:0 0 1rem}.pass-detail-head{flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:1.25rem;display:flex}.pass-detail-title{margin:0;font-size:1.35rem;font-weight:600}.kv-pass-detail{grid-template-columns:minmax(7rem,10rem) 1fr;max-width:40rem}.pass-qr-block{max-width:40rem;margin-top:1.5rem}.pass-qr-title{margin:0 0 .5rem;font-size:.95rem;font-weight:600}.pass-qr-pre{border-radius:var(--radius-md);background:var(--surface-muted);border:1px solid var(--border);font-family:var(--mono);margin:0;padding:1rem;font-size:.78rem;line-height:1.45;overflow:auto}.pass-actions{flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;display:flex}.attendance-intro{margin-bottom:1.25rem}.attendance-intro-title{margin:0 0 .75rem;font-size:1.05rem;font-weight:600}.attendance-intro-body{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.55}.attendance-intro-body p{margin:0 0 .65rem}.attendance-intro-body p:last-child{margin-bottom:0}.attendance-intro-next{border-top:1px dashed var(--border);padding-top:.5rem}.attendance-tabs{flex-wrap:wrap;gap:.35rem;margin-bottom:1.25rem;display:flex}.attendance-tab{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);font:inherit;color:var(--text-muted);cursor:pointer;padding:.45rem .9rem;font-size:.875rem;font-weight:500;transition:background .12s,border-color .12s,color .12s}.attendance-tab:hover{border-color:var(--border-strong);color:var(--text)}.attendance-tab.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.attendance-panel-title{margin:0 0 .5rem;font-size:1.15rem;font-weight:600}.attendance-panel-lead{color:var(--text-muted);max-width:52rem;margin:0 0 1rem;font-size:.9rem;line-height:1.5}.attendance-toolbar .attendance-filters{flex-wrap:wrap;gap:.5rem}.attendance-record-form{flex-direction:column;gap:.75rem;max-width:28rem;display:flex}
