:root{--bg:#0b1727;--card:#ffffff;--muted:#65758b;--primary:#2563eb;--primary2:#06b6d4;--green:#16a34a;--red:#ef4444;--orange:#f97316;--line:#e5e7eb;--sidebar:#0f3c35}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:#eef5ff;color:#15223b}a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;background:linear-gradient(120deg,#1265e6,#1bbccc 45%,#dff34a);position:relative;overflow:hidden}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:999px;filter:blur(10px);opacity:.35}.login-page:before{width:620px;height:620px;background:#fff;left:-200px;bottom:-240px}.login-page:after{width:760px;height:760px;background:#22c55e;right:-260px;top:-220px}.wave{position:absolute;inset:0;background:radial-gradient(circle at 10% 90%,rgba(255,255,255,.22),transparent 32%),radial-gradient(circle at 90% 20%,rgba(255,255,255,.2),transparent 26%);opacity:.9}.login-shell{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .92fr;width:min(1180px,100%);min-height:680px;border-radius:28px;overflow:hidden;box-shadow:0 30px 90px rgba(15,23,42,.25);border:1px solid rgba(255,255,255,.5);background:rgba(255,255,255,.22);backdrop-filter:blur(16px)}.announce-panel{padding:56px;background:linear-gradient(160deg,rgba(18,101,230,.72),rgba(16,185,129,.45));color:white}.login-panel{padding:48px 52px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center}.login-box{width:100%;max-width:440px;text-align:center}.school-logo{width:150px;height:150px;object-fit:contain;margin:0 auto 20px;display:block}.login-title{font-size:29px;font-weight:900;margin:0;color:#12213d}.login-sub{color:#6b7280;font-size:18px;margin:10px 0 28px}.field{display:flex;align-items:center;gap:12px;background:white;border:1px solid #d5dbe8;border-radius:14px;padding:14px 16px;margin-bottom:14px;box-shadow:0 5px 14px rgba(15,23,42,.05)}.field input{border:0;outline:0;width:100%;background:transparent;color:#172033}.btn{border:0;border-radius:14px;padding:13px 18px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(90deg,#1d4ed8,#0ea5e9);color:#fff;box-shadow:0 10px 22px rgba(37,99,235,.28)}.btn-danger{background:#ef4444;color:white}.btn-green{background:#16a34a;color:white}.btn-light{background:#f1f5f9;color:#0f172a;border:1px solid #dbe3ef}.btn-orange{background:#f97316;color:white}.w-full{width:100%}.demo{margin-top:22px;border-top:1px solid #dce3ee;padding-top:18px;color:#4b5563;font-size:14px}.announce-head{display:flex;align-items:center;gap:18px;margin-bottom:28px}.announce-icon{width:74px;height:74px;border-radius:24px;background:rgba(255,255,255,.22);display:grid;place-items:center;font-size:34px}.announce-head h1{margin:0;font-size:34px}.announce-head p{margin:8px 0 0;opacity:.9}.announcement-card{background:rgba(255,255,255,.94);color:#172033;border-radius:18px;margin:16px 0;padding:20px;display:grid;grid-template-columns:70px 1fr auto;gap:18px;align-items:start;box-shadow:0 15px 35px rgba(15,23,42,.13)}.announcement-card .ico{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;color:white;font-size:26px}.announcement-card h3{margin:0 0 8px;font-size:18px}.announcement-card p{margin:0;color:#4b5563;line-height:1.45}.date{font-size:13px;font-weight:800;color:#2563eb;white-space:nowrap}.blue{background:#2563eb}.green{background:#22c55e}.orange{background:#f97316}.auth-error{background:#fee2e2;color:#991b1b;padding:12px;border-radius:12px;margin-bottom:14px;text-align:left}.app{display:grid;grid-template-columns:310px 1fr;min-height:100vh;background:linear-gradient(120deg,#082f49,#064e3b)}.sidebar{background:linear-gradient(160deg,rgba(10,75,68,.96),rgba(15,55,72,.96));color:#fff;padding:20px;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid rgba(255,255,255,.15)}.brand{display:flex;align-items:center;gap:14px;padding:10px 8px 20px}.brand img{width:54px;height:54px;object-fit:contain;background:rgba(255,255,255,.14);border-radius:16px;padding:4px}.brand b{font-size:17px}.brand span{color:#b7d8d1;font-size:13px}.role-pill{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px;margin-bottom:12px;font-weight:800}.menu-section{margin:10px 0}.menu-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:white;padding:12px 14px;border-radius:14px;cursor:pointer;font-weight:800}.menu-toggle span:last-child{transition:.2s}.menu-toggle.is-open span:last-child{transform:rotate(180deg)}.submenu{display:none;padding:8px 0 4px 12px}.submenu.open{display:block}.submenu a{display:block;padding:10px 12px;margin:4px 0;border-radius:12px;color:#e5fff8;font-size:14px}.submenu a:hover,.submenu a.active{background:rgba(255,255,255,.15)}.logout-btn{width:100%;margin-top:14px;background:linear-gradient(90deg,#ef4444,#f97316);color:white}.content{background:#f4f7fb;min-width:0}.topbar{height:70px;background:rgba(255,255,255,.94);display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}.main{padding:28px}.card{background:#fff;border:1px solid #e7edf6;border-radius:20px;padding:22px;box-shadow:0 10px 30px rgba(15,23,42,.06);margin-bottom:22px}.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.stat{padding:22px;border-radius:18px;background:linear-gradient(135deg,#fff,#eff6ff);border:1px solid #dbeafe}.stat b{font-size:31px;display:block;color:#0f172a}.stat span{color:#64748b;font-weight:700}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:top}.table th{font-size:13px;color:#64748b;background:#f8fafc}.badge{display:inline-block;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;background:#e0f2fe;color:#0369a1}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.badge.orange{background:#ffedd5;color:#9a3412}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-control{width:100%;border:1px solid #dbe3ef;border-radius:12px;padding:12px;background:white}.label{font-weight:800;font-size:13px;color:#475569;margin:10px 0 6px;display:block}.alert{padding:13px 16px;border-radius:14px;margin-bottom:16px;font-weight:700}.alert.success{background:#dcfce7;color:#166534}.alert.error{background:#fee2e2;color:#991b1b}.actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.pagination{margin-top:15px}.qr-card{border:1px dashed #94a3b8;border-radius:18px;padding:18px;text-align:center;background:#fff}.qr-box{width:130px;height:130px;margin:10px auto;border:10px solid #111827;display:grid;place-items:center;font-weight:900;font-size:13px;word-break:break-all}.print-only{display:none}@media(max-width:980px){.login-shell{grid-template-columns:1fr}.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.grid-4,.grid-3,.grid-2,.form-row{grid-template-columns:1fr}.announce-panel,.login-panel{padding:28px}.announcement-card{grid-template-columns:1fr}.topbar{height:auto;padding:18px;align-items:flex-start;gap:12px;flex-direction:column}}@media print{.sidebar,.topbar,.no-print{display:none!important}.app{display:block;background:white}.main{padding:0}.card{box-shadow:none;border:0}.print-only{display:block}.content{background:white}.qr-card{break-inside:avoid}}


.muted{color:#64748b;line-height:1.55}.scanner-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#ecfeff,#eff6ff)}.scanner-hero h2{margin:10px 0 8px}.scanner-ready{display:flex;align-items:center;gap:10px;background:#052e2b;color:#d1fae5;border-radius:999px;padding:12px 16px;font-weight:900;white-space:nowrap}.scanner-dot{width:12px;height:12px;background:#22c55e;border-radius:999px;box-shadow:0 0 0 8px rgba(34,197,94,.15);animation:pulseScanner 1.4s infinite}@keyframes pulseScanner{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.72);opacity:.55}}.scanner-card{border:2px solid #bfdbfe}.scanner-top{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.scanner-input{font-size:24px;font-weight:900;letter-spacing:.5px;padding:18px 20px;border:2px solid #2563eb;background:#f8fbff}.scanner-input:focus{outline:4px solid rgba(37,99,235,.16);border-color:#1d4ed8}.scanner-status-box{min-height:46px;display:flex;align-items:center;border:1px solid #dbe3ef;border-radius:12px;padding:12px;background:#f8fafc;font-weight:800;color:#475569}.scanner-status-box.ok{background:#dcfce7;color:#166534;border-color:#86efac}.scanner-status-box.wait{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.scanner-preview{margin-top:14px;border:1px dashed #93c5fd;background:#eff6ff;border-radius:16px;padding:14px;color:#1e3a8a;word-break:break-all}.scanner-actions{margin-top:16px}.help-text{display:block;margin-top:8px;color:#64748b}.guide-list{padding-left:22px;line-height:1.7;color:#334155}.alert.info{background:#e0f2fe;color:#075985}.test-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:14px}.test-box code{display:inline-block;margin-top:8px;background:#0f172a;color:#a7f3d0;border-radius:10px;padding:8px 10px}@media(max-width:980px){.scanner-hero,.scanner-top{flex-direction:column;align-items:stretch}.scanner-ready{justify-content:center}.scanner-input{font-size:18px}}

/* Revisi kartu pelajar QR */
.student-card-list{display:grid;gap:28px}.student-card-page{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:24px;align-items:start;break-after:page}.student-id-card{width:390px;min-height:620px;margin:0 auto;position:relative;overflow:hidden;border-radius:24px;background:#fff;box-shadow:0 18px 45px rgba(15,23,42,.18);border:1px solid #dbeafe;color:#0f2447}.card-bg-photo{position:absolute;left:0;right:0;top:0;height:250px;background:url('../img/sekolah-santo-paulus.jpg') center/cover no-repeat;z-index:0}.card-bg-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.96) 88%)}.card-bg-photo.fade{height:410px;opacity:.2;filter:grayscale(.12)}.card-bg-photo.fade:after{background:rgba(255,255,255,.38)}.student-card-header{position:relative;z-index:2;display:flex;align-items:flex-start;gap:16px;padding:20px 22px 0}.student-card-header.compact{padding-top:18px}.card-school-logo{width:86px;height:120px;object-fit:contain;filter:drop-shadow(0 5px 8px rgba(0,0,0,.18))}.student-card-header h1{font-size:29px;line-height:1;margin:18px 0 7px;color:#082a5e;font-weight:1000;letter-spacing:.8px}.student-card-header p{margin:0;font-size:16px;font-weight:800;color:#123469}.front-card-body{position:relative;z-index:2;display:grid;grid-template-columns:150px 1fr;gap:14px;padding:20px 22px 0;margin-top:56px}.student-photo-box{height:205px;border:5px solid #fff;border-radius:20px;box-shadow:0 8px 20px rgba(15,23,42,.18);overflow:hidden;background:linear-gradient(135deg,#dbeafe,#bfdbfe);display:grid;place-items:center}.student-photo-placeholder{width:100%;height:100%;display:grid;place-items:center;text-align:center;font-size:20px;font-weight:900;color:#1e3a8a;background:linear-gradient(135deg,#e0f2fe,#dbeafe)}.student-basic-info{align-self:end;background:rgba(255,255,255,.94);border-radius:16px;padding:10px 10px;border:1px solid #e2e8f0}.student-basic-info div,.student-detail-panel div{display:grid;grid-template-columns:30px 96px 1fr;gap:8px;align-items:center;border-bottom:1px solid #cbd5e1;padding:8px 0}.student-basic-info div:last-child,.student-detail-panel div:last-child{border-bottom:0}.student-basic-info span,.student-detail-panel span{width:26px;height:26px;border-radius:8px;background:#0b3b75;color:#fff;display:grid;place-items:center;font-size:14px}.student-basic-info b,.student-detail-panel b{color:#0b3b75}.student-basic-info strong,.student-detail-panel strong{font-size:16px;color:#111827}.card-blue-footer{position:absolute;left:-20px;right:-20px;bottom:-20px;height:200px;background:linear-gradient(135deg,#062c61,#084b8f);z-index:1;clip-path:polygon(0 24%,100% 0,100% 100%,0 100%)}.card-blue-footer:before{content:"";position:absolute;inset:28px 0 0 20px;background:radial-gradient(circle at 20% 70%,rgba(255,255,255,.2),transparent 18%),linear-gradient(120deg,transparent,rgba(255,255,255,.08));opacity:.6}.qr-attendance-box{position:relative;z-index:3;width:170px;margin:24px auto 0;background:#fff;border:3px solid #143b70;border-radius:15px;text-align:center;padding:24px 10px 8px;box-shadow:0 8px 20px rgba(15,23,42,.18)}.qr-title{position:absolute;top:-15px;left:18px;right:18px;background:#0b3b75;color:#fff;border-radius:999px;font-weight:1000;padding:5px}.real-qr-box{width:130px;height:130px;margin:0 auto 5px;display:grid;place-items:center;background:#fff}.real-qr-box svg{width:128px!important;height:128px!important}.qr-fallback{border:8px solid #111827;min-height:120px;width:120px;display:grid;place-items:center;word-break:break-all;font-size:10px;font-weight:900;color:#111827;padding:4px}.card-motto{position:absolute;right:26px;bottom:78px;z-index:3;color:#fff;font-weight:900;text-align:center;font-size:13px}.card-motto b{color:#fbbf24;font-size:17px}.data-siswa-label{position:relative;z-index:2;margin:52px auto 0;background:#0b3b75;color:#fff;border-radius:12px;padding:8px 34px;width:max-content;font-size:22px;font-weight:1000;letter-spacing:.5px}.student-detail-panel{position:relative;z-index:2;margin:-6px 24px 20px;background:rgba(255,255,255,.92);border:3px solid #0b3b75;border-radius:18px;padding:25px 18px 14px}.student-detail-panel div{grid-template-columns:30px 112px 1fr}.principal-area{position:relative;z-index:2;margin:20px 26px 0;display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:center}.stamp-seal{width:112px;height:112px;border:4px double #1d4ed8;border-radius:999px;display:grid;place-items:center;text-align:center;color:#1d4ed8;font-weight:1000;line-height:1.1;transform:rotate(-10deg);background:rgba(255,255,255,.22)}.signature-block{text-align:left}.signature-block p{font-weight:900;color:#0b3b75;margin:0 0 4px}.signature-line{font-family:"Brush Script MT","Segoe Script",cursive;font-size:44px;line-height:1;color:#111827;border-bottom:2px solid #111827;margin-bottom:4px;transform:rotate(-4deg)}.signature-block b{display:block;font-size:16px;color:#111827}.signature-block small{font-size:12px;color:#111827}.card-note{position:absolute;left:28px;right:28px;bottom:28px;z-index:3;text-align:center;color:#fff;font-size:12px;line-height:1.7;font-weight:700}@media(max-width:1100px){.student-card-page{grid-template-columns:1fr}.student-id-card{width:min(390px,100%)}}@media print{body{background:#fff}.student-card-page{display:grid;grid-template-columns:1fr 1fr;gap:8mm;page-break-after:always;break-after:page}.student-id-card{width:85.6mm;min-height:135mm;box-shadow:none;border:1px solid #cbd5e1;border-radius:5mm;break-inside:avoid}.student-card-header h1{font-size:22pt}.student-card-header p{font-size:10pt}.card-school-logo{width:18mm;height:25mm}.front-card-body{grid-template-columns:34mm 1fr;margin-top:36px;padding-left:5mm;padding-right:5mm}.student-photo-box{height:48mm}.student-basic-info div,.student-detail-panel div{grid-template-columns:7mm 22mm 1fr;font-size:9pt}.student-basic-info strong,.student-detail-panel strong{font-size:9pt}.qr-attendance-box{width:43mm;margin-top:6mm}.real-qr-box{width:32mm;height:32mm}.real-qr-box svg{width:31mm!important;height:31mm!important}.data-siswa-label{font-size:15pt;margin-top:34px}.student-detail-panel{margin-left:5mm;margin-right:5mm}.principal-area{margin-left:7mm;margin-right:7mm}.stamp-seal{width:25mm;height:25mm;font-size:8pt}.signature-line{font-size:28pt}.card-note{bottom:8mm}.card-motto{bottom:22mm}.card-bg-photo{height:57mm}.card-blue-footer{height:47mm}}
.scanner-closed{background:#4b5563!important;color:#fff}.scanner-closed .scanner-dot{background:#f97316;box-shadow:0 0 0 8px rgba(249,115,22,.14)}

/* Revisi cetak kartu sederhana: tanpa background gambar sekolah dan tanpa logo */
.simple-card-list{gap:24px}.simple-card-page{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}.simple-qr-card{min-height:520px;background:#fff!important;border:2px solid #0b3b75;border-radius:18px;padding:22px;box-shadow:0 10px 30px rgba(15,23,42,.12);display:flex;flex-direction:column}.simple-card-header{text-align:center;border-bottom:3px solid #0b3b75;padding-bottom:12px;margin-bottom:18px}.simple-card-header h1{margin:0;color:#0b3b75;font-size:28px;font-weight:1000;letter-spacing:.8px}.simple-card-header p{margin:6px 0 0;color:#334155;font-weight:800}.simple-student-info{display:grid;gap:8px;margin-bottom:18px}.simple-student-info div{display:grid;grid-template-columns:105px 1fr;gap:8px;border-bottom:1px solid #cbd5e1;padding:8px 0}.simple-student-info b{color:#0b3b75}.simple-student-info span{font-weight:700;color:#111827}.simple-qr-panel{margin:auto auto 0;text-align:center;border:3px solid #0b3b75;border-radius:16px;padding:16px;background:#fff;width:235px}.simple-qr-title{background:#0b3b75;color:#fff;border-radius:999px;padding:8px 10px;font-weight:1000;margin-bottom:12px}.simple-real-qr{width:190px;height:190px;display:grid;place-items:center;margin:0 auto}.simple-real-qr svg{width:190px!important;height:190px!important}.simple-qr-panel small{display:block;margin-top:8px;color:#334155;font-weight:800;word-break:break-all}.simple-back-card{justify-content:space-between}.simple-back-card .back-info{margin-top:8px}.simple-signature-area{text-align:center;margin:24px 0}.simple-signature-area p{font-weight:900;color:#0b3b75;margin:0 0 36px}.simple-signature-line{width:210px;border-bottom:2px solid #111827;margin:0 auto 8px}.simple-signature-area b{display:block}.simple-signature-area small{display:block;margin-top:4px}.simple-card-note{text-align:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:14px;padding:12px;color:#1e3a8a;font-weight:800;line-height:1.5}@media(max-width:1100px){.simple-card-page{grid-template-columns:1fr}}@media print{.simple-card-page{grid-template-columns:1fr 1fr;gap:8mm}.simple-qr-card{width:85.6mm;min-height:125mm;box-shadow:none;border:1.5pt solid #0b3b75;border-radius:4mm;padding:5mm}.simple-card-header h1{font-size:18pt}.simple-card-header p{font-size:10pt}.simple-student-info div{grid-template-columns:24mm 1fr;font-size:9pt;padding:2mm 0}.simple-qr-panel{width:52mm;padding:4mm}.simple-real-qr{width:42mm;height:42mm}.simple-real-qr svg{width:42mm!important;height:42mm!important}.simple-signature-line{width:50mm}.simple-card-note{font-size:8pt}}
