:root{
  --bg:#f4f7fb;--card:#ffffff;--text:#101828;--muted:#667085;--border:#d9e2ef;
  --primary:#155eef;--primary-dark:#0b3ea8;--navy:#061833;--danger:#c81e1e;--success:#087443;--warning:#a15c07;
  --shadow:0 18px 50px rgba(16,24,40,.10);--radius:20px;--focus:0 0 0 4px rgba(21,94,239,.16)
}
*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{margin:0;padding:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}body{min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%}.container{width:min(1200px,100%);margin:0 auto;padding:24px}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 22px;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.logo{display:flex;align-items:center;gap:10px;font-weight:950;letter-spacing:.02em}.brand-mark{width:42px;height:42px;border-radius:15px;display:inline-grid;place-items:center;overflow:hidden;background:#fff;box-shadow:0 10px 24px rgba(21,94,239,.18);border:1px solid #d7e4ff}.brand-mark img{width:100%;height:100%;object-fit:cover}.logo strong{font-size:18px}.brand-badge{display:inline-grid;place-items:center;width:74px;height:74px;border-radius:24px;background:#fff;box-shadow:var(--shadow);border:1px solid #d7e4ff;margin-bottom:14px;overflow:hidden}.brand-badge img{width:100%;height:100%;object-fit:cover}.topnav{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.topnav a{font-weight:800;padding:10px 12px;border-radius:12px;color:#26364f}.topnav a:hover,.topnav a.active{background:#edf3ff;color:var(--primary)}.danger-link{color:var(--danger)!important}.nav-toggle{display:none;border:1px solid var(--border);background:#fff;border-radius:12px;padding:10px 12px;font-weight:900}.hero{display:flex;align-items:center;justify-content:space-between;gap:24px;margin:16px 0 22px}.hero h1{font-size:clamp(28px,5vw,46px);line-height:1.04;margin:0 0 10px;letter-spacing:-.04em}.hero p{max-width:760px}.muted{color:var(--muted)}.small{font-size:12px}.card,.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.scanner-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(340px,.92fr);gap:22px}.scanner-card #reader{width:100%;min-height:340px;border:2px dashed var(--border);border-radius:18px;overflow:hidden;background:#0f172a}.scan-actions,.form-actions,.filter-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.btn,button{border:1px solid var(--border);background:#fff;border-radius:13px;padding:12px 16px;font:inherit;font-weight:850;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px}.btn:hover,button:hover{filter:brightness(.99)}.btn:focus-visible,button:focus-visible,input:focus,select:focus,textarea:focus{outline:none;box-shadow:var(--focus);border-color:#9bbcff}.btn.primary{background:linear-gradient(135deg,var(--primary),#0b4ed8);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-dark)}.btn.full{width:100%}.btn.small{padding:8px 10px;font-size:12px;min-height:36px}.btn.danger{color:var(--danger);border-color:#ffd1d1}.btn.ok{background:#101828;color:#fff;font-size:20px;padding:16px;margin-top:12px}button:disabled{opacity:.55;cursor:not-allowed}.status{font-weight:900;padding:14px;border-radius:14px;border:1px solid var(--border);background:#f8fafc;margin-bottom:14px}.status.success{background:#ecfdf3;color:var(--success);border-color:#b7ebcc}.status.warning{background:#fff7ed;color:var(--warning);border-color:#fed7aa}.status.error{background:#fff1f1;color:var(--danger);border-color:#ffd1d1}.result-list{display:grid;grid-template-columns:132px 1fr;gap:10px 12px}.result-list dt{font-weight:900;color:var(--muted)}.result-list dd{margin:0;font-weight:700}.text-in{color:var(--success)}.text-out{color:var(--danger)}.pill{display:inline-flex;border-radius:999px;font-weight:900;padding:6px 10px;font-size:12px}.pill.in{background:#ecfdf3;color:var(--success)}.pill.out{background:#fff7ed;color:var(--warning)}.time-card{background:linear-gradient(135deg,#061833,#133d8f);color:#fff;border-radius:20px;padding:18px;min-width:170px;box-shadow:0 16px 42px rgba(6,24,51,.18)}.time-card span,.time-card small{display:block;color:#cbd5e1}.time-card strong{font-size:26px}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top left,#dceaff 0,#f7fbff 42%,#eef4ff 100%)}.auth-card{width:min(460px,100%);background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:28px;padding:30px}.auth-card h1{letter-spacing:-.04em}h1,h2{margin-top:0}.stack-form,.form-grid,.filter-grid{display:grid;gap:14px}.form-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.filter-grid{grid-template-columns:repeat(5,minmax(0,1fr));align-items:end}label{display:grid;gap:7px;font-weight:850;font-size:14px}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:13px;padding:12px 13px;font:inherit;background:#fff;color:var(--text)}input[type="file"]{padding:10px;background:#fff}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.alert{border-radius:15px;padding:13px 14px;margin:12px 0;font-weight:800}.alert.danger{background:#fff1f1;color:var(--danger);border:1px solid #ffd1d1}.alert.success{background:#effdf5;color:var(--success);border:1px solid #c8f6dc}.alert.info{background:#eff6ff;color:#1849a9;border:1px solid #c7d7fe}.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:16px;background:#fff}table{width:100%;border-collapse:collapse;min-width:980px}th,td{padding:12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}th{background:#f8fafc;font-size:13px;color:#475467}.inline-form{display:inline}.actions{min-width:260px}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px}.stat-card span{color:var(--muted);font-weight:800}.stat-card strong{display:block;font-size:36px;margin-top:6px}.footer{text-align:center;color:var(--muted);padding:28px}.print-page{width:min(520px,100%);margin:0 auto;padding:24px}.qr-box{text-align:center}.qr-box canvas{width:240px!important;height:240px!important;margin:12px auto;display:block}code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;background:#f2f4f7;border:1px solid var(--border);border-radius:8px;padding:2px 6px;word-break:break-word}.form-grid.petugas-form{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start}.field-block{display:grid;gap:7px;font-weight:850;font-size:14px}.field-group{grid-column:1/-1;border:1px solid var(--border);border-radius:18px;padding:16px;background:#fbfdff}.field-group h3{margin:0 0 12px;font-size:16px}.field-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.field-note{font-size:12px;color:var(--muted)}.actions .qr-action-list{display:flex;flex-direction:column;gap:8px}.qr-chip-list{display:flex;flex-wrap:wrap;gap:8px}.qr-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#edf3ff;border:1px solid #cfe0ff;font-size:12px;font-weight:800}.code-stack{display:grid;gap:6px}.code-stack code{display:inline-block}.hp-cell{min-width:180px}.bootstrap-box{margin-top:16px;padding-top:16px;border-top:1px dashed var(--border)}.photo-field{margin-top:12px;max-width:420px}.hp-thumb{display:block;width:130px;max-width:100%;height:96px;object-fit:cover;border:1px solid var(--border);border-radius:14px;margin-top:10px;background:#f8fafc}.hp-thumb.small-thumb{width:86px;height:64px}.scan-photo{width:120px;max-width:100%;height:90px;object-fit:cover;border-radius:14px;border:1px solid var(--border);background:#f8fafc}.scan-result-list{grid-template-columns:120px minmax(0,1fr)}.scan-result-list dd{word-break:break-word}.splash-screen{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:radial-gradient(circle at center,#ffffff 0,#eef5ff 54%,#dce9ff 100%);transition:opacity .65s ease,visibility .65s ease}.splash-screen.is-hidden{opacity:0;visibility:hidden;pointer-events:none}.splash-inner{display:grid;place-items:center;text-align:center;gap:14px;animation:splashEnter 1.15s cubic-bezier(.2,.8,.2,1) both}.splash-logo{width:min(210px,42vw);height:min(210px,42vw);border-radius:36px;object-fit:cover;filter:drop-shadow(0 0 20px rgba(21,94,239,.35));animation:splashPulse 1.8s ease-in-out infinite}.splash-title{font-weight:950;font-size:clamp(28px,6vw,48px);letter-spacing:-.05em;color:#061833}.splash-subtitle{font-weight:800;color:#155eef}.page-shell{animation:pageIn .6s ease both}.no-js .splash-screen{display:none}.js .page-shell{opacity:1}.js .page-shell.is-ready{opacity:1}.form-progress{display:none;margin-top:10px;font-weight:800;color:#155eef}.form-progress.show{display:block}.no-scroll{overflow:hidden}@keyframes splashEnter{0%{opacity:0;transform:translateY(18px) scale(.92)}100%{opacity:1;transform:none}}@keyframes splashPulse{0%,100%{transform:translateY(0) scale(1);filter:drop-shadow(0 0 14px rgba(21,94,239,.25))}50%{transform:translateY(-4px) scale(1.025);filter:drop-shadow(0 0 28px rgba(21,94,239,.45))}}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}100%{opacity:1;transform:none}}@media (max-width:860px){.container{padding:16px}.hero,.scanner-grid{grid-template-columns:1fr;display:grid}.hero{align-items:start}.form-grid,.filter-grid,.stats-grid{grid-template-columns:1fr}.span-2,.span-3{grid-column:auto}.topbar{align-items:center;flex-wrap:wrap}.nav-toggle{display:inline-flex}.topnav{display:none;width:100%;flex-direction:column;align-items:stretch}.topnav.open{display:flex}.result-list{grid-template-columns:110px 1fr}.scanner-card #reader{min-height:280px}.field-row{grid-template-columns:1fr}.form-grid.petugas-form{grid-template-columns:1fr}.scan-actions,.form-actions,.filter-actions{display:grid;grid-template-columns:1fr}.btn,button{width:100%}body.scan-result-open{overflow:hidden}.result-card.show-result{position:fixed;left:10px;right:10px;bottom:10px;z-index:1000;max-height:calc(100dvh - 24px);overflow:auto;padding:14px;border-radius:20px;box-shadow:0 24px 80px rgba(15,23,42,.28)}.result-card.show-result h2{font-size:18px;margin-bottom:8px}.result-card.show-result .status{padding:10px;margin-bottom:10px}.result-card.show-result .result-list{grid-template-columns:88px 1fr;gap:6px 10px;font-size:13px}.result-card.show-result .btn.ok{position:sticky;bottom:0;z-index:2;margin-top:10px;padding:15px;font-size:18px;border-radius:14px}.result-card.show-result::before{content:'';position:fixed;inset:0;background:rgba(15,23,42,.36);z-index:-1}.scanner-card #reader{min-height:260px}.scan-photo{width:92px;height:70px}.result-card.show-result .scan-photo{width:86px;height:62px}}@media (max-width:420px){.result-card.show-result{left:6px;right:6px;bottom:6px;max-height:calc(100dvh - 12px)}.result-card.show-result .result-list{grid-template-columns:76px 1fr;font-size:12.5px}.splash-logo{width:154px;height:154px}}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.splash-screen{display:none}.js .page-shell{opacity:1!important}}@media print{.topbar,.footer,.scan-actions,.no-print,.splash-screen{display:none!important}.container{width:100%;padding:0}.card{box-shadow:none;border:0}body{background:white}}

/* QR-GUARD session monitoring patch */
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.section-head h2{margin-bottom:4px}.monitor-filter{grid-template-columns:repeat(5,minmax(0,1fr))}.checkline{display:flex;align-items:center;gap:10px;padding:12px 13px;border:1px solid var(--border);border-radius:13px;background:#fbfdff;min-height:46px}.checkline input{width:auto}.session-table{min-width:1120px}.session-table th:first-child,.session-table td:first-child{width:56px;text-align:center}.pill.in{background:#ecfdf3;color:var(--success)}.pill.out{background:#eef4ff;color:#155eef}.pill.done{background:#eef4ff;color:#155eef}.pill.active{background:#ecfdf3;color:var(--success)}@media (min-width:861px){.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.monitor-filter .checkline{grid-column:span 2}.monitor-filter .filter-actions{grid-column:span 3}}@media (max-width:860px){.section-head{display:grid}.monitor-filter{grid-template-columns:1fr}.session-table{min-width:980px}.checkline{align-items:flex-start}.checkline input{margin-top:2px}}


/* QR-GUARD hardening/UI refresh 2026-06-08 */
.eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:10px;padding:7px 11px;border-radius:999px;background:#edf3ff;color:var(--primary);font-size:12px;font-weight:950;letter-spacing:.06em;text-transform:uppercase}.dashboard-hero{align-items:stretch}.dashboard-clock{display:grid;align-content:center}.dashboard-stats{margin-top:4px}.stat-card-modern{position:relative;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.stat-card-modern::after{content:"";position:absolute;inset:auto -30px -54px auto;width:130px;height:130px;border-radius:999px;background:rgba(21,94,239,.08)}.stat-card-modern:hover{transform:translateY(-3px);box-shadow:0 22px 60px rgba(16,24,40,.14);border-color:#c8d7ee}.stat-card-modern small{display:block;margin-top:8px;color:var(--muted);font-size:12px;font-weight:750;line-height:1.35}.stat-card-modern.is-primary{background:linear-gradient(145deg,#ffffff 0,#eef5ff 100%)}.stat-card-modern.is-success{background:linear-gradient(145deg,#ffffff 0,#effdf5 100%)}.stat-card-modern.is-warning{background:linear-gradient(145deg,#ffffff 0,#fff7ed 100%)}.dashboard-insight{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px;background:linear-gradient(135deg,#ffffff,#f7fbff)}.dashboard-insight h2{margin-bottom:8px}.card,.table-wrap,input,select,textarea,.btn,button{transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.card:hover{border-color:#cbd8ea}.topnav a:hover{transform:translateY(-1px)}tbody tr{transition:background .18s ease}tbody tr:hover{background:#f8fbff}.table-wrap table thead th{position:sticky;top:0;z-index:1}.btn:hover,button:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(16,24,40,.08)}.btn:active,button:active{transform:translateY(0)}.form-progress.show{display:inline-flex;align-items:center;gap:8px}.form-progress.show::before{content:"";width:12px;height:12px;border-radius:999px;border:2px solid #c7d7fe;border-top-color:var(--primary);animation:qrgSpin .8s linear infinite}@keyframes qrgSpin{to{transform:rotate(360deg)}}@media (max-width:860px){.dashboard-hero{display:grid}.dashboard-insight{display:grid}.stat-card-modern:hover,.btn:hover,button:hover,.topnav a:hover{transform:none}.table-wrap table thead th{position:static}}@media (prefers-reduced-motion:reduce){.stat-card-modern,.card,.btn,button,.topnav a,tbody tr{transition:none!important}.stat-card-modern:hover,.btn:hover,button:hover,.topnav a:hover{transform:none!important}.form-progress.show::before{animation:none!important}}

/* QR-GUARD role access matrix patch 2026-06-08 */
.permission-table{min-width:880px}.permission-table th,.permission-table td{text-align:center;vertical-align:middle}.permission-table th:first-child,.permission-table td:first-child{text-align:left;min-width:170px}.permission-check{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:850;font-size:12px;padding:8px 10px;border:1px solid var(--border);border-radius:999px;background:#fbfdff;cursor:pointer}.permission-check input{width:auto}.permission-check:has(input:checked){background:#edf3ff;border-color:#b8cffd;color:var(--primary)}
@media (max-width:860px){.permission-table{min-width:760px}.permission-check{width:100%;border-radius:12px}}

/* QR-GUARD WhatsApp/Fonnte patch */
.btn.success{background:linear-gradient(135deg,#059669,#047857);border-color:#059669;color:#fff}.btn.success:hover{background:#047857}.settings-form{align-items:start}.status-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;background:linear-gradient(135deg,#ffffff,#f7fbff)}.status-grid div{border:1px solid var(--border);border-radius:16px;padding:14px;background:#fff}.status-grid span,.status-grid strong{display:block}.public-qr-page{min-height:calc(100vh - 80px);display:grid;place-items:center}.public-qr-card{width:min(520px,100%);text-align:center}.public-qr-card .qr-image{width:260px}.qr-detail-list div span{word-break:break-word}.qr-recipient{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border:1px solid var(--border);border-radius:999px;background:#fbfdff}.scan-actions form{margin:0}.alert.info a{text-decoration:underline}.qr-box .btn.success{white-space:normal}@media (max-width:860px){.status-grid{grid-template-columns:1fr}.qr-recipient{display:flex;border-radius:14px;justify-content:center}.qr-grid{grid-template-columns:1fr!important}.qr-box .scan-actions{display:grid!important}.qr-box .scan-actions form{width:100%}.qr-box .scan-actions form button{width:100%}.public-qr-card .qr-image{width:220px}}

/* QR-GUARD one-click multi QR WhatsApp send */
.qr-send-modal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:18px}.qr-send-modal.open{display:flex}.qr-send-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.48);backdrop-filter:blur(4px)}.qr-send-dialog{position:relative;width:min(620px,100%);max-height:calc(100dvh - 36px);overflow:auto;background:#fff;border:1px solid var(--border);border-radius:24px;box-shadow:0 28px 90px rgba(15,23,42,.32);padding:22px}.qr-send-close{position:absolute;right:14px;top:12px;width:38px;height:38px;min-height:38px;padding:0;border-radius:999px;font-size:24px;line-height:1}.qr-send-head{display:flex;gap:14px;align-items:flex-start;padding-right:42px}.qr-send-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:16px;background:#ecfdf3;color:#047857;font-weight:950;font-size:24px}.qr-send-head h2{margin:0 0 5px}.qr-send-head p{margin:0;color:var(--muted);font-weight:750}.qr-send-list{display:grid;gap:10px;margin:18px 0}.qr-send-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--border);border-radius:16px;padding:13px;background:#fbfdff}.qr-send-item strong{display:block}.qr-send-item p{margin:3px 0 0;color:var(--muted);font-size:13px}.qr-send-status{white-space:nowrap;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:950;background:#f2f4f7;color:#475467}.qr-send-item.is-sending .qr-send-status{background:#eff6ff;color:#155eef}.qr-send-item.is-success .qr-send-status{background:#ecfdf3;color:#087443}.qr-send-item.is-failed .qr-send-status{background:#fff1f1;color:#c81e1e}.qr-send-message{border:1px solid var(--border);border-radius:15px;padding:12px 13px;font-weight:800;background:#f8fafc;color:#475467}.qr-send-message.info{background:#eff6ff;color:#1849a9;border-color:#c7d7fe}.qr-send-message.success{background:#effdf5;color:#087443;border-color:#c8f6dc}.qr-send-message.danger{background:#fff1f1;color:#c81e1e;border-color:#ffd1d1}.qr-send-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}@media (max-width:640px){.qr-send-modal{padding:8px;align-items:flex-end}.qr-send-dialog{border-radius:22px 22px 0 0;max-height:calc(100dvh - 8px);padding:18px}.qr-send-head{padding-right:36px}.qr-send-item{display:grid}.qr-send-status{justify-self:start;white-space:normal}.qr-send-actions{display:grid;grid-template-columns:1fr}.qr-send-actions .btn{width:100%}}

.btn.success.is-sent,.btn.is-sent{background:#f2f4f7;border-color:#cbd5e1;color:#087443}.btn.success.is-sent:hover,.btn.is-sent:hover{background:#eef2f7}

/* QR-GUARD bulk QR download patch 2026-06-10 */
.bulk-download-panel{background:linear-gradient(135deg,#ffffff,#f7fbff)}
.bulk-download-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:14px}
.bulk-download-head h2{margin-bottom:6px}
.bulk-selected-badge{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;border:1px solid #b8cffd;background:#edf3ff;color:#155eef;border-radius:999px;padding:9px 13px;font-size:13px;font-weight:900}
.bulk-selected-badge strong{font-size:18px;line-height:1}
.bulk-download-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.bulk-download-actions .btn{width:auto}
.bulk-download-actions .form-progress{display:none;color:#155eef;font-weight:850}
.bulk-download-actions .form-progress.show{display:inline-flex}
.select-all-qr{width:max-content;max-width:100%;margin-top:8px}
.qr-select-col{width:150px;min-width:150px;text-align:left!important;vertical-align:top!important}
.qr-select-list{display:grid;gap:8px;min-width:132px}
.qr-select-item{display:grid;grid-template-columns:auto 42px 1fr;align-items:center;gap:7px;border:1px solid var(--border);border-radius:13px;background:#fbfdff;padding:8px 9px;cursor:pointer;font-size:12px;font-weight:850;line-height:1.2}
.qr-select-item input{width:auto;margin:0}.qr-select-item span{color:#155eef}.qr-select-item small{color:var(--muted);font-weight:750;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-select-item:has(input:checked){border-color:#9dbbfd;background:#edf3ff}.bulk-notice{position:fixed;right:18px;bottom:18px;z-index:12000;width:min(420px,calc(100vw - 36px));padding:14px 16px;border-radius:16px;border:1px solid var(--border);background:#fff;color:#344054;box-shadow:0 20px 70px rgba(15,23,42,.22);font-weight:850;opacity:0;transform:translateY(14px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}.bulk-notice.show{opacity:1;transform:translateY(0)}.bulk-notice.info{border-color:#c7d7fe;background:#eff6ff;color:#1849a9}.bulk-notice.danger{border-color:#ffd1d1;background:#fff1f1;color:#c81e1e}.bulk-notice.success{border-color:#c8f6dc;background:#effdf5;color:#087443}
@media (max-width:860px){.bulk-download-head{display:grid}.bulk-download-actions{display:grid}.bulk-download-actions .btn{width:100%}.select-all-qr{width:100%}.qr-select-col{min-width:132px}.qr-select-item{grid-template-columns:auto 38px minmax(72px,1fr)}.bulk-notice{right:10px;bottom:10px;width:calc(100vw - 20px)}}

/* QR-GUARD grouped REGU/SUBSI QR download + public QR card refresh 2026-06-10 */
.public-qr-page{padding-top:22px;padding-bottom:22px;background:linear-gradient(180deg,#f4f7fb 0,#eef4fb 100%)}
.public-qr-card.qr-public-template{width:min(540px,100%);padding:28px 28px 24px;text-align:center;border-radius:28px;background:#fff;box-shadow:0 24px 70px rgba(16,24,40,.12)}
.qr-public-logo{display:block;width:min(360px,92%);max-height:240px;object-fit:contain;margin:0 auto 18px;border-radius:18px}
.public-qr-card .qr-public-code{display:block;width:min(255px,76vw);height:auto;margin:8px auto 14px;border:10px solid #fff;box-shadow:0 0 0 1px #d7e4ff;border-radius:10px;background:#fff}
.qr-public-slot{display:block;margin:4px 0 6px;color:#475467;font-weight:800;letter-spacing:.02em}
.qr-public-name{margin:0 0 14px;font-size:clamp(24px,6vw,34px);line-height:1.05;letter-spacing:.04em;font-weight:950;color:#101828;text-transform:uppercase}
.qr-public-device{font-size:16px;line-height:1.45;color:#344054;margin:0 0 12px}.qr-public-device strong{font-weight:950;color:#101828}.qr-public-unit{font-size:16px;font-weight:950;color:#101828;letter-spacing:.02em;text-transform:uppercase;margin:0 0 12px}.qr-token-pill{display:inline-flex;align-items:center;justify-content:center;max-width:100%;padding:8px 12px;border-radius:999px;background:#f2f4f7;border:1px solid #d0d5dd;color:#344054;font-weight:850;overflow-wrap:anywhere}.qr-token-pill code{background:transparent;padding:0;white-space:normal}.qr-public-note{margin:16px 0 0;color:#667085;font-size:12px;line-height:1.45}
.bulk-group-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:18px}.bulk-group-card{border:1px solid #dbe7f8;border-radius:20px;background:#fff;overflow:hidden}.bulk-group-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:15px 16px;background:linear-gradient(135deg,#0b4ed8,#155eef);color:#fff}.bulk-group-header h3{margin:3px 0 0;font-size:18px}.bulk-group-eyebrow{display:inline-flex;align-items:center;border:1px solid rgba(255,255,255,.34);border-radius:999px;padding:4px 9px;font-size:11px;font-weight:950;letter-spacing:.08em}.bulk-group-total{white-space:nowrap;border-radius:999px;background:rgba(255,255,255,.16);padding:7px 10px;font-weight:950;font-size:12px}.bulk-group-list{display:grid}.bulk-group-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 14px;border-top:1px solid #e5edf8}.bulk-group-row:first-child{border-top:0}.bulk-group-row:hover{background:#f8fbff}.bulk-group-row.is-empty{opacity:.62;background:#fafafa}.bulk-group-main{display:grid;gap:3px;min-width:0}.bulk-group-main strong{color:#101828;font-weight:950}.bulk-group-main span{font-size:13px;color:#155eef;font-weight:900}.bulk-group-main small{font-size:12px;color:#667085;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bulk-group-form{margin:0}.bulk-group-form .btn{white-space:nowrap}.bulk-group-regu .bulk-group-header{background:linear-gradient(135deg,#0b4ed8,#155eef)}.bulk-group-subsi .bulk-group-header{background:linear-gradient(135deg,#061833,#155eef)}
@media (max-width:960px){.bulk-group-grid{grid-template-columns:1fr}.bulk-group-row{grid-template-columns:1fr}.bulk-group-form .btn{width:100%}.public-qr-card.qr-public-template{border-radius:22px;padding:22px 16px}.qr-public-logo{width:min(300px,94%);max-height:210px}.qr-public-device{font-size:14px}}
