:root{--bg:#f5f7fa;--panel:#fff;--ink:#172033;--muted:#667085;--line:#d9e1ea;--teal:#0f766e;--blue:#3157c9;--amber:#b45309;--red:#be123c;--shadow:0 14px 35px rgba(16,24,40,.08)}
*{box-sizing:border-box}
html,body,input,select,textarea{font-feature-settings:"lnum" 1}
body{margin:0;background:var(--bg);color:var(--ink);font-family:"Segoe UI",Tahoma,Arial,sans-serif;letter-spacing:0}
button,input,select,textarea{font:inherit}
a{color:inherit}
.layout{display:grid;grid-template-columns:270px 1fr;min-height:100vh}
.side{background:#111827;color:#fff;padding:18px;display:flex;flex-direction:column;gap:14px}
.brand{display:flex;gap:10px;align-items:center;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.15)}
.brand-logo,.mark{width:48px;height:48px;border-radius:8px;object-fit:contain;background:linear-gradient(135deg,#2dd4bf,#60a5fa,#f59e0b);display:grid;place-items:center;color:#0f172a;font-weight:900}
.brand small{color:#cbd5e1}.navTitle{color:#9ca3af;font-size:12px;font-weight:800;padding:12px 10px 4px}
.nav{display:grid;gap:6px}.nav a{color:#dbe3ee;text-decoration:none;padding:10px;border-radius:8px;display:grid;grid-template-columns:28px 1fr;gap:8px;align-items:center}.nav a.active,.nav a:hover{background:rgba(255,255,255,.1);color:#fff}
.ico{width:26px;height:26px;border-radius:7px;background:rgba(255,255,255,.13);display:grid;place-items:center;font-weight:800}
.main{min-width:0}.top{position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:14px 20px;display:flex;justify-content:space-between;gap:12px;align-items:center;z-index:5}
.top h1{margin:0;font-size:22px}.top p{margin:2px 0 0;color:var(--muted);font-size:13px}.content{padding:20px;display:grid;gap:16px}
.panel,.card{background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.panel{padding:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.cards{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:12px}
.card{padding:14px;min-height:105px}.card small{color:var(--muted)}.card strong{display:block;margin-top:9px;font-size:26px;overflow-wrap:anywhere}
.tone1{background:#e8f6f3;border-color:#bde5de}.tone2{background:#edf0ff;border-color:#cfd7ff}.tone3{background:#fff3dc;border-color:#ffdfa2}.tone4{background:#e8f4ff;border-color:#b8dcff}
.rowbar,.head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.rowbar h2,.head h2{margin:0;font-size:17px}
.tools,.filters{display:flex;gap:8px;flex-wrap:wrap;align-items:end}.field,label{display:grid;gap:5px}label,.field label{font-size:12px;font-weight:700;color:var(--muted)}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;min-height:38px;padding:8px 10px;background:#fff;color:var(--ink)}textarea{min-height:90px;resize:vertical}
button,.btn{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:8px;min-height:38px;padding:8px 12px;display:inline-flex;align-items:center;gap:7px;justify-content:center;text-decoration:none;cursor:pointer}
.primary,.btn.primary{background:var(--teal);border-color:var(--teal);color:#fff}.blue{background:var(--blue);border-color:var(--blue);color:#fff}.red{background:var(--red);border-color:var(--red);color:#fff}.small{min-height:31px;padding:5px 8px;font-size:13px}
.table{overflow:auto;border:1px solid var(--line);border-radius:8px;background:#fff}table{width:100%;border-collapse:collapse;min-width:860px}th,td{text-align:right;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle;font-size:14px}th{background:#f8fafc;color:var(--muted);font-size:12px}tr:last-child td{border-bottom:0}
.tag{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;min-height:24px;border-radius:999px;font-size:12px;font-weight:700;margin:1px}.green{background:#e8f6f3;color:var(--teal)}.blueTag{background:#edf0ff;color:var(--blue)}.amber{background:#fff3dc;color:var(--amber)}.redTag{background:#ffe8ef;color:var(--red)}.gray{background:#eef2f6;color:#475467}
.portalGrid{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:14px;max-width:980px;margin:0 auto}.portalTile{border:1px solid var(--line);background:#fff;border-radius:8px;padding:18px;text-align:right;min-height:142px;display:grid;gap:8px;box-shadow:var(--shadow);text-decoration:none}.portalTile:hover{transform:translateY(-2px);border-color:#9cc7c2}.bigIcon{width:48px;height:48px;border-radius:8px;background:#e8f6f3;color:var(--teal);display:grid;place-items:center;font-weight:900;font-size:22px}.portalTile b{font-size:18px}.portalTile small{color:var(--muted);line-height:1.7}
.heroDash{background:linear-gradient(135deg,#0f766e,#3157c9 58%,#b45309);color:#fff;border:0;border-radius:8px;padding:24px;box-shadow:var(--shadow);display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:end}.heroDash h2{margin:0 0 8px;font-size:30px}.heroDash p{margin:0;color:rgba(255,255,255,.82);line-height:1.8}.heroStats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.heroStat{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:12px}.heroStat small{display:block;color:rgba(255,255,255,.78)}.heroStat b{font-size:24px}
.loginPage{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(135deg,#eef7f5,#eef2ff)}.loginBox{width:min(960px,100%);display:grid;grid-template-columns:1fr 390px;gap:16px}.loginBrand{background:linear-gradient(135deg,#0f766e,#3157c9 62%,#b45309);color:#fff;border-radius:8px;padding:28px;display:grid;place-items:center;text-align:center;min-height:360px}.loginBrand h1{font-size:34px;margin:8px 0}.loginBrand p{color:rgba(255,255,255,.82)}
.notice{background:#fff8e6;border:1px solid #fed7aa;border-radius:8px;padding:14px}.success{background:#e8f6f3;border:1px solid #bde5de;border-radius:8px;padding:12px;color:#0f766e}.error{background:#ffe8ef;border:1px solid #fecdd3;border-radius:8px;padding:12px;color:#be123c}.empty{border:1px dashed #c8d2df;border-radius:8px;padding:18px;text-align:center;color:var(--muted);background:#fbfcfe}
.avatar{width:42px;height:42px;border-radius:8px;object-fit:cover;background:#e8edf3;border:1px solid var(--line);display:inline-grid;place-items:center;color:#64748b;font-weight:800}.person{display:flex;align-items:center;gap:10px}
.receipt{width:58mm;margin:auto;background:#fff;color:#111;padding:10px;text-align:center;border:1px dashed #94a3b8}.receipt h2{font-size:16px;margin:4px 0}.receipt p{font-size:12px;margin:3px 0}.receipt .line{border-top:1px dashed #111;margin:8px 0}.receipt .amount{font-size:20px;font-weight:900}
.qr{width:86px;height:86px;display:grid;grid-template-columns:repeat(9,1fr);gap:2px;background:#fff;border:1px solid #111;padding:4px;margin:auto}.qr span{background:#111}.barcode{height:44px;display:flex;gap:2px;justify-content:center;align-items:stretch;margin:8px auto}.barcode span{background:#111;width:2px}
.qrScanner{display:grid;grid-template-columns:180px minmax(240px,1fr);gap:10px;align-items:center;max-width:720px}.qrCamera{background:#0f172a;border:1px solid var(--line);border-radius:8px;aspect-ratio:4/3;overflow:hidden;display:grid;place-items:center}.qrCamera video{width:100%;height:100%;object-fit:cover}.qrScanner small{grid-column:1/-1;color:var(--muted)}
.identityCard{width:min(460px,100%);margin:auto;border:1px solid var(--line);border-radius:8px;background:#fff;padding:18px;display:grid;grid-template-columns:86px 1fr;gap:16px;align-items:center}.identityCard .avatar{width:86px;height:86px;font-size:34px}.identityCard h2{margin:0 0 8px}.identityCard p{color:var(--muted)}
.certificateSheet{background:#fff;border:2px solid #172033;outline:1px solid #172033;outline-offset:-10px;min-height:720px;padding:38px;max-width:900px;margin:auto;text-align:center}.certificateSheet header{display:grid;gap:4px;place-items:center}.certificateSheet header img{max-width:92px;max-height:92px;object-fit:contain}.certificateSheet h1{margin:4px 0;font-size:30px}.certificateSheet h2{font-size:42px;margin:42px 0 20px}.certText{font-size:21px;line-height:2;max-width:720px;margin:18px auto}.certName{font-size:38px;font-weight:900;color:var(--teal);border-bottom:2px solid var(--teal);display:inline-block;padding:6px 26px;margin:12px}.certificateSheet footer{display:flex;justify-content:space-between;align-items:end;margin-top:70px}.certificateSheet footer img{max-width:130px;max-height:95px;object-fit:contain}.stampBox{width:120px;height:120px;border:2px dashed #172033;border-radius:50%;display:grid;place-items:center;color:var(--muted)}
.full{grid-column:1/-1}.permGrid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:10px}.permBox{border:1px solid var(--line);border-radius:8px;background:#fbfcfe;padding:10px}.permBox b{display:block;margin-bottom:8px;color:var(--ink)}.checks{display:grid;grid-template-columns:1fr 1fr;gap:6px}.checks label{display:flex;align-items:center;gap:6px;color:var(--ink);font-weight:600}.checks input{width:auto;min-height:auto}.wideChecks{grid-template-columns:repeat(3,minmax(180px,1fr));margin:12px 0}.checkLine{border:1px solid var(--line);border-radius:8px;background:#fbfcfe;padding:10px}.checkLine small{color:var(--muted)}
.install{display:grid;place-items:center;min-height:100vh;padding:20px}.install-box{width:min(820px,100%);background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px;box-shadow:var(--shadow)}
.versionLine{margin:0 0 12px;color:var(--muted);font-weight:700}.readonlyBadge{color:var(--muted);font-size:13px}.updateOverlay{position:fixed;inset:0;background:rgba(15,23,42,.58);display:none;place-items:center;z-index:1000}.updateOverlay.show{display:grid}.updateOverlay div{background:#fff;border-radius:8px;padding:22px 28px;box-shadow:var(--shadow);font-size:18px;font-weight:800;color:var(--ink)}
.deviceGate{width:min(860px,100%)}.deviceGate h1{margin:0 0 8px;font-size:32px}.deviceGate p{margin:0 0 18px;color:var(--muted)}.deviceChoices{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.deviceCard{min-height:150px;display:grid;align-content:center;text-align:center;border:1px solid var(--line);background:#fff}.deviceCard b{font-size:22px}.deviceCard span{color:var(--muted);font-size:13px;line-height:1.7}.deviceCard:hover{border-color:var(--teal);box-shadow:var(--shadow)}
.updateWizard{display:grid;gap:12px}.sourcePanel{border:1px solid var(--line);border-radius:8px;background:#fbfcfe;padding:14px;display:grid;gap:10px}.sourcePanel[hidden]{display:none}.sourcePanel input[type=file]{background:#fff}.updateWizard hr{width:100%;border:0;border-top:1px solid var(--line)}
.compactBrand{display:flex;align-items:center;gap:10px}.compactBrand b{display:block}.compactBrand small{display:block;color:var(--muted);font-size:12px}
.mobileShell{background:#eef3f7}.mobileMain{min-height:100vh;padding-bottom:86px}.mobileTop{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--line);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.mobileActions{display:flex;gap:6px;align-items:center}.mobileTitle{padding:14px 14px 0}.mobileTitle h1{margin:0;font-size:24px}.mobileTitle p{margin:4px 0 0;color:var(--muted);font-size:13px}.mobileContent{padding:12px 12px 18px}.mobileBottomNav{position:fixed;left:0;right:0;bottom:0;z-index:30;background:#fff;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);gap:2px;padding:7px 7px calc(7px + env(safe-area-inset-bottom));box-shadow:0 -12px 24px rgba(15,23,42,.08)}.mobileBottomNav a{text-decoration:none;color:var(--muted);display:grid;place-items:center;gap:2px;min-height:54px;border-radius:8px;font-size:11px}.mobileBottomNav a span{width:26px;height:26px;border-radius:8px;background:#eef2f6;display:grid;place-items:center;font-weight:900}.mobileBottomNav a.active{color:var(--teal);background:#e8f6f3}.mobileBottomNav a.active span{background:#d2f0ea}.mobileBottomNav b{font-size:11px}.mobileHero{padding:18px;grid-template-columns:1fr}.mobileHero h2{font-size:24px}.mobileHero .heroStats{grid-template-columns:1fr 1fr}.mobilePortal{display:grid;grid-template-columns:1fr;gap:10px}.mobilePortal .portalTile{min-height:108px;grid-template-columns:54px 1fr;align-items:center}.mobilePortal .portalTile small{grid-column:2}.device-mobile .grid2,.device-mobile .grid3,.device-mobile .cards,.device-mobile .permGrid,.device-mobile .qrScanner{grid-template-columns:1fr}.device-mobile table{min-width:720px}.device-mobile .panel{padding:14px}.device-mobile .table{border-radius:8px}.device-mobile input,.device-mobile select,.device-mobile textarea,.device-mobile button,.device-mobile .btn{min-height:44px}
.tabletShell{background:#f4f7fb}.tabletTop{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--line);padding:12px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px}.tabletRibbon{position:sticky;top:73px;z-index:19;background:#fff;border-bottom:1px solid var(--line);display:flex;gap:8px;overflow:auto;padding:10px 18px}.tabletRibbon a{text-decoration:none;color:var(--ink);border:1px solid var(--line);border-radius:8px;background:#fff;min-width:132px;padding:10px;display:flex;align-items:center;gap:8px}.tabletRibbon a.active{border-color:var(--teal);background:#e8f6f3;color:var(--teal)}.tabletMain{max-width:1180px;margin:0 auto}.tabletContent{padding:18px}.device-tablet .portalGrid{grid-template-columns:repeat(2,minmax(220px,1fr))}.device-tablet .grid3{grid-template-columns:repeat(2,1fr)}
@media(max-width:980px){.layout{grid-template-columns:1fr}.side{position:sticky;top:0;z-index:10}.nav{display:flex;overflow:auto}.nav a{min-width:150px}.heroDash,.loginBox{grid-template-columns:1fr}.cards,.grid3,.portalGrid,.permGrid{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}}
@media(max-width:620px){.cards,.portalGrid,.permGrid,.qrScanner,.deviceChoices{grid-template-columns:1fr}.content{padding:12px}.top{align-items:flex-start;flex-direction:column}.loginBrand h1{font-size:25px}.identityCard{grid-template-columns:1fr;text-align:center}}
@media print{.side,.top,.tools,.filters,.noPrint{display:none!important}.layout{display:block}.content{padding:0}.panel,.card,.table{box-shadow:none}.receipt{border:0;width:58mm}.certificateSheet{border:0;outline:0;min-height:96vh}}
