[data-theme=light],:root{--bg:#f0f4f8;--bg2:#fff;--bg3:#e3f2fd;--fg:#334155;--fg2:#475569;--fg3:#94a3b8;--accent:#1565c0;--accent-h:#125aa0;--accent-bg:#1565c014;--info:#2196f3;--info-bg:#2196f314;--warn:#d97706;--warn-bg:#d9770614;--danger:#dc2626;--danger-bg:#dc262614;--success:#1565c0;--success-bg:#1565c014;--border:#e2e8f0;--border-h:#cbd5e1;--shadow:0 1px 3px #00000014,0 1px 2px #0000000f;--shadow-lg:0 10px 25px #0000001a;--input:#fff;--sidebar:#fff;--overlay:#0006;--card-hover:#00000005;--grad1:#1565c00d;--grad2:#2196f30a;--sidebar-w:clamp(180px, 15vw, 260px)}[data-theme=dark]{--bg:#0b1120;--bg2:#131c31;--bg3:#1a2540;--fg:#e2e8f0;--fg2:#94a3b8;--fg3:#64748b;--accent:#1565c0;--accent-h:#125aa0;--accent-bg:#1565c01f;--info:#2196f3;--info-bg:#2196f31f;--success:#1565c0;--success-bg:#1565c01f;--warn:#fbbf24;--warn-bg:#fbbf241a;--danger:#f87171;--danger-bg:#f871711a;--border:#1e293b;--border-h:#334155;--shadow:0 1px 3px #0000004d;--shadow-lg:0 10px 25px #0006;--input:#0f172a;--sidebar:#0d1526;--overlay:#0009;--card-hover:#ffffff08;--grad1:#1565c014;--grad2:#2196f30f}*{box-sizing:border-box;margin:0;padding:0}html{font-size:clamp(14px,.9vw,16px)}body{background:var(--bg);color:var(--fg);min-height:100vh;font-family:Kantumruy,DM Sans,sans-serif;transition:background .3s,color .3s}h1,h2,h3,h4,h5{font-family:Kantumruy,sans-serif;font-weight:700}[data-theme=dark] .main-wrap:before{content:"";background:radial-gradient(ellipse at 20% 50%,var(--grad1) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,var(--grad2) 0%,transparent 60%);pointer-events:none;z-index:0;animation:20s ease-in-out infinite alternate bgPulse;position:fixed;inset:0}@keyframes bgPulse{0%{opacity:.8}to{opacity:1.2}}.hidden{display:none!important}.sidebar{width:var(--sidebar-w);background:var(--sidebar);border-right:1px solid var(--border);z-index:40;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar .nav-item{color:var(--fg2);cursor:pointer;border-radius:8px;align-items:center;gap:12px;margin:2px 12px;padding:12px 20px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.sidebar .nav-item:hover{background:var(--accent-bg);color:var(--accent)}.sidebar .nav-item.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.sidebar .nav-item i{text-align:center;width:20px;font-size:16px}.main-content{margin-left:var(--sidebar-w);z-index:1;min-height:100vh;padding:24px;position:relative}.container{width:100%;max-width:1200px;margin:0 auto}.bottom-nav{background:var(--sidebar);border-top:1px solid var(--border);z-index:40;padding:6px 0 env(safe-area-inset-bottom,6px);display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav .bnav-item{color:var(--fg3);cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 0;font-size:10px;font-weight:500;transition:all .2s;display:flex}.bottom-nav .bnav-item.active{color:var(--accent)}.bottom-nav .bnav-item i{font-size:18px}.card{background:var(--bg2);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;padding:20px;transition:all .2s}.card:hover{box-shadow:var(--shadow-lg)}.stat-card{position:relative;overflow:hidden}.stat-card:after{content:"";opacity:.06;border-radius:50%;width:80px;height:80px;position:absolute;top:-20px;right:-20px}.stat-card.green:after{background:var(--accent)}.stat-card.blue:after{background:var(--info)}.stat-card.amber:after{background:var(--warn)}.stat-card.red:after{background:var(--danger)}.input-field{background:var(--input);border:1px solid var(--border);width:100%;color:var(--fg);border-radius:8px;outline:none;padding:10px 14px;font-family:Kantumruy,DM Sans,sans-serif;font-size:14px;transition:all .2s}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.input-field::placeholder{color:var(--fg3)}select.input-field{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394A3B8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat}.lookup-suggestions{background:var(--bg2);border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:80;border-radius:8px;max-height:280px;padding:6px;position:absolute;top:64px;left:0;right:0;overflow-y:auto}.lookup-suggestion{width:100%;color:var(--fg);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 12px;font-family:Kantumruy,DM Sans,sans-serif;display:flex}.lookup-suggestion:hover{background:var(--card-hover)}.lookup-suggestion span{font-size:14px;font-weight:700}.lookup-suggestion small{color:var(--fg3);font-size:12px}label.field-label{color:var(--fg2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.btn{cursor:pointer;border:none;border-radius:8px;outline:none;align-items:center;gap:8px;padding:10px 20px;font-family:Kantumruy,DM Sans,sans-serif;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-h)}.btn-secondary{background:var(--bg3);color:var(--fg2);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-h);background:var(--card-hover)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{border-radius:6px;padding:6px 12px;font-size:12px}.btn-icon{border-radius:8px;justify-content:center;width:36px;height:36px;padding:8px}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warn{background:var(--warn-bg);color:var(--warn)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.ministry-bar{background:var(--bg3);border-radius:4px;flex:1;height:8px;overflow:hidden}.ministry-bar-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .6s}.student-card{cursor:pointer;align-items:center;gap:14px;padding:14px;transition:all .2s;display:flex}.student-card:hover{background:var(--card-hover);border-radius:10px}.student-photo{object-fit:cover;background:var(--bg3);width:44px;height:44px;color:var(--fg3);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex;overflow:hidden}.student-photo img{object-fit:cover;width:100%;height:100%}.student-name-main{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.student-name-church{color:var(--fg3);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.student-gender-inline{color:var(--fg3);margin-top:6px;font-size:12px;display:none}.bulk-actions{background:var(--bg2);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:8px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;display:flex}.bulk-actions strong{color:var(--fg2);margin-right:4px;font-size:13px}.students-table{flex-direction:column;display:flex}.student-header{border-bottom:1px solid var(--border);color:var(--fg2);grid-template-columns:34px minmax(80px,150px) 1fr minmax(80px,120px) minmax(60px,90px) minmax(60px,90px) minmax(90px,160px) 48px;align-items:center;gap:12px;padding:8px 12px;font-size:12px;font-weight:700;display:grid}.student-row{cursor:pointer;border-bottom:1px solid #0000000a;grid-template-columns:34px minmax(80px,150px) 1fr minmax(80px,120px) minmax(60px,90px) minmax(60px,90px) minmax(90px,160px) 48px;align-items:center;gap:12px;padding:10px 12px;display:grid}.student-row:last-child{border-bottom:none}.student-row:hover{background:var(--card-hover);border-radius:8px}.student-row.selected{background:var(--accent-bg);border-radius:8px}.student-select{justify-content:center;align-items:center;display:flex}.student-select input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.student-row .student-id{color:var(--accent);font-size:13px;font-weight:700}.student-row .student-name{align-items:center;min-width:0;display:flex}.student-row .student-gender,.student-row .student-age,.student-row .student-grade{color:var(--fg3);font-size:13px}.student-header .student-age,.student-row .student-age{text-align:center;justify-self:center}.student-row .student-status{justify-self:start}.student-row .student-actions{justify-self:center}.student-row .student-actions .btn-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.student-row .student-actions{position:relative}.action-menu{background:var(--bg2);border:1px solid var(--border);box-shadow:var(--shadow);z-index:60;border-radius:8px;flex-direction:column;min-width:140px;padding:6px;display:flex;position:absolute;top:44px;right:6px}.action-menu .action-item{text-align:left;cursor:pointer;color:var(--fg);background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-weight:600;display:flex}.action-menu .action-item:hover{background:var(--card-hover)}.action-menu .action-item.delete{color:var(--danger)}@media (width<=900px){.student-row,.student-header{grid-template-columns:34px 120px 1fr 90px 70px 70px 120px 40px;gap:8px}.student-row .student-gender,.student-header .student-gender{text-align:center;justify-self:center;display:block}.student-gender-inline{display:none}.student-name-main,.student-name-church{white-space:normal}}@media (width<=600px){.student-row{flex-direction:row;align-items:center;gap:12px;padding:10px;display:flex}.student-header,.student-row .student-gender{display:none}.student-gender-inline{display:block}.student-row .student-age,.student-row .student-grade{display:none}}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{box-shadow:var(--shadow-lg);border-radius:10px;align-items:center;gap:10px;max-width:360px;padding:14px 20px;font-size:14px;font-weight:500;animation:.3s toastIn;display:flex}.toast-success{color:#a7f3d0;background:#065f46}.toast-error{color:#fca5a5;background:#7f1d1d}.toast-info{color:#93c5fd;background:#1e3a5f}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.3s fadeIn}.modal-overlay{background:var(--overlay);z-index:100;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg2);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:16px;width:100%;max-width:500px;max-height:90vh;animation:.25s fadeIn;overflow-y:auto}.check-item{border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:10px;padding:10px 14px;transition:all .2s;display:flex}.check-item:hover{border-color:var(--accent)}.check-item.checked{border-color:var(--accent);background:var(--accent-bg)}.check-item .check-box{border:2px solid var(--border);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .2s;display:flex}.check-item.checked .check-box{background:var(--accent);border-color:var(--accent);color:#fff}.photo-preview{border:2px dashed var(--border);cursor:pointer;width:100px;height:100px;color:var(--fg3);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:11px;transition:all .2s;display:flex;overflow:hidden}.photo-preview:hover{border-color:var(--accent);color:var(--accent)}.photo-preview img{object-fit:cover;width:100%;height:100%}#camera-video{background:#000;border-radius:12px;width:100%}.empty-state{text-align:center;color:var(--fg3);padding:60px 20px}.empty-state i{opacity:.4;margin-bottom:16px;font-size:48px}.switch{cursor:pointer;width:48px;height:26px;position:relative}.switch input{opacity:0;width:0;height:0}.switch .slider{background:var(--border);border-radius:26px;transition:all .3s;position:absolute;inset:0}.switch .slider:before{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:all .3s;position:absolute;top:3px;left:3px}.switch input:checked+.slider{background:var(--accent)}.switch input:checked+.slider:before{transform:translate(22px)}.tag{background:var(--accent-bg);color:var(--accent);border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;font-weight:600;display:flex}.tag button{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px}.tl-line{background:var(--border);width:2px;position:absolute;top:8px;bottom:8px;left:7px}.tl-dot{border:3px solid var(--accent);background:var(--bg2);border-radius:50%;width:14px;height:14px;position:absolute;top:6px;left:-21px}.tl-dot.partial{border-color:var(--warn)}.tl-dot.empty{border-color:var(--fg3)}.tl-entry{margin-bottom:20px;padding-left:28px;position:relative}.tl-entry:last-child{margin-bottom:0}.tl-card{background:var(--bg3);border-radius:10px;padding:14px 16px;transition:all .2s}.tl-card:hover{background:var(--card-hover)}@media (width<=768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0;padding:16px 16px 90px}.bottom-nav{display:flex!important}}@media (width>=769px){.bottom-nav{display:none!important}}@media print{.sidebar,.bottom-nav,.no-print{display:none!important}.main-content{margin:0!important;padding:20px!important}}.dist-chart{justify-content:center;align-items:flex-end;gap:28px;min-width:max-content;height:260px;padding:64px 6px 10px;display:flex}.dist-col{flex-direction:column;align-items:center;width:clamp(80px,12vw,120px);display:flex;position:relative}.dist-bar-wrapper{justify-content:center;align-items:flex-end;gap:10px;width:100%;height:160px;display:flex;position:relative}.dist-bar{z-index:1;border-radius:12px;transition:height .5s;box-shadow:0 6px 12px #0000000f}.dist-bar.target{background:var(--info-bg);width:48px}.dist-bar.actual{background:var(--info);width:48px}.dist-label{color:var(--fg2);margin-top:8px;font-weight:600}@media (width<=768px){.dist-chart{gap:16px;height:140px}.dist-col{width:80px}.dist-bar.target{width:46px}.dist-bar.actual{width:32px;margin-left:-18px}}.dist-chart-wrap{flex-direction:column;align-items:stretch;width:100%;display:flex}.dist-scroll{width:100%;overflow:auto hidden}.dist-values-row{justify-content:center;align-items:center;gap:28px;width:100%;min-width:max-content;margin-bottom:10px;padding:0 6px;display:flex}.dist-values-cell{pointer-events:none;z-index:999;flex-direction:column;align-items:center;gap:6px;width:clamp(80px,12vw,120px);display:flex}.dist-value{text-align:center;border-radius:8px;min-width:40px;padding:6px 8px;font-size:12px;font-weight:700}.dist-value-target{background:var(--info-bg);color:var(--info)}.dist-value-actual{background:var(--info);color:#fff}@media (width<=768px){.dist-values-row{gap:16px}.dist-values-cell{width:80px}.dist-value{min-width:36px;padding:4px 8px;font-size:11px}}
