:root{--blue:#1769e0;--blue2:#0f4fb5;--ink:#172033;--muted:#667085;--line:#e6ebf2;--soft:#f6f9ff;--white:#fff;--green:#12a150;--yellow:#d69b10;--red:#d93025;--shadow:0 14px 38px rgba(17,37,70,.09);--r:16px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,"SF Pro Display",system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);background:var(--soft);font-size:14px}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}button{cursor:pointer}.btn,.iconBtn{border:0;border-radius:12px;padding:10px 14px;font-size:13.5px;font-weight:650;background:var(--blue);color:white;transition:.2s ease;display:inline-flex;align-items:center;gap:8px;justify-content:center}.btn:hover,.iconBtn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(23,105,224,.18)}.btn.dark{background:#202938}.btn.soft{background:#eaf2ff;color:var(--blue2)}.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}.btn.warn{background:var(--yellow)}.btn.danger{background:var(--red)}.btn.green{background:var(--green)}.mini{padding:7px 10px;border-radius:10px;font-size:12px}.landing{background:#fff}.heroWrap{min-height:100vh;display:flex;flex-direction:column}.landNav{height:66px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(18px,5vw,70px);border-bottom:1px solid var(--line);background:rgba(255,255,255,.88);backdrop-filter:blur(12px);position:sticky;top:0;z-index:5}.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em}.mark{width:36px;height:36px;border-radius:13px;background:linear-gradient(135deg,#1769e0,#7bb0ff);display:grid;place-items:center;color:white;font-weight:900}.hero{display:grid;grid-template-columns:1.02fr .98fr;gap:32px;align-items:center;padding:38px clamp(18px,5vw,70px) 22px}.heroText h1{font-size:clamp(34px,5vw,62px);line-height:.98;letter-spacing:-.055em;margin:0 0 16px}.heroText h1 span{color:var(--blue)}.heroText p{max-width:570px;color:var(--muted);font-size:17px;line-height:1.7;margin:0 0 20px}.cta{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0}.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:620px}.trust .card{padding:16px}.trust b{display:block;font-size:22px}.photoStack{position:relative;min-height:470px}.heroPhoto{height:470px;border-radius:28px;background:url('https://images.unsplash.com/photo-1522202176988-66273c2fd55f?auto=format&fit=crop&w=1300&q=80') center/cover;box-shadow:var(--shadow);position:relative;overflow:hidden}.heroPhoto:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,21,48,.03),rgba(3,21,48,.42))}.floatPanel{position:absolute;left:-22px;bottom:24px;width:270px;background:white;border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:var(--shadow)}.floatPanel b{display:block;margin-bottom:6px}.quickCats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:8px clamp(18px,5vw,70px) 28px}.quickCats .card{display:flex;gap:12px;align-items:center}.highlight{margin:0 clamp(18px,5vw,70px) 30px;border-radius:22px;background:linear-gradient(135deg,#f0f6ff,#fff);border:1px solid var(--line);padding:24px;display:flex;align-items:center;justify-content:space-between;gap:18px}.footer{padding:18px clamp(18px,5vw,70px);border-top:1px solid var(--line);display:flex;justify-content:space-between;color:var(--muted);background:white}.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:0 12px 28px rgba(20,41,77,.045);transition:.2s ease}.card:hover{transform:translateY(-1px)}.loginPage{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 20%,#e8f2ff,transparent 34%),#f8fbff}.loginBox{width:min(980px,100%);display:grid;grid-template-columns:1fr 390px;border:1px solid var(--line);background:#fff;border-radius:28px;overflow:hidden;box-shadow:var(--shadow)}.loginArt{min-height:560px;background:url('https://images.unsplash.com/photo-1588072432836-e10032774350?auto=format&fit=crop&w=1200&q=80') center/cover;position:relative;padding:28px;display:flex;align-items:flex-end}.loginArt:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,32,70,.08),rgba(9,32,70,.62))}.loginArt div{position:relative;color:#fff}.loginArt h2{font-size:38px;line-height:1;margin:0 0 8px;letter-spacing:-.04em}.loginForm{padding:30px;display:flex;flex-direction:column;justify-content:center}.loginForm h1{margin:0 0 7px;font-size:30px;letter-spacing:-.04em}.field{display:grid;gap:7px;margin:10px 0}.field label{font-weight:700;font-size:12px;color:#344054}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:11px 12px;background:#fff;outline:none;transition:.2s ease}.field textarea{min-height:82px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:#85b5ff;box-shadow:0 0 0 4px rgba(23,105,224,.09)}.demoGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#fff;border-right:1px solid var(--line);padding:16px;position:sticky;top:0;height:100vh;overflow:auto}.sideTop{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.navLink{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:#48556a;margin:3px 0;font-weight:650;font-size:13px;transition:.2s ease}.navLink:hover,.navLink.active{background:#eef5ff;color:var(--blue2)}.main{min-width:0}.topbar{height:66px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;background:rgba(246,249,255,.78);backdrop-filter:blur(14px);position:sticky;top:0;z-index:4;border-bottom:1px solid var(--line)}.page{padding:22px}.pageHead{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.pageHead h1{margin:0;font-size:25px;letter-spacing:-.035em}.pageHead p{margin:4px 0 0;color:var(--muted)}.gridCards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric{padding:16px;display:flex;align-items:center;gap:13px}.ic{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:#eef5ff;color:var(--blue);flex:none}.metric b{font-size:23px;display:block}.metric span{color:var(--muted);font-size:12px}.split{display:grid;grid-template-columns:1fr 360px;gap:16px;margin-top:16px}.panel{padding:16px}.panel h3{margin:0 0 12px;font-size:16px}.chartBox{display:grid;place-items:center;min-height:220px}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;margin-bottom:12px}.search{max-width:300px}.tableWrap{overflow:auto;border:1px solid var(--line);border-radius:14px;background:#fff}.table{width:100%;border-collapse:collapse;min-width:760px}.table th{background:#1f2a3d;color:#fff;text-align:left;font-size:12px;letter-spacing:.01em;padding:11px;border-right:1px solid rgba(255,255,255,.14);white-space:nowrap}.table td{padding:11px;border-top:1px solid var(--line);border-right:1px solid var(--line);vertical-align:top}.table tr:hover td{background:#fbfdff}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:750;background:#eef5ff;color:var(--blue2);white-space:nowrap}.badge.green{background:#eaf8ef;color:var(--green)}.badge.yellow{background:#fff6dd;color:#a56f00}.badge.red{background:#fff0ee;color:var(--red)}.formGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.formGrid .wide{grid-column:1/-1}.notice{padding:12px 14px;background:#eef5ff;border:1px solid #cfe2ff;border-radius:14px;color:#205090}.mobileShell{max-width:430px;margin:auto;min-height:100vh;background:#f7faff;box-shadow:0 0 0 1px var(--line);position:relative;padding-bottom:76px}.mobileTop{padding:18px 16px 6px}.studentHero{border-radius:26px;padding:18px;background:linear-gradient(135deg,#1769e0,#73a9ff);color:white;box-shadow:var(--shadow)}.studentHero h1{font-size:22px;margin:8px 0 2px;letter-spacing:-.03em}.studentHero p{margin:0;color:rgba(255,255,255,.83)}.quickGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:12px 16px}.mobileCard{padding:14px;border-radius:20px}.mobileList{padding:0 16px 14px;display:grid;gap:10px}.bottomNav{position:fixed;left:50%;bottom:0;transform:translateX(-50%);width:min(430px,100%);display:grid;grid-template-columns:repeat(5,1fr);gap:2px;padding:8px 10px 10px;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);border-top:1px solid var(--line);z-index:9}.bottomNav a{display:grid;place-items:center;gap:2px;font-size:11px;color:#64748b;font-weight:750;padding:7px 4px;border-radius:14px}.bottomNav a.active{background:#eef5ff;color:var(--blue)}.cameraBox{display:grid;gap:10px}.cameraView{width:100%;aspect-ratio:4/3;background:#101828;border-radius:18px;object-fit:cover}.sigPad{width:100%;height:210px;background:white;border:1px dashed #aac7ef;border-radius:18px;touch-action:none}.invoiceCard{padding:22px;background:#fff;border:1px solid var(--line);border-radius:18px;max-width:760px}.invoiceHead{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:12px}.hidden{display:none!important}.toast{position:fixed;right:18px;bottom:18px;z-index:30;background:#172033;color:white;padding:12px 14px;border-radius:14px;box-shadow:var(--shadow);max-width:360px}.hamb{display:none}.mediaThumb{width:80px;height:54px;border-radius:10px;object-fit:cover;background:#edf2f7}@media(max-width:980px){.hero{grid-template-columns:1fr}.photoStack{min-height:340px}.heroPhoto{height:340px}.quickCats{grid-template-columns:repeat(2,1fr)}.loginBox{grid-template-columns:1fr}.loginArt{min-height:260px}.shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-280px;z-index:20;transition:.2s ease}.sidebar.open{left:0}.hamb{display:inline-flex}.gridCards{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr}.formGrid{grid-template-columns:1fr}.page{padding:16px}.topbar{padding:0 14px}}@media(max-width:560px){.heroText h1{font-size:38px}.hero{padding-top:22px}.trust{grid-template-columns:1fr}.quickCats{grid-template-columns:1fr}.highlight{display:block}.footer{display:block}.gridCards{grid-template-columns:1fr}.pageHead{display:block}.landNav{height:auto;padding-top:12px;padding-bottom:12px}.photoStack{display:none}}
@media print{.sidebar,.topbar,.bottomNav,.toolbar,.btn,.hamb,.landNav{display:none!important}body{background:white}.shell{display:block}.page{padding:0}.card,.tableWrap{box-shadow:none}.table{min-width:0}.mobileShell{box-shadow:none;max-width:none}.invoiceCard{border:0}}

/* Mobile UI polish patch - by sinu */
@media(max-width:640px){
  html,body{width:100%;overflow-x:hidden;background:#edf5ff;-webkit-text-size-adjust:100%;}
  body{font-size:14px;line-height:1.45;}
  .mobileShell{width:100%;max-width:100%;min-height:100svh;margin:0;background:linear-gradient(180deg,#eaf4ff 0%,#f8fbff 42%,#ffffff 100%);box-shadow:none;padding-bottom:92px;overflow:hidden;}
  .mobileShell:before{content:"";position:fixed;inset:0 0 auto 0;height:210px;background:radial-gradient(circle at 18% 4%,rgba(23,105,224,.20),transparent 34%),radial-gradient(circle at 90% 0%,rgba(92,160,255,.20),transparent 30%);pointer-events:none;z-index:-1;}
  .mobileTop{padding:14px 14px 8px;position:relative;}
  .mobileUserBar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 12px;}
  .mobileIdentity{display:flex;align-items:center;gap:10px;min-width:0;}
  .avatarBubble{width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,#0f4fb5,#64a1ff);color:#fff;display:grid;place-items:center;font-weight:850;box-shadow:0 12px 24px rgba(23,105,224,.20);flex:none;}
  .mobileIdentity b{display:block;max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14.5px;letter-spacing:-.01em;}
  .mobileIdentity span{display:block;color:#667085;font-size:12px;margin-top:1px;}
  .mobileLogout{width:38px;height:38px;border-radius:14px;border:1px solid rgba(23,105,224,.14);background:rgba(255,255,255,.82);color:#1769e0;display:grid;place-items:center;box-shadow:0 10px 24px rgba(22,42,80,.06);}
  .studentHero{position:relative;border-radius:28px;padding:18px 16px 17px;background:linear-gradient(135deg,#0e56c5 0%,#1872e9 56%,#76afff 100%);overflow:hidden;box-shadow:0 18px 38px rgba(23,105,224,.22);}
  .studentHero:before{content:"";position:absolute;right:-36px;top:-42px;width:150px;height:150px;border-radius:50%;background:rgba(255,255,255,.18);}
  .studentHero:after{content:"";position:absolute;right:28px;bottom:-48px;width:104px;height:104px;border-radius:34px;background:rgba(255,255,255,.10);transform:rotate(18deg);}
  .studentHero>*{position:relative;z-index:1;}
  .studentHero .badge{border:1px solid rgba(255,255,255,.22);box-shadow:none;}
  .studentHero h1{font-size:24px;line-height:1.05;margin:12px 0 6px;letter-spacing:-.045em;max-width:310px;}
  .studentHero p{font-size:13.5px;line-height:1.55;color:rgba(255,255,255,.88);max-width:330px;}
  .mobileHeroMeta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:13px;}
  .mobileHeroMeta span{padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.16);color:#fff;font-size:12px;font-weight:750;border:1px solid rgba(255,255,255,.16);}
  .quickGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:10px 14px;}
  .mobileMetricGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:12px 14px 4px;}
  .mobileMetric{min-height:116px;padding:13px;border-radius:22px;background:rgba(255,255,255,.92);border:1px solid rgba(214,225,240,.92);box-shadow:0 12px 28px rgba(20,41,77,.07);display:flex;flex-direction:column;justify-content:space-between;}
  .mobileMetric .ic{width:38px;height:38px;border-radius:15px;background:#edf5ff;}
  .mobileMetric b{font-size:22px;line-height:1;letter-spacing:-.03em;}
  .mobileMetric span:last-child{font-size:12px;color:#667085;line-height:1.25;}
  .mobileActionGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:10px 14px 6px;}
  .mobileActionGrid .btn{min-height:46px;border-radius:16px;box-shadow:0 10px 22px rgba(23,105,224,.13);font-size:13px;}
  .mobileMenuGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:9px;padding:0 14px 12px;}
  .mobileMenuGrid a{min-height:70px;border-radius:20px;padding:10px 6px;background:rgba(255,255,255,.94);border:1px solid rgba(214,225,240,.92);display:grid;place-items:center;text-align:center;color:#253044;font-size:11px;font-weight:760;box-shadow:0 10px 24px rgba(20,41,77,.055);}
  .mobileMenuGrid a svg{width:20px;height:20px;color:#1769e0;margin-bottom:3px;}
  .mobileList{padding:6px 14px 16px;display:grid;gap:12px;}
  .mobileCard,.mobileShell .panel{padding:15px;border-radius:22px;background:rgba(255,255,255,.95);border:1px solid rgba(214,225,240,.96);box-shadow:0 14px 32px rgba(20,41,77,.065);}
  .mobileCard h3,.mobileShell .panel h3{font-size:15.5px;letter-spacing:-.02em;margin:0 0 12px;}
  .mobileShell .pageHead{display:block;margin:0;padding:0;}
  .mobileShell .pageHead h1{font-size:22px;line-height:1.08;margin:0;color:#fff;}
  .mobileShell .pageHead p{font-size:13.5px;color:rgba(255,255,255,.86);line-height:1.55;}
  .mobileShell .toolbar{display:grid;gap:8px;align-items:stretch;margin-bottom:12px;}
  .mobileShell .toolbar>div{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
  .mobileShell .toolbar .btn{width:100%;}
  .mobileShell .search{max-width:none;width:100%;}
  .mobileShell .field input,.mobileShell .field select,.mobileShell .field textarea{min-height:46px;border-radius:16px;background:#fbfdff;font-size:14px;}
  .mobileShell .formGrid{grid-template-columns:1fr;gap:10px;}
  .mobileShell .tableWrap{border:0;background:transparent;overflow:visible;border-radius:0;}
  .mobileShell .table{min-width:0;width:100%;border-collapse:separate;border-spacing:0 10px;}
  .mobileShell .table thead{display:none;}
  .mobileShell .table tbody,.mobileShell .table tr,.mobileShell .table td{display:block;width:100%;}
  .mobileShell .table tr{background:#fff;border:1px solid #e3ebf6;border-radius:18px;box-shadow:0 10px 24px rgba(20,41,77,.055);overflow:hidden;padding:8px 0;}
  .mobileShell .table tr:hover td{background:transparent;}
  .mobileShell .table td{border:0;border-bottom:1px solid #eef2f8;padding:9px 12px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;text-align:right;min-height:38px;word-break:break-word;}
  .mobileShell .table td:last-child{border-bottom:0;}
  .mobileShell .table td:before{content:attr(data-label);font-weight:750;color:#64748b;text-transform:capitalize;text-align:left;min-width:42%;max-width:48%;}
  .mobileShell .table td .badge{margin-left:auto;}
  .mobileShell .table td .btn{min-width:92px;}
  .mobileShell .chartBox{min-height:190px;}
  .mobileShell .chartBox svg{width:155px;height:155px;}
  .cameraView{border-radius:22px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.1);}
  .sigPad{height:190px;border-radius:20px;background:linear-gradient(180deg,#fff,#fbfdff);}
  .bottomNav{width:calc(100% - 18px);left:9px;right:9px;bottom:9px;transform:none;border:1px solid rgba(214,225,240,.96);border-radius:24px;grid-template-columns:repeat(5,1fr);padding:7px;background:rgba(255,255,255,.92);box-shadow:0 18px 42px rgba(23,43,77,.16);padding-bottom:calc(7px + env(safe-area-inset-bottom));}
  .bottomNav a{min-height:54px;border-radius:18px;font-size:10.5px;gap:3px;color:#667085;}
  .bottomNav a svg{width:20px;height:20px;}
  .bottomNav a.active{background:linear-gradient(135deg,#1769e0,#65a2ff);color:#fff;box-shadow:0 10px 22px rgba(23,105,224,.24);}
  .toast{left:14px;right:14px;bottom:92px;max-width:none;border-radius:18px;text-align:center;}
}
@media(max-width:380px){
  .mobileMenuGrid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .studentHero h1{font-size:22px;}
  .mobileActionGrid{grid-template-columns:1fr;}
  .mobileMetricGrid{grid-template-columns:1fr 1fr;gap:8px;}
  .mobileMetric{min-height:104px;padding:12px;}
  .bottomNav a span{font-size:10px;}
}
@media(min-width:641px){
  .mobileShell{border-left:1px solid var(--line);border-right:1px solid var(--line);}
}
@media(max-width:640px){
  .mobileShell #app>.card.panel{margin:6px 14px 12px;}
  .mobileShell input.search{min-height:46px;border-radius:16px;background:#fbfdff;font-size:14px;border:1px solid var(--line);padding:11px 12px;}
  .mobileShell .notice{border-radius:18px;line-height:1.5;}
  .mobileShell .btn{min-height:42px;}
  .mobileShell .btn.mini{min-height:34px;}
  .mobileShell .invoiceCard{border-radius:22px;max-width:100%;padding:16px;}
}

/* Lucide + mobile drawer refinement */
.li,.lucide{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:none;vertical-align:-3px}.li svg,.lucide{width:18px;height:18px;stroke:currentColor}.navLink .li,.bottomNav .li,.drawerNav .li{margin-right:0}.mobileUserBar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.mobileIdentity{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.mobileIdentity b,.mobileIdentity span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobileIdentity span{font-size:12px;color:rgba(23,32,51,.58)}.avatarBubble{width:38px;height:38px;border-radius:15px;background:#eaf2ff;color:#1769e0;display:grid;place-items:center;font-weight:850;box-shadow:inset 0 0 0 1px #d8e7ff}.mobileMenuBtn,.mobileLogout,.drawerClose,.drawerLogout{border:1px solid var(--line);background:#fff;color:#172033;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.2s ease}.mobileMenuBtn,.mobileLogout,.drawerClose{width:42px;height:42px;padding:0}.mobileMenuBtn:hover,.mobileLogout:hover,.drawerClose:hover,.drawerLogout:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(17,37,70,.1)}.mobileDrawer{position:fixed;top:0;left:calc(50% - 215px);transform:translateX(-105%);width:min(360px,88vw);height:100vh;background:#fff;z-index:40;border-right:1px solid var(--line);box-shadow:0 24px 70px rgba(17,37,70,.22);padding:14px;transition:.22s ease;overflow:auto}.mobileDrawer.open{transform:translateX(0)}@media(max-width:430px){.mobileDrawer{left:0}.mobileDrawer.open{transform:translateX(0)}}.mobileShade{position:fixed;inset:0;background:rgba(15,23,42,.38);z-index:35;opacity:0;pointer-events:none;transition:.2s ease}.mobileShade.show{opacity:1;pointer-events:auto}.drawerHead{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.drawerProfile{padding:14px;border:1px solid #dbe9ff;background:linear-gradient(135deg,#f4f8ff,#fff);border-radius:18px;margin-bottom:12px}.drawerProfile b{display:block;font-size:16px}.drawerProfile span{color:var(--muted);font-size:12px}.drawerNav{display:grid;gap:6px}.drawerNav a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:14px;color:#48556a;font-weight:700;font-size:13px}.drawerNav a.active,.drawerNav a:hover{background:#eef5ff;color:var(--blue2)}.drawerLogout{width:100%;padding:11px 12px;margin-top:12px;font-weight:750}.mobileMetricGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:12px 16px}.mobileMetric{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;display:flex;align-items:center;gap:10px;box-shadow:0 10px 24px rgba(20,41,77,.045)}.mobileMetric b{font-size:19px;display:block}.mobileMetric span:last-child{font-size:12px;color:var(--muted)}.mobileActionGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:0 16px 12px}.mobileActionGrid .btn{min-height:45px}.mobileMenuGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:0 16px 12px}.mobileMenuGrid a{background:#fff;border:1px solid var(--line);border-radius:18px;min-height:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;font-size:11.5px;font-weight:750;color:#334155;box-shadow:0 10px 24px rgba(20,41,77,.04)}.mobileHeroMeta{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.mobileHeroMeta span{font-size:11.5px;font-weight:750;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);padding:7px 9px;border-radius:999px;color:#fff}.studentHero .pageHead{margin:4px 0 0}.studentHero .pageHead h1{color:#fff;font-size:24px}.studentHero .pageHead p{color:rgba(255,255,255,.82)}@media(max-width:380px){.mobileMenuGrid{grid-template-columns:repeat(3,minmax(0,1fr))}.mobileActionGrid{grid-template-columns:1fr}.mobileMetricGrid{grid-template-columns:1fr}.studentHero h1{font-size:20px}.bottomNav a{font-size:10px}.bottomNav .li,.bottomNav .lucide{width:17px;height:17px}}@media(max-width:980px){.topbar .btn#logout{display:inline-flex}.sidebar.open:after{content:"";position:fixed;inset:0;background:rgba(15,23,42,.25);z-index:-1}}

/* AI OpenAI topic picker refinement */
.hint{display:block;margin-top:6px;color:#64748b;font-size:12px;line-height:1.45}.aiResultBox{margin-top:14px;border:1px solid #d9e8ff;background:linear-gradient(180deg,#f7fbff,#fff);border-radius:16px;padding:14px;box-shadow:0 14px 34px rgba(23,105,224,.08)}.aiResultBox h3{margin:0 0 10px;color:#172033}.aiResultBox pre{white-space:pre-wrap;word-break:break-word;margin:0;background:#0f172a;color:#f8fafc;border-radius:14px;padding:14px;line-height:1.55;max-height:440px;overflow:auto;font-family:Inter,ui-sans-serif,system-ui,sans-serif;font-size:13px}.field input[list]{padding-right:12px}

/* Profil dokumen, chat, dan absen maps */
.notifDot{margin-left:auto;min-width:19px;height:19px;border-radius:999px;background:#d93025;color:#fff;font-size:11px;font-weight:850;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;box-shadow:0 8px 18px rgba(217,48,37,.24)}.notifBtn{position:relative}.notifDot.floating{position:absolute;right:-5px;top:-5px;margin:0;border:2px solid #fff}.mapBox{width:100%;min-height:238px;border:1px solid #dbe7f5;border-radius:22px;overflow:hidden;background:#eef5ff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)}.mapBox iframe{width:100%;height:260px;border:0;display:block}.mapEmpty{height:238px;display:grid;place-items:center;text-align:center;color:#667085;font-weight:750;padding:16px}.locStats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.locStats span{background:#f8fbff;border:1px solid #e3edf8;border-radius:14px;padding:10px;font-size:12px;color:#667085}.locStats b{display:block;color:#172033;font-size:13px;margin-top:2px;word-break:break-all}.locationBox{display:grid;gap:10px}.chatList{display:grid;gap:10px}.chatBubble{border:1px solid #e3ebf6;border-radius:18px;padding:12px;background:#fff;box-shadow:0 10px 24px rgba(20,41,77,.045)}.chatBubble.me{margin-left:28px;background:linear-gradient(135deg,#eef5ff,#fff);border-color:#cfe2ff}.chatBubble.admin{margin-right:28px;background:#f8fafc}.chatBubble b{display:block;font-size:13px;color:#0f4fb5}.chatBubble p{margin:5px 0 6px;line-height:1.5}.chatBubble small{color:#667085}.mobileShell .card .card.panel{box-shadow:none;border-radius:18px;background:#fbfdff;margin:0;padding:12px}@media(max-width:380px){.locStats{grid-template-columns:1fr}.mapBox iframe{height:220px}.mapEmpty{height:210px}}
.adminPlainBrand{display:grid;gap:0;line-height:1.05}.adminPlainBrand span{font-size:17px;font-weight:850;color:#0f1f35;letter-spacing:-.03em}.adminPlainBrand small{font-size:11px;color:#667085;font-weight:750}.receiptBody{background:#f5f5f5!important;padding:18px;display:grid;place-items:start center}.receiptPaper{width:320px;max-width:100%;background:#fff;color:#111;border:1px solid #e5e7eb;border-radius:10px;padding:18px 16px;font-family:Inter,Arial,sans-serif;box-shadow:0 14px 34px rgba(16,24,40,.08)}.receiptCenter{text-align:center}.receiptCenter h2{margin:0;font-size:20px;letter-spacing:-.03em}.receiptCenter small,.receiptPaper .small{color:#667085;font-size:11px}.receiptDash{border-top:1px dashed #98a2b3;margin:12px 0}.receiptRow{display:flex;justify-content:space-between;gap:14px;font-size:12px;padding:5px 0}.receiptRow span{color:#667085}.receiptRow b{text-align:right;font-weight:800}.receiptRow.total{font-size:16px;border-top:1px solid #111;border-bottom:1px solid #111;margin:8px 0;padding:9px 0}.receiptNote{font-size:11px;text-align:center;color:#475467;line-height:1.45}.btn.warn{background:#d69b10;color:white}.btn.green{background:#12a150;color:white}.btn.danger{background:#d92d20;color:white}

/* Absensi terpadu: wajah + TTD + maps dalam satu halaman */
.attendanceStack{display:grid;gap:12px}.stepTitle{display:flex;align-items:center;justify-content:space-between;gap:10px}.stepTitle b{font-size:15px}.stepTitle span{font-size:12px;color:#667085;background:#f2f6fb;border:1px solid #e4edf7;border-radius:999px;padding:5px 9px}.attendanceActions{display:flex;gap:8px;flex-wrap:wrap}.facePreview{width:100%;max-height:260px;object-fit:cover;border-radius:22px;border:1px solid #dbe7f5;background:#101828}.mobileShell .attendanceStack .notice{font-size:12.5px}.mobileShell .cameraView{min-height:230px;background:#0f172a}.mobileShell .sigPad{height:220px}.mobileShell .mapBox{min-height:245px}@media(max-width:380px){.attendanceActions .btn{width:100%}.mobileShell .cameraView{min-height:205px}.mobileShell .sigPad{height:190px}}
/* Chat produksi: pesan langsung terlihat setelah terkirim */
.chatComposer form{display:grid;gap:10px}.chatComposer textarea{width:100%;min-height:112px;border:1px solid #dbe7f5;border-radius:16px;padding:12px 14px;font:500 14px Inter,system-ui,sans-serif;resize:vertical;background:#fff}.chatComposer button{justify-content:center}.chatList{max-height:58vh;overflow:auto;scroll-behavior:smooth;padding:2px}.chatBubble{position:relative}.chatBubble.me{border-top-right-radius:8px}.chatBubble.admin{border-top-left-radius:8px}.chatAdminGrid{grid-template-columns:minmax(320px,520px)}@media(max-width:720px){.chatList{max-height:52vh}.chatBubble.me{margin-left:16px}.chatBubble.admin{margin-right:16px}}
.saveStamp{display:inline-flex;align-items:center;margin-left:8px;padding:8px 10px;border-radius:12px;background:#e8f7ef;color:#0f7a3d;font-size:13px;font-weight:700;border:1px solid #bde8cf}
button[disabled]{opacity:.65;cursor:wait}

/* Patch realtime chat + pengerjaan soal AI */
.chatRealtimeLayout{display:grid;grid-template-columns:minmax(310px,420px) minmax(0,1fr);gap:16px;align-items:start}.chatThreadCard{min-height:520px}.adminBubbleList{max-height:62vh;background:linear-gradient(180deg,#f8fbff,#fff);border:1px solid #e1ebf8;border-radius:18px;padding:12px}.adminBubbleList .chatBubble{max-width:76%}.adminBubbleList .chatBubble.me{margin-left:auto;margin-right:0;background:linear-gradient(135deg,#1769e0,#63a3ff);color:#fff;border-color:#1769e0}.adminBubbleList .chatBubble.me b,.adminBubbleList .chatBubble.me small{color:#fff}.adminBubbleList .chatBubble.admin{margin-right:auto;margin-left:0;background:#fff}.aiStudentHelp{margin:12px 16px}.aiExerciseOverlay{position:fixed;inset:0;background:rgba(15,23,42,.46);z-index:80;display:grid;place-items:center;padding:16px}.aiExerciseBox{width:min(820px,96vw);max-height:92vh;overflow:auto;background:#fff;border:1px solid #dce8f6;border-radius:24px;box-shadow:0 30px 90px rgba(15,23,42,.28);padding:18px}.aiExerciseHead{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.aiExerciseHead b{display:block;font-size:18px;color:#172033}.aiExerciseHead span{display:block;font-size:12px;color:#64748b;margin-top:3px}.aiQuestionContent pre{white-space:pre-wrap;word-break:break-word;margin:0;background:#0f172a;color:#f8fafc;border-radius:16px;padding:14px;line-height:1.55;max-height:330px;overflow:auto;font-family:Inter,system-ui,sans-serif;font-size:13px}.aiExerciseBox label{display:block;margin:14px 0 8px;font-size:13px;font-weight:800;color:#172033}.aiExerciseBox textarea{width:100%;min-height:170px;border:1px solid #dbe7f5;border-radius:16px;padding:13px 14px;font:500 14px Inter,system-ui,sans-serif;resize:vertical;background:#fbfdff}@media(max-width:860px){.chatRealtimeLayout{grid-template-columns:1fr}.adminBubbleList .chatBubble{max-width:88%}.aiExerciseBox{border-radius:20px;padding:14px}.aiQuestionContent pre{max-height:280px}}
.studentWorkGrid{display:grid;gap:12px}.workCard{background:#fff;border:1px solid #e3ebf6;border-radius:18px;padding:14px;box-shadow:0 12px 28px rgba(20,41,77,.055)}.workTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.workTop b{display:block;font-size:15px;color:#172033;letter-spacing:-.01em}.workTop span{display:block;font-size:12px;color:#667085;margin-top:3px}.workCard p{margin:10px 0;color:#475467;line-height:1.55}.workMeta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}.workMeta span,.workMeta a{font-size:12px;background:#f3f7fd;border:1px solid #e1ebf8;color:#37506d;border-radius:999px;padding:7px 9px}.workMeta a{color:#1769e0;font-weight:750}.workBtn{width:100%;min-height:44px}@media(max-width:640px){.studentWorkGrid{gap:10px}.workCard{border-radius:20px;padding:13px}.workTop{display:grid;grid-template-columns:1fr;gap:8px}.workBtn{min-height:46px;border-radius:16px}}
/* Patch siswa: foto profil benar-benar tampil setelah upload, tanpa mengubah klik kanan. */
.avatarPhoto{overflow:hidden;padding:0;background:#eef6ff;border:2px solid rgba(255,255,255,.75)}
.avatarPhoto img{width:100%;height:100%;object-fit:cover;display:block;border-radius:999px}
.studentGuard .aiQuestionContent,.studentGuard .workCard p,.studentGuard .mobileCard table{user-select:none;-webkit-user-select:none}
.studentGuard input,.studentGuard textarea{user-select:text;-webkit-user-select:text}
.aiCardActions,.aiAfterSubmit{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:10px}

.aiAfterSubmit .aiResultBox{display:block}
/* feedback siswa dibuat langsung terbaca, bukan popup tersembunyi */
.doneBtn{background:#eef4ff!important;color:#1d4ed8!important;border:1px solid #bfdbfe!important;box-shadow:none!important;cursor:default!important}
.doneBtn:disabled{opacity:1!important}
.feedbackPreview{margin:10px 0 0;padding:10px 12px;border:1px solid #dbeafe;background:#f8fbff;border-radius:14px;display:grid;gap:4px;color:#334155}
.feedbackPreview b{font-size:13px;color:#1d4ed8}
.feedbackPreview span{font-size:12.5px;line-height:1.5;display:block}
.studentFeedbackPanel{margin:12px 0;padding:13px;border:1px solid #dbeafe;background:#f8fbff;border-radius:16px;box-shadow:0 8px 24px rgba(15,23,42,.05)}
.studentFeedbackPanel>div{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:8px}
.studentFeedbackPanel b{color:#1d4ed8;font-size:14px}.studentFeedbackPanel span{font-size:12px;color:#64748b}
.studentFeedbackPanel pre{white-space:pre-wrap;font-family:inherit;font-size:13px;line-height:1.55;margin:0;color:#172033}
.studentFeedbackPanel.alwaysOpen{background:#ffffff;border-color:#bfdbfe}
.workCard.isDone{background:#f8fbff;border-color:#bfdbfe}.workCard.isDone .workBtn[disabled],.btn[disabled]{pointer-events:none}.workCard.isDone::after{display:none;content:''}
.materialOverlay .materialContent pre{white-space:pre-wrap;word-break:break-word;margin:0;background:#f7fbff;color:#172033;border:1px solid #dce8f6;border-radius:16px;padding:14px;line-height:1.6;max-height:420px;overflow:auto;font-family:Inter,system-ui,sans-serif;font-size:14px}.materialOverlay .aiExerciseBox{width:min(760px,96vw)}.materialOverlay .btn svg{flex:0 0 auto}
/* Patch memo + absensi TTD + progress siswa */
.progressStudentList{display:grid;gap:12px}.progressStudent{border:1px solid #e3eaf5;border-radius:14px;padding:12px;background:#fff}.progressStudentTop{display:flex;justify-content:space-between;gap:10px;align-items:center}.progressStudentTop b{font-size:14px}.progressStudentTop span{font-size:12px;color:#667085}.progressTrack{height:10px;background:#eef4ff;border-radius:99px;overflow:hidden;margin:9px 0}.progressTrack span{display:block;height:100%;background:#1769e0;border-radius:99px;transition:.2s ease}.progressStudent small{color:#52627a}.sigPad{touch-action:none;background:#fff;border:1px dashed #b8c4d6;border-radius:16px;width:100%;height:220px}.attendanceActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.attendanceStack .notice{background:#eef6ff;border-color:#cce1ff;color:#0f4f9f}
@media(max-width:760px){.sigPad{height:190px}.progressStudentTop{align-items:flex-start;flex-direction:column}.split{grid-template-columns:1fr!important}}
/* Patch BHB: grafik batang progress siswa */
.studentBarChart{display:grid;gap:12px;margin-top:8px}
.studentBarItem{display:grid;grid-template-columns:minmax(180px,280px) 1fr;gap:14px;align-items:center;padding:12px;border:1px solid #e3ebf7;border-radius:14px;background:#fff}
.studentBarName b{display:block;font-size:14px;color:#0f172a}.studentBarName span{font-size:12px;color:#64748b}.studentBarTrack{height:28px;background:#eef5ff;border-radius:999px;position:relative;overflow:hidden;border:1px solid #d7e7fb}.studentBarTrack i{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#2563eb,#38bdf8);border-radius:999px;transition:.2s ease}.studentBarTrack em{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-style:normal;font-size:12px;font-weight:800;color:#0f172a}
@media(max-width:760px){.studentBarItem{grid-template-columns:1fr}.studentBarTrack{height:30px}}
/* Patch reminder admin tanggal 10 */
.reminderGrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.reminderCard{border-color:#dbe8ff;background:linear-gradient(180deg,#fff,#f8fbff)}.reminderCard.hot{box-shadow:0 18px 44px rgba(37,99,235,.12);border-color:#9ec5ff}.reminderTitle{display:grid;grid-template-columns:42px 1fr auto;gap:12px;align-items:start}.reminderTitle>span{width:42px;height:42px;border-radius:14px;background:#eef5ff;color:#1769e0;display:grid;place-items:center}.reminderTitle h3{margin:0 0 4px}.reminderTitle p{margin:0;color:#64748b;font-size:12.5px}.reminderTitle strong{font-size:26px;color:#0f172a;letter-spacing:-.04em}.reminderList{display:grid;gap:9px;margin-top:12px;max-height:310px;overflow:auto;padding-right:4px}.reminderRow{border:1px solid #e5edf8;background:#fff;border-radius:14px;padding:10px 12px;display:grid;gap:3px}.reminderRow b{font-size:13.5px;color:#0f172a}.reminderRow span{font-size:12.5px;color:#334155}.reminderRow small{font-size:11.5px;color:#64748b;line-height:1.35}.reminderActions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}@media(max-width:980px){.reminderGrid{grid-template-columns:1fr}.reminderList{max-height:260px}}

/* Patch reminder siswa */
.studentReminderStack{display:grid;gap:12px;margin:14px 0}.studentReminderStack .reminderCard{margin:0}.studentReminderStack .reminderTitle{grid-template-columns:38px 1fr auto}.studentReminderStack .reminderTitle>span{width:38px;height:38px;border-radius:13px}.studentReminderStack .reminderTitle strong{font-size:22px}.studentReminderStack .reminderList{max-height:230px}.studentReminderStack .reminderRow{border-radius:13px;padding:10px}.studentReminderStack .reminderActions .btn{width:auto}
.billingTemplateBox{grid-column:1/-1;margin-top:-4px}.billingTemplateBox .notice{margin-bottom:10px}.billingTemplateBox pre{white-space:pre-wrap;background:#f8fbff;border:1px solid #dbe7f7;border-radius:14px;padding:14px;font-family:inherit;line-height:1.55;color:#172033;max-height:260px;overflow:auto}.billingTemplateBox .copyBillTpl{margin-top:8px}
/* Patch profil siswa: foto profil dipisah dari berkas wajib */
.profilePhotoBox{display:grid;gap:10px;align-items:start}
.profilePhotoBox img{width:96px;height:96px;border-radius:24px;object-fit:cover;border:1px solid #dbe7f7;background:#f8fbff;box-shadow:0 10px 26px rgba(15,23,42,.08)}
.profilePhotoBox input[type=file]{width:100%}

/* Patch siswa: list ringkas + PDF rapi - by sinu */
.bankAutoBox{line-height:1.65}
.studentSimpleList{display:grid;gap:8px;margin-top:8px}
.historyLine{border-bottom:1px solid #e6edf7;padding:10px 2px;background:transparent}
.historyLine:last-child{border-bottom:0}
.historyLineTop{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.historyLineTop b{display:block;font-size:13.5px;color:#172033;line-height:1.35}
.historyLineTop small{display:block;margin-top:3px;font-size:11.5px;color:#64748b}
.historyLineRight{display:grid;gap:5px;justify-items:end;flex:none}.historyLineRight strong{font-size:13px;color:#0f4fb5}.historyPairs{display:grid;grid-template-columns:1fr 1fr;gap:6px 10px;margin-top:8px}.historyPairs span{display:grid;gap:2px}.historyPairs em{font-style:normal;font-size:11px;color:#667085;text-transform:capitalize}.historyPairs b{font-size:12.5px;font-weight:650;color:#334155}.historyLine p{margin:8px 0 0;font-size:12.5px;color:#475467;line-height:1.55}.miniLink{display:inline-flex;padding:5px 8px;border-radius:9px;background:#eef5ff;color:#1769e0;font-weight:750;font-size:12px}.studentSimpleList.riwayat_pembayaran .historyLineRight strong{color:#12a150}.studentSimpleList.riwayat-absen .historyPairs{grid-template-columns:1fr}@media(max-width:640px){.studentSimpleList{gap:0}.historyLine{padding:11px 0}.historyPairs{grid-template-columns:1fr}.historyLineTop{align-items:flex-start}.historyLineRight{max-width:42%;text-align:right}}
@media print{.mobileTop,.bottomNav,.toolbar,.btn,.mobileDrawer,.mobileShade,.aiStudentHelp{display:none!important}.mobileShell{max-width:none!important;box-shadow:none!important;background:#fff!important;padding:0!important}.mobileList{padding:0!important}.mobileCard{box-shadow:none!important;border:0!important;border-radius:0!important}.studentWorkGrid{display:block}.workCard{box-shadow:none!important;border:1px solid #cfd8e5!important;border-radius:10px!important;page-break-inside:avoid;margin-bottom:10px}.workCard p,.feedbackPreview span{color:#172033!important}.historyLine{page-break-inside:avoid}.tableWrap{border:1px solid #cfd8e5!important}.table{min-width:0!important;border-collapse:collapse!important}.table th,.table td{border:1px solid #cfd8e5!important;padding:8px!important}.badge{border:1px solid currentColor;background:#fff!important}}

/* Dashboard siswa compact metrics - by sinu */
@media screen and (max-width:640px){
  body.studentGuard .mobileMetricGrid,
  body.studentGuard .mobileShell .mobileMetricGrid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:8px!important;
    padding:10px 14px 4px!important;
  }
  body.studentGuard .mobileMetric,
  body.studentGuard .mobileShell .mobileMetric{
    min-height:86px!important;
    padding:10px 9px!important;
    border-radius:16px!important;
    gap:8px!important;
    align-items:center!important;
    box-shadow:0 8px 20px rgba(20,41,77,.045)!important;
  }
  body.studentGuard .mobileMetric .ic{
    width:32px!important;
    height:32px!important;
    min-width:32px!important;
    border-radius:12px!important;
  }
  body.studentGuard .mobileMetric b{
    font-size:17px!important;
    line-height:1.05!important;
    letter-spacing:-.025em!important;
  }
  body.studentGuard .mobileMetric span:last-child{
    font-size:11px!important;
    line-height:1.25!important;
    white-space:normal!important;
  }
  body.studentGuard .mobileMetric .li,
  body.studentGuard .mobileMetric .lucide{
    width:16px!important;
    height:16px!important;
  }
}
@media screen and (max-width:340px){
  body.studentGuard .mobileMetricGrid{gap:7px!important;padding-left:10px!important;padding-right:10px!important;}
  body.studentGuard .mobileMetric{padding:9px 8px!important;}
  body.studentGuard .mobileMetric b{font-size:16px!important;}
  body.studentGuard .mobileMetric span:last-child{font-size:10.5px!important;}
}

/* Patch login langsung + logo/gambar login bisa diganti dari admin */
.mark.markImage{background:#fff;border:1px solid var(--line);padding:3px;overflow:hidden}
.mark.markImage img{width:100%;height:100%;object-fit:cover;border-radius:10px;display:block}
.settingMediaPreview{display:flex;align-items:center;gap:10px;background:#f8fbff;border:1px solid #dbe7f5;border-radius:14px;padding:10px;margin-bottom:8px}
.settingMediaPreview img{width:74px;height:54px;border-radius:12px;object-fit:cover;background:#eef5ff;border:1px solid #e1ebf8}
.settingMediaPreview span{font-size:12px;color:#667085;font-weight:750}
.field small{display:block;color:#667085;font-size:11.5px;margin-top:6px;line-height:1.45}
@media(max-width:520px){.loginPage{padding:14px}.loginBox{border-radius:22px}.loginArt{min-height:210px}.loginForm{padding:24px}.loginArt h2{font-size:30px}}

/* Firebase push prompt, sengaja kecil agar tidak menutup layar HP. */
.fcmPrompt{position:fixed;right:18px;bottom:18px;z-index:80;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.96);border:1px solid rgba(15,35,75,.12);box-shadow:0 18px 45px rgba(14,32,70,.18);border-radius:18px;padding:10px 12px;color:#243047;backdrop-filter:blur(12px)}
.fcmPrompt span{font-size:12px;color:var(--muted)}
.fcmPrompt .btn{padding:9px 12px;border-radius:12px;font-size:13px}
@media(max-width:640px){.fcmPrompt{left:14px;right:14px;bottom:78px;justify-content:space-between}.fcmPrompt .btn{flex:1;justify-content:center}}

/* Security Center additions */
.securityStats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:16px 0}
.securityStat{background:linear-gradient(135deg,#ffffff,#eef5ff);border:1px solid rgba(23,105,224,.14);border-radius:20px;padding:16px;box-shadow:0 12px 35px rgba(15,38,80,.07);display:grid;gap:5px}
.securityStat span{width:40px;height:40px;border-radius:14px;background:#1769e0;color:#fff;display:grid;place-items:center;margin-bottom:4px}
.securityStat b{font-size:20px;color:#13233b}.securityStat small{color:var(--muted)}
.securityForm h3{margin:20px 0 10px}.securityGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.securityGrid .wide{grid-column:1/-1}.externalGrid{grid-template-columns:repeat(3,minmax(0,1fr))}
.checkRow{display:flex;align-items:center;gap:9px;border:1px solid rgba(17,31,55,.1);background:#f8fbff;border-radius:14px;padding:12px 13px;font-weight:700;color:#22324a}.checkRow input{width:17px;height:17px;accent-color:#1769e0}
.securityChecklist{display:grid;gap:10px}.securityChecklistItem{border:1px solid rgba(17,31,55,.1);background:#f9fbff;border-radius:15px;padding:12px}.securityChecklistItem b{display:block;color:#14223a;margin-bottom:4px}.securityChecklistItem span{color:var(--muted);font-size:13px;line-height:1.5}
.securityCaptchaBox{margin:14px 0;padding:12px;border:1px solid rgba(23,105,224,.18);background:#f5f9ff;border-radius:16px}.securityCaptchaBox label{display:block;font-weight:800;margin-bottom:8px;color:#14233c}.securityCaptchaBox small{display:block;margin-top:8px;color:var(--muted);font-size:12px}.genericCaptcha{display:flex;gap:10px;align-items:center}.genericCaptcha span{font-weight:900;background:#fff;border:1px solid rgba(17,31,55,.1);border-radius:12px;padding:10px 12px}.genericCaptcha input{flex:1;min-width:110px}.formActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
@media(max-width:920px){.securityStats{grid-template-columns:repeat(2,minmax(0,1fr))}.securityGrid,.externalGrid{grid-template-columns:1fr}.securityGrid .wide{grid-column:auto}}
@media(max-width:560px){.securityStats{grid-template-columns:1fr}.genericCaptcha{align-items:stretch;flex-direction:column}}
