:root{--brand:#4f46e5;--brand-hover:#4338ca;--brand-light:#eef2ff;--surface:#fff;--surface-2:#f8f9fc;--sidebar-bg:#1e1e2d;--sidebar-txt:#a3a3c2;--sidebar-act:#4f46e5;--text:#111827;--text-muted:#6b7280;--border:#e5e7eb;--danger:#ef4444;--warn:#f59e0b;--success:#10b981;--radius:6px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #0000001a;color:var(--text);background:var(--surface-2);-webkit-font-smoothing:antialiased;font:14px/1.5 system-ui,Segoe UI,sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{overflow:hidden}a{color:var(--brand);text-decoration:none}img{display:block}input,select,textarea,button{font:inherit}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow-y:auto}.sidebar-logo{color:#fff;letter-spacing:-.3px;padding:20px 16px 12px;font-size:17px;font-weight:700}.sidebar-logo span{color:var(--brand-light);opacity:.7;margin-top:1px;font-size:11px;font-weight:400;display:block}.nav-section{padding:8px 0 0}.nav-section-label{letter-spacing:.8px;text-transform:uppercase;color:#557;padding:8px 16px 4px;font-size:10px;font-weight:600}.nav-link{color:var(--sidebar-txt);cursor:pointer;border-radius:0;align-items:center;gap:10px;padding:8px 16px;font-size:13.5px;transition:background .12s,color .12s;display:flex}.nav-link:hover{color:#fff;background:#ffffff0f}.nav-link.active{color:#fff;background:#4f46e540}.nav-icon{text-align:center;flex-shrink:0;width:16px;font-style:normal}.sidebar-bottom{margin-top:auto;padding:12px 16px}.logout-btn{width:100%;color:var(--sidebar-txt);border-radius:var(--radius);cursor:pointer;background:#ffffff12;border:1px solid #ffffff1a;padding:8px 12px;font-size:13px;transition:background .12s}.logout-btn:hover{color:#fca5a5;background:#ef444433;border-color:#ef44444d}.main-area{flex-direction:column;flex:1;display:flex;overflow-y:auto}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:flex-start;align-items:center;gap:12px;padding:12px 24px;display:flex}.topbar-title{color:var(--text);font-size:16px;font-weight:600}.topbar-right{align-items:center;gap:12px;margin-left:auto;display:flex}.hamburger{color:var(--text);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1;display:none}.sidebar-overlay{display:none}.user-badge{color:var(--text-muted);font-size:12px}.page-body{flex:1;padding:24px}@media (width<=768px){.hamburger{align-items:center;display:inline-flex}.sidebar{z-index:100;height:100%;transition:transform .2s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:2px 0 14px #00000059}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:90;background:#00000073;display:block;position:fixed;inset:0}.topbar{padding:12px 16px}.page-body{padding:16px}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.card-title{font-size:14px;font-weight:600}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 20px}.stat-label{color:var(--text-muted);margin-bottom:6px;font-size:12px;font-weight:500}.stat-value{color:var(--text);font-size:28px;font-weight:700}.stat-sub{color:var(--text-muted);margin-top:4px;font-size:11px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13.5px}th{text-align:left;background:var(--surface-2);color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 14px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:10px 14px}tr:last-child td{border-bottom:0}tr:hover td{background:var(--surface-2)}tr.row-selected td{background:color-mix(in srgb, var(--brand) 8%, transparent)}.btn{border-radius:var(--radius);cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .13s,opacity .13s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-primary:hover:not(:disabled){background:var(--brand-hover);border-color:var(--brand-hover)}.btn-ghost{color:var(--text-muted);border-color:var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-2)}.btn-danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn-danger:hover:not(:disabled){background:#fef2f2}.btn-sm{padding:4px 10px;font-size:12px}.badge{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.badge-green{color:#065f46;background:#d1fae5}.badge-red{color:#991b1b;background:#fee2e2}.badge-yellow{color:#92400e;background:#fef3c7}.badge-blue{color:#1e40af;background:#dbeafe}.badge-gray{color:#4b5563;background:#f3f4f6}.form-group{margin-bottom:14px}.form-label{color:var(--text-muted);margin-bottom:5px;font-size:12.5px;font-weight:500;display:block}.form-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--surface);outline:none;padding:8px 11px;font-size:13.5px;transition:border-color .15s}.form-input:focus{border-color:var(--brand)}.form-select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);padding:8px 11px;font-size:13.5px}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;display:flex}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);width:480px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-md);border-radius:8px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{font-size:15px;font-weight:600}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:2px 6px;font-size:18px;line-height:1}.modal-body{padding:20px}.login-page{background:var(--surface-2);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);width:380px;box-shadow:var(--shadow-md);border-radius:10px;padding:36px 32px}.login-logo{color:var(--brand);margin-bottom:4px;font-size:22px;font-weight:700}.login-sub{color:var(--text-muted);margin-bottom:28px;font-size:13px}.login-error{color:var(--danger);border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:10px 14px;font-size:13px}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-title{font-size:20px;font-weight:700}.empty-state{text-align:center;color:var(--text-muted);padding:48px;font-size:13px}.loading{text-align:center;color:var(--text-muted);padding:48px}.error-msg{color:var(--danger);border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:12px 16px;font-size:13px}.row-actions{gap:6px;display:flex}.text-muted{color:var(--text-muted)}.mt-16{margin-top:16px}.flex-gap{align-items:center;gap:12px;display:flex}.idcard-pages{font-family:Nunito,Segoe UI,Arial,sans-serif}.print-page{background:#fff;flex-wrap:wrap;align-content:flex-start;gap:4mm;width:297mm;min-height:210mm;margin:0 auto 20px;padding:4mm 6mm;display:flex;box-shadow:0 4px 24px #00000024}.print-page.fold-layout{flex-flow:wrap;align-content:flex-start;gap:4mm;width:297mm;min-height:210mm;padding:3mm 4mm}.print-page.front-only-layout{gap:4mm;width:297mm;min-height:210mm;padding:4mm 6mm}.page-label{color:#bbb;text-align:center;width:100%;margin-bottom:1mm;font-size:9px}.card-pair{outline-offset:2mm;outline:.3mm dashed #ccc;align-items:stretch;display:flex;position:relative}.fold-line{background:#fff;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:4mm;display:flex;position:relative}.fold-line:before{content:"";border-left:.4mm dashed #aaa;width:0;position:absolute;top:0;bottom:0;left:50%}.fold-line-label{color:#bbb;writing-mode:vertical-rl;letter-spacing:.5mm;z-index:1;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#fff;padding:1mm 0;font-size:1.4mm}.fold-line-icon{z-index:1;-webkit-user-select:none;user-select:none;background:#fff;font-size:3.5mm;line-height:1;position:absolute;top:-.5mm}.id-card{background:#fff;border-radius:4mm;flex-shrink:0;width:63mm;height:99mm;font-family:Nunito,Arial,sans-serif;position:relative;overflow:hidden;box-shadow:0 3px 12px #00000040}.id-card:after{content:"";pointer-events:none;z-index:50;border:.35mm dashed #b4b4c88c;border-radius:3mm;position:absolute;inset:1.2mm}.card-front{flex-direction:column;display:flex}.top-arch{z-index:6;background:linear-gradient(#1a237e 0%,#283593 100%);border-radius:0 0 50% 50%/0 0 4mm 4mm;height:11mm;position:absolute;top:0;left:0;right:0}.corner-tl{z-index:8;background:radial-gradient(circle at 62% 62%,#ff6b35,#e84b1a);border-radius:50%;width:22mm;height:22mm;position:absolute;top:-9mm;left:-9mm}.corner-tr{z-index:8;background:radial-gradient(circle at 38% 62%,#ffe840,#ffd600);border-radius:50%;width:22mm;height:22mm;position:absolute;top:-9mm;right:-9mm}.cf-header{z-index:2;text-align:center;background:#fff;flex-direction:column;align-items:center;gap:.25mm;padding:6mm 2mm .3mm;display:flex;position:relative}.cf-mascot{object-fit:contain;border-radius:50%;width:16mm;height:16mm}.cf-logo-text{width:42mm;height:auto}.cf-logo-name{color:#1a237e;letter-spacing:.2mm;font-size:4.2mm;font-weight:900}.cf-branch{color:#333;letter-spacing:.1mm;font-size:2.8mm;font-weight:800}.cf-tagline{color:#666;letter-spacing:.05mm;font-size:2.4mm;font-weight:700}.cf-ribbon-wrap{z-index:3;position:relative}.cf-ribbon-wrap:before{content:"";z-index:2;border-top:0 solid #0000;border-bottom:1.5mm solid #0000;border-left:2mm solid #3a0060;border-right:0 solid #0000;width:0;height:0;position:absolute;top:100%;left:0}.cf-ribbon-wrap:after{content:"";z-index:2;border-top:0 solid #0000;border-bottom:1.5mm solid #0000;border-left:0 solid #0000;border-right:2mm solid #3a0060;width:0;height:0;position:absolute;top:100%;right:0}.cf-ribbon{z-index:3;clip-path:polygon(0% 0%,100% 0%,96% 50%,100% 100%,0% 100%,4% 50%);color:#fff;text-align:center;letter-spacing:.4mm;text-transform:uppercase;white-space:nowrap;text-shadow:0 .3mm 1mm #0006;background:linear-gradient(#ab47bc 0%,#7b1fa2 35%,#4a0072 100%);padding:1.8mm 7mm;font-size:1.9mm;font-weight:900;position:relative}.cf-photo-area{z-index:2;background:#fff;justify-content:center;align-items:center;padding:.8mm 0 .5mm;display:flex;position:relative}.cf-photo-ring{background:linear-gradient(135deg,#1a237e 0%,#3f51b5 50%,#ffd600 100%);border-radius:50%;width:20mm;height:20mm;padding:.8mm;box-shadow:0 2px 8px #1a237e59}.cf-photo-circle{background:#e0e0e0;border:.5mm solid #fff;border-radius:50%;width:100%;height:100%;overflow:hidden}.cf-photo-circle img{object-fit:cover;width:100%;height:100%;display:block}.cf-photo-placeholder{color:#bdbdbd;background:#f0f0f0;justify-content:center;align-items:center;width:100%;height:100%;font-size:9mm;display:flex}.deco-left{flex-direction:column;align-items:center;gap:1mm;display:flex;position:absolute;top:50%;left:2.5mm;transform:translateY(-50%)}.deco-right{text-align:center;position:absolute;top:50%;right:2mm;transform:translateY(-50%)}.abc-block{color:#fff;border-radius:1.5mm;justify-content:center;align-items:center;width:5mm;height:5mm;font-size:3.2mm;font-weight:900;display:flex;box-shadow:0 1px 3px #0000004d}.star-deco{font-size:4.5mm;line-height:1.2}.cf-info{z-index:2;background:linear-gradient(#1a237e 0%,#0d1757 100%);border-radius:5mm 5mm 0 0;flex-direction:column;flex:1;margin-top:-2mm;padding:1.4mm 2.5mm .4mm;display:flex;position:relative;overflow:hidden}.cf-info:before{content:"";z-index:-1;background:linear-gradient(#1a237e 0% 100%);border-radius:50%;height:6mm;position:absolute;top:-3.5mm;left:-3mm;right:-3mm}.cf-name{text-align:center;color:#fff;letter-spacing:.2mm;text-shadow:0 1px 3px #0006;margin-bottom:.3mm;font-size:3mm;font-weight:900;line-height:1.15}.cf-class-row{justify-content:center;align-items:center;gap:2mm;margin-bottom:.7mm;display:flex}.cf-class-dash{background:#ffd600;border-radius:1mm;width:7mm;height:.5mm}.cf-class-text{color:#ffd600;letter-spacing:.6mm;font-size:2.5mm;font-weight:800}.cf-details{grid-template-columns:auto 1.5mm 1fr;row-gap:.35mm;width:100%;display:grid}.cf-two-col{grid-column:1/-1;align-items:center;gap:0;display:flex}.cf-two-col .cf-half{flex:1;align-items:center;min-width:0;display:flex}.cf-two-col .cf-half+.cf-half{border-left:.3mm solid #90caf94d;padding-left:2mm}.cf-two-col .cf-lbl{flex-shrink:0;padding-right:.5mm}.cf-two-col .cf-colon{flex-shrink:0}.cf-two-col .cf-val{text-overflow:ellipsis;white-space:nowrap;padding-left:.5mm;overflow:hidden}.cf-lbl{color:#90caf9;white-space:nowrap;padding-right:1mm;font-size:2.1mm;font-weight:700;line-height:1.45}.cf-colon{color:#90caf9;font-size:2.1mm;line-height:1.45}.cf-val{color:#fff;padding-left:1mm;font-size:2.1mm;font-weight:700;line-height:1.45}.cf-addr-lbl{color:#90caf9;white-space:nowrap;padding-top:.2mm;padding-right:1mm;font-size:2.1mm;font-weight:700;line-height:1.45}.cf-addr-val{color:#fff;padding-left:1mm;font-size:2mm;font-weight:600;line-height:1.55}.cf-footer{z-index:2;text-align:center;color:#333;letter-spacing:.3mm;background:linear-gradient(90deg,#ffd600 0%,#ffea00 50%,#ffd600 100%);padding:.6mm 1mm;font-size:2mm;font-weight:900;position:relative}.cf-footer .heart{color:#e84b1a}.card-front.front-only .cf-footer{letter-spacing:0;padding:1mm 2mm;font-size:1.7mm;font-weight:700;line-height:1.45}.cf-footer-addr-icon{font-size:1.8mm}.card-back{flex-direction:column;display:flex}.cb-top-stripe{background:linear-gradient(90deg,#e84b1a,#ffd600,#43a832,#2563eb,#8b35c8);height:2.5mm}.cb-header{text-align:center;border-bottom:.3mm solid #ede7f6;padding:1.5mm 3mm 1mm}.cb-logo-row{justify-content:center;align-items:center;gap:1.5mm;display:flex}.cb-mascot{object-fit:contain;flex-shrink:0;width:11mm;height:11mm}.cb-logo-text{max-width:38mm;height:auto}.cb-logo-name{color:#1a237e;font-size:3mm;font-weight:900}.cb-branch{color:#333;margin-bottom:.1mm;font-size:1.8mm;font-weight:800}.cb-tagline{color:#555;font-size:1.5mm;font-weight:600}.cb-dots{justify-content:center;gap:1.8mm;padding:.8mm 0 .6mm;display:flex}.cb-dots span{border-radius:50%;width:3mm;height:3mm}.cb-dots .d1{background:#e84b1a}.cb-dots .d2{background:#ff8c00}.cb-dots .d3{background:#43a832}.cb-dots .d4{background:#2563eb}.cb-body{flex-direction:column;flex:1;gap:.7mm;padding:.5mm 3mm;display:flex;overflow:hidden}.cb-addr-block{border:.3mm solid #e0e0e0;border-radius:2mm;overflow:hidden}.cb-block-head{color:#fff;text-align:center;letter-spacing:.5mm;background:linear-gradient(90deg,#6a1b9a,#9c27b0);padding:.9mm;font-size:1.9mm;font-weight:800}.cb-block-body{align-items:flex-start;gap:1.2mm;padding:1.2mm 1.8mm;display:flex}.cb-block-icon{flex-shrink:0;margin-top:.3mm;font-size:3.5mm}.cb-block-text{color:#333;font-size:1.7mm;font-weight:600;line-height:1.55}.cb-row{border-bottom:.2mm solid #f5f5f5;align-items:flex-start;gap:1.5mm;padding:.7mm 0;display:flex}.cb-row:last-of-type{border-bottom:none}.cb-row-icon{flex-shrink:0;font-size:3.5mm}.cb-row-title{margin-bottom:.3mm;font-size:1.7mm;font-weight:800}.cb-row-title.green{color:#2e7d32}.cb-row-title.orange{color:#e65100}.cb-row-title.blue{color:#1565c0}.cb-row-value{color:#444;font-size:1.7mm;font-weight:600}.cb-sig-line{border-bottom:.3mm solid #aaa;width:34mm;height:5mm;margin-top:.5mm}.cb-rules-box{background:#fafafa;border:.3mm solid #e8e8e8;border-radius:1.5mm;padding:1mm 1.5mm}.cb-rules{flex-direction:column;gap:.6mm;display:flex}.cb-rule{color:#333;align-items:flex-start;gap:1mm;font-size:1.55mm;font-weight:600;line-height:1.45;display:flex}.cb-rule-bullet{flex-shrink:0;font-size:1.6mm}.cb-qr-row{align-items:center;gap:2.5mm;margin-top:.5mm;display:flex}.cb-qr-wrap{flex-shrink:0}.cb-qr{border:.3mm solid #ccc;width:14mm;height:14mm;overflow:hidden}.cb-qr img,.cb-qr canvas{display:block;width:100%!important;height:100%!important}.cb-thankyou{text-align:center;color:#2e7d32;font-size:1.55mm;font-style:italic;font-weight:700;line-height:1.6}.cb-footer{color:#fff;text-align:center;letter-spacing:.2mm;background:linear-gradient(90deg,#5c0f8b,#9c27b0);padding:1.5mm;font-size:1.8mm;font-weight:700}.idcard-pages *,.idcard-pages :before,.idcard-pages :after{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}@media print{body{background:#fff}.sidebar,.topbar,.id-gen-toolbar,.no-print{display:none!important}.app-shell{height:auto!important;display:block!important;overflow:visible!important}.main-area{width:100%!important;overflow:visible!important}.page-body{padding:0!important;overflow:visible!important}.print-page{box-shadow:none;page-break-after:always;break-after:page;gap:4mm;width:100%;margin:0;padding:4mm 6mm}.print-page:last-child{page-break-after:avoid;break-after:avoid}.print-page.fold-layout{gap:4mm;padding:3mm 4mm}.print-page.front-only-layout{gap:4mm;padding:4mm 6mm}.fold-line-label,.fold-line-icon{display:none}.card-pair{outline:none}.page-label{display:none}@page{size:A4 landscape;margin:4mm}}
