:root{--bg:#0b0b0c;--surface:#111113;--surface-2:#151518;--border:#26262a;--text:#f5f5f5;--muted:#a1a1aa;--muted-2:#71717a;--primary-bg:#fff;--primary-text:#0b0b0c;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--radius:16px;--shadow:0 18px 40px #00000059;--ring:0 0 0 3px #ffffff1f;--header-height:72px;--footer-height:60px;font-family:Inter,SF Pro Text,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body{min-height:100%;margin:0;padding:0}body{background:var(--bg);color:var(--text);line-height:1.5}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,input,select,textarea{font:inherit}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-header{min-height:var(--header-height);border-bottom:1px solid var(--border);z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b0b0ce6;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;display:flex}.brand-link{letter-spacing:-.02em;font-size:18px;font-weight:700}.nav{align-items:center;gap:16px;font-size:14px;display:flex}.nav a{color:var(--muted);transition:color .2s}.nav a:hover{color:var(--text)}.user{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.nav-toggle{border:1px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--text);border-radius:12px;justify-content:center;align-items:center;display:none}.nav-toggle span{background:var(--text);width:18px;height:2px;display:block;position:relative}.nav-toggle span:before,.nav-toggle span:after{content:"";background:var(--text);width:18px;height:2px;position:absolute;left:0}.nav-toggle span:before{top:-6px}.nav-toggle span:after{top:6px}.mobile-nav{pointer-events:none;z-index:60;position:fixed;inset:0}.mobile-nav.open{pointer-events:auto}.mobile-nav-backdrop{opacity:0;background:#0009;transition:opacity .2s;position:absolute;inset:0}.mobile-nav.open .mobile-nav-backdrop{opacity:1}.mobile-nav-panel{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;gap:20px;width:min(320px,85vw);height:100%;padding:24px;transition:transform .25s;display:flex;position:absolute;top:0;right:0;transform:translate(100%)}.mobile-nav.open .mobile-nav-panel{transform:translate(0)}.mobile-nav-panel a{color:var(--text)}.app-main{flex:1}.app-footer{min-height:var(--footer-height);border-top:1px solid var(--border);text-align:center;color:var(--muted);padding:18px 20px;font-size:12px}.page{width:100%;max-width:1200px;margin:0 auto;padding:32px 20px 64px}.admin-shell{grid-template-columns:240px 1fr;align-items:start;gap:24px;display:grid}.admin-nav{top:calc(var(--header-height) + 24px);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);align-self:start;gap:12px;padding:16px;display:grid;position:sticky}.admin-nav-title{text-transform:uppercase;letter-spacing:.2em;color:var(--muted-2);font-size:11px;font-weight:600}.admin-nav-links{gap:8px;display:grid}.admin-nav a{color:var(--muted);border:1px solid #0000;border-radius:10px;padding:8px 10px;transition:color .2s,border-color .2s,background .2s}.admin-nav a:hover{color:var(--text)}.admin-nav a.active{color:var(--text);background:var(--surface-2);border-color:var(--border)}.admin-content{gap:16px;display:grid}.admin-nav-mobile{margin-bottom:8px}.page-header,.hero{justify-content:space-between;align-items:flex-start;gap:20px;padding-bottom:12px;display:flex}.page-title,.hero h1{letter-spacing:-.03em;margin:0 0 8px;font-size:32px}h1,h2,h3{margin:0 0 8px;font-weight:600}h2{font-size:18px}p{margin:0}.eyebrow{text-transform:uppercase;letter-spacing:.2em;color:var(--muted-2);margin-bottom:6px;font-size:11px;font-weight:600}.muted{color:var(--muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.card-body,.stack{gap:16px;display:grid}.form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.form-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.label{color:var(--muted);gap:8px;font-size:13px;display:grid}.toggle{border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.input,.select,textarea,input[type=file]{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:10px 12px}.input-wrap{align-items:center;display:flex;position:relative}.input-with-addon{width:100%;padding-right:44px}.input-addon{justify-content:center;align-items:center;display:inline-flex;position:absolute;right:8px}.icon-button{border:1px solid var(--border);width:32px;height:32px;color:var(--text);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.icon-button:hover{border-color:#fff6}.input:focus,.select:focus,textarea:focus,input[type=file]:focus{box-shadow:var(--ring);border-color:#fff3;outline:none}.file-input{background:var(--surface-2);border-style:dashed;width:100%;padding:12px}.btn{cursor:pointer;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:8px;font-weight:600;transition:transform .1s,box-shadow .1s,background .2s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn-primary{background:var(--primary-bg);color:var(--primary-text);border-color:var(--primary-bg);box-shadow:0 10px 20px #ffffff14}.btn-secondary{background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-ghost{color:var(--text);background:0 0;border-color:#0000}.btn-ghost:hover{border-color:var(--border)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-sm{padding:8px 12px;font-size:13px}.btn-md{padding:10px 16px;font-size:14px}.btn-block{width:100%}.ghost{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:inline-flex}.ghost:hover{border-color:#fff6}.badge{border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-neutral{color:var(--muted)}.badge-success{color:var(--success);border-color:#22c55e66}.badge-warning{color:var(--warning);border-color:#f59e0b66}.badge-danger{color:var(--danger);border-color:#ef444466}.badge-info{color:var(--text);border-color:#fff3}.ghost-badge{color:var(--muted);border-style:dashed}.badge.demo{color:var(--warning);border-color:#f59e0b66}.badge.present{color:var(--success);border-color:#22c55e66}.badge.absent{color:var(--danger);border-color:#ef444466}.alert{border:1px solid var(--border);background:#ffffff08;border-radius:12px;padding:10px 12px;font-size:13px}.alert-success{color:var(--success);border-color:#22c55e66}.alert-danger{color:var(--danger);border-color:#ef444466}.alert-warning{color:var(--warning);border-color:#f59e0b66}.alert-info{color:var(--muted);border-color:#fff3}.code-block{border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:12px;margin:0;padding:12px 14px;overflow-x:auto}.actions{flex-wrap:wrap;align-items:center;gap:12px;margin-top:12px;display:flex}.modal-backdrop{z-index:80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:min(560px,100%);max-height:calc(100vh - 40px);box-shadow:var(--shadow);padding:18px;overflow:auto}.modal-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.teacher-roster-scroll{max-height:60vh;overflow:auto}.teacher-roster-table thead th{z-index:1;background:var(--surface);position:sticky;top:0}.status{color:var(--muted);font-size:13px}.table,.faces{border-collapse:collapse;width:100%;font-size:13px}.table th,.table td,.faces th,.faces td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:10px 8px}.table thead th,.faces thead th{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600}.table-wrap{overflow-x:auto}.layout{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.link-card{transition:transform .12s,box-shadow .12s;display:block}.link-card:hover{transform:translateY(-2px);box-shadow:0 18px 36px #0006}.card-list{gap:12px;display:grid}.list{gap:8px;display:grid}.list-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.empty-state{color:var(--muted);gap:6px;padding:12px 0;display:grid}.slot-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;display:grid}.slot-card{background:var(--surface-2);border-color:var(--border);text-align:left;align-items:flex-start;width:100%}.slot-card.active{border-color:#ffffff80;box-shadow:0 0 0 1px #fff3}.filters{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:14px}.filters-body{margin-top:12px;display:none}.filters.open .filters-body{display:block}.auth-page{place-items:center;display:grid}.auth-shell{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start;gap:24px;width:min(980px,100%);display:grid}.auth-card{gap:16px;display:grid}.unknown-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.unknown-groups{gap:16px;display:grid}.unknown-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.unknown-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:8px;padding:10px;display:flex}.photo-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:8px;display:grid}.photo-card{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:12px}.photo-frame{position:relative}.photo-frame img{border-radius:10px;width:100%}.canvas-wrap{background:var(--surface-2);border:1px dashed var(--border);border-radius:12px;justify-content:center;align-items:center;min-height:280px;display:flex;overflow:hidden}canvas{border-radius:12px;max-width:100%;height:auto}.face-box{border:2px solid var(--success);pointer-events:none;border-radius:6px;position:absolute}.face-label{background:var(--success);color:var(--primary-text);pointer-events:none;border-radius:6px;padding:2px 6px;font-size:11px;font-weight:700;position:absolute;top:-1px;left:-1px}.photo-meta{justify-content:space-between;align-items:center;margin-top:8px;font-size:12px;display:flex}.stats-panel{gap:10px;font-size:13px;display:grid}.stats-row{flex-wrap:wrap;justify-content:space-between;gap:8px;display:flex}.tips-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:0;overflow:hidden}.tips-card summary{cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;list-style:none;display:flex}.tips-card summary::-webkit-details-marker{display:none}.tips-body{gap:8px;padding:0 16px 16px;display:grid}.hero-landing{align-items:center;gap:28px;padding:12px 0 24px;display:grid}.hero-copy{gap:12px;display:grid}.hero-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.hero-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);gap:12px;padding:20px;display:grid}.section{gap:16px;margin-top:28px;display:grid}#how-it-works{scroll-margin-top:96px}.section-title{justify-content:space-between;align-items:center;display:flex}.steps-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:10px;padding:16px;display:grid}.icon-badge{border:1px solid var(--border);background:var(--surface-2);border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex}.auth-layout{align-items:center;gap:24px;width:min(1100px,100%);display:grid}.auth-copy{gap:12px;display:grid}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:16px;padding:20px;display:grid}.auth-page{min-height:calc(100vh - var(--header-height,72px) - var(--footer-height,60px));justify-content:center;align-items:center;display:flex}.auth-features{gap:12px;display:grid}.auth-feature{align-items:flex-start;gap:12px;display:flex}.auth-feature svg{flex-shrink:0}.only-mobile{display:none}.only-desktop{display:block}@media (max-width:960px){.nav,.user{display:none}.nav-toggle{display:inline-flex}}@media (max-width:720px){.page{padding:24px 16px 48px}.page-header,.hero{flex-direction:column}.form-grid{grid-template-columns:1fr}.actions{flex-direction:column;align-items:stretch}.btn{width:100%}.only-desktop{display:none}.only-mobile{display:block}}@media (max-width:900px){.admin-shell{grid-template-columns:1fr}.admin-nav{display:none;position:static}.admin-nav-mobile{display:block}}@media (min-width:721px){.filters-body{display:block}}@media (min-width:900px){.hero-landing{grid-template-columns:1.2fr .8fr}.auth-layout{grid-template-columns:1.1fr .9fr}}@media (max-width:899px){.auth-layout{grid-template-areas:"card""copy"}.auth-card{order:-1}}
